1 | <?php |
||
21 | trait ClassmapTrait |
||
22 | { |
||
23 | /** |
||
24 | * service objects stored by its classname |
||
25 | * |
||
26 | * @var object[] |
||
27 | */ |
||
28 | protected $classMap = []; |
||
29 | |||
30 | /** |
||
31 | * has service created by its classname/interface name already? |
||
32 | * returns the matching classname or NULL |
||
33 | * |
||
34 | * @param string $className |
||
35 | * @return string|NULL |
||
36 | */ |
||
37 | protected function hasClass(string $className): ?string |
||
38 | { |
||
39 | // not a classname |
||
40 | if (!\class_exists($className) && !\interface_exists($className)) { |
||
41 | return NULL; |
||
42 | } |
||
43 | |||
44 | // exact match found |
||
45 | if (isset($this->classMap[$className])) { |
||
46 | return $className; |
||
47 | } |
||
48 | |||
49 | // try subclass exists or not |
||
50 | $classes = array_keys($this->classMap); |
||
51 | foreach ($classes as $class) { |
||
52 | if (is_a($class, $className, TRUE)) { |
||
53 | return $class; |
||
54 | } |
||
55 | } |
||
56 | |||
57 | return NULL; |
||
58 | } |
||
59 | |||
60 | /** |
||
61 | * Retrieve object from classmap if match found |
||
62 | * |
||
63 | * @param string $className |
||
64 | * @return object|null |
||
65 | */ |
||
66 | protected function matchClass(string $className): ?object |
||
73 | |||
74 | /** |
||
75 | * Store object in classmap |
||
76 | * |
||
77 | * @param object $object |
||
78 | */ |
||
79 | protected function storeClass(object $object): void |
||
83 | } |