mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-08 13:51:01 +01:00
a4d33ef117
Summary: Generally, `phutil_json_decode` should be preferred over `json_decode`. Test Plan: Eyeballed. Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley, #blessed_reviewers Subscribers: aurelijus, Korvin, epriestley Differential Revision: https://secure.phabricator.com/D12678
98 lines
2.4 KiB
PHP
98 lines
2.4 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Provides command-line access to the Conduit API.
|
|
*/
|
|
final class ArcanistCallConduitWorkflow extends ArcanistWorkflow {
|
|
|
|
public function getWorkflowName() {
|
|
return 'call-conduit';
|
|
}
|
|
|
|
public function getCommandSynopses() {
|
|
return phutil_console_format(<<<EOTEXT
|
|
**call-conduit** __method__
|
|
EOTEXT
|
|
);
|
|
}
|
|
|
|
public function getCommandHelp() {
|
|
return phutil_console_format(<<<EOTEXT
|
|
Supports: http, https
|
|
Allows you to make a raw Conduit method call:
|
|
|
|
- Run this command from a working directory.
|
|
- Call parameters are REQUIRED and read as a JSON blob from stdin.
|
|
- Results are written to stdout as a JSON blob.
|
|
|
|
This workflow is primarily useful for writing scripts which integrate
|
|
with Phabricator. Examples:
|
|
|
|
$ echo '{}' | arc call-conduit conduit.ping
|
|
$ echo '{"phid":"PHID-FILE-xxxx"}' | arc call-conduit file.download
|
|
EOTEXT
|
|
);
|
|
}
|
|
|
|
public function getArguments() {
|
|
return array(
|
|
'*' => 'method',
|
|
);
|
|
}
|
|
|
|
protected function shouldShellComplete() {
|
|
return false;
|
|
}
|
|
|
|
public function requiresConduit() {
|
|
return true;
|
|
}
|
|
|
|
public function requiresAuthentication() {
|
|
return true;
|
|
}
|
|
|
|
public function run() {
|
|
$method = $this->getArgument('method', array());
|
|
if (count($method) !== 1) {
|
|
throw new ArcanistUsageException(
|
|
pht('Provide exactly one Conduit method name.'));
|
|
}
|
|
$method = reset($method);
|
|
|
|
$console = PhutilConsole::getConsole();
|
|
if (!function_exists('posix_isatty') || posix_isatty(STDIN)) {
|
|
$console->writeErr(
|
|
"%s\n",
|
|
pht('Waiting for JSON parameters on stdin...'));
|
|
}
|
|
$params = @file_get_contents('php://stdin');
|
|
try {
|
|
$params = phutil_json_decode($params);
|
|
} catch (PhutilJSONParserException $ex) {
|
|
throw new ArcanistUsageException(
|
|
pht('Provide method parameters on stdin as a JSON blob.'));
|
|
}
|
|
|
|
$error = null;
|
|
$error_message = null;
|
|
try {
|
|
$result = $this->getConduit()->callMethodSynchronous(
|
|
$method,
|
|
$params);
|
|
} catch (ConduitClientException $ex) {
|
|
$error = $ex->getErrorCode();
|
|
$error_message = $ex->getMessage();
|
|
$result = null;
|
|
}
|
|
|
|
echo json_encode(array(
|
|
'error' => $error,
|
|
'errorMessage' => $error_message,
|
|
'response' => $result,
|
|
))."\n";
|
|
|
|
return 0;
|
|
}
|
|
|
|
}
|