1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-25 22:18:19 +01:00

Use PhutilClassMapQuery

Summary: Use `PhutilClassMapQuery` where appropriate.

Test Plan: Browsed around the UI to verify things seemed somewhat working.

Reviewers: epriestley, #blessed_reviewers

Reviewed By: epriestley, #blessed_reviewers

Subscribers: epriestley, Korvin

Differential Revision: https://secure.phabricator.com/D13429
This commit is contained in:
Joshua Spence 2015-07-07 22:34:30 +10:00
parent 6a3c1ba05c
commit f695dcea9e
27 changed files with 102 additions and 443 deletions

View file

@ -65,11 +65,11 @@ abstract class AlmanacServiceType extends Phobject {
* @return map<string, object> Dictionary of available service types. * @return map<string, object> Dictionary of available service types.
*/ */
public static function getAllServiceTypes() { public static function getAllServiceTypes() {
$types = id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getServiceTypeShortName')
->setSortMethod('getServiceTypeName')
return msort($types, 'getServiceTypeName'); ->execute();
} }

View file

@ -34,35 +34,10 @@ abstract class PhabricatorAuthFactor extends Phobject {
} }
public static function getAllFactors() { public static function getAllFactors() {
static $factors; return id(new PhutilClassMapQuery())
if ($factors === null) {
$map = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getFactorKey')
->execute();
$factors = array();
foreach ($map as $factor) {
$key = $factor->getFactorKey();
if (empty($factors[$key])) {
$factors[$key] = $factor;
} else {
$this_class = get_class($factor);
$that_class = get_class($factors[$key]);
throw new Exception(
pht(
'Two auth factors (with classes "%s" and "%s") both provide '.
'implementations with the same key ("%s"). Each factor must '.
'have a unique key.',
$this_class,
$that_class,
$key));
}
}
}
return $factors;
} }
protected function newConfigForUser(PhabricatorUser $user) { protected function newConfigForUser(PhabricatorUser $user) {

View file

@ -55,16 +55,9 @@ abstract class PhabricatorAuthProvider extends Phobject {
} }
public static function getAllBaseProviders() { public static function getAllBaseProviders() {
static $providers; return id(new PhutilClassMapQuery())
if ($providers === null) {
$objects = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->execute();
$providers = $objects;
}
return $providers;
} }
public static function getAllProviders() { public static function getAllProviders() {

View file

@ -383,13 +383,13 @@ abstract class PhabricatorApplication
static $applications; static $applications;
if ($applications === null) { if ($applications === null) {
$apps = id(new PhutilSymbolLoader()) $apps = id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setSortMethod('getApplicationOrder')
->execute();
// Reorder the applications into "application order". Notably, this // Reorder the applications into "application order". Notably, this
// ensures their event handlers register in application order. // ensures their event handlers register in application order.
$apps = msort($apps, 'getApplicationOrder');
$apps = mgroup($apps, 'getApplicationGroup'); $apps = mgroup($apps, 'getApplicationGroup');
$group_order = array_keys(self::getApplicationGroups()); $group_order = array_keys(self::getApplicationGroups());

View file

@ -36,34 +36,10 @@ abstract class CelerityPostprocessor
} }
final public static function getAllPostprocessors() { final public static function getAllPostprocessors() {
static $postprocessors; return id(new PhutilClassMapQuery())
if ($postprocessors === null) {
$objects = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getPostprocessorKey')
->execute();
$map = array();
foreach ($objects as $object) {
$key = $object->getPostprocessorKey();
if (empty($map[$key])) {
$map[$key] = $object;
continue;
}
throw new Exception(
pht(
'Two postprocessors (of classes "%s" and "%s") define the same '.
'postprocessor key ("%s"). Each postprocessor must define a '.
'unique key.',
get_class($object),
get_class($map[$key]),
$key));
}
$postprocessors = $map;
}
return $postprocessors;
} }
} }

View file

@ -23,11 +23,10 @@ abstract class CelerityPhysicalResources extends CelerityResources {
static $resources_map; static $resources_map;
if ($resources_map === null) { if ($resources_map === null) {
$resources_map = array(); $resources_list = id(new PhutilClassMapQuery())
$resources_list = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getName')
->execute();
foreach ($resources_list as $resources) { foreach ($resources_list as $resources) {
$name = $resources->getName(); $name = $resources->getName();
@ -39,21 +38,9 @@ abstract class CelerityPhysicalResources extends CelerityResources {
'lowercase latin letters and digits.', 'lowercase latin letters and digits.',
$name)); $name));
} }
}
if (empty($resources_map[$name])) { $resources_map = $resources_list;
$resources_map[$name] = $resources;
} else {
$old = get_class($resources_map[$name]);
$new = get_class($resources);
throw new Exception(
pht(
'Celerity resource maps must have unique names, but maps %s and '.
'%s share the same name, "%s".',
$old,
$new,
$name));
}
}
} }
return $resources_map; return $resources_map;

View file

@ -112,17 +112,10 @@ abstract class PhabricatorSetupCheck extends Phobject {
} }
final public static function loadAllChecks() { final public static function loadAllChecks() {
$symbols = id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->setConcreteOnly(true) ->setSortMethod('getExecutionOrder')
->selectAndLoadSymbols(); ->execute();
$checks = array();
foreach ($symbols as $symbol) {
$checks[] = newv($symbol['name'], array());
}
return msort($checks, 'getExecutionOrder');
} }
final public static function runAllChecks() { final public static function runAllChecks() {

View file

@ -46,36 +46,10 @@ abstract class PhabricatorDashboardPanelType extends Phobject {
} }
public static function getAllPanelTypes() { public static function getAllPanelTypes() {
static $types; return id(new PhutilClassMapQuery())
if ($types === null) {
$objects = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getPanelTypeKey')
->execute();
$map = array();
foreach ($objects as $object) {
$key = $object->getPanelTypeKey();
if (!empty($map[$key])) {
$this_class = get_class($object);
$that_class = get_class($map[$key]);
throw new Exception(
pht(
'Two dashboard panels (of classes "%s" and "%s") have the '.
'same panel type key ("%s"). Each panel type must have a '.
'unique panel type key.',
$this_class,
$that_class,
$key));
}
$map[$key] = $object;
}
$types = $map;
}
return $types;
} }
} }

View file

@ -372,21 +372,9 @@ abstract class DrydockBlueprintImplementation extends Phobject {
public static function getAllBlueprintImplementations() { public static function getAllBlueprintImplementations() {
static $list = null; return id(new PhutilClassMapQuery())
if ($list === null) {
$blueprints = id(new PhutilSymbolLoader())
->setType('class')
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->setConcreteOnly(true) ->execute();
->selectAndLoadSymbols();
$list = ipull($blueprints, 'name', 'name');
foreach ($list as $class_name => $ignored) {
$list[$class_name] = newv($class_name, array());
}
}
return $list;
} }
public static function getAllBlueprintImplementationsForResource($type) { public static function getAllBlueprintImplementationsForResource($type) {

View file

@ -3,17 +3,9 @@
abstract class PhabricatorFactEngine extends Phobject { abstract class PhabricatorFactEngine extends Phobject {
final public static function loadAllEngines() { final public static function loadAllEngines() {
$classes = id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->setConcreteOnly(true) ->execute();
->selectAndLoadSymbols();
$objects = array();
foreach ($classes as $class) {
$objects[] = newv($class['name'], array());
}
return $objects;
} }
public function getFactSpecs(array $fact_types) { public function getFactSpecs(array $fact_types) {

View file

@ -224,36 +224,11 @@ abstract class PhabricatorFileStorageEngine extends Phobject {
* @task load * @task load
*/ */
public static function loadAllEngines() { public static function loadAllEngines() {
static $engines; return id(new PhutilClassMapQuery())
if ($engines === null) {
$objects = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getEngineIdentifier')
->setSortMethod('getEnginePriority')
$map = array(); ->execute();
foreach ($objects as $engine) {
$key = $engine->getEngineIdentifier();
if (empty($map[$key])) {
$map[$key] = $engine;
} else {
throw new Exception(
pht(
'Storage engines "%s" and "%s" have the same engine '.
'identifier "%s". Each storage engine must have a unique '.
'identifier.',
get_class($engine),
get_class($map[$key]),
$key));
}
}
$map = msort($map, 'getEnginePriority');
$engines = $map;
}
return $engines;
} }

View file

@ -28,33 +28,11 @@ abstract class PhabricatorFileTransform extends Phobject {
} }
public static function getAllTransforms() { public static function getAllTransforms() {
static $map; return id(new PhutilClassMapQuery())
if ($map === null) {
$xforms = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setExpandMethod('generateTransforms')
->setUniqueMethod('getTransformKey')
$result = array(); ->execute();
foreach ($xforms as $xform_template) {
foreach ($xform_template->generateTransforms() as $xform) {
$key = $xform->getTransformKey();
if (isset($result[$key])) {
throw new Exception(
pht(
'Two %s objects define the same transform key ("%s"), but '.
'each transform must have a unique key.',
__CLASS__,
$key));
}
$result[$key] = $xform;
}
}
$map = $result;
}
return $map;
} }
public static function getTransformByKey($key) { public static function getTransformByKey($key) {

View file

@ -10,35 +10,10 @@ abstract class HarbormasterBuildAutoplan extends Phobject {
} }
public static function getAllAutoplans() { public static function getAllAutoplans() {
static $plans; return id(new PhutilClassMapQuery())
if ($plans === null) {
$objects = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getAutoplanPlanKey')
->execute();
$map = array();
foreach ($objects as $object) {
$key = $object->getAutoplanPlanKey();
if (!empty($map[$key])) {
$other = $map[$key];
throw new Exception(
pht(
'Two build autoplans (of classes "%s" and "%s") define the same '.
'key ("%s"). Each autoplan must have a unique key.',
get_class($other),
get_class($object),
$key));
}
$map[$key] = $object;
}
ksort($map);
$plans = $map;
}
return $plans;
} }
} }

View file

@ -8,9 +8,9 @@ abstract class HarbormasterBuildStepImplementation extends Phobject {
private $settings; private $settings;
public static function getImplementations() { public static function getImplementations() {
return id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->execute();
} }
public static function getImplementation($class) { public static function getImplementation($class) {

View file

@ -1023,14 +1023,11 @@ abstract class HeraldAdapter extends Phobject {
} }
public static function getAllAdapters() { public static function getAllAdapters() {
static $adapters; return id(new PhutilClassMapQuery())
if (!$adapters) {
$adapters = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getAdapterContentType')
$adapters = msort($adapters, 'getAdapterSortKey'); ->setSortMethod('getAdapterSortKey')
} ->execute();
return $adapters;
} }
public static function getAdapterForContentType($content_type) { public static function getAdapterForContentType($content_type) {

View file

@ -3,19 +3,10 @@
abstract class ManiphestExcelFormat extends Phobject { abstract class ManiphestExcelFormat extends Phobject {
final public static function loadAllFormats() { final public static function loadAllFormats() {
$classes = id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->setConcreteOnly(true) ->setSortMethod('getOrder')
->selectAndLoadSymbols(); ->execute();
$objects = array();
foreach ($classes as $class) {
$objects[$class['name']] = newv($class['name'], array());
}
$objects = msort($objects, 'getOrder');
return $objects;
} }
abstract public function getName(); abstract public function getName();

View file

@ -47,27 +47,10 @@ abstract class PhabricatorApplicationConfigurationPanel
PhabricatorController $controller); PhabricatorController $controller);
public static function loadAllPanels() { public static function loadAllPanels() {
$objects = id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getPanelKey')
->execute();
$panels = array();
foreach ($objects as $object) {
$key = $object->getPanelKey();
if (empty($panels[$key])) {
$panels[$key] = $object;
} else {
throw new Exception(
pht(
'Application configuration panels "%s" and "%s" have the same '.
'panel key, "%s". Each panel must have a unique key.',
get_class($object),
get_class($panels[$key]),
$key));
}
}
return $panels;
} }
public static function loadAllPanelsForApplication( public static function loadAllPanelsForApplication(

View file

@ -60,21 +60,11 @@ abstract class MetaMTAEmailTransactionCommand extends Phobject {
} }
public static function getAllCommands() { public static function getAllCommands() {
static $commands; return id(new PhutilClassMapQuery())
if ($commands === null) {
$kinds = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setExpandMethod('getCommandObjects')
$commands = array(); ->setUniqueMethod('getCommand')
foreach ($kinds as $kind) { ->execute();
foreach ($kind->getCommandObjects() as $command) {
$commands[] = $command;
}
}
}
return $commands;
} }
public static function getAllCommandsForObject( public static function getAllCommandsForObject(

View file

@ -58,31 +58,10 @@ abstract class NuanceSourceDefinition extends Phobject {
} }
public static function getAllDefinitions() { public static function getAllDefinitions() {
static $definitions; return id(new PhutilClassMapQuery())
if ($definitions === null) {
$definitions = array();
$objects = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getSourceTypeConstant')
foreach ($objects as $definition) { ->execute();
$key = $definition->getSourceTypeConstant();
$name = $definition->getName();
if (isset($definitions[$key])) {
$conflict = $definitions[$key];
throw new Exception(
pht(
'Definition %s conflicts with definition %s. This is a '.
'programming error.',
$conflict,
$name));
}
$definitions[$key] = $definition;
}
}
return $definitions;
} }
/** /**

View file

@ -16,10 +16,10 @@ abstract class PassphraseCredentialType extends Phobject {
} }
public static function getAllTypes() { public static function getAllTypes() {
$types = id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getCredentialType')
return $types; ->execute();
} }
public static function getAllCreateableTypes() { public static function getAllCreateableTypes() {

View file

@ -159,37 +159,10 @@ abstract class PhabricatorPHIDType extends Phobject {
* @return dict<string, PhabricatorPHIDType> Map of type constants to types. * @return dict<string, PhabricatorPHIDType> Map of type constants to types.
*/ */
final public static function getAllTypes() { final public static function getAllTypes() {
static $types; return id(new PhutilClassMapQuery())
if ($types === null) {
$objects = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getTypeConstant')
->execute();
$map = array();
$original = array();
foreach ($objects as $object) {
$type = $object->getTypeConstant();
if (isset($map[$type])) {
$that_class = $original[$type];
$this_class = get_class($object);
throw new Exception(
pht(
"Two %s classes (%s, %s) both handle PHID type '%s'. ".
"A type may be handled by only one class.",
__CLASS__,
$that_class,
$this_class,
$type));
}
$original[$type] = get_class($object);
$map[$type] = $object;
}
$types = $map;
}
return $types;
} }

View file

@ -117,9 +117,9 @@ abstract class PhortunePaymentProvider extends Phobject {
public static function getAllProviders() { public static function getAllProviders() {
return id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->execute();
} }
public function isEnabled() { public function isEnabled() {

View file

@ -79,16 +79,10 @@ abstract class PhabricatorPolicyCapability extends Phobject {
} }
final public static function getCapabilityMap() { final public static function getCapabilityMap() {
static $map; return id(new PhutilClassMapQuery())
if ($map === null) {
$capabilities = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getCapabilityKey')
->execute();
$map = mpull($capabilities, null, 'getCapabilityKey');
}
return $map;
} }
} }

View file

@ -559,11 +559,9 @@ abstract class PhabricatorApplicationSearchEngine extends Phobject {
* @task construct * @task construct
*/ */
public static function getAllEngines() { public static function getAllEngines() {
$engines = id(new PhutilSymbolLoader()) return id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->execute();
return $engines;
} }

View file

@ -106,35 +106,11 @@ abstract class PhabricatorSearchEngine extends Phobject {
* @task load * @task load
*/ */
public static function loadAllEngines() { public static function loadAllEngines() {
static $engines; return id(new PhutilClassMapQuery())
if ($engines === null) {
$objects = id(new PhutilSymbolLoader())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getEngineIdentifier')
->setSortMethod('getEnginePriority')
$map = array(); ->execute();
foreach ($objects as $engine) {
$key = $engine->getEngineIdentifier();
if (empty($map[$key])) {
$map[$key] = $engine;
} else {
throw new Exception(
pht(
'Search engines "%s" and "%s" have the same engine identifier '.
'"%s". Each storage engine must have a unique identifier.',
get_class($engine),
get_class($map[$key]),
$key));
}
}
$map = msort($map, 'getEnginePriority');
$engines = $map;
}
return $engines;
} }
/** /**

View file

@ -156,39 +156,22 @@ abstract class PhabricatorEdgeType extends Phobject {
static $type_map; static $type_map;
if ($type_map === null) { if ($type_map === null) {
$types = id(new PhutilSymbolLoader()) $types = id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getEdgeConstant')
->execute();
$map = array();
foreach ($types as $class => $type) {
$const = $type->getEdgeConstant();
if (isset($map[$const])) {
throw new Exception(
pht(
'Two edge types ("%s", "%s") share the same edge constant '.
'(%d). Each edge type must have a unique constant.',
$class,
get_class($map[$const]),
$const));
}
$map[$const] = $type;
}
// Check that all the inverse edge definitions actually make sense. If // Check that all the inverse edge definitions actually make sense. If
// edge type A says B is its inverse, B must exist and say that A is its // edge type A says B is its inverse, B must exist and say that A is its
// inverse. // inverse.
foreach ($map as $const => $type) { foreach ($types as $const => $type) {
$inverse = $type->getInverseEdgeConstant(); $inverse = $type->getInverseEdgeConstant();
if ($inverse === null) { if ($inverse === null) {
continue; continue;
} }
if (empty($map[$inverse])) { if (empty($types[$inverse])) {
throw new Exception( throw new Exception(
pht( pht(
'Edge type "%s" ("%d") defines an inverse type ("%d") which '. 'Edge type "%s" ("%d") defines an inverse type ("%d") which '.
@ -198,7 +181,7 @@ abstract class PhabricatorEdgeType extends Phobject {
$inverse)); $inverse));
} }
$inverse_inverse = $map[$inverse]->getInverseEdgeConstant(); $inverse_inverse = $types[$inverse]->getInverseEdgeConstant();
if ($inverse_inverse !== $const) { if ($inverse_inverse !== $const) {
throw new Exception( throw new Exception(
pht( pht(
@ -212,7 +195,7 @@ abstract class PhabricatorEdgeType extends Phobject {
} }
} }
$type_map = $map; $type_map = $types;
} }
return $type_map; return $type_map;

View file

@ -212,11 +212,11 @@ abstract class PhabricatorPasswordHasher extends Phobject {
* @task hashing * @task hashing
*/ */
public static function getAllHashers() { public static function getAllHashers() {
$objects = id(new PhutilSymbolLoader()) $objects = id(new PhutilClassMapQuery())
->setAncestorClass(__CLASS__) ->setAncestorClass(__CLASS__)
->loadObjects(); ->setUniqueMethod('getHashName')
->execute();
$map = array();
foreach ($objects as $object) { foreach ($objects as $object) {
$name = $object->getHashName(); $name = $object->getHashName();
@ -233,20 +233,9 @@ abstract class PhabricatorPasswordHasher extends Phobject {
$maximum_length, $maximum_length,
$potential_length)); $potential_length));
} }
if (isset($map[$name])) {
throw new Exception(
pht(
'Two hashers use the same hash name ("%s"), "%s" and "%s". Each '.
'hasher must have a unique name.',
$name,
get_class($object),
get_class($map[$name])));
}
$map[$name] = $object;
} }
return $map; return $objects;
} }