2011-03-07 15:13:36 -08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
abstract class DiffusionController extends PhabricatorController {
|
|
|
|
|
2016-01-05 12:38:22 -08:00
|
|
|
private $diffusionRequest;
|
2014-04-29 15:07:00 -07:00
|
|
|
|
|
|
|
protected function getDiffusionRequest() {
|
|
|
|
if (!$this->diffusionRequest) {
|
2016-01-05 12:38:22 -08:00
|
|
|
throw new PhutilInvalidStateException('loadDiffusionContext');
|
2014-04-29 15:07:00 -07:00
|
|
|
}
|
|
|
|
return $this->diffusionRequest;
|
|
|
|
}
|
|
|
|
|
2016-01-05 12:38:22 -08:00
|
|
|
protected function hasDiffusionRequest() {
|
|
|
|
return (bool)$this->diffusionRequest;
|
|
|
|
}
|
|
|
|
|
Accept and route VCS HTTP requests
Summary:
Mostly ripped from D7391, with some changes:
- Serve repositories at `/diffusion/X/`, with no special `/git/` or `/serve/` URI component.
- This requires a little bit of magic, but I got the magic working for Git, Mercurial and SVN, and it seems reasonable.
- I think having one URI for everything will make it easier for users to understand.
- One downside is that git will clone into `X` by default, but I think that's not a big deal, and we can work around that in the future easily enough.
- Accept HTTP requests for Git, SVN and Mercurial repositories.
- Auth logic is a little different in order to be more consistent with how other things work.
- Instead of AphrontBasicAuthResponse, added "VCSResponse". Mercurial can print strings we send it on the CLI if we're careful, so support that. I did a fair amount of digging and didn't have any luck with git or svn.
- Commands we don't know about are assumed to require "Push" capability by default.
No actual VCS data going over the wire yet.
Test Plan:
Ran a bunch of stuff like this:
$ hg clone http://local.aphront.com:8080/diffusion/P/
abort: HTTP Error 403: This repository is not available over HTTP.
...and got pretty reasonable-seeming errors in all cases. All this can do is produce errors for now.
Reviewers: hach-que, btrahan
Reviewed By: hach-que
CC: aran
Maniphest Tasks: T2230
Differential Revision: https://secure.phabricator.com/D7417
2013-10-26 07:56:17 -07:00
|
|
|
public function willBeginExecution() {
|
|
|
|
$request = $this->getRequest();
|
2013-11-05 15:24:58 -08:00
|
|
|
|
Accept and route VCS HTTP requests
Summary:
Mostly ripped from D7391, with some changes:
- Serve repositories at `/diffusion/X/`, with no special `/git/` or `/serve/` URI component.
- This requires a little bit of magic, but I got the magic working for Git, Mercurial and SVN, and it seems reasonable.
- I think having one URI for everything will make it easier for users to understand.
- One downside is that git will clone into `X` by default, but I think that's not a big deal, and we can work around that in the future easily enough.
- Accept HTTP requests for Git, SVN and Mercurial repositories.
- Auth logic is a little different in order to be more consistent with how other things work.
- Instead of AphrontBasicAuthResponse, added "VCSResponse". Mercurial can print strings we send it on the CLI if we're careful, so support that. I did a fair amount of digging and didn't have any luck with git or svn.
- Commands we don't know about are assumed to require "Push" capability by default.
No actual VCS data going over the wire yet.
Test Plan:
Ran a bunch of stuff like this:
$ hg clone http://local.aphront.com:8080/diffusion/P/
abort: HTTP Error 403: This repository is not available over HTTP.
...and got pretty reasonable-seeming errors in all cases. All this can do is produce errors for now.
Reviewers: hach-que, btrahan
Reviewed By: hach-que
CC: aran
Maniphest Tasks: T2230
Differential Revision: https://secure.phabricator.com/D7417
2013-10-26 07:56:17 -07:00
|
|
|
// Check if this is a VCS request, e.g. from "git clone", "hg clone", or
|
|
|
|
// "svn checkout". If it is, we jump off into repository serving code to
|
|
|
|
// process the request.
|
2016-01-05 12:38:22 -08:00
|
|
|
|
|
|
|
$serve_controller = new DiffusionServeController();
|
|
|
|
if ($serve_controller->isVCSRequest($request)) {
|
2013-11-06 17:55:46 -08:00
|
|
|
return $this->delegateToController($serve_controller);
|
Accept and route VCS HTTP requests
Summary:
Mostly ripped from D7391, with some changes:
- Serve repositories at `/diffusion/X/`, with no special `/git/` or `/serve/` URI component.
- This requires a little bit of magic, but I got the magic working for Git, Mercurial and SVN, and it seems reasonable.
- I think having one URI for everything will make it easier for users to understand.
- One downside is that git will clone into `X` by default, but I think that's not a big deal, and we can work around that in the future easily enough.
- Accept HTTP requests for Git, SVN and Mercurial repositories.
- Auth logic is a little different in order to be more consistent with how other things work.
- Instead of AphrontBasicAuthResponse, added "VCSResponse". Mercurial can print strings we send it on the CLI if we're careful, so support that. I did a fair amount of digging and didn't have any luck with git or svn.
- Commands we don't know about are assumed to require "Push" capability by default.
No actual VCS data going over the wire yet.
Test Plan:
Ran a bunch of stuff like this:
$ hg clone http://local.aphront.com:8080/diffusion/P/
abort: HTTP Error 403: This repository is not available over HTTP.
...and got pretty reasonable-seeming errors in all cases. All this can do is produce errors for now.
Reviewers: hach-que, btrahan
Reviewed By: hach-que
CC: aran
Maniphest Tasks: T2230
Differential Revision: https://secure.phabricator.com/D7417
2013-10-26 07:56:17 -07:00
|
|
|
}
|
|
|
|
|
2013-11-06 17:55:46 -08:00
|
|
|
return parent::willBeginExecution();
|
Accept and route VCS HTTP requests
Summary:
Mostly ripped from D7391, with some changes:
- Serve repositories at `/diffusion/X/`, with no special `/git/` or `/serve/` URI component.
- This requires a little bit of magic, but I got the magic working for Git, Mercurial and SVN, and it seems reasonable.
- I think having one URI for everything will make it easier for users to understand.
- One downside is that git will clone into `X` by default, but I think that's not a big deal, and we can work around that in the future easily enough.
- Accept HTTP requests for Git, SVN and Mercurial repositories.
- Auth logic is a little different in order to be more consistent with how other things work.
- Instead of AphrontBasicAuthResponse, added "VCSResponse". Mercurial can print strings we send it on the CLI if we're careful, so support that. I did a fair amount of digging and didn't have any luck with git or svn.
- Commands we don't know about are assumed to require "Push" capability by default.
No actual VCS data going over the wire yet.
Test Plan:
Ran a bunch of stuff like this:
$ hg clone http://local.aphront.com:8080/diffusion/P/
abort: HTTP Error 403: This repository is not available over HTTP.
...and got pretty reasonable-seeming errors in all cases. All this can do is produce errors for now.
Reviewers: hach-que, btrahan
Reviewed By: hach-que
CC: aran
Maniphest Tasks: T2230
Differential Revision: https://secure.phabricator.com/D7417
2013-10-26 07:56:17 -07:00
|
|
|
}
|
|
|
|
|
2016-01-05 08:49:10 -08:00
|
|
|
protected function loadDiffusionContextForEdit() {
|
|
|
|
return $this->loadContext(
|
|
|
|
array(
|
|
|
|
'edit' => true,
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
2016-01-05 04:42:07 -08:00
|
|
|
protected function loadDiffusionContext() {
|
2016-01-05 08:49:10 -08:00
|
|
|
return $this->loadContext(array());
|
|
|
|
}
|
|
|
|
|
|
|
|
private function loadContext(array $options) {
|
2016-01-05 04:42:07 -08:00
|
|
|
$request = $this->getRequest();
|
|
|
|
$viewer = $this->getViewer();
|
|
|
|
|
2016-01-05 10:34:04 -08:00
|
|
|
$identifier = $this->getRepositoryIdentifierFromRequest($request);
|
2016-01-05 04:42:07 -08:00
|
|
|
|
2016-01-05 08:49:10 -08:00
|
|
|
$params = $options + array(
|
2016-01-05 04:42:07 -08:00
|
|
|
'repository' => $identifier,
|
|
|
|
'user' => $viewer,
|
2016-01-05 10:34:04 -08:00
|
|
|
'blob' => $this->getDiffusionBlobFromRequest($request),
|
2016-01-05 05:00:22 -08:00
|
|
|
'commit' => $request->getURIData('commit'),
|
|
|
|
'path' => $request->getURIData('path'),
|
|
|
|
'line' => $request->getURIData('line'),
|
|
|
|
'branch' => $request->getURIData('branch'),
|
|
|
|
'lint' => $request->getStr('lint'),
|
|
|
|
);
|
2016-01-05 04:42:07 -08:00
|
|
|
|
|
|
|
$drequest = DiffusionRequest::newFromDictionary($params);
|
|
|
|
|
|
|
|
if (!$drequest) {
|
|
|
|
return new Aphront404Response();
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->diffusionRequest = $drequest;
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2016-01-05 10:34:04 -08:00
|
|
|
protected function getDiffusionBlobFromRequest(AphrontRequest $request) {
|
|
|
|
return $request->getURIData('dblob');
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getRepositoryIdentifierFromRequest(
|
|
|
|
AphrontRequest $request) {
|
|
|
|
|
|
|
|
$identifier = $request->getURIData('repositoryCallsign');
|
|
|
|
if (strlen($identifier)) {
|
|
|
|
return $identifier;
|
|
|
|
}
|
|
|
|
|
2016-01-05 12:38:22 -08:00
|
|
|
$id = $request->getURIData('repositoryID');
|
|
|
|
if (strlen($id)) {
|
|
|
|
return (int)$id;
|
|
|
|
}
|
2016-01-05 10:34:04 -08:00
|
|
|
|
2016-01-05 12:38:22 -08:00
|
|
|
return null;
|
2016-01-05 04:42:07 -08:00
|
|
|
}
|
2015-01-09 13:29:08 -08:00
|
|
|
|
2011-03-12 16:17:34 -08:00
|
|
|
public function buildCrumbs(array $spec = array()) {
|
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
|
|
|
$crumbs = $this->buildApplicationCrumbs();
|
2011-03-30 22:08:41 -07:00
|
|
|
$crumb_list = $this->buildCrumbList($spec);
|
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 ($crumb_list as $crumb) {
|
|
|
|
$crumbs->addCrumb($crumb);
|
|
|
|
}
|
2011-03-30 22:08:41 -07:00
|
|
|
return $crumbs;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function buildCrumbList(array $spec = array()) {
|
2011-03-12 16:17:34 -08:00
|
|
|
|
2012-04-19 09:39:19 -07:00
|
|
|
$spec = $spec + array(
|
|
|
|
'commit' => null,
|
|
|
|
'tags' => null,
|
2012-05-10 09:28:19 +02:00
|
|
|
'branches' => null,
|
2012-04-19 09:39:19 -07:00
|
|
|
'view' => null,
|
|
|
|
);
|
|
|
|
|
2011-03-12 16:17:34 -08:00
|
|
|
$crumb_list = array();
|
|
|
|
|
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
|
|
|
// On the home page, we don't have a DiffusionRequest.
|
Improve Diffusion behavior for directories with impressive numbers of files
Summary:
Fixes T4366. Two years ago, Facebook put 16,000 files in a directory. Today, the page has nearly loaded.
Paginate large directories.
Test Plan:
- Viewed home and browse views in Git, Mercurial and Subversion.
I put an artificially small page size (5) on home:
{F1055653}
I pushed 16,000 files to a directory and paged through them. Here's the last page, which rendered in about 200ms:
{F1055655}
Our behavior is a bit better than GitHub here, which shows only the first 1,000 files, disables pagination, and can't retrieve history for the files:
{F1055656}
Reviewers: chad
Reviewed By: chad
Maniphest Tasks: T4366
Differential Revision: https://secure.phabricator.com/D14956
2016-01-06 03:57:57 -08:00
|
|
|
if ($this->hasDiffusionRequest()) {
|
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
|
|
|
$drequest = $this->getDiffusionRequest();
|
|
|
|
$repository = $drequest->getRepository();
|
|
|
|
} else {
|
|
|
|
$drequest = null;
|
|
|
|
$repository = null;
|
|
|
|
}
|
|
|
|
|
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
|
|
|
if (!$repository) {
|
2011-03-30 22:08:41 -07:00
|
|
|
return $crumb_list;
|
2011-03-12 16:17:34 -08:00
|
|
|
}
|
|
|
|
|
2014-02-03 16:00:27 -08:00
|
|
|
$repository_name = $repository->getName();
|
2011-03-12 16:17:34 -08:00
|
|
|
|
2012-05-10 09:28:19 +02:00
|
|
|
if (!$spec['commit'] && !$spec['tags'] && !$spec['branches']) {
|
2012-01-19 11:49:51 -08:00
|
|
|
$branch_name = $drequest->getBranch();
|
|
|
|
if ($branch_name) {
|
2012-12-12 18:40:18 -08:00
|
|
|
$repository_name .= ' ('.$branch_name.')';
|
2012-01-19 11:49:51 -08:00
|
|
|
}
|
2011-03-12 16:17:34 -08:00
|
|
|
}
|
|
|
|
|
2015-01-23 11:35:09 -08:00
|
|
|
$crumb = id(new PHUICrumbView())
|
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
|
|
|
->setName($repository_name);
|
|
|
|
if (!$spec['view'] && !$spec['commit'] &&
|
|
|
|
!$spec['tags'] && !$spec['branches']) {
|
|
|
|
$crumb_list[] = $crumb;
|
|
|
|
return $crumb_list;
|
2011-03-12 16:17:34 -08:00
|
|
|
}
|
2013-09-23 12:54:12 -07:00
|
|
|
$crumb->setHref(
|
|
|
|
$drequest->generateURI(
|
|
|
|
array(
|
|
|
|
'action' => 'branch',
|
|
|
|
'path' => '/',
|
|
|
|
)));
|
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
|
|
|
$crumb_list[] = $crumb;
|
2011-03-12 16:17:34 -08:00
|
|
|
|
2014-05-13 13:52:48 -07:00
|
|
|
$stable_commit = $drequest->getStableCommit();
|
2016-01-02 12:21:13 -08:00
|
|
|
$commit_name = $repository->formatCommitName($stable_commit);
|
|
|
|
$commit_uri = $repository->getCommitURI($stable_commit);
|
2012-04-23 18:36:25 -07:00
|
|
|
|
|
|
|
if ($spec['tags']) {
|
2015-01-23 11:35:09 -08:00
|
|
|
$crumb = new PHUICrumbView();
|
2012-04-23 18:36:25 -07:00
|
|
|
if ($spec['commit']) {
|
2016-01-02 12:21:13 -08:00
|
|
|
$crumb->setName(pht('Tags for %s', $commit_name));
|
|
|
|
$crumb->setHref($commit_uri);
|
2012-04-23 18:36:25 -07:00
|
|
|
} else {
|
2013-05-11 08:23:19 -07:00
|
|
|
$crumb->setName(pht('Tags'));
|
2012-04-23 18:36:25 -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
|
|
|
$crumb_list[] = $crumb;
|
2011-03-30 22:08:41 -07:00
|
|
|
return $crumb_list;
|
2011-03-12 16:17:34 -08:00
|
|
|
}
|
|
|
|
|
2012-05-10 09:28:19 +02:00
|
|
|
if ($spec['branches']) {
|
2015-01-23 11:35:09 -08:00
|
|
|
$crumb = id(new PHUICrumbView())
|
2013-05-11 08:23:19 -07:00
|
|
|
->setName(pht('Branches'));
|
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
|
|
|
$crumb_list[] = $crumb;
|
2012-05-10 09:28:19 +02:00
|
|
|
return $crumb_list;
|
|
|
|
}
|
|
|
|
|
2012-04-23 18:36:25 -07:00
|
|
|
if ($spec['commit']) {
|
2015-01-23 11:35:09 -08:00
|
|
|
$crumb = id(new PHUICrumbView())
|
2016-01-02 12:21:13 -08:00
|
|
|
->setName($commit_name)
|
|
|
|
->setHref($commit_uri);
|
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
|
|
|
$crumb_list[] = $crumb;
|
2012-04-19 09:39:19 -07:00
|
|
|
return $crumb_list;
|
|
|
|
}
|
|
|
|
|
2015-01-23 11:35:09 -08:00
|
|
|
$crumb = new PHUICrumbView();
|
2011-03-12 16:17:34 -08:00
|
|
|
$view = $spec['view'];
|
|
|
|
|
|
|
|
switch ($view) {
|
|
|
|
case 'history':
|
2013-05-11 08:23:19 -07:00
|
|
|
$view_name = pht('History');
|
2011-03-12 16:17:34 -08:00
|
|
|
break;
|
|
|
|
case 'browse':
|
2013-05-11 08:23:19 -07:00
|
|
|
$view_name = pht('Browse');
|
2011-03-12 16:17:34 -08:00
|
|
|
break;
|
2012-11-08 11:11:44 -08:00
|
|
|
case 'lint':
|
2013-05-11 08:23:19 -07:00
|
|
|
$view_name = pht('Lint');
|
2012-11-08 11:11:44 -08:00
|
|
|
break;
|
2011-03-13 22:03:30 -07:00
|
|
|
case 'change':
|
2013-05-11 08:23:19 -07:00
|
|
|
$view_name = pht('Change');
|
2013-09-23 12:54:12 -07:00
|
|
|
break;
|
2011-03-12 16:17:34 -08:00
|
|
|
}
|
|
|
|
|
2015-01-23 11:35:09 -08:00
|
|
|
$crumb = id(new PHUICrumbView())
|
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
|
|
|
->setName($view_name);
|
2011-03-12 16:17:34 -08:00
|
|
|
|
2013-09-19 11:57:33 -07:00
|
|
|
$crumb_list[] = $crumb;
|
2011-03-30 22:08:41 -07:00
|
|
|
return $crumb_list;
|
2011-03-12 16:17:34 -08:00
|
|
|
}
|
|
|
|
|
2013-05-01 14:44:28 -07:00
|
|
|
protected function callConduitWithDiffusionRequest(
|
|
|
|
$method,
|
|
|
|
array $params = array()) {
|
|
|
|
|
|
|
|
$user = $this->getRequest()->getUser();
|
|
|
|
$drequest = $this->getDiffusionRequest();
|
|
|
|
|
|
|
|
return DiffusionQuery::callConduitWithDiffusionRequest(
|
|
|
|
$user,
|
|
|
|
$drequest,
|
|
|
|
$method,
|
|
|
|
$params);
|
|
|
|
}
|
2013-05-24 12:37:42 -07:00
|
|
|
|
|
|
|
protected function getRepositoryControllerURI(
|
|
|
|
PhabricatorRepository $repository,
|
|
|
|
$path) {
|
2016-01-02 12:21:13 -08:00
|
|
|
return $repository->getPathURI($path);
|
2013-05-24 12:37:42 -07:00
|
|
|
}
|
|
|
|
|
2013-09-23 12:55:23 -07:00
|
|
|
protected function renderPathLinks(DiffusionRequest $drequest, $action) {
|
2013-09-19 16:01:04 -07:00
|
|
|
$path = $drequest->getPath();
|
|
|
|
$path_parts = array_filter(explode('/', trim($path, '/')));
|
|
|
|
|
2013-10-14 09:40:05 -07:00
|
|
|
$divider = phutil_tag(
|
|
|
|
'span',
|
|
|
|
array(
|
2014-10-08 00:01:04 +11:00
|
|
|
'class' => 'phui-header-divider',
|
|
|
|
),
|
2013-10-14 09:40:05 -07:00
|
|
|
'/');
|
|
|
|
|
2013-09-19 16:01:04 -07:00
|
|
|
$links = array();
|
|
|
|
if ($path_parts) {
|
|
|
|
$links[] = phutil_tag(
|
|
|
|
'a',
|
|
|
|
array(
|
|
|
|
'href' => $drequest->generateURI(
|
|
|
|
array(
|
2013-09-23 12:55:23 -07:00
|
|
|
'action' => $action,
|
2013-09-19 16:01:04 -07:00
|
|
|
'path' => '',
|
|
|
|
)),
|
|
|
|
),
|
2016-01-02 12:03:08 -08:00
|
|
|
$drequest->getRepository()->getDisplayName());
|
2013-10-14 09:40:05 -07:00
|
|
|
$links[] = $divider;
|
2013-09-19 16:01:04 -07:00
|
|
|
$accum = '';
|
|
|
|
$last_key = last_key($path_parts);
|
|
|
|
foreach ($path_parts as $key => $part) {
|
|
|
|
$accum .= '/'.$part;
|
|
|
|
if ($key === $last_key) {
|
|
|
|
$links[] = $part;
|
|
|
|
} else {
|
|
|
|
$links[] = phutil_tag(
|
|
|
|
'a',
|
|
|
|
array(
|
|
|
|
'href' => $drequest->generateURI(
|
|
|
|
array(
|
2013-09-23 12:55:23 -07:00
|
|
|
'action' => $action,
|
2013-10-03 15:51:47 -07:00
|
|
|
'path' => $accum.'/',
|
2013-09-19 16:01:04 -07:00
|
|
|
)),
|
|
|
|
),
|
2013-10-14 09:40:05 -07:00
|
|
|
$part);
|
|
|
|
$links[] = $divider;
|
2013-09-19 16:01:04 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
2016-01-02 11:28:31 -08:00
|
|
|
$links[] = $drequest->getRepository()->getDisplayName();
|
2013-10-14 09:40:05 -07:00
|
|
|
$links[] = $divider;
|
2013-09-19 16:01:04 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
return $links;
|
|
|
|
}
|
|
|
|
|
Add an "importing" state to repositories and clean up the UI
Summary:
Fixes T3217. Ref T776. Ref T1493. Broadly, this introduces a mechanism which works like this:
- When a repository is created, we set an "importing" flag.
- After discovery completes, we check if a repository has no importing commits. Basically, this is the first time we catch up to HEAD.
- If we're caught up, clear the "importing" flag.
This flag lets us fix some issues:
- T3217. Currently, when you import a new repository and users have rules like "Email me on every commit ever" or "trigger an audit on every commit", we take a bunch of publish actions. Instead, implicitly disable publishing during import.
- An imported but un-pulled repository currently has an incomprehensible error on `/diffusion/X/`. Fix that.
- Show more cues in the UI about importing.
- Made some exceptions more specific.
Test Plan:
This is the new screen for a completely new repo, replacing a giant exception:
{F75443}
- Created a repository, saw it "importing".
- Pulled and discovered it.
- Processed its commits.
- Ran discovery again, saw import flag clear.
- Also this repository was empty, which hit some of the other code.
This is the new "parsed empty repository" UI, which isn't good, but is less broken:
{F75446}
Reviewers: btrahan
Reviewed By: btrahan
CC: aran, hach-que
Maniphest Tasks: T3607, T1493, T776, T3217
Differential Revision: https://secure.phabricator.com/D7429
2013-10-26 19:59:57 -07:00
|
|
|
protected function renderStatusMessage($title, $body) {
|
2015-03-01 14:45:56 -08:00
|
|
|
return id(new PHUIInfoView())
|
|
|
|
->setSeverity(PHUIInfoView::SEVERITY_WARNING)
|
Add an "importing" state to repositories and clean up the UI
Summary:
Fixes T3217. Ref T776. Ref T1493. Broadly, this introduces a mechanism which works like this:
- When a repository is created, we set an "importing" flag.
- After discovery completes, we check if a repository has no importing commits. Basically, this is the first time we catch up to HEAD.
- If we're caught up, clear the "importing" flag.
This flag lets us fix some issues:
- T3217. Currently, when you import a new repository and users have rules like "Email me on every commit ever" or "trigger an audit on every commit", we take a bunch of publish actions. Instead, implicitly disable publishing during import.
- An imported but un-pulled repository currently has an incomprehensible error on `/diffusion/X/`. Fix that.
- Show more cues in the UI about importing.
- Made some exceptions more specific.
Test Plan:
This is the new screen for a completely new repo, replacing a giant exception:
{F75443}
- Created a repository, saw it "importing".
- Pulled and discovered it.
- Processed its commits.
- Ran discovery again, saw import flag clear.
- Also this repository was empty, which hit some of the other code.
This is the new "parsed empty repository" UI, which isn't good, but is less broken:
{F75446}
Reviewers: btrahan
Reviewed By: btrahan
CC: aran, hach-que
Maniphest Tasks: T3607, T1493, T776, T3217
Differential Revision: https://secure.phabricator.com/D7429
2013-10-26 19:59:57 -07:00
|
|
|
->setTitle($title)
|
|
|
|
->appendChild($body);
|
|
|
|
}
|
2013-11-01 08:44:37 -07:00
|
|
|
|
2016-01-05 05:00:22 -08:00
|
|
|
protected function renderTablePagerBox(PHUIPagerView $pager) {
|
|
|
|
return id(new PHUIBoxView())
|
|
|
|
->addMargin(PHUI::MARGIN_LARGE)
|
|
|
|
->appendChild($pager);
|
|
|
|
}
|
|
|
|
|
2016-01-07 03:50:16 -08:00
|
|
|
protected function renderDirectoryReadme(DiffusionBrowseResultSet $browse) {
|
|
|
|
$readme_path = $browse->getReadmePath();
|
|
|
|
if ($readme_path === null) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
$drequest = $this->getDiffusionRequest();
|
|
|
|
$viewer = $this->getViewer();
|
|
|
|
|
|
|
|
try {
|
|
|
|
$result = $this->callConduitWithDiffusionRequest(
|
|
|
|
'diffusion.filecontentquery',
|
|
|
|
array(
|
|
|
|
'path' => $readme_path,
|
|
|
|
'commit' => $drequest->getStableCommit(),
|
|
|
|
));
|
|
|
|
} catch (Exception $ex) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
$file_phid = $result['filePHID'];
|
|
|
|
if (!$file_phid) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
$file = id(new PhabricatorFileQuery())
|
|
|
|
->setViewer($viewer)
|
|
|
|
->withPHIDs(array($file_phid))
|
|
|
|
->executeOne();
|
|
|
|
if (!$file) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
$corpus = $file->loadFileData();
|
|
|
|
|
|
|
|
if (!strlen($corpus)) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return id(new DiffusionReadmeView())
|
|
|
|
->setUser($this->getViewer())
|
|
|
|
->setPath($readme_path)
|
|
|
|
->setContent($corpus);
|
|
|
|
}
|
|
|
|
|
2011-03-07 15:13:36 -08:00
|
|
|
}
|