1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-11 07:11:04 +01:00

When a Herald rule blocks a push, show which rule fired in the push log UI

Summary:
Ref T13164. See PHI765. We currently show "Rejected: Herald" in the push log UI, but don't show which rule rejected a push.

We store this data, and it's potentially useful: either for hunting down a particular issue, or for getting a general sense of how often a reject rule is triggering (maybe because you want to tune how aggressive it is).

Show this data in the web UI, and include it in the data export payload.

Test Plan:
  - Pushed to a hosted repository so that I got blocked by a Herald rule.
  - Viewed the push logs in the web UI, now saw which rule triggered things.
  - Exported logs to CSV, saw Herald rule PHIDs in the data.

{F5776211}

Reviewers: amckinley

Reviewed By: amckinley

Maniphest Tasks: T13164

Differential Revision: https://secure.phabricator.com/D19555
This commit is contained in:
epriestley 2018-08-01 08:39:08 -07:00
parent 96e3c73159
commit d8834377be
2 changed files with 22 additions and 5 deletions

View file

@ -14,6 +14,8 @@ final class DiffusionPushLogListView extends AphrontView {
$logs = $this->logs; $logs = $this->logs;
$viewer = $this->getViewer(); $viewer = $this->getViewer();
$reject_herald = PhabricatorRepositoryPushLog::REJECT_HERALD;
$handle_phids = array(); $handle_phids = array();
foreach ($logs as $log) { foreach ($logs as $log) {
$handle_phids[] = $log->getPusherPHID(); $handle_phids[] = $log->getPusherPHID();
@ -21,9 +23,13 @@ final class DiffusionPushLogListView extends AphrontView {
if ($device_phid) { if ($device_phid) {
$handle_phids[] = $device_phid; $handle_phids[] = $device_phid;
} }
if ($log->getPushEvent()->getRejectCode() == $reject_herald) {
$handle_phids[] = $log->getPushEvent()->getRejectDetails();
}
} }
$handles = $viewer->loadHandles($handle_phids); $viewer->loadHandles($handle_phids);
// Only administrators can view remote addresses. // Only administrators can view remote addresses.
$remotes_visible = $viewer->getIsAdmin(); $remotes_visible = $viewer->getIsAdmin();
@ -74,10 +80,17 @@ final class DiffusionPushLogListView extends AphrontView {
$flag_names); $flag_names);
$reject_code = $log->getPushEvent()->getRejectCode(); $reject_code = $log->getPushEvent()->getRejectCode();
if ($reject_code == $reject_herald) {
$rule_phid = $log->getPushEvent()->getRejectDetails();
$handle = $viewer->renderHandle($rule_phid);
$reject_label = pht('Blocked: %s', $handle);
} else {
$reject_label = idx( $reject_label = idx(
$reject_map, $reject_map,
$reject_code, $reject_code,
pht('Unknown ("%s")', $reject_code)); pht('Unknown ("%s")', $reject_code));
}
$rows[] = array( $rows[] = array(
phutil_tag( phutil_tag(

View file

@ -149,6 +149,9 @@ final class PhabricatorRepositoryPushLogSearchEngine
id(new PhabricatorStringExportField()) id(new PhabricatorStringExportField())
->setKey('resultName') ->setKey('resultName')
->setLabel(pht('Result Name')), ->setLabel(pht('Result Name')),
id(new PhabricatorStringExportField())
->setKey('resultDetails')
->setLabel(pht('Result Details')),
id(new PhabricatorIntExportField()) id(new PhabricatorIntExportField())
->setKey('writeWait') ->setKey('writeWait')
->setLabel(pht('Write Wait (us)')), ->setLabel(pht('Write Wait (us)')),
@ -237,6 +240,7 @@ final class PhabricatorRepositoryPushLogSearchEngine
'flagNames' => $flag_names, 'flagNames' => $flag_names,
'result' => $result, 'result' => $result,
'resultName' => $result_name, 'resultName' => $result_name,
'resultDetails' => $event->getRejectDetails(),
'writeWait' => $event->getWriteWait(), 'writeWait' => $event->getWriteWait(),
'readWait' => $event->getReadWait(), 'readWait' => $event->getReadWait(),
'hostWait' => $event->getHostWait(), 'hostWait' => $event->getHostWait(),