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@12
|
12 use Zend\Feed\Reader\Exception\InvalidArgumentException;
|
Chris@12
|
13
|
Chris@0
|
14 class StandaloneExtensionManager implements ExtensionManagerInterface
|
Chris@0
|
15 {
|
Chris@0
|
16 private $extensions = [
|
Chris@12
|
17 'Atom\Entry' => Extension\Atom\Entry::class,
|
Chris@12
|
18 'Atom\Feed' => Extension\Atom\Feed::class,
|
Chris@12
|
19 'Content\Entry' => Extension\Content\Entry::class,
|
Chris@12
|
20 'CreativeCommons\Entry' => Extension\CreativeCommons\Entry::class,
|
Chris@12
|
21 'CreativeCommons\Feed' => Extension\CreativeCommons\Feed::class,
|
Chris@12
|
22 'DublinCore\Entry' => Extension\DublinCore\Entry::class,
|
Chris@12
|
23 'DublinCore\Feed' => Extension\DublinCore\Feed::class,
|
Chris@12
|
24 'Podcast\Entry' => Extension\Podcast\Entry::class,
|
Chris@12
|
25 'Podcast\Feed' => Extension\Podcast\Feed::class,
|
Chris@12
|
26 'Slash\Entry' => Extension\Slash\Entry::class,
|
Chris@12
|
27 'Syndication\Feed' => Extension\Syndication\Feed::class,
|
Chris@12
|
28 'Thread\Entry' => Extension\Thread\Entry::class,
|
Chris@12
|
29 'WellFormedWeb\Entry' => Extension\WellFormedWeb\Entry::class,
|
Chris@0
|
30 ];
|
Chris@0
|
31
|
Chris@0
|
32 /**
|
Chris@0
|
33 * Do we have the extension?
|
Chris@0
|
34 *
|
Chris@0
|
35 * @param string $extension
|
Chris@0
|
36 * @return bool
|
Chris@0
|
37 */
|
Chris@0
|
38 public function has($extension)
|
Chris@0
|
39 {
|
Chris@0
|
40 return array_key_exists($extension, $this->extensions);
|
Chris@0
|
41 }
|
Chris@0
|
42
|
Chris@0
|
43 /**
|
Chris@0
|
44 * Retrieve the extension
|
Chris@0
|
45 *
|
Chris@0
|
46 * @param string $extension
|
Chris@0
|
47 * @return Extension\AbstractEntry|Extension\AbstractFeed
|
Chris@0
|
48 */
|
Chris@0
|
49 public function get($extension)
|
Chris@0
|
50 {
|
Chris@0
|
51 $class = $this->extensions[$extension];
|
Chris@0
|
52 return new $class();
|
Chris@0
|
53 }
|
Chris@12
|
54
|
Chris@12
|
55 /**
|
Chris@12
|
56 * Add an extension.
|
Chris@12
|
57 *
|
Chris@12
|
58 * @param string $name
|
Chris@12
|
59 * @param string $class
|
Chris@12
|
60 */
|
Chris@12
|
61 public function add($name, $class)
|
Chris@12
|
62 {
|
Chris@12
|
63 if (is_string($class)
|
Chris@12
|
64 && (
|
Chris@12
|
65 is_a($class, Extension\AbstractEntry::class, true)
|
Chris@12
|
66 || is_a($class, Extension\AbstractFeed::class, true)
|
Chris@12
|
67 )
|
Chris@12
|
68 ) {
|
Chris@12
|
69 $this->extensions[$name] = $class;
|
Chris@12
|
70 return;
|
Chris@12
|
71 }
|
Chris@12
|
72
|
Chris@12
|
73 throw new InvalidArgumentException(sprintf(
|
Chris@12
|
74 'Plugin of type %s is invalid; must implement %2$s\Extension\AbstractFeed '
|
Chris@12
|
75 . 'or %2$s\Extension\AbstractEntry',
|
Chris@12
|
76 $class,
|
Chris@12
|
77 __NAMESPACE__
|
Chris@12
|
78 ));
|
Chris@12
|
79 }
|
Chris@12
|
80
|
Chris@12
|
81 /**
|
Chris@12
|
82 * Remove an extension.
|
Chris@12
|
83 *
|
Chris@12
|
84 * @param string $name
|
Chris@12
|
85 */
|
Chris@12
|
86 public function remove($name)
|
Chris@12
|
87 {
|
Chris@12
|
88 unset($this->extensions[$name]);
|
Chris@12
|
89 }
|
Chris@0
|
90 }
|