Cache application visibility in the request cache
Summary: Ref T8575. We check if users can see applications frequently, and caching on the Query isn't especially effective. Use the new Request cache instead. Test Plan: - Saw `/feed/` drop 7% (from ~830ms to ~770ms) on profiles. Reviewers: btrahan, avivey Reviewed By: avivey Subscribers: avivey, epriestley Maniphest Tasks: T8575 Differential Revision: https://secure.phabricator.com/D13321
This commit is contained in:
		| @@ -449,16 +449,27 @@ abstract class PhabricatorApplication | |||||||
|     $class, |     $class, | ||||||
|     PhabricatorUser $viewer) { |     PhabricatorUser $viewer) { | ||||||
|  |  | ||||||
|     if (!self::isClassInstalled($class)) { |     $cache = PhabricatorCaches::getRequestCache(); | ||||||
|       return false; |     $viewer_phid = $viewer->getPHID(); | ||||||
|     } |     $key = 'app.'.$class.'.installed.'.$viewer_phid; | ||||||
|  |  | ||||||
|     return PhabricatorPolicyFilter::hasCapability( |     $result = $cache->getKey($key); | ||||||
|  |     if ($result === null) { | ||||||
|  |       if (!self::isClassInstalled($class)) { | ||||||
|  |         $result = false; | ||||||
|  |       } else { | ||||||
|  |         $result = PhabricatorPolicyFilter::hasCapability( | ||||||
|           $viewer, |           $viewer, | ||||||
|           self::getByClass($class), |           self::getByClass($class), | ||||||
|           PhabricatorPolicyCapability::CAN_VIEW); |           PhabricatorPolicyCapability::CAN_VIEW); | ||||||
|       } |       } | ||||||
|  |  | ||||||
|  |       $cache->setKey($key, $result); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     return $result; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |  | ||||||
| /* -(  PhabricatorPolicyInterface  )----------------------------------------- */ | /* -(  PhabricatorPolicyInterface  )----------------------------------------- */ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -35,7 +35,6 @@ abstract class PhabricatorPolicyAwareQuery extends PhabricatorOffsetPagedQuery { | |||||||
|   private $workspace = array(); |   private $workspace = array(); | ||||||
|   private $inFlightPHIDs = array(); |   private $inFlightPHIDs = array(); | ||||||
|   private $policyFilteredPHIDs = array(); |   private $policyFilteredPHIDs = array(); | ||||||
|   private $canUseApplication; |  | ||||||
|  |  | ||||||
|   /** |   /** | ||||||
|    * Should we continue or throw an exception when a query result is filtered |    * Should we continue or throw an exception when a query result is filtered | ||||||
| @@ -679,21 +678,13 @@ abstract class PhabricatorPolicyAwareQuery extends PhabricatorOffsetPagedQuery { | |||||||
|    *   execute the query. |    *   execute the query. | ||||||
|    */ |    */ | ||||||
|   public function canViewerUseQueryApplication() { |   public function canViewerUseQueryApplication() { | ||||||
|     if ($this->canUseApplication === null) { |  | ||||||
|     $class = $this->getQueryApplicationClass(); |     $class = $this->getQueryApplicationClass(); | ||||||
|     if (!$class) { |     if (!$class) { | ||||||
|         $this->canUseApplication = true; |       return true; | ||||||
|       } else { |  | ||||||
|         $result = id(new PhabricatorApplicationQuery()) |  | ||||||
|           ->setViewer($this->getViewer()) |  | ||||||
|           ->withClasses(array($class)) |  | ||||||
|           ->execute(); |  | ||||||
|  |  | ||||||
|         $this->canUseApplication = (bool)$result; |  | ||||||
|       } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return $this->canUseApplication; |     $viewer = $this->getViewer(); | ||||||
|  |     return PhabricatorApplication::isClassInstalledForViewer($class, $viewer); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 epriestley
					epriestley