Chris@0
|
1 <?php
|
Chris@0
|
2 /**
|
Chris@0
|
3 * Zend Framework (http://framework.zend.com/)
|
Chris@0
|
4 *
|
Chris@0
|
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
|
Chris@0
|
6 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
|
Chris@0
|
7 * @license http://framework.zend.com/license/new-bsd New BSD License
|
Chris@0
|
8 */
|
Chris@0
|
9
|
Chris@0
|
10 namespace Zend\Feed\Reader;
|
Chris@0
|
11
|
Chris@0
|
12 use Zend\ServiceManager\AbstractPluginManager;
|
Chris@0
|
13 use Zend\ServiceManager\Exception\InvalidServiceException;
|
Chris@0
|
14 use Zend\ServiceManager\Factory\InvokableFactory;
|
Chris@0
|
15
|
Chris@0
|
16 /**
|
Chris@0
|
17 * Plugin manager implementation for feed reader extensions based on the
|
Chris@0
|
18 * AbstractPluginManager.
|
Chris@0
|
19 *
|
Chris@0
|
20 * Validation checks that we have an Extension\AbstractEntry or
|
Chris@0
|
21 * Extension\AbstractFeed.
|
Chris@0
|
22 */
|
Chris@12
|
23 class ExtensionPluginManager extends AbstractPluginManager implements ExtensionManagerInterface
|
Chris@0
|
24 {
|
Chris@0
|
25 /**
|
Chris@0
|
26 * Aliases for default set of extension classes
|
Chris@0
|
27 *
|
Chris@0
|
28 * @var array
|
Chris@0
|
29 */
|
Chris@0
|
30 protected $aliases = [
|
Chris@0
|
31 'atomentry' => Extension\Atom\Entry::class,
|
Chris@0
|
32 'atomEntry' => Extension\Atom\Entry::class,
|
Chris@0
|
33 'AtomEntry' => Extension\Atom\Entry::class,
|
Chris@12
|
34 'Atom\Entry' => Extension\Atom\Entry::class,
|
Chris@0
|
35 'atomfeed' => Extension\Atom\Feed::class,
|
Chris@0
|
36 'atomFeed' => Extension\Atom\Feed::class,
|
Chris@0
|
37 'AtomFeed' => Extension\Atom\Feed::class,
|
Chris@12
|
38 'Atom\Feed' => Extension\Atom\Feed::class,
|
Chris@0
|
39 'contententry' => Extension\Content\Entry::class,
|
Chris@0
|
40 'contentEntry' => Extension\Content\Entry::class,
|
Chris@0
|
41 'ContentEntry' => Extension\Content\Entry::class,
|
Chris@12
|
42 'Content\Entry' => Extension\Content\Entry::class,
|
Chris@0
|
43 'creativecommonsentry' => Extension\CreativeCommons\Entry::class,
|
Chris@0
|
44 'creativeCommonsEntry' => Extension\CreativeCommons\Entry::class,
|
Chris@0
|
45 'CreativeCommonsEntry' => Extension\CreativeCommons\Entry::class,
|
Chris@12
|
46 'CreativeCommons\Entry' => Extension\CreativeCommons\Entry::class,
|
Chris@0
|
47 'creativecommonsfeed' => Extension\CreativeCommons\Feed::class,
|
Chris@0
|
48 'creativeCommonsFeed' => Extension\CreativeCommons\Feed::class,
|
Chris@0
|
49 'CreativeCommonsFeed' => Extension\CreativeCommons\Feed::class,
|
Chris@12
|
50 'CreativeCommons\Feed' => Extension\CreativeCommons\Feed::class,
|
Chris@0
|
51 'dublincoreentry' => Extension\DublinCore\Entry::class,
|
Chris@0
|
52 'dublinCoreEntry' => Extension\DublinCore\Entry::class,
|
Chris@0
|
53 'DublinCoreEntry' => Extension\DublinCore\Entry::class,
|
Chris@12
|
54 'DublinCore\Entry' => Extension\DublinCore\Entry::class,
|
Chris@0
|
55 'dublincorefeed' => Extension\DublinCore\Feed::class,
|
Chris@0
|
56 'dublinCoreFeed' => Extension\DublinCore\Feed::class,
|
Chris@0
|
57 'DublinCoreFeed' => Extension\DublinCore\Feed::class,
|
Chris@12
|
58 'DublinCore\Feed' => Extension\DublinCore\Feed::class,
|
Chris@0
|
59 'podcastentry' => Extension\Podcast\Entry::class,
|
Chris@0
|
60 'podcastEntry' => Extension\Podcast\Entry::class,
|
Chris@0
|
61 'PodcastEntry' => Extension\Podcast\Entry::class,
|
Chris@12
|
62 'Podcast\Entry' => Extension\Podcast\Entry::class,
|
Chris@0
|
63 'podcastfeed' => Extension\Podcast\Feed::class,
|
Chris@0
|
64 'podcastFeed' => Extension\Podcast\Feed::class,
|
Chris@0
|
65 'PodcastFeed' => Extension\Podcast\Feed::class,
|
Chris@12
|
66 'Podcast\Feed' => Extension\Podcast\Feed::class,
|
Chris@0
|
67 'slashentry' => Extension\Slash\Entry::class,
|
Chris@0
|
68 'slashEntry' => Extension\Slash\Entry::class,
|
Chris@0
|
69 'SlashEntry' => Extension\Slash\Entry::class,
|
Chris@12
|
70 'Slash\Entry' => Extension\Slash\Entry::class,
|
Chris@0
|
71 'syndicationfeed' => Extension\Syndication\Feed::class,
|
Chris@0
|
72 'syndicationFeed' => Extension\Syndication\Feed::class,
|
Chris@0
|
73 'SyndicationFeed' => Extension\Syndication\Feed::class,
|
Chris@12
|
74 'Syndication\Feed' => Extension\Syndication\Feed::class,
|
Chris@0
|
75 'threadentry' => Extension\Thread\Entry::class,
|
Chris@0
|
76 'threadEntry' => Extension\Thread\Entry::class,
|
Chris@0
|
77 'ThreadEntry' => Extension\Thread\Entry::class,
|
Chris@12
|
78 'Thread\Entry' => Extension\Thread\Entry::class,
|
Chris@0
|
79 'wellformedwebentry' => Extension\WellFormedWeb\Entry::class,
|
Chris@0
|
80 'wellFormedWebEntry' => Extension\WellFormedWeb\Entry::class,
|
Chris@0
|
81 'WellFormedWebEntry' => Extension\WellFormedWeb\Entry::class,
|
Chris@12
|
82 'WellFormedWeb\Entry' => Extension\WellFormedWeb\Entry::class,
|
Chris@0
|
83 ];
|
Chris@0
|
84
|
Chris@0
|
85 /**
|
Chris@0
|
86 * Factories for default set of extension classes
|
Chris@0
|
87 *
|
Chris@0
|
88 * @var array
|
Chris@0
|
89 */
|
Chris@0
|
90 protected $factories = [
|
Chris@0
|
91 Extension\Atom\Entry::class => InvokableFactory::class,
|
Chris@0
|
92 Extension\Atom\Feed::class => InvokableFactory::class,
|
Chris@0
|
93 Extension\Content\Entry::class => InvokableFactory::class,
|
Chris@0
|
94 Extension\CreativeCommons\Entry::class => InvokableFactory::class,
|
Chris@0
|
95 Extension\CreativeCommons\Feed::class => InvokableFactory::class,
|
Chris@0
|
96 Extension\DublinCore\Entry::class => InvokableFactory::class,
|
Chris@0
|
97 Extension\DublinCore\Feed::class => InvokableFactory::class,
|
Chris@0
|
98 Extension\Podcast\Entry::class => InvokableFactory::class,
|
Chris@0
|
99 Extension\Podcast\Feed::class => InvokableFactory::class,
|
Chris@0
|
100 Extension\Slash\Entry::class => InvokableFactory::class,
|
Chris@0
|
101 Extension\Syndication\Feed::class => InvokableFactory::class,
|
Chris@0
|
102 Extension\Thread\Entry::class => InvokableFactory::class,
|
Chris@0
|
103 Extension\WellFormedWeb\Entry::class => InvokableFactory::class,
|
Chris@0
|
104 // Legacy (v2) due to alias resolution; canonical form of resolved
|
Chris@0
|
105 // alias is used to look up the factory, while the non-normalized
|
Chris@0
|
106 // resolved alias is used as the requested name passed to the factory.
|
Chris@0
|
107 'zendfeedreaderextensionatomentry' => InvokableFactory::class,
|
Chris@0
|
108 'zendfeedreaderextensionatomfeed' => InvokableFactory::class,
|
Chris@0
|
109 'zendfeedreaderextensioncontententry' => InvokableFactory::class,
|
Chris@0
|
110 'zendfeedreaderextensioncreativecommonsentry' => InvokableFactory::class,
|
Chris@0
|
111 'zendfeedreaderextensioncreativecommonsfeed' => InvokableFactory::class,
|
Chris@0
|
112 'zendfeedreaderextensiondublincoreentry' => InvokableFactory::class,
|
Chris@0
|
113 'zendfeedreaderextensiondublincorefeed' => InvokableFactory::class,
|
Chris@0
|
114 'zendfeedreaderextensionpodcastentry' => InvokableFactory::class,
|
Chris@0
|
115 'zendfeedreaderextensionpodcastfeed' => InvokableFactory::class,
|
Chris@0
|
116 'zendfeedreaderextensionslashentry' => InvokableFactory::class,
|
Chris@0
|
117 'zendfeedreaderextensionsyndicationfeed' => InvokableFactory::class,
|
Chris@0
|
118 'zendfeedreaderextensionthreadentry' => InvokableFactory::class,
|
Chris@0
|
119 'zendfeedreaderextensionwellformedwebentry' => InvokableFactory::class,
|
Chris@0
|
120 ];
|
Chris@0
|
121
|
Chris@0
|
122 /**
|
Chris@0
|
123 * Do not share instances (v2)
|
Chris@0
|
124 *
|
Chris@0
|
125 * @var bool
|
Chris@0
|
126 */
|
Chris@0
|
127 protected $shareByDefault = false;
|
Chris@0
|
128
|
Chris@0
|
129 /**
|
Chris@0
|
130 * Do not share instances (v3)
|
Chris@0
|
131 *
|
Chris@0
|
132 * @var bool
|
Chris@0
|
133 */
|
Chris@0
|
134 protected $sharedByDefault = false;
|
Chris@0
|
135
|
Chris@0
|
136 /**
|
Chris@0
|
137 * Validate the plugin
|
Chris@0
|
138 *
|
Chris@0
|
139 * Checks that the extension loaded is of a valid type.
|
Chris@0
|
140 *
|
Chris@0
|
141 * @param mixed $plugin
|
Chris@0
|
142 * @return void
|
Chris@0
|
143 * @throws Exception\InvalidArgumentException if invalid
|
Chris@0
|
144 */
|
Chris@0
|
145 public function validate($plugin)
|
Chris@0
|
146 {
|
Chris@0
|
147 if ($plugin instanceof Extension\AbstractEntry
|
Chris@0
|
148 || $plugin instanceof Extension\AbstractFeed
|
Chris@0
|
149 ) {
|
Chris@0
|
150 // we're okay
|
Chris@0
|
151 return;
|
Chris@0
|
152 }
|
Chris@0
|
153
|
Chris@0
|
154 throw new InvalidServiceException(sprintf(
|
Chris@0
|
155 'Plugin of type %s is invalid; must implement %s\Extension\AbstractFeed '
|
Chris@0
|
156 . 'or %s\Extension\AbstractEntry',
|
Chris@0
|
157 (is_object($plugin) ? get_class($plugin) : gettype($plugin)),
|
Chris@0
|
158 __NAMESPACE__,
|
Chris@0
|
159 __NAMESPACE__
|
Chris@0
|
160 ));
|
Chris@0
|
161 }
|
Chris@0
|
162
|
Chris@0
|
163 /**
|
Chris@0
|
164 * Validate the plugin (v2)
|
Chris@0
|
165 *
|
Chris@0
|
166 * @param mixed $plugin
|
Chris@0
|
167 * @return void
|
Chris@0
|
168 * @throws Exception\InvalidArgumentException if invalid
|
Chris@0
|
169 */
|
Chris@0
|
170 public function validatePlugin($plugin)
|
Chris@0
|
171 {
|
Chris@0
|
172 try {
|
Chris@0
|
173 $this->validate($plugin);
|
Chris@0
|
174 } catch (InvalidServiceException $e) {
|
Chris@0
|
175 throw new Exception\InvalidArgumentException(sprintf(
|
Chris@0
|
176 'Plugin of type %s is invalid; must implement %s\Extension\AbstractFeed '
|
Chris@0
|
177 . 'or %s\Extension\AbstractEntry',
|
Chris@0
|
178 (is_object($plugin) ? get_class($plugin) : gettype($plugin)),
|
Chris@0
|
179 __NAMESPACE__,
|
Chris@0
|
180 __NAMESPACE__
|
Chris@0
|
181 ));
|
Chris@0
|
182 }
|
Chris@0
|
183 }
|
Chris@0
|
184 }
|