mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-25 22:18:18 +01:00
Allow anyone to run arc commit
on an accepted revision
Test Plan: Using SVN make some changes to the repo, run `arc diff`. As other user accept the revision, add the changes to your repo using `arc patch` and then run `arc commit --revision revisionID` to commit them. Arcanist should ask if you are sure that you want to commit this revision and if you answer `Y` it should commit to SNV repo. Reviewers: epriestley, jungejason Reviewed By: epriestley CC: aran, mareksapota, epriestley Differential Revision: 1055
This commit is contained in:
parent
ebc2644994
commit
bb05ddfb5a
2 changed files with 71 additions and 29 deletions
|
@ -68,6 +68,9 @@ EOTEXT
|
|||
$repository_api = $this->getRepositoryAPI();
|
||||
$conduit = $this->getConduit();
|
||||
|
||||
$revision_id = $this->getArgument('revision');
|
||||
|
||||
if (!$revision_id) {
|
||||
$revision_data = $conduit->callMethodSynchronous(
|
||||
'differential.find',
|
||||
array(
|
||||
|
@ -75,26 +78,53 @@ EOTEXT
|
|||
'guids' => array(
|
||||
$this->getUserPHID(),
|
||||
),
|
||||
));
|
||||
)
|
||||
);
|
||||
|
||||
try {
|
||||
$revision_id = $this->getArgument('revision');
|
||||
$revision = $this->chooseRevision(
|
||||
$revision_data,
|
||||
$revision_id,
|
||||
'Which revision do you want to commit?');
|
||||
} catch (ArcanistChooseInvalidRevisionException $ex) {
|
||||
throw new ArcanistUsageException(
|
||||
"Revision D{$revision_id} is not committable. You can only commit ".
|
||||
"revisions you own which have been 'accepted'.");
|
||||
null,
|
||||
'Which revision do you want to commit?'
|
||||
);
|
||||
$revision_id = $revision->getID();
|
||||
} catch (ArcanistChooseNoRevisionsException $ex) {
|
||||
throw new ArcanistUsageException(
|
||||
"You have no committable Differential revisions. You can only commit ".
|
||||
"revisions you own which have been 'accepted'.");
|
||||
"You have no committable Differential revisions. You can only ".
|
||||
"commit revisions which have been 'accepted'.");
|
||||
}
|
||||
}
|
||||
|
||||
$revision_id = $revision->getID();
|
||||
$revision_name = $revision->getName();
|
||||
$revision = null;
|
||||
try {
|
||||
$revision = $conduit->callMethodSynchronous(
|
||||
'differential.getrevision',
|
||||
array(
|
||||
'revision_id' => $revision_id,
|
||||
)
|
||||
);
|
||||
} catch (Exception $ex) {
|
||||
throw new ArcanistUsageException(
|
||||
"Revision D{$revision_id} does not exist."
|
||||
);
|
||||
}
|
||||
|
||||
if ($revision['statusName'] != 'Accepted') {
|
||||
throw new ArcanistUsageException(
|
||||
"Revision D{$revision_id} is not committable. You can only commit ".
|
||||
"revisions which have been 'accepted'."
|
||||
);
|
||||
}
|
||||
|
||||
if ($revision['authorPHID'] != $this->getUserPHID()) {
|
||||
$prompt = "You are not the author of revision D{$revision_id}, ".
|
||||
'are you sure you want to commit it?';
|
||||
if (!phutil_console_confirm($prompt)) {
|
||||
throw new ArcanistUserAbortException();
|
||||
}
|
||||
}
|
||||
|
||||
$revision_name = $revision['title'];
|
||||
|
||||
$message = $conduit->callMethodSynchronous(
|
||||
'differential.getcommitmessage',
|
||||
|
@ -140,8 +170,7 @@ EOTEXT
|
|||
return $err;
|
||||
}
|
||||
|
||||
protected function getCommitFileList(
|
||||
ArcanistDifferentialRevisionRef $revision) {
|
||||
protected function getCommitFileList(array $revision) {
|
||||
$repository_api = $this->getRepositoryAPI();
|
||||
|
||||
if (!($repository_api instanceof ArcanistSubversionAPI)) {
|
||||
|
@ -151,9 +180,22 @@ EOTEXT
|
|||
|
||||
$conduit = $this->getConduit();
|
||||
|
||||
$revision_id = $revision->getID();
|
||||
$revision_id = $revision['id'];
|
||||
|
||||
$revision = reset($conduit->callMethodSynchronous(
|
||||
'differential.find',
|
||||
array(
|
||||
'query' => 'revision-ids',
|
||||
'guids' => array($revision_id,)
|
||||
)
|
||||
));
|
||||
if (!$revision) {
|
||||
throw new ArcanistUsageException(
|
||||
"Revision D{$revision_id} does not exist."
|
||||
);
|
||||
}
|
||||
$revision_source = $revision['sourcePath'];
|
||||
|
||||
$revision_source = $revision->getSourcePath();
|
||||
$working_copy = $repository_api->getPath();
|
||||
if ($revision_source != $working_copy) {
|
||||
$prompt =
|
||||
|
|
|
@ -106,7 +106,7 @@ EOTEXT
|
|||
}
|
||||
|
||||
if ($revision) {
|
||||
if ($revision['authorPHID'] != $this->getUserPHID()) {
|
||||
if (!$is_finalize && $revision['authorPHID'] != $this->getUserPHID()) {
|
||||
$prompt = "You are not the author of revision D{$revision_id}, ".
|
||||
'are you sure you want to mark it committed?';
|
||||
if (!phutil_console_confirm($prompt)) {
|
||||
|
|
Loading…
Add table
Reference in a new issue