mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-01 02:10:59 +01:00
Always pull extra browse information over Ajax, and batch some of the queries
Summary: This code is currently quite complicated because we pull history data inline for SVN files, and via ajax for everything else (SVN dirs, everything in Git and Hg). Always pull over ajax; batch some of the queries. Test Plan: {F34860} Reviewers: btrahan Reviewed By: btrahan Subscribers: epriestley, vrana, aran Maniphest Tasks: T2683 Differential Revision: https://secure.phabricator.com/D5255
This commit is contained in:
parent
df59f4b047
commit
e03deb7d4a
4 changed files with 119 additions and 120 deletions
|
@ -12,8 +12,11 @@ final class DiffusionLastModifiedController extends DiffusionController {
|
||||||
|
|
||||||
$paths = $request->getStr('paths');
|
$paths = $request->getStr('paths');
|
||||||
$paths = json_decode($paths, true);
|
$paths = json_decode($paths, true);
|
||||||
|
if (!is_array($paths)) {
|
||||||
|
return new Aphront400Response();
|
||||||
|
}
|
||||||
|
|
||||||
$output = array();
|
$commits = array();
|
||||||
foreach ($paths as $path) {
|
foreach ($paths as $path) {
|
||||||
$prequest = clone $drequest;
|
$prequest = clone $drequest;
|
||||||
$prequest->setPath($path);
|
$prequest->setPath($path);
|
||||||
|
@ -31,6 +34,8 @@ final class DiffusionLastModifiedController extends DiffusionController {
|
||||||
$commit_data = PhabricatorRepositoryCommitData::newFromDictionary(
|
$commit_data = PhabricatorRepositoryCommitData::newFromDictionary(
|
||||||
$conduit_result['commitData']);
|
$conduit_result['commitData']);
|
||||||
|
|
||||||
|
$commit->attachCommitData($commit_data);
|
||||||
|
|
||||||
$phids = array();
|
$phids = array();
|
||||||
if ($commit_data) {
|
if ($commit_data) {
|
||||||
if ($commit_data->getCommitDetail('authorPHID')) {
|
if ($commit_data->getCommitDetail('authorPHID')) {
|
||||||
|
@ -41,18 +46,110 @@ final class DiffusionLastModifiedController extends DiffusionController {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
$phids = array_keys($phids);
|
$commits[$path] = $commit;
|
||||||
$handles = $this->loadViewerHandles($phids);
|
}
|
||||||
|
|
||||||
$view = new DiffusionBrowseTableView();
|
$phids = array_keys($phids);
|
||||||
$view->setUser($request->getUser());
|
$handles = $this->loadViewerHandles($phids);
|
||||||
$output[$path] = $view->renderLastModifiedColumns(
|
|
||||||
|
$branch = $drequest->loadBranch();
|
||||||
|
if ($branch) {
|
||||||
|
$lint_query = id(new DiffusionLintCountQuery())
|
||||||
|
->withBranchIDs(array($branch->getID()))
|
||||||
|
->withPaths(array_keys($commits));
|
||||||
|
|
||||||
|
if ($drequest->getLint()) {
|
||||||
|
$lint_query->withCodes(array($drequest->getLint()));
|
||||||
|
}
|
||||||
|
|
||||||
|
$lint = $lint_query->execute();
|
||||||
|
} else {
|
||||||
|
$lint = array();
|
||||||
|
}
|
||||||
|
|
||||||
|
$output = array();
|
||||||
|
foreach ($commits as $path => $commit) {
|
||||||
|
$prequest = clone $drequest;
|
||||||
|
$prequest->setPath($path);
|
||||||
|
|
||||||
|
$output[$path] = $this->renderColumns(
|
||||||
$prequest,
|
$prequest,
|
||||||
$handles,
|
$handles,
|
||||||
$commit,
|
$commit,
|
||||||
$commit_data);
|
idx($lint, $path));
|
||||||
}
|
}
|
||||||
|
|
||||||
return id(new AphrontAjaxResponse())->setContent($output);
|
return id(new AphrontAjaxResponse())->setContent($output);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function renderColumns(
|
||||||
|
DiffusionRequest $drequest,
|
||||||
|
array $handles,
|
||||||
|
PhabricatorRepositoryCommit $commit = null,
|
||||||
|
$lint = null) {
|
||||||
|
assert_instances_of($handles, 'PhabricatorObjectHandle');
|
||||||
|
$viewer = $this->getRequest()->getUser();
|
||||||
|
|
||||||
|
if ($commit) {
|
||||||
|
$epoch = $commit->getEpoch();
|
||||||
|
$modified = DiffusionView::linkCommit(
|
||||||
|
$drequest->getRepository(),
|
||||||
|
$commit->getCommitIdentifier());
|
||||||
|
$date = phabricator_date($epoch, $viewer);
|
||||||
|
$time = phabricator_time($epoch, $viewer);
|
||||||
|
} else {
|
||||||
|
$modified = '';
|
||||||
|
$date = '';
|
||||||
|
$time = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$data = $commit->getCommitData();
|
||||||
|
if ($data) {
|
||||||
|
$author_phid = $data->getCommitDetail('authorPHID');
|
||||||
|
if ($author_phid && isset($handles[$author_phid])) {
|
||||||
|
$author = $handles[$author_phid]->renderLink();
|
||||||
|
} else {
|
||||||
|
$author = DiffusionView::renderName($data->getAuthorName());
|
||||||
|
}
|
||||||
|
|
||||||
|
$committer = $data->getCommitDetail('committer');
|
||||||
|
if ($committer) {
|
||||||
|
$committer_phid = $data->getCommitDetail('committerPHID');
|
||||||
|
if ($committer_phid && isset($handles[$committer_phid])) {
|
||||||
|
$committer = $handles[$committer_phid]->renderLink();
|
||||||
|
} else {
|
||||||
|
$committer = DiffusionView::renderName($committer);
|
||||||
|
}
|
||||||
|
if ($author != $committer) {
|
||||||
|
$author = hsprintf('%s/%s', $author, $committer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$details = AphrontTableView::renderSingleDisplayLine($data->getSummary());
|
||||||
|
} else {
|
||||||
|
$author = '';
|
||||||
|
$details = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
$return = array(
|
||||||
|
'commit' => $modified,
|
||||||
|
'date' => $date,
|
||||||
|
'time' => $time,
|
||||||
|
'author' => $author,
|
||||||
|
'details' => $details,
|
||||||
|
);
|
||||||
|
|
||||||
|
if ($lint !== null) {
|
||||||
|
$return['lint'] = phutil_tag(
|
||||||
|
'a',
|
||||||
|
array('href' => $drequest->generateURI(array(
|
||||||
|
'action' => 'lint',
|
||||||
|
'lint' => null,
|
||||||
|
))),
|
||||||
|
number_format($lint));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $return;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,96 +17,6 @@ final class DiffusionBrowseTableView extends DiffusionView {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function renderLastModifiedColumns(
|
|
||||||
DiffusionRequest $drequest,
|
|
||||||
array $handles,
|
|
||||||
PhabricatorRepositoryCommit $commit = null,
|
|
||||||
PhabricatorRepositoryCommitData $data = null) {
|
|
||||||
assert_instances_of($handles, 'PhabricatorObjectHandle');
|
|
||||||
|
|
||||||
if ($commit) {
|
|
||||||
$epoch = $commit->getEpoch();
|
|
||||||
$modified = DiffusionView::linkCommit(
|
|
||||||
$drequest->getRepository(),
|
|
||||||
$commit->getCommitIdentifier());
|
|
||||||
$date = phabricator_date($epoch, $this->user);
|
|
||||||
$time = phabricator_time($epoch, $this->user);
|
|
||||||
} else {
|
|
||||||
$modified = '';
|
|
||||||
$date = '';
|
|
||||||
$time = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($data) {
|
|
||||||
$author_phid = $data->getCommitDetail('authorPHID');
|
|
||||||
if ($author_phid && isset($handles[$author_phid])) {
|
|
||||||
$author = $handles[$author_phid]->renderLink();
|
|
||||||
} else {
|
|
||||||
$author = self::renderName($data->getAuthorName());
|
|
||||||
}
|
|
||||||
|
|
||||||
$committer = $data->getCommitDetail('committer');
|
|
||||||
if ($committer) {
|
|
||||||
$committer_phid = $data->getCommitDetail('committerPHID');
|
|
||||||
if ($committer_phid && isset($handles[$committer_phid])) {
|
|
||||||
$committer = $handles[$committer_phid]->renderLink();
|
|
||||||
} else {
|
|
||||||
$committer = self::renderName($committer);
|
|
||||||
}
|
|
||||||
if ($author != $committer) {
|
|
||||||
$author = hsprintf('%s/%s', $author, $committer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$details = AphrontTableView::renderSingleDisplayLine($data->getSummary());
|
|
||||||
} else {
|
|
||||||
$author = '';
|
|
||||||
$details = '';
|
|
||||||
}
|
|
||||||
|
|
||||||
$return = array(
|
|
||||||
'commit' => $modified,
|
|
||||||
'date' => $date,
|
|
||||||
'time' => $time,
|
|
||||||
'author' => $author,
|
|
||||||
'details' => $details,
|
|
||||||
);
|
|
||||||
|
|
||||||
$lint = self::loadLintMessagesCount($drequest);
|
|
||||||
if ($lint !== null) {
|
|
||||||
$return['lint'] = phutil_tag(
|
|
||||||
'a',
|
|
||||||
array('href' => $drequest->generateURI(array(
|
|
||||||
'action' => 'lint',
|
|
||||||
'lint' => null,
|
|
||||||
))),
|
|
||||||
number_format($lint));
|
|
||||||
}
|
|
||||||
|
|
||||||
return $return;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static function loadLintMessagesCount(DiffusionRequest $drequest) {
|
|
||||||
$path = $drequest->getPath();
|
|
||||||
$branch = $drequest->loadBranch();
|
|
||||||
if (!$branch) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
$query = id(new DiffusionLintCountQuery())
|
|
||||||
->withBranchIDs(array($branch->getID()))
|
|
||||||
->withPaths(array($path));
|
|
||||||
|
|
||||||
$code = $drequest->getLint();
|
|
||||||
if ($code) {
|
|
||||||
$query->withCodes(array($code));
|
|
||||||
}
|
|
||||||
|
|
||||||
$result = $query->execute();
|
|
||||||
|
|
||||||
return idx($result, $path);
|
|
||||||
}
|
|
||||||
|
|
||||||
public function render() {
|
public function render() {
|
||||||
$request = $this->getDiffusionRequest();
|
$request = $this->getDiffusionRequest();
|
||||||
$repository = $request->getRepository();
|
$repository = $request->getRepository();
|
||||||
|
@ -152,29 +62,18 @@ final class DiffusionBrowseTableView extends DiffusionView {
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
$commit = $path->getLastModifiedCommit();
|
$dict = array(
|
||||||
if ($commit) {
|
'lint' => celerity_generate_unique_node_id(),
|
||||||
$drequest = clone $request;
|
'commit' => celerity_generate_unique_node_id(),
|
||||||
$drequest->setPath($request->getPath().$path->getPath().$dir_slash);
|
'date' => celerity_generate_unique_node_id(),
|
||||||
$dict = $this->renderLastModifiedColumns(
|
'time' => celerity_generate_unique_node_id(),
|
||||||
$drequest,
|
'author' => celerity_generate_unique_node_id(),
|
||||||
$this->handles,
|
'details' => celerity_generate_unique_node_id(),
|
||||||
$commit,
|
);
|
||||||
$path->getLastCommitData());
|
|
||||||
} else {
|
|
||||||
$dict = array(
|
|
||||||
'lint' => celerity_generate_unique_node_id(),
|
|
||||||
'commit' => celerity_generate_unique_node_id(),
|
|
||||||
'date' => celerity_generate_unique_node_id(),
|
|
||||||
'time' => celerity_generate_unique_node_id(),
|
|
||||||
'author' => celerity_generate_unique_node_id(),
|
|
||||||
'details' => celerity_generate_unique_node_id(),
|
|
||||||
);
|
|
||||||
|
|
||||||
$need_pull[$base_path.$path->getPath().$dir_slash] = $dict;
|
$need_pull[$base_path.$path->getPath().$dir_slash] = $dict;
|
||||||
foreach ($dict as $k => $uniq) {
|
foreach ($dict as $k => $uniq) {
|
||||||
$dict[$k] = phutil_tag('span', array('id' => $uniq), '');
|
$dict[$k] = phutil_tag('span', array('id' => $uniq), '');
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$editor_button = '';
|
$editor_button = '';
|
||||||
|
|
|
@ -144,7 +144,7 @@ abstract class DiffusionView extends AphrontView {
|
||||||
"D{$id}");
|
"D{$id}");
|
||||||
}
|
}
|
||||||
|
|
||||||
final protected static function renderName($name) {
|
final public static function renderName($name) {
|
||||||
$email = new PhutilEmailAddress($name);
|
$email = new PhutilEmailAddress($name);
|
||||||
if ($email->getDisplayName() && $email->getDomainName()) {
|
if ($email->getDisplayName() && $email->getDomainName()) {
|
||||||
Javelin::initBehavior('phabricator-tooltips', array());
|
Javelin::initBehavior('phabricator-tooltips', array());
|
||||||
|
|
|
@ -13,6 +13,9 @@ JX.behavior('diffusion-pull-lastmodified', function(config) {
|
||||||
.setHandler(function(r) {
|
.setHandler(function(r) {
|
||||||
for (var k in r) {
|
for (var k in r) {
|
||||||
for (var l in r[k]) {
|
for (var l in r[k]) {
|
||||||
|
if (!config.map[k][l]) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
JX.DOM.setContent(JX.$(config.map[k][l]), JX.$H(r[k][l]));
|
JX.DOM.setContent(JX.$(config.map[k][l]), JX.$H(r[k][l]));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue