1 | <?php |
||
10 | final class LoaderManager |
||
11 | { |
||
12 | /** |
||
13 | * @var LoaderInterface[] |
||
14 | */ |
||
15 | private $loaders = []; |
||
16 | |||
17 | /** |
||
18 | * @var DecoderManager |
||
19 | 62 | */ |
|
20 | private $decoderManager = []; |
||
21 | 62 | ||
22 | 60 | /** |
|
23 | 60 | * @param LoaderInterface[] $loaders |
|
24 | 60 | */ |
|
25 | public function __construct(array $loaders = [], DecoderManager $decoderManager = null) |
||
26 | { |
||
27 | 2 | if (empty($loaders)) { |
|
28 | 2 | $this->registerDefaultFileLoader(); |
|
29 | 1 | $this->registerDefaultWebLoaders(); |
|
30 | 2 | } |
|
31 | |||
32 | if (empty($decoderManager)) { |
||
33 | $this->decoderManager = new DecoderManager(); |
||
34 | } |
||
35 | |||
36 | foreach ($loaders as $prefix => $loader) { |
||
37 | $this->registerLoader($prefix, $loader); |
||
38 | 14 | } |
|
39 | } |
||
40 | 14 | ||
41 | 14 | /** |
|
42 | * Register a LoaderInterface for the given prefix. |
||
43 | * |
||
44 | * @param string $prefix |
||
45 | * @param LoaderInterface $loader |
||
46 | */ |
||
47 | public function registerLoader($prefix, LoaderInterface $loader) |
||
48 | 10 | { |
|
49 | $this->loaders[$prefix] = $loader; |
||
50 | 10 | } |
|
51 | |||
52 | /** |
||
53 | * Get all registered loaders, keyed by the prefix they are registered to load schemas for. |
||
54 | * |
||
55 | * @return LoaderInterface[] |
||
56 | */ |
||
57 | public function getLoaders() |
||
58 | { |
||
59 | return $this->loaders; |
||
60 | } |
||
61 | 50 | ||
62 | /** |
||
63 | 50 | * Get the loader for the given prefix. |
|
64 | 2 | * |
|
65 | * @param string $prefix |
||
66 | * |
||
67 | 48 | * @return LoaderInterface |
|
68 | * @throws \InvalidArgumentException |
||
69 | */ |
||
70 | public function getLoader($prefix) |
||
71 | { |
||
72 | if (!$this->hasLoader($prefix)) { |
||
73 | throw new \InvalidArgumentException(sprintf('A loader is not registered for the prefix "%s"', $prefix)); |
||
74 | } |
||
75 | 52 | ||
76 | return $this->loaders[$prefix]; |
||
77 | 52 | } |
|
78 | |||
79 | /** |
||
80 | * @param string $prefix |
||
81 | * |
||
82 | * @return bool |
||
83 | 60 | */ |
|
84 | public function hasLoader($prefix) |
||
88 | |||
89 | /** |
||
90 | * Register the default file loader. |
||
91 | */ |
||
92 | private function registerDefaultFileLoader() |
||
96 | 60 | ||
97 | 60 | /** |
|
98 | 60 | * Register the default web loaders. If the curl extension is loaded, |
|
99 | 30 | * the CurlWebLoader will be used. Otherwise the FileGetContentsWebLoader |
|
100 | * will be used. You can override this by registering your own loader |
||
101 | * for the 'http' and 'https' protocols. |
||
102 | */ |
||
103 | 60 | private function registerDefaultWebLoaders() |
|
113 | |||
114 | /** |
||
115 | * @return DecoderManager |
||
116 | */ |
||
117 | public function getDecoderManager() |
||
121 | |||
122 | /** |
||
123 | * @param \League\JsonReference\DecoderManager $decoderManager |
||
124 | * |
||
125 | * @return \League\JsonReference\LoaderManager |
||
126 | */ |
||
127 | public function setDecoderManager(DecoderManager $decoderManager) |
||
133 | } |
||
134 |