mirror of
https://we.phorge.it/source/phorge.git
synced 2025-04-05 00:48:22 +02:00
Summary: Fixes T6200. Ref T6237. When creating a diff from the web view, allow the user to select the repository at that time. When viewing a diff that has no associated revision and then creating a revision, pass along the repository phid to the create revision controller. Within the create revision controller, default the repository selector to this repository phid. Finally, in the editor, stop aggressively resetting the repository phid for every TYPE_UPDATE; rather, do so if its not a new object -- the diff should reign supreme in that case -- or if there's no repository -- let the diff be the guide. Test Plan: - made a diff with an associated repo, made a revision from the diff, saw the associated repo and it stuck on save! - made a diff with an associated repo, made a revision from the diff but changed the repo and it stuck on save! - made a diff with an associated repo, made a revision from the diff but changed the repo to nothing and it stuck on save! Reviewers: epriestley Reviewed By: epriestley Subscribers: Korvin, epriestley Maniphest Tasks: T6237, T6200 Differential Revision: https://secure.phabricator.com/D10872
127 lines
3.8 KiB
PHP
127 lines
3.8 KiB
PHP
<?php
|
|
|
|
final class DifferentialDiffCreateController extends DifferentialController {
|
|
|
|
public function processRequest() {
|
|
|
|
$request = $this->getRequest();
|
|
|
|
$diff = null;
|
|
$repository_phid = null;
|
|
$repository_value = array();
|
|
$errors = array();
|
|
$e_diff = null;
|
|
$e_file = null;
|
|
$validation_exception = null;
|
|
if ($request->isFormPost()) {
|
|
|
|
$repository_tokenizer = $request->getArr(
|
|
id(new DifferentialRepositoryField())->getFieldKey());
|
|
if ($repository_tokenizer) {
|
|
$repository_phid = reset($repository_tokenizer);
|
|
}
|
|
|
|
if ($request->getFileExists('diff-file')) {
|
|
$diff = PhabricatorFile::readUploadedFileData($_FILES['diff-file']);
|
|
} else {
|
|
$diff = $request->getStr('diff');
|
|
}
|
|
|
|
if (!strlen($diff)) {
|
|
$errors[] = pht(
|
|
'You can not create an empty diff. Copy/paste a diff, or upload a '.
|
|
'diff file.');
|
|
$e_diff = pht('Required');
|
|
$e_file = pht('Required');
|
|
}
|
|
|
|
if (!$errors) {
|
|
try {
|
|
$call = new ConduitCall(
|
|
'differential.createrawdiff',
|
|
array(
|
|
'diff' => $diff,
|
|
'repositoryPHID' => $repository_phid,));
|
|
$call->setUser($request->getUser());
|
|
$result = $call->execute();
|
|
$path = id(new PhutilURI($result['uri']))->getPath();
|
|
return id(new AphrontRedirectResponse())->setURI($path);
|
|
} catch (PhabricatorApplicationTransactionValidationException $ex) {
|
|
$validation_exception = $ex;
|
|
}
|
|
}
|
|
}
|
|
|
|
$form = new AphrontFormView();
|
|
$arcanist_href = PhabricatorEnv::getDoclink('Arcanist User Guide');
|
|
$arcanist_link = phutil_tag(
|
|
'a',
|
|
array(
|
|
'href' => $arcanist_href,
|
|
'target' => '_blank',
|
|
),
|
|
'Arcanist');
|
|
|
|
$cancel_uri = $this->getApplicationURI();
|
|
|
|
if ($repository_phid) {
|
|
$repository_value = $this->loadViewerHandles(array($repository_phid));
|
|
}
|
|
|
|
$form
|
|
->setAction('/differential/diff/create/')
|
|
->setEncType('multipart/form-data')
|
|
->setUser($request->getUser())
|
|
->appendInstructions(
|
|
pht(
|
|
'The best way to create a Differential diff is by using %s, but you '.
|
|
'can also just paste a diff (for example, from %s, %s or %s) into '.
|
|
'this box, or upload a diff file.',
|
|
$arcanist_link,
|
|
phutil_tag('tt', array(), 'svn diff'),
|
|
phutil_tag('tt', array(), 'git diff'),
|
|
phutil_tag('tt', array(), 'hg diff --git')))
|
|
->appendChild(
|
|
id(new AphrontFormTextAreaControl())
|
|
->setLabel(pht('Raw Diff'))
|
|
->setName('diff')
|
|
->setValue($diff)
|
|
->setHeight(AphrontFormTextAreaControl::HEIGHT_VERY_TALL)
|
|
->setError($e_diff))
|
|
->appendChild(
|
|
id(new AphrontFormFileControl())
|
|
->setLabel(pht('Raw Diff From File'))
|
|
->setName('diff-file')
|
|
->setError($e_file))
|
|
->appendChild(
|
|
id(new AphrontFormTokenizerControl())
|
|
->setName(id(new DifferentialRepositoryField())->getFieldKey())
|
|
->setLabel(pht('Repository'))
|
|
->setDatasource(new DiffusionRepositoryDatasource())
|
|
->setValue($repository_value)
|
|
->setLimit(1))
|
|
->appendChild(
|
|
id(new AphrontFormSubmitControl())
|
|
->addCancelButton($cancel_uri)
|
|
->setValue(pht('Create Diff')));
|
|
|
|
$form_box = id(new PHUIObjectBoxView())
|
|
->setHeaderText(pht('Create New Diff'))
|
|
->setValidationException($validation_exception)
|
|
->setForm($form)
|
|
->setFormErrors($errors);
|
|
|
|
$crumbs = $this->buildApplicationCrumbs();
|
|
$crumbs->addTextCrumb(pht('Create Diff'));
|
|
|
|
return $this->buildApplicationPage(
|
|
array(
|
|
$crumbs,
|
|
$form_box,
|
|
),
|
|
array(
|
|
'title' => pht('Create Diff'),
|
|
));
|
|
}
|
|
|
|
}
|