2011-03-11 09:34:22 -08:00
|
|
|
<?php
|
|
|
|
|
2012-03-09 15:46:25 -08:00
|
|
|
final class DiffusionCommitController extends DiffusionController {
|
2011-03-11 09:34:22 -08:00
|
|
|
|
2011-04-07 14:55:06 -07:00
|
|
|
const CHANGES_LIMIT = 100;
|
|
|
|
|
2012-03-26 09:44:06 -07:00
|
|
|
private $auditAuthorityPHIDs;
|
2012-07-16 15:00:32 -07:00
|
|
|
private $highlightedAudits;
|
2012-03-26 09:44:06 -07:00
|
|
|
|
2015-10-02 16:11:03 -07:00
|
|
|
private $commitParents;
|
|
|
|
private $commitRefs;
|
|
|
|
private $commitMerges;
|
|
|
|
private $commitErrors;
|
|
|
|
private $commitExists;
|
|
|
|
|
2013-09-27 10:49:45 -07:00
|
|
|
public function shouldAllowPublic() {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-01-05 04:42:07 -08:00
|
|
|
public function handleRequest(AphrontRequest $request) {
|
|
|
|
$response = $this->loadDiffusionContext();
|
|
|
|
if ($response) {
|
|
|
|
return $response;
|
|
|
|
}
|
2015-01-09 13:29:08 -08:00
|
|
|
|
2016-01-05 04:42:07 -08:00
|
|
|
$drequest = $this->getDiffusionRequest();
|
2015-10-02 16:11:03 -07:00
|
|
|
|
2016-01-05 04:42:07 -08:00
|
|
|
$user = $request->getUser();
|
2011-03-11 09:34:22 -08:00
|
|
|
|
2012-05-02 13:43:45 -07:00
|
|
|
if ($request->getStr('diff')) {
|
|
|
|
return $this->buildRawDiffResponse($drequest);
|
|
|
|
}
|
|
|
|
|
2014-04-27 09:43:05 -07:00
|
|
|
$repository = $drequest->getRepository();
|
2011-03-30 19:22:11 -07:00
|
|
|
|
2011-03-13 16:19:39 -07:00
|
|
|
$content = array();
|
2014-04-27 09:43:05 -07:00
|
|
|
$commit = id(new DiffusionCommitQuery())
|
|
|
|
->setViewer($request->getUser())
|
|
|
|
->withRepository($repository)
|
|
|
|
->withIdentifiers(array($drequest->getCommit()))
|
|
|
|
->needCommitData(true)
|
|
|
|
->needAuditRequests(true)
|
|
|
|
->executeOne();
|
2011-03-26 23:52:09 -07:00
|
|
|
|
2013-09-23 12:53:55 -07:00
|
|
|
$crumbs = $this->buildCrumbs(array(
|
|
|
|
'commit' => true,
|
|
|
|
));
|
|
|
|
|
2011-03-26 23:52:09 -07:00
|
|
|
if (!$commit) {
|
2015-10-02 16:11:03 -07:00
|
|
|
if (!$this->getCommitExists()) {
|
2012-08-09 09:27:45 -07:00
|
|
|
return new Aphront404Response();
|
|
|
|
}
|
2013-09-23 12:53:55 -07:00
|
|
|
|
2015-03-01 14:45:56 -08:00
|
|
|
$error = id(new PHUIInfoView())
|
2013-09-23 12:53:55 -07:00
|
|
|
->setTitle(pht('Commit Still Parsing'))
|
|
|
|
->appendChild(
|
|
|
|
pht(
|
|
|
|
'Failed to load the commit because the commit has not been '.
|
|
|
|
'parsed yet.'));
|
|
|
|
|
|
|
|
return $this->buildApplicationPage(
|
|
|
|
array(
|
|
|
|
$crumbs,
|
|
|
|
$error,
|
|
|
|
),
|
|
|
|
array(
|
|
|
|
'title' => pht('Commit Still Parsing'),
|
|
|
|
));
|
2011-03-26 23:52:09 -07:00
|
|
|
}
|
|
|
|
|
2014-04-27 09:43:05 -07:00
|
|
|
$audit_requests = $commit->getAudits();
|
2013-07-24 15:29:46 -07:00
|
|
|
$this->auditAuthorityPHIDs =
|
|
|
|
PhabricatorAuditCommentEditor::loadAuditPHIDsForUser($user);
|
|
|
|
|
2014-04-27 09:43:05 -07:00
|
|
|
$commit_data = $commit->getCommitData();
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$is_foreign = $commit_data->getCommitDetail('foreign-svn-stub');
|
|
|
|
if ($is_foreign) {
|
|
|
|
$subpath = $commit_data->getCommitDetail('svn-subpath');
|
|
|
|
|
2015-03-01 14:45:56 -08:00
|
|
|
$error_panel = new PHUIInfoView();
|
2013-05-11 08:23:19 -07:00
|
|
|
$error_panel->setTitle(pht('Commit Not Tracked'));
|
2015-03-01 14:45:56 -08:00
|
|
|
$error_panel->setSeverity(PHUIInfoView::SEVERITY_WARNING);
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$error_panel->appendChild(
|
2015-05-22 17:27:56 +10:00
|
|
|
pht(
|
|
|
|
"This Diffusion repository is configured to track only one ".
|
|
|
|
"subdirectory of the entire Subversion repository, and this commit ".
|
|
|
|
"didn't affect the tracked subdirectory ('%s'), so no ".
|
|
|
|
"information is available.",
|
|
|
|
$subpath));
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$content[] = $error_panel;
|
|
|
|
} else {
|
|
|
|
$engine = PhabricatorMarkupEngine::newDifferentialMarkupEngine();
|
2013-03-04 12:33:05 -08:00
|
|
|
$engine->setConfig('viewer', $user);
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
|
|
|
|
require_celerity_resource('phabricator-remarkup-css');
|
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
$headsup_view = id(new PHUIHeaderView())
|
2013-02-21 15:09:35 -08:00
|
|
|
->setHeader(nonempty($commit->getSummary(), pht('Commit Detail')));
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
|
|
|
|
$headsup_actions = $this->renderHeadsupActionList($commit, $repository);
|
|
|
|
|
|
|
|
$commit_properties = $this->loadCommitProperties(
|
|
|
|
$commit,
|
|
|
|
$commit_data,
|
2013-07-24 15:29:46 -07:00
|
|
|
$audit_requests);
|
2013-10-11 07:53:56 -07:00
|
|
|
$property_list = id(new PHUIPropertyListView())
|
2013-05-09 14:21:21 -07:00
|
|
|
->setHasKeyboardShortcuts(true)
|
|
|
|
->setUser($user)
|
|
|
|
->setObject($commit);
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
foreach ($commit_properties as $key => $value) {
|
|
|
|
$property_list->addProperty($key, $value);
|
|
|
|
}
|
|
|
|
|
2013-04-19 21:56:13 -07:00
|
|
|
$message = $commit_data->getCommitMessage();
|
|
|
|
|
|
|
|
$revision = $commit->getCommitIdentifier();
|
2013-09-18 10:13:00 -07:00
|
|
|
$message = $this->linkBugtraq($message);
|
2013-04-19 21:56:13 -07:00
|
|
|
|
|
|
|
$message = $engine->markupText($message);
|
|
|
|
|
2013-05-09 14:21:21 -07:00
|
|
|
$property_list->invokeWillRenderEvent();
|
2013-10-16 13:09:12 -07:00
|
|
|
$property_list->setActionList($headsup_actions);
|
|
|
|
|
|
|
|
$detail_list = new PHUIPropertyListView();
|
2013-11-04 11:07:51 -08:00
|
|
|
$detail_list->addSectionHeader(
|
|
|
|
pht('Description'),
|
|
|
|
PHUIPropertyListView::ICON_SUMMARY);
|
2013-10-16 13:09:12 -07:00
|
|
|
$detail_list->addTextContent(
|
2013-01-29 11:01:47 -08:00
|
|
|
phutil_tag(
|
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'class' => 'diffusion-commit-message phabricator-remarkup',
|
|
|
|
),
|
2013-04-19 21:56:13 -07:00
|
|
|
$message));
|
2013-09-28 15:55:38 -07:00
|
|
|
|
2015-05-31 08:36:44 -07:00
|
|
|
$headsup_view->setTall(true);
|
2015-10-02 16:11:03 -07:00
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
$object_box = id(new PHUIObjectBoxView())
|
|
|
|
->setHeader($headsup_view)
|
2015-10-02 16:11:03 -07:00
|
|
|
->setFormErrors($this->getCommitErrors())
|
2013-10-16 13:09:12 -07:00
|
|
|
->addPropertyList($property_list)
|
|
|
|
->addPropertyList($detail_list);
|
2013-09-28 15:55:38 -07:00
|
|
|
|
|
|
|
$content[] = $object_box;
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
}
|
2011-03-13 16:19:39 -07:00
|
|
|
|
2012-02-24 14:14:39 -08:00
|
|
|
$content[] = $this->buildComments($commit);
|
2012-02-24 13:02:14 -08:00
|
|
|
|
2013-01-30 12:01:49 -08:00
|
|
|
$hard_limit = 1000;
|
|
|
|
|
2013-10-26 19:16:10 -07:00
|
|
|
if ($commit->isImported()) {
|
|
|
|
$change_query = DiffusionPathChangeQuery::newFromDiffusionRequest(
|
|
|
|
$drequest);
|
|
|
|
$change_query->setLimit($hard_limit + 1);
|
|
|
|
$changes = $change_query->loadChanges();
|
|
|
|
} else {
|
|
|
|
$changes = array();
|
|
|
|
}
|
2011-03-13 16:19:39 -07:00
|
|
|
|
2013-01-30 12:01:49 -08:00
|
|
|
$was_limited = (count($changes) > $hard_limit);
|
|
|
|
if ($was_limited) {
|
|
|
|
$changes = array_slice($changes, 0, $hard_limit);
|
|
|
|
}
|
|
|
|
|
2012-03-23 15:32:26 -07:00
|
|
|
$content[] = $this->buildMergesTable($commit);
|
|
|
|
|
2014-04-27 09:43:05 -07:00
|
|
|
$highlighted_audits = $commit->getAuthorityAudits(
|
|
|
|
$user,
|
|
|
|
$this->auditAuthorityPHIDs);
|
2013-08-28 16:32:40 -07:00
|
|
|
|
2011-04-07 14:55:06 -07:00
|
|
|
$count = count($changes);
|
2011-03-19 14:38:50 -07:00
|
|
|
|
2011-03-26 23:52:09 -07:00
|
|
|
$bad_commit = null;
|
|
|
|
if ($count == 0) {
|
|
|
|
$bad_commit = queryfx_one(
|
|
|
|
id(new PhabricatorRepository())->establishConnection('r'),
|
|
|
|
'SELECT * FROM %T WHERE fullCommitName = %s',
|
|
|
|
PhabricatorRepository::TABLE_BADCOMMIT,
|
2016-01-02 11:28:31 -08:00
|
|
|
$commit->getMonogram());
|
2011-03-26 23:52:09 -07:00
|
|
|
}
|
|
|
|
|
2015-08-15 12:57:20 -07:00
|
|
|
$show_changesets = false;
|
2011-03-26 23:52:09 -07:00
|
|
|
if ($bad_commit) {
|
2013-10-26 19:16:10 -07:00
|
|
|
$content[] = $this->renderStatusMessage(
|
|
|
|
pht('Bad Commit'),
|
|
|
|
$bad_commit['description']);
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
} else if ($is_foreign) {
|
|
|
|
// Don't render anything else.
|
2013-10-26 19:16:10 -07:00
|
|
|
} else if (!$commit->isImported()) {
|
|
|
|
$content[] = $this->renderStatusMessage(
|
|
|
|
pht('Still Importing...'),
|
|
|
|
pht(
|
|
|
|
'This commit is still importing. Changes will be visible once '.
|
|
|
|
'the import finishes.'));
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
} else if (!count($changes)) {
|
2013-10-26 19:16:10 -07:00
|
|
|
$content[] = $this->renderStatusMessage(
|
|
|
|
pht('Empty Commit'),
|
|
|
|
pht(
|
|
|
|
'This commit is empty and does not affect any paths.'));
|
2013-01-30 12:01:49 -08:00
|
|
|
} else if ($was_limited) {
|
2013-10-26 19:16:10 -07:00
|
|
|
$content[] = $this->renderStatusMessage(
|
|
|
|
pht('Enormous Commit'),
|
2013-01-30 12:01:49 -08:00
|
|
|
pht(
|
|
|
|
'This commit is enormous, and affects more than %d files. '.
|
|
|
|
'Changes are not shown.',
|
|
|
|
$hard_limit));
|
2015-10-02 16:11:03 -07:00
|
|
|
} else if (!$this->getCommitExists()) {
|
|
|
|
$content[] = $this->renderStatusMessage(
|
|
|
|
pht('Commit No Longer Exists'),
|
|
|
|
pht('This commit no longer exists in the repository.'));
|
2011-03-26 23:52:09 -07:00
|
|
|
} else {
|
2015-08-15 12:57:20 -07:00
|
|
|
$show_changesets = true;
|
|
|
|
|
2013-09-06 10:05:24 -07:00
|
|
|
// The user has clicked "Show All Changes", and we should show all the
|
|
|
|
// changes inline even if there are more than the soft limit.
|
|
|
|
$show_all_details = $request->getBool('show_all');
|
|
|
|
|
2014-01-09 08:51:57 -08:00
|
|
|
$change_panel = new PHUIObjectBoxView();
|
|
|
|
$header = new PHUIHeaderView();
|
2015-05-25 21:28:49 +10:00
|
|
|
$header->setHeader(pht('Changes (%s)', new PhutilNumber($count)));
|
2012-08-21 15:01:20 -07:00
|
|
|
$change_panel->setID('toc');
|
2014-01-09 08:51:57 -08:00
|
|
|
|
2015-05-25 21:28:49 +10:00
|
|
|
if ($count > self::CHANGES_LIMIT && !$show_all_details) {
|
2014-01-09 08:51:57 -08:00
|
|
|
$icon = id(new PHUIIconView())
|
2014-05-12 10:08:32 -07:00
|
|
|
->setIconFont('fa-files-o');
|
2014-01-09 08:51:57 -08:00
|
|
|
|
|
|
|
$button = id(new PHUIButtonView())
|
|
|
|
->setText(pht('Show All Changes'))
|
|
|
|
->setHref('?show_all=true')
|
|
|
|
->setTag('a')
|
|
|
|
->setIcon($icon);
|
2013-10-26 19:16:10 -07:00
|
|
|
|
2015-03-01 14:45:56 -08:00
|
|
|
$warning_view = id(new PHUIInfoView())
|
|
|
|
->setSeverity(PHUIInfoView::SEVERITY_WARNING)
|
2015-05-22 17:27:56 +10:00
|
|
|
->setTitle(pht('Very Large Commit'))
|
2013-10-30 09:20:48 -07:00
|
|
|
->appendChild(
|
2014-06-09 11:36:49 -07:00
|
|
|
pht('This commit is very large. Load each file individually.'));
|
2011-04-07 14:55:06 -07:00
|
|
|
|
2015-03-06 17:03:18 -08:00
|
|
|
$change_panel->setInfoView($warning_view);
|
2014-01-09 08:51:57 -08:00
|
|
|
$header->addActionLink($button);
|
2011-04-07 14:55:06 -07:00
|
|
|
}
|
|
|
|
|
2015-08-15 12:57:20 -07:00
|
|
|
$changesets = DiffusionPathChange::convertToDifferentialChangesets(
|
|
|
|
$user,
|
|
|
|
$changes);
|
|
|
|
|
|
|
|
// TODO: This table and panel shouldn't really be separate, but we need
|
|
|
|
// to clean up the "Load All Files" interaction first.
|
|
|
|
$change_table = $this->buildTableOfContents(
|
|
|
|
$changesets);
|
|
|
|
|
2015-05-19 23:14:22 -07:00
|
|
|
$change_panel->setTable($change_table);
|
2014-01-09 08:51:57 -08:00
|
|
|
$change_panel->setHeader($header);
|
2011-03-26 23:52:09 -07:00
|
|
|
|
|
|
|
$content[] = $change_panel;
|
|
|
|
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$vcs = $repository->getVersionControlSystem();
|
|
|
|
switch ($vcs) {
|
|
|
|
case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN:
|
|
|
|
$vcs_supports_directory_changes = true;
|
|
|
|
break;
|
|
|
|
case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
|
Basic support for Mercurial in Diffusion
Summary: Change import script plus almost all the view stuff. Still some rough
edges but this seems to mostly work. Blame is currently unsupported but I think
everything else works properly.
Test Plan:
Imported the hg repository itself. It doesn't immediately seem completely
broken. Here are some screens:
https://secure.phabricator.com/file/view/PHID-FILE-1438b71cc7c4a2eb4569/
https://secure.phabricator.com/file/view/PHID-FILE-3cec4f72f39e7de2d041/
https://secure.phabricator.com/file/view/PHID-FILE-2ea4883f160e8e5098f9/
https://secure.phabricator.com/file/view/PHID-FILE-35f751a36ebf65399ade/
All the parsers were able to churn through it without errors.
Ran the new "reparse.php" script in various one-commit and repository modes.
Browsed/imported some git repos for good measure.
NOTE: The hg repository is only 15,000 commits and around 1,000 files.
Performance is okay but hg doesn't provide performant, native APIs to get some
data efficiently so we have to do some dumb stuff. If some of these interfaces
are cripplingly slow or whatever, let me know and we can start bundling some
Mercurial extensions with Arcanist.
Reviewers: Makinde, jungejason, nh, tuomaspelkonen, aran
Reviewed By: Makinde
CC: aran, Makinde, epriestley
Differential Revision: 960
2011-09-26 11:07:38 -07:00
|
|
|
case PhabricatorRepositoryType::REPOSITORY_TYPE_MERCURIAL:
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$vcs_supports_directory_changes = false;
|
|
|
|
break;
|
|
|
|
default:
|
2015-05-22 17:27:56 +10:00
|
|
|
throw new Exception(pht('Unknown VCS.'));
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
}
|
2011-03-30 22:08:41 -07:00
|
|
|
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$references = array();
|
|
|
|
foreach ($changesets as $key => $changeset) {
|
|
|
|
$file_type = $changeset->getFileType();
|
|
|
|
if ($file_type == DifferentialChangeType::FILE_DIRECTORY) {
|
|
|
|
if (!$vcs_supports_directory_changes) {
|
|
|
|
unset($changesets[$key]);
|
|
|
|
continue;
|
2011-03-30 22:08:41 -07:00
|
|
|
}
|
2011-03-30 19:22:11 -07:00
|
|
|
}
|
|
|
|
|
Fix many encoding and architecture problems in Diffusion request and URI handling
Summary:
Diffusion request/uri handling is currently a big, hastily ported mess. In particular, it has:
- Tons and tons of duplicated code.
- Bugs with handling unusual branch and file names.
- An excessively large (and yet insufficiently expressive) API on DiffusionRequest, including a nonsensical concrete base class.
- Other tools were doing hacky things like passing ":" branch names.
This diff attempts to fix these issues.
- Make the base class abstract (it was concrete ONLY for "/diffusion/").
- Move all URI generation to DiffusionRequest. Make the core static. Add unit tests.
- Delete the 300 copies of URI generation code throughout Diffusion.
- Move all URI parsing to DiffusionRequest. Make the core static. Add unit tests.
- Add an appropriate static initializer for other callers.
- Convert all code calling `newFromAphrontRequestDictionary` outside of Diffusion to the new `newFromDictionary` API.
- Refactor static initializers to be sensibly-sized.
- Refactor derived DiffusionRequest classes to remove duplicated code.
- Properly encode branch names (fixes branches with "/", see <https://github.com/facebook/phabricator/issues/100>).
- Properly encode path names (fixes issues in D1742).
- Properly escape delimiter characters ";" and "$" in path names so files like "$100" are not interpreted as "line 100".
- Fix a couple warnings.
- Fix a couple lint issues.
- Fix a bug where we would not parse filenames with spaces in them correctly in the Git browse query.
- Fix a bug where Git change queries would fail unnecessarily.
- Provide or improve some documentation.
This thing is pretty gigantic but also kind of hard to split up. If it's unreasonably difficult to review, let me know and I can take a stab at it though.
This supplants D1742.
Test Plan:
- Used home, repository, branch, browse, change, history, diff (ajax), lastmodified (ajax) views of Diffusion.
- Used Owners typeaheads and search.
- Used diffusion.getrecentcommitsbypath method.
- Pushed a change to an absurdly-named file on an absurdly-named branch, everything worked properly.
{F9185}
Reviewers: nh, vrana, btrahan
Reviewed By: btrahan
CC: aran, epriestley
Differential Revision: https://secure.phabricator.com/D1921
2012-03-19 19:52:14 -07:00
|
|
|
$references[$key] = $drequest->generateURI(
|
|
|
|
array(
|
|
|
|
'action' => 'rendering-ref',
|
|
|
|
'path' => $changeset->getFilename(),
|
|
|
|
));
|
2011-03-30 19:22:11 -07:00
|
|
|
}
|
2011-03-26 23:52:09 -07:00
|
|
|
|
2012-04-07 11:45:31 -07:00
|
|
|
// TODO: Some parts of the views still rely on properties of the
|
Add inline comments to Diffusion/Audit
Summary:
- Add inline comments to Audits, like Differential.
- Creates new storage for the comments in the Audits database.
- Creates a new PhabricatorAuditInlineComment class, similar to DifferentialInlineComment.
- Defines an Interface which Differential and Audit comments conform to.
- Makes consumers of DifferentialInlineComments consume objects which implement that interface instead.
- Adds save
NOTE: Some features are still missing! Wanted to cut this off before it got crazy:
- Inline comments aren't shown in the main comment list.
- Inline comments aren't shown in the emails.
- Inline comments aren't previewed.
I'll followup with those but this was getting pretty big.
@vrana, does the SQL change look correct?
Test Plan:
- Created, edited, deleted, replied to, reloaded and saved inline comments in Diffusion, on the left and right side of diffs.
- Created, edited, deleted, replied to, reloaded and saved inline comments in Differentila, on the left and right side of primary and diff-versus-diff diffs.
Reviewers: btrahan, vrana
Reviewed By: btrahan
CC: aran, epriestley
Maniphest Tasks: T904
Differential Revision: https://secure.phabricator.com/D1898
2012-03-14 12:56:01 -07:00
|
|
|
// DifferentialChangeset. Make the objects ephemeral to make sure we don't
|
|
|
|
// accidentally save them, and then set their ID to the appropriate ID for
|
|
|
|
// this application (the path IDs).
|
2012-08-06 23:01:23 -07:00
|
|
|
$path_ids = array_flip(mpull($changes, 'getPath'));
|
Add inline comments to Diffusion/Audit
Summary:
- Add inline comments to Audits, like Differential.
- Creates new storage for the comments in the Audits database.
- Creates a new PhabricatorAuditInlineComment class, similar to DifferentialInlineComment.
- Defines an Interface which Differential and Audit comments conform to.
- Makes consumers of DifferentialInlineComments consume objects which implement that interface instead.
- Adds save
NOTE: Some features are still missing! Wanted to cut this off before it got crazy:
- Inline comments aren't shown in the main comment list.
- Inline comments aren't shown in the emails.
- Inline comments aren't previewed.
I'll followup with those but this was getting pretty big.
@vrana, does the SQL change look correct?
Test Plan:
- Created, edited, deleted, replied to, reloaded and saved inline comments in Diffusion, on the left and right side of diffs.
- Created, edited, deleted, replied to, reloaded and saved inline comments in Differentila, on the left and right side of primary and diff-versus-diff diffs.
Reviewers: btrahan, vrana
Reviewed By: btrahan
CC: aran, epriestley
Maniphest Tasks: T904
Differential Revision: https://secure.phabricator.com/D1898
2012-03-14 12:56:01 -07:00
|
|
|
foreach ($changesets as $changeset) {
|
|
|
|
$changeset->makeEphemeral();
|
|
|
|
$changeset->setID($path_ids[$changeset->getFilename()]);
|
|
|
|
}
|
|
|
|
|
2013-09-06 10:05:24 -07:00
|
|
|
if ($count <= self::CHANGES_LIMIT || $show_all_details) {
|
2012-08-06 23:01:23 -07:00
|
|
|
$visible_changesets = $changesets;
|
|
|
|
} else {
|
|
|
|
$visible_changesets = array();
|
2014-07-24 17:59:28 -07:00
|
|
|
$inlines = PhabricatorAuditInlineComment::loadDraftAndPublishedComments(
|
|
|
|
$user,
|
|
|
|
$commit->getPHID());
|
2012-08-06 23:01:23 -07:00
|
|
|
$path_ids = mpull($inlines, null, 'getPathID');
|
|
|
|
foreach ($changesets as $key => $changeset) {
|
|
|
|
if (array_key_exists($changeset->getID(), $path_ids)) {
|
|
|
|
$visible_changesets[$key] = $changeset;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-02 11:28:31 -08:00
|
|
|
$change_list_title = $commit->getDisplayName();
|
|
|
|
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$change_list = new DifferentialChangesetListView();
|
2012-12-12 21:21:56 -08:00
|
|
|
$change_list->setTitle($change_list_title);
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$change_list->setChangesets($changesets);
|
2012-08-06 23:01:23 -07:00
|
|
|
$change_list->setVisibleChangesets($visible_changesets);
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
$change_list->setRenderingReferences($references);
|
2016-01-02 12:21:13 -08:00
|
|
|
$change_list->setRenderURI(
|
|
|
|
$repository->getPathURI('diff/'));
|
2012-04-09 23:42:12 -07:00
|
|
|
$change_list->setRepository($repository);
|
2012-01-16 11:08:54 -08:00
|
|
|
$change_list->setUser($user);
|
2014-01-16 14:58:14 -08:00
|
|
|
|
|
|
|
// TODO: Try to setBranch() to something reasonable here?
|
Improve several Diffusion UI error states
Summary:
Give users better errors and UI:
- For subpath SVN repositories, default the path to the subdirectory, not to
"/". This makes the home screen useful and things generally less confusing.
- For unparsed commits, show a more descriptive error message without the
"blah blah" silliness.
- For paths outside of the subpath parse tree, short circuit into an
appropriate error message.
- For foreign SVN stub commits (see D892), show an explicit message.
Test Plan: Looked at unparsed commits, subpath repositories, foreign stub
commits, and paths outside of the subpath parse tree. Received sensible error
messages.
Reviewers: jungejason, nh, tuomaspelkonen, aran
Reviewed By: jungejason
CC: aran, jungejason
Differential Revision: 894
2011-09-04 14:39:52 -07:00
|
|
|
|
2012-03-19 19:57:41 -07:00
|
|
|
$change_list->setStandaloneURI(
|
2016-01-02 12:21:13 -08:00
|
|
|
$repository->getPathURI('diff/'));
|
|
|
|
|
2012-03-19 19:57:41 -07:00
|
|
|
$change_list->setRawFileURIs(
|
|
|
|
// TODO: Implement this, somewhat tricky if there's an octopus merge
|
|
|
|
// or whatever?
|
|
|
|
null,
|
2016-01-02 12:21:13 -08:00
|
|
|
$repository->getPathURI('diff/?view=r'));
|
2012-03-19 19:57:41 -07:00
|
|
|
|
Add inline comments to Diffusion/Audit
Summary:
- Add inline comments to Audits, like Differential.
- Creates new storage for the comments in the Audits database.
- Creates a new PhabricatorAuditInlineComment class, similar to DifferentialInlineComment.
- Defines an Interface which Differential and Audit comments conform to.
- Makes consumers of DifferentialInlineComments consume objects which implement that interface instead.
- Adds save
NOTE: Some features are still missing! Wanted to cut this off before it got crazy:
- Inline comments aren't shown in the main comment list.
- Inline comments aren't shown in the emails.
- Inline comments aren't previewed.
I'll followup with those but this was getting pretty big.
@vrana, does the SQL change look correct?
Test Plan:
- Created, edited, deleted, replied to, reloaded and saved inline comments in Diffusion, on the left and right side of diffs.
- Created, edited, deleted, replied to, reloaded and saved inline comments in Differentila, on the left and right side of primary and diff-versus-diff diffs.
Reviewers: btrahan, vrana
Reviewed By: btrahan
CC: aran, epriestley
Maniphest Tasks: T904
Differential Revision: https://secure.phabricator.com/D1898
2012-03-14 12:56:01 -07:00
|
|
|
$change_list->setInlineCommentControllerURI(
|
2012-07-23 11:01:28 -07:00
|
|
|
'/diffusion/inline/edit/'.phutil_escape_uri($commit->getPHID()).'/');
|
Add inline comments to Diffusion/Audit
Summary:
- Add inline comments to Audits, like Differential.
- Creates new storage for the comments in the Audits database.
- Creates a new PhabricatorAuditInlineComment class, similar to DifferentialInlineComment.
- Defines an Interface which Differential and Audit comments conform to.
- Makes consumers of DifferentialInlineComments consume objects which implement that interface instead.
- Adds save
NOTE: Some features are still missing! Wanted to cut this off before it got crazy:
- Inline comments aren't shown in the main comment list.
- Inline comments aren't shown in the emails.
- Inline comments aren't previewed.
I'll followup with those but this was getting pretty big.
@vrana, does the SQL change look correct?
Test Plan:
- Created, edited, deleted, replied to, reloaded and saved inline comments in Diffusion, on the left and right side of diffs.
- Created, edited, deleted, replied to, reloaded and saved inline comments in Differentila, on the left and right side of primary and diff-versus-diff diffs.
Reviewers: btrahan, vrana
Reviewed By: btrahan
CC: aran, epriestley
Maniphest Tasks: T904
Differential Revision: https://secure.phabricator.com/D1898
2012-03-14 12:56:01 -07:00
|
|
|
|
2013-01-30 12:01:07 -08:00
|
|
|
$content[] = $change_list->render();
|
2011-03-26 23:52:09 -07:00
|
|
|
}
|
2011-03-13 16:19:39 -07:00
|
|
|
|
2013-01-30 12:01:07 -08:00
|
|
|
$content[] = $this->renderAddCommentPanel($commit, $audit_requests);
|
|
|
|
|
2013-02-04 17:00:27 -08:00
|
|
|
$prefs = $user->loadPreferences();
|
|
|
|
$pref_filetree = PhabricatorUserPreferences::PREFERENCE_DIFF_FILETREE;
|
|
|
|
$pref_collapse = PhabricatorUserPreferences::PREFERENCE_NAV_COLLAPSED;
|
|
|
|
$show_filetree = $prefs->getPreference($pref_filetree);
|
|
|
|
$collapsed = $prefs->getPreference($pref_collapse);
|
|
|
|
|
2015-08-15 12:57:20 -07:00
|
|
|
if ($show_changesets && $show_filetree) {
|
2013-01-21 07:45:42 -08:00
|
|
|
$nav = id(new DifferentialChangesetFileTreeSideNavBuilder())
|
2016-01-02 11:28:31 -08:00
|
|
|
->setTitle($commit->getDisplayName())
|
|
|
|
->setBaseURI(new PhutilURI($commit->getURI()))
|
2013-01-21 07:45:42 -08:00
|
|
|
->build($changesets)
|
|
|
|
->setCrumbs($crumbs)
|
2013-02-04 17:00:27 -08:00
|
|
|
->setCollapsed((bool)$collapsed)
|
2013-01-21 07:45:42 -08:00
|
|
|
->appendChild($content);
|
|
|
|
$content = $nav;
|
|
|
|
} else {
|
|
|
|
$content = array($crumbs, $content);
|
|
|
|
}
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
|
|
|
|
return $this->buildApplicationPage(
|
2013-01-21 07:45:42 -08:00
|
|
|
$content,
|
2011-03-11 09:34:22 -08:00
|
|
|
array(
|
2016-01-02 11:28:31 -08:00
|
|
|
'title' => $commit->getDisplayName(),
|
2013-05-25 08:46:06 -07:00
|
|
|
'pageObjects' => array($commit->getPHID()),
|
2013-02-19 13:33:10 -08:00
|
|
|
));
|
2011-03-11 09:34:22 -08:00
|
|
|
}
|
|
|
|
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
private function loadCommitProperties(
|
2011-04-01 17:11:05 -07:00
|
|
|
PhabricatorRepositoryCommit $commit,
|
2012-03-26 12:21:48 -07:00
|
|
|
PhabricatorRepositoryCommitData $data,
|
2013-07-24 15:29:46 -07:00
|
|
|
array $audit_requests) {
|
2012-08-08 10:03:41 -07:00
|
|
|
|
2013-12-05 11:59:41 -08:00
|
|
|
$viewer = $this->getRequest()->getUser();
|
2012-08-08 10:03:41 -07:00
|
|
|
$commit_phid = $commit->getPHID();
|
2013-12-05 11:59:41 -08:00
|
|
|
$drequest = $this->getDiffusionRequest();
|
|
|
|
$repository = $drequest->getRepository();
|
2012-08-08 10:03:41 -07:00
|
|
|
|
2013-04-15 08:41:41 -07:00
|
|
|
$edge_query = id(new PhabricatorEdgeQuery())
|
2012-08-08 10:03:41 -07:00
|
|
|
->withSourcePHIDs(array($commit_phid))
|
|
|
|
->withEdgeTypes(array(
|
2014-07-17 15:42:06 -07:00
|
|
|
DiffusionCommitHasTaskEdgeType::EDGECONST,
|
2015-01-01 14:43:26 +11:00
|
|
|
DiffusionCommitHasRevisionEdgeType::EDGECONST,
|
Write edges for commit reverts
Summary:
Ref T1751. When a commit reverts another commit:
- Add an edge linking them;
- Show the edge in Diffusion.
Next steps are:
- If the reverted commit is associated with a Differential revision, leave a comment;
- Also leave a comment on the commit (no API yet);
- Also trigger an audit by the original commit's author.
Test Plan: Used `scripts/repository/reparse.php --message ...` to parse commits with revert language. Verified they appear correctly in Diffusion, and update Differential.
Reviewers: btrahan, epriestley
Reviewed By: btrahan, epriestley
Subscribers: Korvin, epriestley, cburroughs, joshuaspence, sascha-egerer, aran
Maniphest Tasks: T4896, T1751
Differential Revision: https://secure.phabricator.com/D5846
2015-01-05 06:52:38 +11:00
|
|
|
DiffusionCommitRevertsCommitEdgeType::EDGECONST,
|
|
|
|
DiffusionCommitRevertedByCommitEdgeType::EDGECONST,
|
2013-04-15 08:41:41 -07:00
|
|
|
));
|
|
|
|
|
|
|
|
$edges = $edge_query->execute();
|
2012-08-08 10:03:41 -07:00
|
|
|
|
|
|
|
$task_phids = array_keys(
|
2014-07-17 15:42:06 -07:00
|
|
|
$edges[$commit_phid][DiffusionCommitHasTaskEdgeType::EDGECONST]);
|
2013-04-12 22:48:16 -07:00
|
|
|
$revision_phid = key(
|
2015-01-01 14:43:26 +11:00
|
|
|
$edges[$commit_phid][DiffusionCommitHasRevisionEdgeType::EDGECONST]);
|
2012-08-08 10:03:41 -07:00
|
|
|
|
Write edges for commit reverts
Summary:
Ref T1751. When a commit reverts another commit:
- Add an edge linking them;
- Show the edge in Diffusion.
Next steps are:
- If the reverted commit is associated with a Differential revision, leave a comment;
- Also leave a comment on the commit (no API yet);
- Also trigger an audit by the original commit's author.
Test Plan: Used `scripts/repository/reparse.php --message ...` to parse commits with revert language. Verified they appear correctly in Diffusion, and update Differential.
Reviewers: btrahan, epriestley
Reviewed By: btrahan, epriestley
Subscribers: Korvin, epriestley, cburroughs, joshuaspence, sascha-egerer, aran
Maniphest Tasks: T4896, T1751
Differential Revision: https://secure.phabricator.com/D5846
2015-01-05 06:52:38 +11:00
|
|
|
$reverts_phids = array_keys(
|
|
|
|
$edges[$commit_phid][DiffusionCommitRevertsCommitEdgeType::EDGECONST]);
|
|
|
|
$reverted_by_phids = array_keys(
|
|
|
|
$edges[$commit_phid][DiffusionCommitRevertedByCommitEdgeType::EDGECONST]);
|
|
|
|
|
2013-04-15 08:41:41 -07:00
|
|
|
$phids = $edge_query->getDestinationPHIDs(array($commit_phid));
|
|
|
|
|
2011-04-01 17:11:05 -07:00
|
|
|
if ($data->getCommitDetail('authorPHID')) {
|
|
|
|
$phids[] = $data->getCommitDetail('authorPHID');
|
|
|
|
}
|
|
|
|
if ($data->getCommitDetail('reviewerPHID')) {
|
|
|
|
$phids[] = $data->getCommitDetail('reviewerPHID');
|
|
|
|
}
|
2012-05-23 08:34:36 -07:00
|
|
|
if ($data->getCommitDetail('committerPHID')) {
|
|
|
|
$phids[] = $data->getCommitDetail('committerPHID');
|
|
|
|
}
|
2011-04-01 17:11:05 -07:00
|
|
|
|
2013-12-05 11:59:41 -08:00
|
|
|
// NOTE: We should never normally have more than a single push log, but
|
|
|
|
// it can occur naturally if a commit is pushed, then the branch it was
|
|
|
|
// on is deleted, then the commit is pushed again (or through other similar
|
|
|
|
// chains of events). This should be rare, but does not indicate a bug
|
|
|
|
// or data issue.
|
|
|
|
|
|
|
|
// NOTE: We never query push logs in SVN because the commiter is always
|
|
|
|
// the pusher and the commit time is always the push time; the push log
|
|
|
|
// is redundant and we save a query by skipping it.
|
|
|
|
|
|
|
|
$push_logs = array();
|
|
|
|
if ($repository->isHosted() && !$repository->isSVN()) {
|
|
|
|
$push_logs = id(new PhabricatorRepositoryPushLogQuery())
|
|
|
|
->setViewer($viewer)
|
|
|
|
->withRepositoryPHIDs(array($repository->getPHID()))
|
|
|
|
->withNewRefs(array($commit->getCommitIdentifier()))
|
|
|
|
->withRefTypes(array(PhabricatorRepositoryPushLog::REFTYPE_COMMIT))
|
|
|
|
->execute();
|
|
|
|
foreach ($push_logs as $log) {
|
|
|
|
$phids[] = $log->getPusherPHID();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-04-01 17:11:05 -07:00
|
|
|
$handles = array();
|
|
|
|
if ($phids) {
|
2012-09-04 19:02:56 -07:00
|
|
|
$handles = $this->loadViewerHandles($phids);
|
2011-04-01 17:11:05 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
$props = array();
|
|
|
|
|
2012-03-30 14:12:10 -07:00
|
|
|
if ($commit->getAuditStatus()) {
|
|
|
|
$status = PhabricatorAuditCommitStatusConstants::getStatusName(
|
|
|
|
$commit->getAuditStatus());
|
2014-01-14 14:09:52 -08:00
|
|
|
$tag = id(new PHUITagView())
|
|
|
|
->setType(PHUITagView::TYPE_STATE)
|
2013-07-24 15:29:46 -07:00
|
|
|
->setName($status);
|
|
|
|
|
|
|
|
switch ($commit->getAuditStatus()) {
|
|
|
|
case PhabricatorAuditCommitStatusConstants::NEEDS_AUDIT:
|
2014-01-14 14:09:52 -08:00
|
|
|
$tag->setBackgroundColor(PHUITagView::COLOR_ORANGE);
|
2013-07-24 15:29:46 -07:00
|
|
|
break;
|
|
|
|
case PhabricatorAuditCommitStatusConstants::CONCERN_RAISED:
|
2014-01-14 14:09:52 -08:00
|
|
|
$tag->setBackgroundColor(PHUITagView::COLOR_RED);
|
2013-07-24 15:29:46 -07:00
|
|
|
break;
|
|
|
|
case PhabricatorAuditCommitStatusConstants::PARTIALLY_AUDITED:
|
2014-01-14 14:09:52 -08:00
|
|
|
$tag->setBackgroundColor(PHUITagView::COLOR_BLUE);
|
2013-07-24 15:29:46 -07:00
|
|
|
break;
|
|
|
|
case PhabricatorAuditCommitStatusConstants::FULLY_AUDITED:
|
2014-01-14 14:09:52 -08:00
|
|
|
$tag->setBackgroundColor(PHUITagView::COLOR_GREEN);
|
2013-07-24 15:29:46 -07:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$props['Status'] = $tag;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($audit_requests) {
|
2013-10-05 07:54:42 -07:00
|
|
|
$user_requests = array();
|
|
|
|
$other_requests = array();
|
|
|
|
foreach ($audit_requests as $audit_request) {
|
|
|
|
if ($audit_request->isUser()) {
|
|
|
|
$user_requests[] = $audit_request;
|
|
|
|
} else {
|
|
|
|
$other_requests[] = $audit_request;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($user_requests) {
|
|
|
|
$props['Auditors'] = $this->renderAuditStatusView(
|
|
|
|
$user_requests);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($other_requests) {
|
|
|
|
$props['Project/Package Auditors'] = $this->renderAuditStatusView(
|
|
|
|
$other_requests);
|
|
|
|
}
|
2012-03-30 14:12:10 -07:00
|
|
|
}
|
|
|
|
|
2013-12-07 11:12:38 -08:00
|
|
|
$author_phid = $data->getCommitDetail('authorPHID');
|
|
|
|
$author_name = $data->getAuthorName();
|
|
|
|
|
2013-12-05 11:59:41 -08:00
|
|
|
if (!$repository->isSVN()) {
|
|
|
|
$authored_info = id(new PHUIStatusItemView());
|
|
|
|
// TODO: In Git, a distinct authorship date is available. When present,
|
|
|
|
// we should show it here.
|
|
|
|
|
|
|
|
if ($author_phid) {
|
|
|
|
$authored_info->setTarget($handles[$author_phid]->renderLink());
|
|
|
|
} else if (strlen($author_name)) {
|
|
|
|
$authored_info->setTarget($author_name);
|
|
|
|
}
|
2012-03-30 14:12:10 -07:00
|
|
|
|
2013-12-05 11:59:41 -08:00
|
|
|
$props['Authored'] = id(new PHUIStatusListView())
|
|
|
|
->addItem($authored_info);
|
2011-04-01 17:11:05 -07:00
|
|
|
}
|
|
|
|
|
2013-12-05 11:59:41 -08:00
|
|
|
$committed_info = id(new PHUIStatusItemView())
|
|
|
|
->setNote(phabricator_datetime($commit->getEpoch(), $viewer));
|
|
|
|
|
|
|
|
$committer_phid = $data->getCommitDetail('committerPHID');
|
|
|
|
$committer_name = $data->getCommitDetail('committer');
|
|
|
|
if ($committer_phid) {
|
|
|
|
$committed_info->setTarget($handles[$committer_phid]->renderLink());
|
|
|
|
} else if (strlen($committer_name)) {
|
|
|
|
$committed_info->setTarget($committer_name);
|
|
|
|
} else if ($author_phid) {
|
|
|
|
$committed_info->setTarget($handles[$author_phid]->renderLink());
|
|
|
|
} else if (strlen($author_name)) {
|
|
|
|
$committed_info->setTarget($author_name);
|
2011-04-01 17:11:05 -07:00
|
|
|
}
|
|
|
|
|
2013-12-12 14:15:26 +10:00
|
|
|
$props['Committed'] = id(new PHUIStatusListView())
|
2013-12-05 11:59:41 -08:00
|
|
|
->addItem($committed_info);
|
|
|
|
|
|
|
|
if ($push_logs) {
|
|
|
|
$pushed_list = new PHUIStatusListView();
|
|
|
|
|
|
|
|
foreach ($push_logs as $push_log) {
|
|
|
|
$pushed_item = id(new PHUIStatusItemView())
|
|
|
|
->setTarget($handles[$push_log->getPusherPHID()]->renderLink())
|
|
|
|
->setNote(phabricator_datetime($push_log->getEpoch(), $viewer));
|
|
|
|
$pushed_list->addItem($pushed_item);
|
2012-05-23 08:34:36 -07:00
|
|
|
}
|
2013-12-05 11:59:41 -08:00
|
|
|
|
|
|
|
$props['Pushed'] = $pushed_list;
|
|
|
|
}
|
|
|
|
|
|
|
|
$reviewer_phid = $data->getCommitDetail('reviewerPHID');
|
|
|
|
if ($reviewer_phid) {
|
|
|
|
$props['Reviewer'] = $handles[$reviewer_phid]->renderLink();
|
2012-05-23 08:34:36 -07:00
|
|
|
}
|
|
|
|
|
2011-04-01 17:11:05 -07:00
|
|
|
if ($revision_phid) {
|
|
|
|
$props['Differential Revision'] = $handles[$revision_phid]->renderLink();
|
|
|
|
}
|
|
|
|
|
2015-10-02 16:11:03 -07:00
|
|
|
$parents = $this->getCommitParents();
|
2012-03-26 12:21:48 -07:00
|
|
|
if ($parents) {
|
2015-10-02 16:11:03 -07:00
|
|
|
$props['Parents'] = $viewer->renderHandleList(mpull($parents, 'getPHID'));
|
2012-03-26 12:21:48 -07:00
|
|
|
}
|
|
|
|
|
2015-10-02 16:11:03 -07:00
|
|
|
if ($this->getCommitExists()) {
|
|
|
|
$props['Branches'] = phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
|
|
|
'id' => 'commit-branches',
|
|
|
|
),
|
|
|
|
pht('Unknown'));
|
|
|
|
$props['Tags'] = phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
|
|
|
'id' => 'commit-tags',
|
|
|
|
),
|
|
|
|
pht('Unknown'));
|
2012-01-19 11:49:51 -08:00
|
|
|
|
2016-01-02 12:21:13 -08:00
|
|
|
$identifier = $commit->getCommitIdentifier();
|
|
|
|
$root = $repository->getPathURI("commit/{$identifier}");
|
2015-10-02 16:11:03 -07:00
|
|
|
Javelin::initBehavior(
|
|
|
|
'diffusion-commit-branches',
|
|
|
|
array(
|
|
|
|
$root.'/branches/' => 'commit-branches',
|
|
|
|
$root.'/tags/' => 'commit-tags',
|
|
|
|
));
|
|
|
|
}
|
2012-04-23 18:36:25 -07:00
|
|
|
|
2015-10-02 16:11:03 -07:00
|
|
|
$refs = $this->getCommitRefs();
|
2012-04-25 07:21:03 -07:00
|
|
|
if ($refs) {
|
2015-10-02 16:11:03 -07:00
|
|
|
$ref_links = array();
|
|
|
|
foreach ($refs as $ref_data) {
|
|
|
|
$ref_links[] = phutil_tag(
|
|
|
|
'a',
|
|
|
|
array(
|
|
|
|
'href' => $ref_data['href'],
|
|
|
|
),
|
|
|
|
$ref_data['ref']);
|
|
|
|
}
|
|
|
|
$props['References'] = phutil_implode_html(', ', $ref_links);
|
2012-04-25 07:21:03 -07:00
|
|
|
}
|
|
|
|
|
Write edges for commit reverts
Summary:
Ref T1751. When a commit reverts another commit:
- Add an edge linking them;
- Show the edge in Diffusion.
Next steps are:
- If the reverted commit is associated with a Differential revision, leave a comment;
- Also leave a comment on the commit (no API yet);
- Also trigger an audit by the original commit's author.
Test Plan: Used `scripts/repository/reparse.php --message ...` to parse commits with revert language. Verified they appear correctly in Diffusion, and update Differential.
Reviewers: btrahan, epriestley
Reviewed By: btrahan, epriestley
Subscribers: Korvin, epriestley, cburroughs, joshuaspence, sascha-egerer, aran
Maniphest Tasks: T4896, T1751
Differential Revision: https://secure.phabricator.com/D5846
2015-01-05 06:52:38 +11:00
|
|
|
if ($reverts_phids) {
|
2015-03-30 07:39:37 -07:00
|
|
|
$props[pht('Reverts')] = $viewer->renderHandleList($reverts_phids);
|
Write edges for commit reverts
Summary:
Ref T1751. When a commit reverts another commit:
- Add an edge linking them;
- Show the edge in Diffusion.
Next steps are:
- If the reverted commit is associated with a Differential revision, leave a comment;
- Also leave a comment on the commit (no API yet);
- Also trigger an audit by the original commit's author.
Test Plan: Used `scripts/repository/reparse.php --message ...` to parse commits with revert language. Verified they appear correctly in Diffusion, and update Differential.
Reviewers: btrahan, epriestley
Reviewed By: btrahan, epriestley
Subscribers: Korvin, epriestley, cburroughs, joshuaspence, sascha-egerer, aran
Maniphest Tasks: T4896, T1751
Differential Revision: https://secure.phabricator.com/D5846
2015-01-05 06:52:38 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($reverted_by_phids) {
|
2015-03-30 07:39:37 -07:00
|
|
|
$props[pht('Reverted By')] = $viewer->renderHandleList(
|
Write edges for commit reverts
Summary:
Ref T1751. When a commit reverts another commit:
- Add an edge linking them;
- Show the edge in Diffusion.
Next steps are:
- If the reverted commit is associated with a Differential revision, leave a comment;
- Also leave a comment on the commit (no API yet);
- Also trigger an audit by the original commit's author.
Test Plan: Used `scripts/repository/reparse.php --message ...` to parse commits with revert language. Verified they appear correctly in Diffusion, and update Differential.
Reviewers: btrahan, epriestley
Reviewed By: btrahan, epriestley
Subscribers: Korvin, epriestley, cburroughs, joshuaspence, sascha-egerer, aran
Maniphest Tasks: T4896, T1751
Differential Revision: https://secure.phabricator.com/D5846
2015-01-05 06:52:38 +11:00
|
|
|
$reverted_by_phids);
|
|
|
|
}
|
|
|
|
|
2012-04-04 17:34:25 -07:00
|
|
|
if ($task_phids) {
|
|
|
|
$task_list = array();
|
|
|
|
foreach ($task_phids as $phid) {
|
|
|
|
$task_list[] = $handles[$phid]->renderLink();
|
|
|
|
}
|
2013-02-13 14:50:15 -08:00
|
|
|
$task_list = phutil_implode_html(phutil_tag('br'), $task_list);
|
2012-04-04 17:34:25 -07:00
|
|
|
$props['Tasks'] = $task_list;
|
|
|
|
}
|
|
|
|
|
2012-03-30 14:12:10 -07:00
|
|
|
return $props;
|
2011-04-01 17:11:05 -07:00
|
|
|
}
|
|
|
|
|
2012-04-03 16:22:31 -07:00
|
|
|
private function buildComments(PhabricatorRepositoryCommit $commit) {
|
Transactions - deploy buildTransactionTimeline to remaining applications
Summary:
Ref T4712. Specifically...
- Differential
- needed getApplicationTransactionViewObject() implemented
- Audit
- needed getApplicationTransactionViewObject() implemented
- Repository
- one object needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true)
- Ponder
- BONUS BUG FIX - leaving a comment on an answer had a bad redirect URI
- both PonderQuestion and PonderAnswer needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) on both "history" controllers
- left a "TODO" on buildAnswers on the question view controller, which is non-standard and should be re-written eventually
- Phortune
- BONUS BUG FIX - fix new user "createNewAccount" code to not fatal
- PhortuneAccount, PhortuneMerchant, and PhortuneCart needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) on Account view, merchant view, and cart view controller
- Fund
- Legalpad
- Nuance
- NuanceSource needed PhabricatorApplicationTransactionInterface implemented
- Releeph (this product is kind of a mess...)
- HACKQUEST - had to manually create an arcanist project to even be able to make a "product" and get started...!
- BONUS BUG FIX - make sure to "setName" on product edit
- ReleephProject (should be ReleepProduct...?), ReleephBranch, and ReleepRequest needed PhabricatorApplicationTransactionInterface implemented
- Harbormaster
- HarbormasterBuildable, HarbormasterBuild, HarbormasterBuildPlan, and HarbormasterBuildStep all needed PhabricatorApplicationTransactionInterface implemented
- setShouldTerminate(true) all over the place
Test Plan: foreach application, viewed the timeline(s) and made sure they still rendered
Reviewers: epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T4712
Differential Revision: https://secure.phabricator.com/D10925
2014-12-03 15:35:47 -08:00
|
|
|
$timeline = $this->buildTransactionTimeline(
|
|
|
|
$commit,
|
|
|
|
new PhabricatorAuditTransactionQuery());
|
2015-01-23 11:32:38 -08:00
|
|
|
$commit->willRenderTimeline($timeline, $this->getRequest());
|
|
|
|
return $timeline;
|
2012-02-24 14:14:39 -08:00
|
|
|
}
|
|
|
|
|
2012-07-23 09:15:10 -07:00
|
|
|
private function renderAddCommentPanel(
|
2012-04-03 16:22:31 -07:00
|
|
|
PhabricatorRepositoryCommit $commit,
|
2013-01-30 12:01:07 -08:00
|
|
|
array $audit_requests) {
|
2012-04-03 16:22:31 -07:00
|
|
|
assert_instances_of($audit_requests, 'PhabricatorRepositoryAuditRequest');
|
2013-09-27 10:49:45 -07:00
|
|
|
|
|
|
|
$request = $this->getRequest();
|
|
|
|
$user = $request->getUser();
|
|
|
|
|
|
|
|
if (!$user->isLoggedIn()) {
|
|
|
|
return id(new PhabricatorApplicationTransactionCommentView())
|
|
|
|
->setUser($user)
|
|
|
|
->setRequestURI($request->getRequestURI());
|
|
|
|
}
|
2012-02-24 15:04:53 -08:00
|
|
|
|
|
|
|
$is_serious = PhabricatorEnv::getEnvConfig('phabricator.serious-business');
|
|
|
|
|
2013-01-30 12:01:07 -08:00
|
|
|
$pane_id = celerity_generate_unique_node_id();
|
2012-03-18 19:44:28 -07:00
|
|
|
Javelin::initBehavior(
|
|
|
|
'differential-keyboard-navigation',
|
|
|
|
array(
|
2012-07-23 09:15:10 -07:00
|
|
|
'haunt' => $pane_id,
|
2012-03-18 19:44:28 -07:00
|
|
|
));
|
|
|
|
|
2012-02-27 13:00:23 -08:00
|
|
|
$draft = id(new PhabricatorDraft())->loadOneWhere(
|
|
|
|
'authorPHID = %s AND draftKey = %s',
|
|
|
|
$user->getPHID(),
|
|
|
|
'diffusion-audit-'.$commit->getID());
|
|
|
|
if ($draft) {
|
|
|
|
$draft = $draft->getDraft();
|
|
|
|
} else {
|
|
|
|
$draft = null;
|
|
|
|
}
|
|
|
|
|
2012-03-26 09:44:06 -07:00
|
|
|
$actions = $this->getAuditActions($commit, $audit_requests);
|
|
|
|
|
2015-04-18 08:38:47 -07:00
|
|
|
$mailable_source = new PhabricatorMetaMTAMailableDatasource();
|
|
|
|
$auditor_source = new DiffusionAuditorDatasource();
|
|
|
|
|
2012-02-24 15:04:53 -08:00
|
|
|
$form = id(new AphrontFormView())
|
|
|
|
->setUser($user)
|
|
|
|
->setAction('/audit/addcomment/')
|
|
|
|
->addHiddenInput('commit', $commit->getPHID())
|
|
|
|
->appendChild(
|
|
|
|
id(new AphrontFormSelectControl())
|
2013-05-11 08:23:19 -07:00
|
|
|
->setLabel(pht('Action'))
|
2012-02-24 15:04:53 -08:00
|
|
|
->setName('action')
|
2012-02-27 13:00:23 -08:00
|
|
|
->setID('audit-action')
|
2012-03-26 09:44:06 -07:00
|
|
|
->setOptions($actions))
|
2015-03-31 14:10:55 -07:00
|
|
|
->appendControl(
|
2012-04-23 13:50:04 -07:00
|
|
|
id(new AphrontFormTokenizerControl())
|
2013-05-11 08:23:19 -07:00
|
|
|
->setLabel(pht('Add Auditors'))
|
2012-04-23 13:50:04 -07:00
|
|
|
->setName('auditors')
|
|
|
|
->setControlID('add-auditors')
|
|
|
|
->setControlStyle('display: none')
|
|
|
|
->setID('add-auditors-tokenizer')
|
2015-04-18 08:38:47 -07:00
|
|
|
->setDisableBehavior(true)
|
|
|
|
->setDatasource($auditor_source))
|
2015-03-31 14:10:55 -07:00
|
|
|
->appendControl(
|
2012-04-23 13:50:04 -07:00
|
|
|
id(new AphrontFormTokenizerControl())
|
2013-05-11 08:23:19 -07:00
|
|
|
->setLabel(pht('Add CCs'))
|
2012-04-23 13:50:04 -07:00
|
|
|
->setName('ccs')
|
|
|
|
->setControlID('add-ccs')
|
|
|
|
->setControlStyle('display: none')
|
|
|
|
->setID('add-ccs-tokenizer')
|
2015-04-18 08:38:47 -07:00
|
|
|
->setDisableBehavior(true)
|
|
|
|
->setDatasource($mailable_source))
|
2012-02-24 15:04:53 -08:00
|
|
|
->appendChild(
|
2012-09-19 12:27:28 -07:00
|
|
|
id(new PhabricatorRemarkupControl())
|
2013-05-11 08:23:19 -07:00
|
|
|
->setLabel(pht('Comments'))
|
2012-02-24 15:04:53 -08:00
|
|
|
->setName('content')
|
2012-02-27 13:00:23 -08:00
|
|
|
->setValue($draft)
|
2012-11-27 14:06:31 -08:00
|
|
|
->setID('audit-content')
|
|
|
|
->setUser($user))
|
2012-02-24 15:04:53 -08:00
|
|
|
->appendChild(
|
|
|
|
id(new AphrontFormSubmitControl())
|
2014-04-18 17:51:46 -07:00
|
|
|
->setValue(pht('Submit')));
|
2012-02-24 15:04:53 -08:00
|
|
|
|
2013-09-17 09:12:37 -07:00
|
|
|
$header = new PHUIHeaderView();
|
2013-05-18 10:49:37 -07:00
|
|
|
$header->setHeader(
|
2013-05-11 08:23:19 -07:00
|
|
|
$is_serious ? pht('Audit Commit') : pht('Creative Accounting'));
|
2012-02-24 15:04:53 -08:00
|
|
|
|
2012-04-23 13:50:04 -07:00
|
|
|
Javelin::initBehavior(
|
|
|
|
'differential-add-reviewers-and-ccs',
|
|
|
|
array(
|
|
|
|
'dynamic' => array(
|
|
|
|
'add-auditors-tokenizer' => array(
|
|
|
|
'actions' => array('add_auditors' => 1),
|
2014-07-17 15:45:21 -07:00
|
|
|
'src' => $auditor_source->getDatasourceURI(),
|
2012-04-23 13:50:04 -07:00
|
|
|
'row' => 'add-auditors',
|
2014-07-17 15:45:21 -07:00
|
|
|
'placeholder' => $auditor_source->getPlaceholderText(),
|
2012-04-23 13:50:04 -07:00
|
|
|
),
|
|
|
|
'add-ccs-tokenizer' => array(
|
|
|
|
'actions' => array('add_ccs' => 1),
|
2014-07-17 15:44:29 -07:00
|
|
|
'src' => $mailable_source->getDatasourceURI(),
|
2012-04-23 13:50:04 -07:00
|
|
|
'row' => 'add-ccs',
|
2014-07-17 15:44:29 -07:00
|
|
|
'placeholder' => $mailable_source->getPlaceholderText(),
|
2012-04-23 13:50:04 -07:00
|
|
|
),
|
|
|
|
),
|
|
|
|
'select' => 'audit-action',
|
|
|
|
));
|
|
|
|
|
|
|
|
Javelin::initBehavior('differential-feedback-preview', array(
|
2012-02-27 13:00:23 -08:00
|
|
|
'uri' => '/audit/preview/'.$commit->getID().'/',
|
|
|
|
'preview' => 'audit-preview',
|
|
|
|
'content' => 'audit-content',
|
|
|
|
'action' => 'audit-action',
|
2012-04-23 13:50:04 -07:00
|
|
|
'previewTokenizers' => array(
|
|
|
|
'auditors' => 'add-auditors-tokenizer',
|
|
|
|
'ccs' => 'add-ccs-tokenizer',
|
|
|
|
),
|
2012-07-23 11:01:28 -07:00
|
|
|
'inline' => 'inline-comment-preview',
|
|
|
|
'inlineuri' => '/diffusion/inline/preview/'.$commit->getPHID().'/',
|
2012-02-27 13:00:23 -08:00
|
|
|
));
|
|
|
|
|
2013-11-11 09:23:23 -08:00
|
|
|
$loading = phutil_tag_div(
|
|
|
|
'aphront-panel-preview-loading-text',
|
|
|
|
pht('Loading preview...'));
|
|
|
|
|
|
|
|
$preview_panel = phutil_tag_div(
|
|
|
|
'aphront-panel-preview aphront-panel-flush',
|
|
|
|
array(
|
|
|
|
phutil_tag('div', array('id' => 'audit-preview'), $loading),
|
2014-10-08 00:01:04 +11:00
|
|
|
phutil_tag('div', array('id' => 'inline-comment-preview')),
|
2013-11-11 09:23:23 -08:00
|
|
|
));
|
2012-02-27 13:00:23 -08:00
|
|
|
|
2013-01-30 12:01:07 -08:00
|
|
|
// TODO: This is pretty awkward, unify the CSS between Diffusion and
|
|
|
|
// Differential better.
|
|
|
|
require_celerity_resource('differential-core-view-css');
|
|
|
|
|
2013-11-11 09:23:23 -08:00
|
|
|
$anchor = id(new PhabricatorAnchorView())
|
|
|
|
->setAnchorName('comment')
|
|
|
|
->setNavigationMarker(true)
|
|
|
|
->render();
|
|
|
|
|
2013-09-28 15:55:38 -07:00
|
|
|
$comment_box = id(new PHUIObjectBoxView())
|
|
|
|
->setHeader($header)
|
Provide more structure to PHUIObjectBoxView
Summary:
Three changes here.
- Add `setActionList()`, and use that to set the action list.
- Add `setPropertyList()`, and use that to set the property list.
These will let us add some apropriate CSS so we can fix the border issue, and get rid of a bunch of goofy `.x + .y` selectors.
- Replace `addContent()` with `appendChild()`.
This is just a consistency thing; `AphrontView` already provides `appendChild()`, and `addContent()` did the same thing.
Test Plan:
- Viewed "All Config".
- Viewed a countdown.
- Viewed a revision (add comment, change list, table of contents, comment, local commits, open revisions affecting these files, update history).
- Viewed Diffusion (browse, change, history, repository, lint).
- Viewed Drydock (resource, lease).
- Viewed Files.
- Viewed Herald.
- Viewed Legalpad.
- Viewed macro (edit, edit audio, view).
- Viewed Maniphest.
- Viewed Applications.
- Viewed Paste.
- Viewed People.
- Viewed Phulux.
- Viewed Pholio.
- Viewed Phame (blog, post).
- Viewed Phortune (account, product).
- Viewed Ponder (questions, answers, comments).
- Viewed Releeph.
- Viewed Projects.
- Viewed Slowvote.
NOTE: Images in Files aren't on a black background anymore -- I assume that's on purpose?
NOTE: Some jankiness in Phortune, I'll clean that up when I get back to it. Not related to this diff.
Reviewers: chad
Reviewed By: chad
CC: aran
Differential Revision: https://secure.phabricator.com/D7174
2013-09-30 09:36:04 -07:00
|
|
|
->appendChild($form);
|
2013-09-28 15:55:38 -07:00
|
|
|
|
2013-02-13 14:50:15 -08:00
|
|
|
return phutil_tag(
|
2013-01-30 12:01:07 -08:00
|
|
|
'div',
|
|
|
|
array(
|
|
|
|
'id' => $pane_id,
|
|
|
|
),
|
2013-11-11 09:23:23 -08:00
|
|
|
phutil_tag_div(
|
|
|
|
'differential-add-comment-panel',
|
|
|
|
array($anchor, $comment_box, $preview_panel)));
|
2012-02-24 15:04:53 -08:00
|
|
|
}
|
|
|
|
|
2012-03-26 09:44:06 -07:00
|
|
|
/**
|
|
|
|
* Return a map of available audit actions for rendering into a <select />.
|
|
|
|
* This shows the user valid actions, and does not show nonsense/invalid
|
|
|
|
* actions (like closing an already-closed commit, or resigning from a commit
|
|
|
|
* you have no association with).
|
|
|
|
*/
|
|
|
|
private function getAuditActions(
|
|
|
|
PhabricatorRepositoryCommit $commit,
|
|
|
|
array $audit_requests) {
|
2012-04-03 16:22:31 -07:00
|
|
|
assert_instances_of($audit_requests, 'PhabricatorRepositoryAuditRequest');
|
2012-03-26 09:44:06 -07:00
|
|
|
$user = $this->getRequest()->getUser();
|
|
|
|
|
|
|
|
$user_is_author = ($commit->getAuthorPHID() == $user->getPHID());
|
|
|
|
|
|
|
|
$user_request = null;
|
|
|
|
foreach ($audit_requests as $audit_request) {
|
|
|
|
if ($audit_request->getAuditorPHID() == $user->getPHID()) {
|
|
|
|
$user_request = $audit_request;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$actions = array();
|
|
|
|
$actions[PhabricatorAuditActionConstants::COMMENT] = true;
|
2012-04-23 13:50:04 -07:00
|
|
|
$actions[PhabricatorAuditActionConstants::ADD_CCS] = true;
|
|
|
|
$actions[PhabricatorAuditActionConstants::ADD_AUDITORS] = true;
|
2012-03-26 09:44:06 -07:00
|
|
|
|
|
|
|
// We allow you to accept your own commits. A use case here is that you
|
|
|
|
// notice an issue with your own commit and "Raise Concern" as an indicator
|
|
|
|
// to other auditors that you're on top of the issue, then later resolve it
|
|
|
|
// and "Accept". You can not accept on behalf of projects or packages,
|
|
|
|
// however.
|
|
|
|
$actions[PhabricatorAuditActionConstants::ACCEPT] = true;
|
|
|
|
$actions[PhabricatorAuditActionConstants::CONCERN] = true;
|
|
|
|
|
|
|
|
|
|
|
|
// To resign, a user must have authority on some request and not be the
|
|
|
|
// commit's author.
|
|
|
|
if (!$user_is_author) {
|
|
|
|
$may_resign = false;
|
2012-05-07 13:37:41 -07:00
|
|
|
|
|
|
|
$authority_map = array_fill_keys($this->auditAuthorityPHIDs, true);
|
2012-03-26 09:44:06 -07:00
|
|
|
foreach ($audit_requests as $request) {
|
2012-05-07 13:37:41 -07:00
|
|
|
if (empty($authority_map[$request->getAuditorPHID()])) {
|
2012-03-26 09:44:06 -07:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
$may_resign = true;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the user has already resigned, don't show "Resign...".
|
|
|
|
$status_resigned = PhabricatorAuditStatusConstants::RESIGNED;
|
|
|
|
if ($user_request) {
|
|
|
|
if ($user_request->getAuditStatus() == $status_resigned) {
|
|
|
|
$may_resign = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($may_resign) {
|
|
|
|
$actions[PhabricatorAuditActionConstants::RESIGN] = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$status_concern = PhabricatorAuditCommitStatusConstants::CONCERN_RAISED;
|
|
|
|
$concern_raised = ($commit->getAuditStatus() == $status_concern);
|
2013-01-18 17:53:52 -08:00
|
|
|
$can_close_option = PhabricatorEnv::getEnvConfig(
|
|
|
|
'audit.can-author-close-audit');
|
|
|
|
if ($can_close_option && $user_is_author && $concern_raised) {
|
2012-03-26 09:44:06 -07:00
|
|
|
$actions[PhabricatorAuditActionConstants::CLOSE] = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
foreach ($actions as $constant => $ignored) {
|
|
|
|
$actions[$constant] =
|
|
|
|
PhabricatorAuditActionConstants::getActionName($constant);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $actions;
|
|
|
|
}
|
|
|
|
|
2012-03-23 15:32:26 -07:00
|
|
|
private function buildMergesTable(PhabricatorRepositoryCommit $commit) {
|
2015-09-10 19:28:49 -07:00
|
|
|
$viewer = $this->getViewer();
|
2012-03-23 15:32:26 -07:00
|
|
|
$drequest = $this->getDiffusionRequest();
|
2015-02-03 09:54:32 -08:00
|
|
|
$repository = $drequest->getRepository();
|
2012-03-23 15:32:26 -07:00
|
|
|
|
2015-10-02 16:11:03 -07:00
|
|
|
$merges = $this->getCommitMerges();
|
2012-03-23 15:32:26 -07:00
|
|
|
if (!$merges) {
|
|
|
|
return null;
|
|
|
|
}
|
2015-10-02 16:11:03 -07:00
|
|
|
|
|
|
|
$limit = $this->getMergeDisplayLimit();
|
2012-03-23 15:32:26 -07:00
|
|
|
|
|
|
|
$caption = null;
|
|
|
|
if (count($merges) > $limit) {
|
|
|
|
$merges = array_slice($merges, 0, $limit);
|
2015-03-06 15:32:12 -08:00
|
|
|
$caption = new PHUIInfoView();
|
|
|
|
$caption->setSeverity(PHUIInfoView::SEVERITY_NOTICE);
|
|
|
|
$caption->appendChild(
|
2015-03-26 17:12:00 -07:00
|
|
|
pht(
|
2015-05-22 17:27:56 +10:00
|
|
|
'This commit merges a very large number of changes. '.
|
|
|
|
'Only the first %s are shown.',
|
2015-03-26 17:12:00 -07:00
|
|
|
new PhutilNumber($limit)));
|
2012-03-23 15:32:26 -07:00
|
|
|
}
|
|
|
|
|
2015-09-10 19:28:49 -07:00
|
|
|
$history_table = id(new DiffusionHistoryTableView())
|
|
|
|
->setUser($viewer)
|
|
|
|
->setDiffusionRequest($drequest)
|
|
|
|
->setHistory($merges);
|
2012-03-23 15:32:26 -07:00
|
|
|
|
2015-09-10 19:28:49 -07:00
|
|
|
$history_table->loadRevisions();
|
2012-03-23 15:32:26 -07:00
|
|
|
|
2015-03-06 15:32:12 -08:00
|
|
|
$panel = new PHUIObjectBoxView();
|
|
|
|
$panel->setHeaderText(pht('Merged Changes'));
|
2015-05-19 23:14:22 -07:00
|
|
|
$panel->setTable($history_table);
|
2015-03-06 15:32:12 -08:00
|
|
|
if ($caption) {
|
2015-03-06 17:03:18 -08:00
|
|
|
$panel->setInfoView($caption);
|
2015-03-06 15:32:12 -08:00
|
|
|
}
|
2012-03-23 15:32:26 -07:00
|
|
|
|
|
|
|
return $panel;
|
|
|
|
}
|
|
|
|
|
2012-03-30 14:12:10 -07:00
|
|
|
private function renderHeadsupActionList(
|
2012-08-08 10:03:41 -07:00
|
|
|
PhabricatorRepositoryCommit $commit,
|
|
|
|
PhabricatorRepository $repository) {
|
2012-03-30 14:12:10 -07:00
|
|
|
|
2012-05-02 13:43:45 -07:00
|
|
|
$request = $this->getRequest();
|
|
|
|
$user = $request->getUser();
|
2012-03-30 14:12:10 -07:00
|
|
|
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
$actions = id(new PhabricatorActionListView())
|
|
|
|
->setUser($user)
|
Remove all setObjectURI() from ActionListViews
Summary:
Ref T10004. After D14804, we get this behavior by default and no longer need to set it explicitly.
(If some endpoint did eventually need to set it explicitly, it could just change what it passes to `setHref()`, but I believe we currently have no such endpoints and do not foresee ever having any.)
Test Plan:
- As a logged out user, clicked various links in Differential, Maniphest, Files, etc., always got redirected to a sensible place after login.
- Grepped for `setObjectURI()`, `getObjectURI()` (there are a few remaining callsites, but to a different method with the same name in Doorkeeper).
Reviewers: chad
Reviewed By: chad
Subscribers: hach-que
Maniphest Tasks: T10004
Differential Revision: https://secure.phabricator.com/D14805
2015-12-17 06:31:33 -08:00
|
|
|
->setObject($commit);
|
2012-03-30 14:12:10 -07:00
|
|
|
|
2013-09-27 10:49:45 -07:00
|
|
|
$can_edit = PhabricatorPolicyFilter::hasCapability(
|
|
|
|
$user,
|
|
|
|
$commit,
|
|
|
|
PhabricatorPolicyCapability::CAN_EDIT);
|
|
|
|
|
2016-01-02 12:21:13 -08:00
|
|
|
$identifier = $commit->getCommitIdentifier();
|
|
|
|
$uri = $repository->getPathURI("commit/{$identifier}/edit/");
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
|
|
|
|
$action = id(new PhabricatorActionView())
|
2013-05-11 08:23:19 -07:00
|
|
|
->setName(pht('Edit Commit'))
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
->setHref($uri)
|
2014-05-12 10:08:32 -07:00
|
|
|
->setIcon('fa-pencil')
|
2013-09-27 10:49:45 -07:00
|
|
|
->setDisabled(!$can_edit)
|
|
|
|
->setWorkflow(!$can_edit);
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
$actions->addAction($action);
|
2012-03-30 14:12:10 -07:00
|
|
|
|
|
|
|
require_celerity_resource('phabricator-object-selector-css');
|
|
|
|
require_celerity_resource('javelin-behavior-phabricator-object-selector');
|
|
|
|
|
2014-07-23 10:03:09 +10:00
|
|
|
$maniphest = 'PhabricatorManiphestApplication';
|
2013-04-06 11:39:59 -07:00
|
|
|
if (PhabricatorApplication::isClassInstalled($maniphest)) {
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
$action = id(new PhabricatorActionView())
|
2013-05-11 08:23:19 -07:00
|
|
|
->setName(pht('Edit Maniphest Tasks'))
|
2014-05-12 10:08:32 -07:00
|
|
|
->setIcon('fa-anchor')
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
->setHref('/search/attach/'.$commit->getPHID().'/TASK/edge/')
|
2013-09-27 10:49:45 -07:00
|
|
|
->setWorkflow(true)
|
|
|
|
->setDisabled(!$can_edit);
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
$actions->addAction($action);
|
2012-11-01 17:36:04 -07:00
|
|
|
}
|
2012-03-30 14:12:10 -07:00
|
|
|
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
$action = id(new PhabricatorActionView())
|
2013-05-11 08:23:19 -07:00
|
|
|
->setName(pht('Download Raw Diff'))
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
->setHref($request->getRequestURI()->alter('diff', true))
|
2014-05-12 10:08:32 -07:00
|
|
|
->setIcon('fa-download');
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
$actions->addAction($action);
|
2012-03-30 14:12:10 -07:00
|
|
|
|
upgrade diffusion to use modern header UI and fix a few quirks
Summary:
upgrades are CrumbsView, HeaderView, PropertyListView, and ActionListView. I had to modify CrumbsView stuff a bit to handle the "advanced" diffusion crumbs.
Quirks fixed include making file tree view show up in diffusion, the page not have extra space when the file tree is hidden, links no longer breaking once you visit files (since without the change the files always got "/" appended and thus 404'd), and a differential quirk where it read "next step:" and that colon is a no no,
Test Plan: played around in diffusion and differential
Reviewers: epriestley
Reviewed By: epriestley
CC: aran, Korvin, chad
Maniphest Tasks: T2048, T2178
Differential Revision: https://secure.phabricator.com/D4169
2012-12-12 17:50:42 -08:00
|
|
|
return $actions;
|
2012-03-30 14:12:10 -07:00
|
|
|
}
|
|
|
|
|
2012-05-02 13:43:45 -07:00
|
|
|
private function buildRawDiffResponse(DiffusionRequest $drequest) {
|
2013-05-14 13:53:32 -07:00
|
|
|
$raw_diff = $this->callConduitWithDiffusionRequest(
|
|
|
|
'diffusion.rawdiffquery',
|
|
|
|
array(
|
|
|
|
'commit' => $drequest->getCommit(),
|
2014-10-08 00:01:04 +11:00
|
|
|
'path' => $drequest->getPath(),
|
|
|
|
));
|
2012-05-02 13:43:45 -07:00
|
|
|
|
2012-07-09 10:38:25 -07:00
|
|
|
$file = PhabricatorFile::buildFromFileDataOrHash(
|
|
|
|
$raw_diff,
|
|
|
|
array(
|
|
|
|
'name' => $drequest->getCommit().'.diff',
|
2013-12-30 11:27:02 -08:00
|
|
|
'ttl' => (60 * 60 * 24),
|
|
|
|
'viewPolicy' => PhabricatorPolicies::POLICY_NOONE,
|
2012-07-09 10:38:25 -07:00
|
|
|
));
|
2012-05-02 13:43:45 -07:00
|
|
|
|
2013-12-30 11:27:02 -08:00
|
|
|
$unguarded = AphrontWriteGuard::beginScopedUnguardedWrites();
|
2014-09-04 12:51:33 -07:00
|
|
|
$file->attachToObject($drequest->getRepository()->getPHID());
|
2013-12-30 11:27:02 -08:00
|
|
|
unset($unguarded);
|
|
|
|
|
2014-08-19 15:53:15 -07:00
|
|
|
return $file->getRedirectResponse();
|
2012-05-02 13:43:45 -07:00
|
|
|
}
|
|
|
|
|
2013-07-24 15:29:46 -07:00
|
|
|
private function renderAuditStatusView(array $audit_requests) {
|
|
|
|
assert_instances_of($audit_requests, 'PhabricatorRepositoryAuditRequest');
|
2015-03-30 07:55:33 -07:00
|
|
|
$viewer = $this->getViewer();
|
2013-07-24 15:29:46 -07:00
|
|
|
|
|
|
|
$authority_map = array_fill_keys($this->auditAuthorityPHIDs, true);
|
|
|
|
|
|
|
|
$view = new PHUIStatusListView();
|
|
|
|
foreach ($audit_requests as $request) {
|
2014-10-20 15:47:10 -07:00
|
|
|
$code = $request->getAuditStatus();
|
2013-07-24 15:29:46 -07:00
|
|
|
$item = new PHUIStatusItemView();
|
2014-10-20 15:47:10 -07:00
|
|
|
$item->setIcon(
|
|
|
|
PhabricatorAuditStatusConstants::getStatusIcon($code),
|
|
|
|
PhabricatorAuditStatusConstants::getStatusColor($code),
|
|
|
|
PhabricatorAuditStatusConstants::getStatusName($code));
|
2013-07-24 15:29:46 -07:00
|
|
|
|
|
|
|
$note = array();
|
|
|
|
foreach ($request->getAuditReasons() as $reason) {
|
|
|
|
$note[] = phutil_tag('div', array(), $reason);
|
|
|
|
}
|
|
|
|
$item->setNote($note);
|
|
|
|
|
|
|
|
$auditor_phid = $request->getAuditorPHID();
|
2015-03-30 07:55:33 -07:00
|
|
|
$target = $viewer->renderHandle($auditor_phid);
|
2013-07-24 15:29:46 -07:00
|
|
|
$item->setTarget($target);
|
|
|
|
|
|
|
|
if (isset($authority_map[$auditor_phid])) {
|
|
|
|
$item->setHighlighted(true);
|
|
|
|
}
|
|
|
|
|
|
|
|
$view->addItem($item);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
2013-09-18 10:13:00 -07:00
|
|
|
private function linkBugtraq($corpus) {
|
|
|
|
$url = PhabricatorEnv::getEnvConfig('bugtraq.url');
|
|
|
|
if (!strlen($url)) {
|
|
|
|
return $corpus;
|
|
|
|
}
|
|
|
|
|
|
|
|
$regexes = PhabricatorEnv::getEnvConfig('bugtraq.logregex');
|
|
|
|
if (!$regexes) {
|
|
|
|
return $corpus;
|
|
|
|
}
|
|
|
|
|
|
|
|
$parser = id(new PhutilBugtraqParser())
|
|
|
|
->setBugtraqPattern("[[ {$url} | %BUGID% ]]")
|
|
|
|
->setBugtraqCaptureExpression(array_shift($regexes));
|
|
|
|
|
|
|
|
$select = array_shift($regexes);
|
|
|
|
if ($select) {
|
|
|
|
$parser->setBugtraqSelectExpression($select);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $parser->processCorpus($corpus);
|
|
|
|
}
|
|
|
|
|
2015-08-15 12:57:20 -07:00
|
|
|
private function buildTableOfContents(array $changesets) {
|
2015-08-17 10:14:22 -07:00
|
|
|
$drequest = $this->getDiffusionRequest();
|
2015-08-15 12:57:20 -07:00
|
|
|
$viewer = $this->getViewer();
|
|
|
|
|
|
|
|
$toc_view = id(new PHUIDiffTableOfContentsListView())
|
|
|
|
->setUser($viewer);
|
|
|
|
|
|
|
|
// TODO: This is hacky, we just want access to the linkX() methods on
|
|
|
|
// DiffusionView.
|
|
|
|
$diffusion_view = id(new DiffusionEmptyResultView())
|
2015-08-17 10:14:22 -07:00
|
|
|
->setDiffusionRequest($drequest);
|
|
|
|
|
|
|
|
$have_owners = PhabricatorApplication::isClassInstalledForViewer(
|
|
|
|
'PhabricatorOwnersApplication',
|
|
|
|
$viewer);
|
|
|
|
|
|
|
|
if (!$changesets) {
|
|
|
|
$have_owners = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($have_owners) {
|
|
|
|
if ($viewer->getPHID()) {
|
|
|
|
$packages = id(new PhabricatorOwnersPackageQuery())
|
|
|
|
->setViewer($viewer)
|
2015-08-18 13:36:05 -07:00
|
|
|
->withStatuses(array(PhabricatorOwnersPackage::STATUS_ACTIVE))
|
2015-08-17 10:14:22 -07:00
|
|
|
->withAuthorityPHIDs(array($viewer->getPHID()))
|
|
|
|
->execute();
|
|
|
|
$toc_view->setAuthorityPackages($packages);
|
|
|
|
}
|
2015-08-15 12:57:20 -07:00
|
|
|
|
2015-08-17 10:14:22 -07:00
|
|
|
$repository = $drequest->getRepository();
|
|
|
|
$repository_phid = $repository->getPHID();
|
|
|
|
|
|
|
|
$control_query = id(new PhabricatorOwnersPackageQuery())
|
|
|
|
->setViewer($viewer)
|
2015-08-18 13:36:05 -07:00
|
|
|
->withStatuses(array(PhabricatorOwnersPackage::STATUS_ACTIVE))
|
2015-08-17 10:14:22 -07:00
|
|
|
->withControl($repository_phid, mpull($changesets, 'getFilename'));
|
|
|
|
$control_query->execute();
|
|
|
|
}
|
2015-08-15 12:57:20 -07:00
|
|
|
|
|
|
|
foreach ($changesets as $changeset_id => $changeset) {
|
|
|
|
$path = $changeset->getFilename();
|
|
|
|
$anchor = substr(md5($path), 0, 8);
|
|
|
|
|
|
|
|
$history_link = $diffusion_view->linkHistory($path);
|
2015-09-10 19:28:49 -07:00
|
|
|
$browse_link = $diffusion_view->linkBrowse(
|
|
|
|
$path,
|
|
|
|
array(
|
|
|
|
'type' => $changeset->getFileType(),
|
|
|
|
));
|
2015-08-15 12:57:20 -07:00
|
|
|
|
|
|
|
$item = id(new PHUIDiffTableOfContentsItemView())
|
|
|
|
->setChangeset($changeset)
|
|
|
|
->setAnchor($anchor)
|
|
|
|
->setContext(
|
|
|
|
array(
|
|
|
|
$history_link,
|
|
|
|
' ',
|
|
|
|
$browse_link,
|
|
|
|
));
|
|
|
|
|
2015-08-17 10:14:22 -07:00
|
|
|
if ($have_owners) {
|
2015-08-20 04:46:17 -07:00
|
|
|
$packages = $control_query->getControllingPackagesForPath(
|
2015-08-17 10:14:22 -07:00
|
|
|
$repository_phid,
|
|
|
|
$changeset->getFilename());
|
2015-08-20 04:46:17 -07:00
|
|
|
$item->setPackages($packages);
|
2015-08-17 10:14:22 -07:00
|
|
|
}
|
|
|
|
|
2015-08-15 12:57:20 -07:00
|
|
|
$toc_view->addItem($item);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $toc_view;
|
|
|
|
}
|
|
|
|
|
2015-10-02 16:11:03 -07:00
|
|
|
private function loadCommitState() {
|
|
|
|
$viewer = $this->getViewer();
|
|
|
|
$drequest = $this->getDiffusionRequest();
|
|
|
|
$repository = $drequest->getRepository();
|
|
|
|
$commit = $drequest->getCommit();
|
|
|
|
|
|
|
|
// TODO: We could use futures here and resolve these calls in parallel.
|
|
|
|
|
|
|
|
$exceptions = array();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$parent_refs = $this->callConduitWithDiffusionRequest(
|
|
|
|
'diffusion.commitparentsquery',
|
|
|
|
array(
|
|
|
|
'commit' => $commit,
|
|
|
|
));
|
|
|
|
|
|
|
|
if ($parent_refs) {
|
|
|
|
$parents = id(new DiffusionCommitQuery())
|
|
|
|
->setViewer($viewer)
|
|
|
|
->withRepository($repository)
|
|
|
|
->withIdentifiers($parent_refs)
|
|
|
|
->execute();
|
|
|
|
} else {
|
|
|
|
$parents = array();
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->commitParents = $parents;
|
|
|
|
} catch (Exception $ex) {
|
|
|
|
$this->commitParents = false;
|
|
|
|
$exceptions[] = $ex;
|
|
|
|
}
|
|
|
|
|
|
|
|
$merge_limit = $this->getMergeDisplayLimit();
|
|
|
|
|
|
|
|
try {
|
2015-10-05 15:57:41 -07:00
|
|
|
if ($repository->isSVN()) {
|
|
|
|
$this->commitMerges = array();
|
|
|
|
} else {
|
|
|
|
$merges = $this->callConduitWithDiffusionRequest(
|
|
|
|
'diffusion.mergedcommitsquery',
|
|
|
|
array(
|
|
|
|
'commit' => $commit,
|
|
|
|
'limit' => $merge_limit + 1,
|
|
|
|
));
|
|
|
|
$this->commitMerges = DiffusionPathChange::newFromConduit($merges);
|
|
|
|
}
|
2015-10-02 16:11:03 -07:00
|
|
|
} catch (Exception $ex) {
|
|
|
|
$this->commitMerges = false;
|
|
|
|
$exceptions[] = $ex;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
if ($repository->isGit()) {
|
|
|
|
$refs = $this->callConduitWithDiffusionRequest(
|
|
|
|
'diffusion.refsquery',
|
|
|
|
array(
|
|
|
|
'commit' => $commit,
|
|
|
|
));
|
|
|
|
} else {
|
|
|
|
$refs = array();
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->commitRefs = $refs;
|
|
|
|
} catch (Exception $ex) {
|
|
|
|
$this->commitRefs = false;
|
|
|
|
$exceptions[] = $ex;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($exceptions) {
|
|
|
|
$exists = $this->callConduitWithDiffusionRequest(
|
|
|
|
'diffusion.existsquery',
|
|
|
|
array(
|
|
|
|
'commit' => $commit,
|
|
|
|
));
|
|
|
|
|
|
|
|
if ($exists) {
|
|
|
|
$this->commitExists = true;
|
|
|
|
foreach ($exceptions as $exception) {
|
|
|
|
$this->commitErrors[] = $exception->getMessage();
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$this->commitExists = false;
|
|
|
|
$this->commitErrors[] = pht(
|
|
|
|
'This commit no longer exists in the repository. It may have '.
|
|
|
|
'been part of a branch which was deleted.');
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$this->commitExists = true;
|
|
|
|
$this->commitErrors = array();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getMergeDisplayLimit() {
|
|
|
|
return 50;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getCommitExists() {
|
|
|
|
if ($this->commitExists === null) {
|
|
|
|
$this->loadCommitState();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->commitExists;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getCommitParents() {
|
|
|
|
if ($this->commitParents === null) {
|
|
|
|
$this->loadCommitState();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->commitParents;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getCommitRefs() {
|
|
|
|
if ($this->commitRefs === null) {
|
|
|
|
$this->loadCommitState();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->commitRefs;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getCommitMerges() {
|
|
|
|
if ($this->commitMerges === null) {
|
|
|
|
$this->loadCommitState();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->commitMerges;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function getCommitErrors() {
|
|
|
|
if ($this->commitErrors === null) {
|
|
|
|
$this->loadCommitState();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->commitErrors;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2011-03-11 09:34:22 -08:00
|
|
|
}
|