2011-01-24 20:01:53 +01:00
|
|
|
<?php
|
|
|
|
|
Rename Conduit classes
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
2014-07-25 02:54:15 +02:00
|
|
|
final class DifferentialCreateDiffConduitAPIMethod
|
|
|
|
extends DifferentialConduitAPIMethod {
|
|
|
|
|
|
|
|
public function getAPIMethodName() {
|
|
|
|
return 'differential.creatediff';
|
|
|
|
}
|
2011-01-24 20:01:53 +01:00
|
|
|
|
|
|
|
public function getMethodDescription() {
|
2014-06-09 20:36:49 +02:00
|
|
|
return 'Create a new Differential diff.';
|
2011-01-24 20:01:53 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function defineParamTypes() {
|
2014-05-15 06:59:03 +02:00
|
|
|
|
|
|
|
$vcs_const = $this->formatStringConstants(
|
|
|
|
array(
|
|
|
|
'svn',
|
|
|
|
'git',
|
|
|
|
'hg',
|
|
|
|
));
|
|
|
|
|
|
|
|
$status_const = $this->formatStringConstants(
|
|
|
|
array(
|
|
|
|
'none',
|
|
|
|
'skip',
|
|
|
|
'okay',
|
|
|
|
'warn',
|
|
|
|
'fail',
|
|
|
|
'postponed',
|
|
|
|
));
|
|
|
|
|
2011-01-24 20:01:53 +01:00
|
|
|
return array(
|
|
|
|
'changes' => 'required list<dict>',
|
|
|
|
'sourceMachine' => 'required string',
|
|
|
|
'sourcePath' => 'required string',
|
|
|
|
'branch' => 'required string',
|
2012-06-30 23:45:30 +02:00
|
|
|
'bookmark' => 'optional string',
|
2014-05-15 06:59:03 +02:00
|
|
|
'sourceControlSystem' => 'required '.$vcs_const,
|
2011-01-24 20:01:53 +01:00
|
|
|
'sourceControlPath' => 'required string',
|
|
|
|
'sourceControlBaseRevision' => 'required string',
|
|
|
|
'creationMethod' => 'optional string',
|
|
|
|
'arcanistProject' => 'optional string',
|
2014-05-15 06:59:03 +02:00
|
|
|
'lintStatus' => 'required '.$status_const,
|
|
|
|
'unitStatus' => 'required '.$status_const,
|
2014-01-27 00:29:22 +01:00
|
|
|
'repositoryPHID' => 'optional phid',
|
|
|
|
|
|
|
|
'parentRevisionID' => 'deprecated',
|
|
|
|
'authorPHID' => 'deprecated',
|
|
|
|
'repositoryUUID' => 'deprecated',
|
2011-01-24 20:01:53 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function defineReturnType() {
|
|
|
|
return 'nonempty dict';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function defineErrorTypes() {
|
|
|
|
return array(
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function execute(ConduitAPIRequest $request) {
|
2014-03-21 22:39:56 +01:00
|
|
|
$viewer = $request->getUser();
|
2011-01-24 20:01:53 +01:00
|
|
|
$change_data = $request->getValue('changes');
|
|
|
|
|
|
|
|
$changes = array();
|
|
|
|
foreach ($change_data as $dict) {
|
|
|
|
$changes[] = ArcanistDiffChange::newFromDictionary($dict);
|
|
|
|
}
|
|
|
|
|
|
|
|
$diff = DifferentialDiff::newFromRawChanges($changes);
|
|
|
|
$diff->setSourcePath($request->getValue('sourcePath'));
|
|
|
|
$diff->setSourceMachine($request->getValue('sourceMachine'));
|
|
|
|
|
|
|
|
$diff->setBranch($request->getValue('branch'));
|
|
|
|
$diff->setCreationMethod($request->getValue('creationMethod'));
|
2014-03-21 22:39:56 +01:00
|
|
|
$diff->setAuthorPHID($viewer->getPHID());
|
2012-06-30 23:45:30 +02:00
|
|
|
$diff->setBookmark($request->getValue('bookmark'));
|
2011-01-24 20:01:53 +01:00
|
|
|
|
2014-01-27 00:29:22 +01:00
|
|
|
// TODO: Remove this eventually; for now continue writing the UUID. Note
|
|
|
|
// that we'll overwrite it below if we identify a repository, and `arc`
|
|
|
|
// no longer sends it. This stuff is retained for backward compatibility.
|
|
|
|
$diff->setRepositoryUUID($request->getValue('repositoryUUID'));
|
|
|
|
|
|
|
|
$repository_phid = $request->getValue('repositoryPHID');
|
|
|
|
if ($repository_phid) {
|
|
|
|
$repository = id(new PhabricatorRepositoryQuery())
|
2014-03-21 22:39:56 +01:00
|
|
|
->setViewer($viewer)
|
2014-01-27 00:29:22 +01:00
|
|
|
->withPHIDs(array($repository_phid))
|
|
|
|
->executeOne();
|
|
|
|
if ($repository) {
|
|
|
|
$diff->setRepositoryPHID($repository->getPHID());
|
|
|
|
$diff->setRepositoryUUID($repository->getUUID());
|
2011-01-24 20:01:53 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$system = $request->getValue('sourceControlSystem');
|
|
|
|
$diff->setSourceControlSystem($system);
|
|
|
|
$diff->setSourceControlPath($request->getValue('sourceControlPath'));
|
|
|
|
$diff->setSourceControlBaseRevision(
|
|
|
|
$request->getValue('sourceControlBaseRevision'));
|
|
|
|
|
2011-04-06 05:49:31 +02:00
|
|
|
$project_name = $request->getValue('arcanistProject');
|
|
|
|
$project_phid = null;
|
|
|
|
if ($project_name) {
|
|
|
|
$arcanist_project = id(new PhabricatorRepositoryArcanistProject())
|
|
|
|
->loadOneWhere(
|
|
|
|
'name = %s',
|
|
|
|
$project_name);
|
|
|
|
if (!$arcanist_project) {
|
|
|
|
$arcanist_project = new PhabricatorRepositoryArcanistProject();
|
|
|
|
$arcanist_project->setName($project_name);
|
|
|
|
$arcanist_project->save();
|
|
|
|
}
|
|
|
|
$project_phid = $arcanist_project->getPHID();
|
|
|
|
}
|
|
|
|
|
|
|
|
$diff->setArcanistProjectPHID($project_phid);
|
2011-01-24 20:01:53 +01:00
|
|
|
|
|
|
|
switch ($request->getValue('lintStatus')) {
|
|
|
|
case 'skip':
|
|
|
|
$diff->setLintStatus(DifferentialLintStatus::LINT_SKIP);
|
|
|
|
break;
|
|
|
|
case 'okay':
|
|
|
|
$diff->setLintStatus(DifferentialLintStatus::LINT_OKAY);
|
|
|
|
break;
|
|
|
|
case 'warn':
|
|
|
|
$diff->setLintStatus(DifferentialLintStatus::LINT_WARN);
|
|
|
|
break;
|
|
|
|
case 'fail':
|
|
|
|
$diff->setLintStatus(DifferentialLintStatus::LINT_FAIL);
|
|
|
|
break;
|
2012-07-06 04:39:30 +02:00
|
|
|
case 'postponed':
|
|
|
|
$diff->setLintStatus(DifferentialLintStatus::LINT_POSTPONED);
|
|
|
|
break;
|
2011-01-24 20:01:53 +01:00
|
|
|
case 'none':
|
|
|
|
default:
|
|
|
|
$diff->setLintStatus(DifferentialLintStatus::LINT_NONE);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ($request->getValue('unitStatus')) {
|
|
|
|
case 'skip':
|
|
|
|
$diff->setUnitStatus(DifferentialUnitStatus::UNIT_SKIP);
|
|
|
|
break;
|
|
|
|
case 'okay':
|
|
|
|
$diff->setUnitStatus(DifferentialUnitStatus::UNIT_OKAY);
|
|
|
|
break;
|
|
|
|
case 'warn':
|
|
|
|
$diff->setUnitStatus(DifferentialUnitStatus::UNIT_WARN);
|
|
|
|
break;
|
|
|
|
case 'fail':
|
|
|
|
$diff->setUnitStatus(DifferentialUnitStatus::UNIT_FAIL);
|
|
|
|
break;
|
2011-06-09 01:16:59 +02:00
|
|
|
case 'postponed':
|
|
|
|
$diff->setUnitStatus(DifferentialUnitStatus::UNIT_POSTPONED);
|
|
|
|
break;
|
2011-01-24 20:01:53 +01:00
|
|
|
case 'none':
|
|
|
|
default:
|
|
|
|
$diff->setUnitStatus(DifferentialUnitStatus::UNIT_NONE);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$diff->save();
|
|
|
|
|
2014-03-21 22:39:56 +01:00
|
|
|
// If we didn't get an explicit `repositoryPHID` (which means the client is
|
|
|
|
// old, or couldn't figure out which repository the working copy belongs
|
|
|
|
// to), apply heuristics to try to figure it out.
|
|
|
|
|
|
|
|
if (!$repository_phid) {
|
|
|
|
$repository = id(new DifferentialRepositoryLookup())
|
|
|
|
->setDiff($diff)
|
|
|
|
->setViewer($viewer)
|
|
|
|
->lookupRepository();
|
|
|
|
if ($repository) {
|
|
|
|
$diff->setRepositoryPHID($repository->getPHID());
|
|
|
|
$diff->setRepositoryUUID($repository->getUUID());
|
|
|
|
$diff->save();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-02-01 01:59:01 +01:00
|
|
|
$path = '/differential/diff/'.$diff->getID().'/';
|
|
|
|
$uri = PhabricatorEnv::getURI($path);
|
|
|
|
|
2011-01-24 20:01:53 +01:00
|
|
|
return array(
|
|
|
|
'diffid' => $diff->getID(),
|
2011-02-01 01:59:01 +01:00
|
|
|
'uri' => $uri,
|
2011-01-24 20:01:53 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|