1
0
Fork 0
mirror of https://we.phorge.it/source/arcanist.git synced 2025-01-25 14:08:18 +01:00

Allow "arc upload" to work correctly if it can not hash content

Summary:
Ref T12464. This is similar to D17619 and prepares us to move to SHA256 in the client.

Note that it's fine if `arc` and Phabricator disagree about hashing algorithms. We don't really trust the client anyway, so if things are mismatched clients will just end up transferring a bit more data instead of getting to cheat when Phabricator already has copies of data.

Test Plan: Ran `arc upload`, got a clean upload.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T12464

Differential Revision: https://secure.phabricator.com/D17621
This commit is contained in:
epriestley 2017-04-04 15:46:31 -07:00
parent 82b7cd778a
commit c4e84550fc

View file

@ -222,15 +222,6 @@ final class ArcanistFileDataRef extends Phobject {
$path)); $path));
} }
$hash = @sha1_file($path);
if ($hash === false) {
throw new Exception(
pht(
'Unable to upload file: failed to calculate file data hash for '.
'path "%s".',
$path));
}
$size = @filesize($path); $size = @filesize($path);
if ($size === false) { if ($size === false) {
throw new Exception( throw new Exception(
@ -240,11 +231,11 @@ final class ArcanistFileDataRef extends Phobject {
$path)); $path));
} }
$this->hash = $hash; $this->hash = $this->newFileHash($path);
$this->size = $size; $this->size = $size;
} else { } else {
$data = $this->data; $data = $this->data;
$this->hash = sha1($data); $this->hash = $this->newDataHash($data);
$this->size = strlen($data); $this->size = strlen($data);
} }
} }
@ -354,4 +345,12 @@ final class ArcanistFileDataRef extends Phobject {
return $data; return $data;
} }
private function newFileHash($path) {
return null;
}
private function newDataHash($data) {
return null;
}
} }