mirror of
https://we.phorge.it/source/phorge.git
synced 2024-11-28 09:42:41 +01:00
f07d0ae7c3
Summary: I think I like this better -- but maybe right-aligned? Test Plan: {F1180295} {F1180296} Reviewers: chad Reviewed By: chad Differential Revision: https://secure.phabricator.com/D15495
128 lines
3.2 KiB
PHP
128 lines
3.2 KiB
PHP
<?php
|
|
|
|
final class DiffusionPushLogListView extends AphrontView {
|
|
|
|
private $logs;
|
|
private $handles;
|
|
|
|
public function setLogs(array $logs) {
|
|
assert_instances_of($logs, 'PhabricatorRepositoryPushLog');
|
|
$this->logs = $logs;
|
|
return $this;
|
|
}
|
|
|
|
public function setHandles(array $handles) {
|
|
$this->handles = $handles;
|
|
return $this;
|
|
}
|
|
|
|
public function render() {
|
|
$logs = $this->logs;
|
|
$viewer = $this->getUser();
|
|
$handles = $this->handles;
|
|
|
|
// Figure out which repositories are editable. We only let you see remote
|
|
// IPs if you have edit capability on a repository.
|
|
$editable_repos = array();
|
|
if ($logs) {
|
|
$editable_repos = id(new PhabricatorRepositoryQuery())
|
|
->setViewer($viewer)
|
|
->requireCapabilities(
|
|
array(
|
|
PhabricatorPolicyCapability::CAN_VIEW,
|
|
PhabricatorPolicyCapability::CAN_EDIT,
|
|
))
|
|
->withPHIDs(mpull($logs, 'getRepositoryPHID'))
|
|
->execute();
|
|
$editable_repos = mpull($editable_repos, null, 'getPHID');
|
|
}
|
|
|
|
$rows = array();
|
|
foreach ($logs as $log) {
|
|
$repository = $log->getRepository();
|
|
|
|
// Reveal this if it's valid and the user can edit the repository.
|
|
$remote_address = '-';
|
|
if (isset($editable_repos[$log->getRepositoryPHID()])) {
|
|
$remote_address = $log->getPushEvent()->getRemoteAddress();
|
|
}
|
|
|
|
$event_id = $log->getPushEvent()->getID();
|
|
|
|
$old_ref_link = null;
|
|
if ($log->getRefOld() != DiffusionCommitHookEngine::EMPTY_HASH) {
|
|
$old_ref_link = phutil_tag(
|
|
'a',
|
|
array(
|
|
'href' => $repository->getCommitURI($log->getRefOld()),
|
|
),
|
|
$log->getRefOldShort());
|
|
}
|
|
|
|
$rows[] = array(
|
|
phutil_tag(
|
|
'a',
|
|
array(
|
|
'href' => '/diffusion/pushlog/view/'.$event_id.'/',
|
|
),
|
|
$event_id),
|
|
phutil_tag(
|
|
'a',
|
|
array(
|
|
'href' => $repository->getURI(),
|
|
),
|
|
$repository->getDisplayName()),
|
|
$handles[$log->getPusherPHID()]->renderLink(),
|
|
$remote_address,
|
|
$log->getPushEvent()->getRemoteProtocol(),
|
|
$log->getRefType(),
|
|
$log->getRefName(),
|
|
$old_ref_link,
|
|
phutil_tag(
|
|
'a',
|
|
array(
|
|
'href' => $repository->getCommitURI($log->getRefNew()),
|
|
),
|
|
$log->getRefNewShort()),
|
|
|
|
// TODO: Make these human-readable.
|
|
$log->getChangeFlags(),
|
|
$log->getPushEvent()->getRejectCode(),
|
|
$viewer->formatShortDateTime($log->getEpoch()),
|
|
);
|
|
}
|
|
|
|
$table = id(new AphrontTableView($rows))
|
|
->setHeaders(
|
|
array(
|
|
pht('Push'),
|
|
pht('Repository'),
|
|
pht('Pusher'),
|
|
pht('From'),
|
|
pht('Via'),
|
|
pht('Type'),
|
|
pht('Name'),
|
|
pht('Old'),
|
|
pht('New'),
|
|
pht('Flags'),
|
|
pht('Code'),
|
|
pht('Date'),
|
|
))
|
|
->setColumnClasses(
|
|
array(
|
|
'',
|
|
'',
|
|
'',
|
|
'',
|
|
'',
|
|
'',
|
|
'wide',
|
|
'n',
|
|
'n',
|
|
'right',
|
|
));
|
|
|
|
return $table;
|
|
}
|
|
|
|
}
|