From d85338894469ebc2e47469f6cc1d0a1aa06b3d87 Mon Sep 17 00:00:00 2001 From: Gareth Evans Date: Sun, 26 May 2013 08:43:09 -0700 Subject: [PATCH] Render handles in View and Edit Policies Summary: Fixes T3184 We make sure that we're not working with a global policy that just sets the title correctly. Otherwise we have a PHID to work with and set the handle as required. Test Plan: Change policies on a mock and see the title render correctly. Reviewers: epriestley Reviewed By: epriestley CC: aran, Korvin Maniphest Tasks: T3184 Differential Revision: https://secure.phabricator.com/D6042 --- .../policy/query/PhabricatorPolicyQuery.php | 10 +++++++++ .../PhabricatorApplicationTransaction.php | 21 +++++++++++++++---- 2 files changed, 27 insertions(+), 4 deletions(-) diff --git a/src/applications/policy/query/PhabricatorPolicyQuery.php b/src/applications/policy/query/PhabricatorPolicyQuery.php index 20d14b4dc4..beb2837576 100644 --- a/src/applications/policy/query/PhabricatorPolicyQuery.php +++ b/src/applications/policy/query/PhabricatorPolicyQuery.php @@ -118,6 +118,16 @@ final class PhabricatorPolicyQuery extends PhabricatorQuery { return $results; } + public static function isGlobalPolicy($policy) { + $globalPolicies = self::getGlobalPolicies(); + + if (isset($globalPolicies[$policy])) { + return true; + } + + return false; + } + private static function getGlobalPolicies() { static $constants = array( PhabricatorPolicies::POLICY_PUBLIC, diff --git a/src/applications/transactions/storage/PhabricatorApplicationTransaction.php b/src/applications/transactions/storage/PhabricatorApplicationTransaction.php index ddd678dd18..0f24de5dae 100644 --- a/src/applications/transactions/storage/PhabricatorApplicationTransaction.php +++ b/src/applications/transactions/storage/PhabricatorApplicationTransaction.php @@ -123,6 +123,15 @@ abstract class PhabricatorApplicationTransaction $phids[] = ipull($old, 'dst'); $phids[] = ipull($new, 'dst'); break; + case PhabricatorTransactions::TYPE_EDIT_POLICY: + case PhabricatorTransactions::TYPE_VIEW_POLICY: + if (!PhabricatorPolicyQuery::isGlobalPolicy($old)) { + $phids[] = array($old); + } + if (!PhabricatorPolicyQuery::isGlobalPolicy($new)) { + $phids[] = array($new); + } + break; } return array_mergev($phids); @@ -242,16 +251,20 @@ abstract class PhabricatorApplicationTransaction '%s changed the visibility of this %s from "%s" to "%s".', $this->renderHandleLink($author_phid), $this->getApplicationObjectTypeName(), - $old, - $new); + PhabricatorPolicyQuery::isGlobalPolicy($old) ? + $old : $this->renderHandleLink($old), + PhabricatorPolicyQuery::isGlobalPolicy($new) ? + $new : $this->renderHandleLink($new)); case PhabricatorTransactions::TYPE_EDIT_POLICY: // TODO: Render human-readable. return pht( '%s changed the edit policy of this %s from "%s" to "%s".', $this->renderHandleLink($author_phid), $this->getApplicationObjectTypeName(), - $old, - $new); + PhabricatorPolicyQuery::isGlobalPolicy($old) ? + $old : $this->renderHandleLink($old), + PhabricatorPolicyQuery::isGlobalPolicy($new) ? + $new : $this->renderHandleLink($new)); case PhabricatorTransactions::TYPE_SUBSCRIBERS: $add = array_diff($new, $old); $rem = array_diff($old, $new);