mirror of
https://we.phorge.it/source/arcanist.git
synced 2024-12-04 04:32:42 +01:00
66d204be81
Summary: This commit doesn't change license of any file. It just makes the license implicit (inherited from LICENSE file in the root directory). We are removing the headers for these reasons: - It wastes space in editors, less code is visible in editor upon opening a file. - It brings noise to diff of the first change of any file every year. - It confuses Git file copy detection when creating small files. - We don't have an explicit license header in other files (JS, CSS, images, documentation). - Using license header in every file is not obligatory: http://www.apache.org/dev/apply-license.html#new. This change is approved by Alma Chao (Lead Open Source and IP Counsel at Facebook). Test Plan: Verified that the license survived only in unit tests and LICENSE file. Reviewers: epriestley, btrahan, edward Reviewed By: epriestley CC: aran, Korvin, davidrecordon Maniphest Tasks: T2035 Differential Revision: https://secure.phabricator.com/D3881
109 lines
2.2 KiB
PHP
109 lines
2.2 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Upload a file to Phabricator.
|
|
*
|
|
* @group workflow
|
|
*/
|
|
final class ArcanistUploadWorkflow extends ArcanistBaseWorkflow {
|
|
|
|
private $paths;
|
|
private $json;
|
|
|
|
public function getWorkflowName() {
|
|
return 'upload';
|
|
}
|
|
|
|
public function getCommandSynopses() {
|
|
return phutil_console_format(<<<EOTEXT
|
|
**upload** __file__ [__file__ ...] [--json]
|
|
EOTEXT
|
|
);
|
|
}
|
|
|
|
public function getCommandHelp() {
|
|
return phutil_console_format(<<<EOTEXT
|
|
Supports: filesystems
|
|
Upload a file from local disk.
|
|
EOTEXT
|
|
);
|
|
}
|
|
|
|
public function getArguments() {
|
|
return array(
|
|
'json' => array(
|
|
'help' => 'Output upload information in JSON format.',
|
|
),
|
|
'*' => 'paths',
|
|
);
|
|
}
|
|
|
|
protected function didParseArguments() {
|
|
if (!$this->getArgument('paths')) {
|
|
throw new ArcanistUsageException("Specify one or more files to upload.");
|
|
}
|
|
|
|
$this->paths = $this->getArgument('paths');
|
|
$this->json = $this->getArgument('json');
|
|
}
|
|
|
|
public function requiresAuthentication() {
|
|
return true;
|
|
}
|
|
|
|
private function getPaths() {
|
|
return $this->paths;
|
|
}
|
|
|
|
private function getJSON() {
|
|
return $this->json;
|
|
}
|
|
|
|
public function run() {
|
|
|
|
$conduit = $this->getConduit();
|
|
|
|
$results = array();
|
|
|
|
foreach ($this->paths as $path) {
|
|
$name = basename($path);
|
|
$this->writeStatusMessage("Uploading '{$name}'...\n");
|
|
try {
|
|
$data = Filesystem::readFile($path);
|
|
} catch (FilesystemException $ex) {
|
|
$this->writeStatusMessage(
|
|
"Unable to upload file: ".$ex->getMessage()."\n");
|
|
$results[$path] = null;
|
|
continue;
|
|
}
|
|
|
|
$phid = $conduit->callMethodSynchronous(
|
|
'file.upload',
|
|
array(
|
|
'data_base64' => base64_encode($data),
|
|
'name' => $name,
|
|
));
|
|
$info = $conduit->callMethodSynchronous(
|
|
'file.info',
|
|
array(
|
|
'phid' => $phid,
|
|
));
|
|
|
|
$results[$path] = $info;
|
|
|
|
if (!$this->getJSON()) {
|
|
$id = $info['id'];
|
|
echo " F{$id} {$name}: ".$info['uri']."\n\n";
|
|
}
|
|
}
|
|
|
|
if ($this->getJSON()) {
|
|
echo json_encode($results)."\n";
|
|
} else {
|
|
$this->writeStatusMessage("Done.\n");
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
}
|