annotate vendor/zendframework/zend-feed/src/Reader/ExtensionPluginManager.php @ 12:7a779792577d

Update Drupal core to v8.4.5 (via Composer)
author Chris Cannam
date Fri, 23 Feb 2018 15:52:07 +0000
parents 4c8ae668cc8c
children c2387f117808
rev   line source
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 }