Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
<?php
|
|
|
|
|
2015-06-15 18:02:26 +10:00
|
|
|
abstract class DifferentialLandingStrategy extends Phobject {
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
|
2015-06-02 22:14:01 +10:00
|
|
|
abstract public function processLandRequest(
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
AphrontRequest $request,
|
|
|
|
DifferentialRevision $revision,
|
|
|
|
PhabricatorRepository $repository);
|
|
|
|
|
|
|
|
/**
|
2014-07-25 08:20:39 +10:00
|
|
|
* @return PhabricatorActionView or null.
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
*/
|
2015-06-02 22:14:01 +10:00
|
|
|
abstract public function createMenuItem(
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
PhabricatorUser $viewer,
|
|
|
|
DifferentialRevision $revision,
|
|
|
|
PhabricatorRepository $repository);
|
|
|
|
|
|
|
|
/**
|
2014-07-25 08:20:39 +10:00
|
|
|
* @return PhabricatorActionView which can be attached to the revision view.
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
*/
|
2014-01-30 09:07:50 -08:00
|
|
|
protected function createActionView($revision, $name) {
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
$strategy = get_class($this);
|
|
|
|
$revision_id = $revision->getId();
|
|
|
|
return id(new PhabricatorActionView())
|
|
|
|
->setRenderAsForm(true)
|
2014-01-30 09:07:50 -08:00
|
|
|
->setWorkflow(true)
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
->setName($name)
|
2014-01-30 09:07:50 -08:00
|
|
|
->setHref("/differential/revision/land/{$revision_id}/{$strategy}/");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if this action should be disabled, and explain why.
|
|
|
|
*
|
|
|
|
* By default, this method checks for push permissions, and for the
|
|
|
|
* revision being Accepted.
|
|
|
|
*
|
2014-07-25 08:20:39 +10:00
|
|
|
* @return False for "not disabled"; human-readable text explaining why, if
|
|
|
|
* it is disabled.
|
2014-01-30 09:07:50 -08:00
|
|
|
*/
|
|
|
|
public function isActionDisabled(
|
|
|
|
PhabricatorUser $viewer,
|
|
|
|
DifferentialRevision $revision,
|
|
|
|
PhabricatorRepository $repository) {
|
|
|
|
|
|
|
|
$status = $revision->getStatus();
|
|
|
|
if ($status != ArcanistDifferentialRevisionStatus::ACCEPTED) {
|
2014-06-09 11:36:49 -07:00
|
|
|
return pht('Only Accepted revisions can be landed.');
|
2014-01-30 09:07:50 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!PhabricatorPolicyFilter::hasCapability(
|
|
|
|
$viewer,
|
|
|
|
$repository,
|
2014-07-25 08:20:39 +10:00
|
|
|
DiffusionPushCapability::CAPABILITY)) {
|
2014-06-09 11:36:49 -07:00
|
|
|
return pht('You do not have permissions to push to this repository.');
|
2014-01-30 09:07:50 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-07-25 08:20:39 +10:00
|
|
|
* Might break if repository is not Git.
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
*/
|
|
|
|
protected function getGitWorkspace(PhabricatorRepository $repository) {
|
|
|
|
try {
|
2015-01-05 06:33:42 +11:00
|
|
|
return DifferentialGetWorkingCopy::getCleanGitWorkspace($repository);
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
} catch (Exception $e) {
|
2015-05-22 17:27:56 +10:00
|
|
|
throw new PhutilProxyException(
|
|
|
|
pht('Failed to allocate a workspace.'),
|
|
|
|
$e);
|
2013-11-08 11:37:57 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-07-25 08:20:39 +10:00
|
|
|
* Might break if repository is not Mercurial.
|
2013-11-08 11:37:57 -08:00
|
|
|
*/
|
|
|
|
protected function getMercurialWorkspace(PhabricatorRepository $repository) {
|
|
|
|
try {
|
|
|
|
return DifferentialGetWorkingCopy::getCleanMercurialWorkspace(
|
|
|
|
$repository);
|
|
|
|
} catch (Exception $e) {
|
2015-05-22 17:27:56 +10:00
|
|
|
throw new PhutilProxyException(
|
|
|
|
pht('Failed to allocate a workspace.'),
|
|
|
|
$e);
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
}
|
|
|
|
}
|
2014-07-25 08:20:39 +10:00
|
|
|
|
Land Revision button for hosted git repos
Summary:
ref T182.
Simple approach of clone, patch, push. While waiting for drydock, implement a hackish mutex
setup for the workspace, which should work ok as long as there's only one committer who is
carefull about theses things.
Less obvious note: This is taking the both author and commiter's 'primary email' for the commit -
which might rub some people wrong.
Test Plan:
With a hosted repo, created some diffs and landed them.
Also clicked button for some error cases, got the right error message.
Reviewers: epriestley, #blessed_reviewers
Reviewed By: epriestley
CC: hach-que, Korvin, epriestley, aran
Maniphest Tasks: T182
Differential Revision: https://secure.phabricator.com/D7486
2013-11-05 13:00:12 -08:00
|
|
|
}
|