mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-28 15:38:19 +01:00
023dee0d3b
Summary: Ref T5655. Rename Conduit classes and provide a `getAPIMethodName` method to declare the API method. Test Plan: ``` > echo '{}' | arc --conduit-uri='http://phabricator.joshuaspence.com' call-conduit user.whoami Waiting for JSON parameters on stdin... {"error":null,"errorMessage":null,"response":{"phid":"PHID-USER-lioqffnwn6y475mu5ndb","userName":"josh","realName":"Joshua Spence","image":"http:\/\/phabricator.joshuaspence.com\/res\/1404425321T\/phabricator\/3eb28cd9\/rsrc\/image\/avatar.png","uri":"http:\/\/phabricator.joshuaspence.com\/p\/josh\/","roles":["admin","verified","approved","activated"]}} ``` Reviewers: epriestley, #blessed_reviewers Reviewed By: epriestley, #blessed_reviewers Subscribers: epriestley, Korvin, hach-que Maniphest Tasks: T5655 Differential Revision: https://secure.phabricator.com/D9991
81 lines
2.2 KiB
PHP
81 lines
2.2 KiB
PHP
<?php
|
|
|
|
final class ReleephQueryRequestsConduitAPIMethod
|
|
extends ReleephConduitAPIMethod {
|
|
|
|
public function getAPIMethodName() {
|
|
return 'releeph.queryrequests';
|
|
}
|
|
|
|
public function getMethodDescription() {
|
|
return
|
|
'Return information about all Releeph requests linked to the given ids.';
|
|
}
|
|
|
|
public function defineParamTypes() {
|
|
return array(
|
|
'revisionPHIDs' => 'optional list<phid>',
|
|
'requestedCommitPHIDs' => 'optional list<phid>'
|
|
);
|
|
}
|
|
|
|
public function defineReturnType() {
|
|
return 'dict<string, wild>';
|
|
}
|
|
|
|
public function defineErrorTypes() {
|
|
return array();
|
|
}
|
|
|
|
protected function execute(ConduitAPIRequest $conduit_request) {
|
|
$revision_phids = $conduit_request->getValue('revisionPHIDs');
|
|
$requested_commit_phids =
|
|
$conduit_request->getValue('requestedCommitPHIDs');
|
|
$result = array();
|
|
|
|
if (!$revision_phids && !$requested_commit_phids) {
|
|
return $result;
|
|
}
|
|
|
|
$query = new ReleephRequestQuery();
|
|
$query->setViewer($conduit_request->getUser());
|
|
|
|
if ($revision_phids) {
|
|
$query->withRequestedObjectPHIDs($revision_phids);
|
|
} else if ($requested_commit_phids) {
|
|
$query->withRequestedCommitPHIDs($requested_commit_phids);
|
|
}
|
|
|
|
$releephRequests = $query->execute();
|
|
|
|
foreach ($releephRequests as $releephRequest) {
|
|
$branch = $releephRequest->getBranch();
|
|
|
|
$request_commit_phid = $releephRequest->getRequestCommitPHID();
|
|
|
|
$object = $releephRequest->getRequestedObject();
|
|
if ($object instanceof DifferentialRevision) {
|
|
$object_phid = $object->getPHID();
|
|
} else {
|
|
$object_phid = null;
|
|
}
|
|
|
|
$status = $releephRequest->getStatus();
|
|
$statusName = ReleephRequestStatus::getStatusDescriptionFor($status);
|
|
$url = PhabricatorEnv::getProductionURI('/RQ'.$releephRequest->getID());
|
|
|
|
$result[] = array(
|
|
'branchBasename' => $branch->getBasename(),
|
|
'branchSymbolic' => $branch->getSymbolicName(),
|
|
'requestID' => $releephRequest->getID(),
|
|
'revisionPHID' => $object_phid,
|
|
'status' => $status,
|
|
'statusName' => $statusName,
|
|
'url' => $url,
|
|
);
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
}
|