Loader::initializePlugin()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 12
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
eloc 7
nc 2
nop 2
dl 0
loc 12
rs 9.4285
c 0
b 0
f 0
1
<?php
2
3
/*
4
 * This file is part of Jitamin.
5
 *
6
 * Copyright (C) Jitamin Team
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace Jitamin\Foundation\Plugin;
13
14
use Composer\Autoload\ClassLoader;
15
use DirectoryIterator;
16
use Jitamin\Foundation\Tool;
17
use LogicException;
18
19
/**
20
 * Plugin Loader.
21
 */
22
class Loader extends \Jitamin\Foundation\Base
23
{
24
    /**
25
     * Plugin instances.
26
     *
27
     * @var array
28
     */
29
    protected $plugins = [];
30
31
    /**
32
     * Get list of loaded plugins.
33
     *
34
     * @return Base[]
35
     */
36
    public function getPlugins()
37
    {
38
        return $this->plugins;
39
    }
40
41
    /**
42
     * Scan plugin folder and load plugins.
43
     */
44
    public function scan()
45
    {
46
        if (file_exists(PLUGINS_DIR)) {
47
            $loader = new ClassLoader();
48
            $loader->addPsr4('Jitamin\Plugin\\', PLUGINS_DIR);
49
            $loader->register();
50
51
            $dir = new DirectoryIterator(PLUGINS_DIR);
52
53
            foreach ($dir as $fileInfo) {
54
                if ($fileInfo->isDir() && substr($fileInfo->getFilename(), 0, 1) !== '.') {
55
                    $pluginName = $fileInfo->getFilename();
56
                    $this->loadSchema($pluginName);
57
                    $this->initializePlugin($pluginName, $this->loadPlugin($pluginName));
58
                }
59
            }
60
        }
61
    }
62
63
    /**
64
     * Load plugin schema.
65
     *
66
     * @param string $pluginName
67
     */
68
    public function loadSchema($pluginName)
69
    {
70
        if (SchemaHandler::hasSchema($pluginName)) {
71
            $schemaHandler = new SchemaHandler($this->container);
72
            $schemaHandler->loadSchema($pluginName);
73
        }
74
    }
75
76
    /**
77
     * Load plugin.
78
     *
79
     * @param string $pluginName
80
     *
81
     * @throws LogicException
82
     *
83
     * @return Base
84
     */
85
    public function loadPlugin($pluginName)
86
    {
87
        $className = '\Jitamin\Plugin\\'.$pluginName.'\\Plugin';
88
89
        if (!class_exists($className)) {
90
            throw new LogicException('Unable to load this plugin class '.$className);
91
        }
92
93
        return new $className($this->container);
94
    }
95
96
    /**
97
     * Initialize plugin.
98
     *
99
     * @param string $pluginName
100
     * @param Base   $plugin
101
     */
102
    public function initializePlugin($pluginName, Base $plugin)
103
    {
104
        if (method_exists($plugin, 'onStartup')) {
105
            $this->dispatcher->addListener('app.bootstrap', [$plugin, 'onStartup']);
0 ignored issues
show
Documentation introduced by
The property dispatcher does not exist on object<Jitamin\Foundation\Plugin\Loader>. Since you implemented __get, maybe consider adding a @property annotation.

Since your code implements the magic getter _get, this function will be called for any read access on an undefined variable. You can add the @property annotation to your class or interface to document the existence of this variable.

<?php

/**
 * @property int $x
 * @property int $y
 * @property string $text
 */
class MyLabel
{
    private $properties;

    private $allowedProperties = array('x', 'y', 'text');

    public function __get($name)
    {
        if (isset($properties[$name]) && in_array($name, $this->allowedProperties)) {
            return $properties[$name];
        } else {
            return null;
        }
    }

    public function __set($name, $value)
    {
        if (in_array($name, $this->allowedProperties)) {
            $properties[$name] = $value;
        } else {
            throw new \LogicException("Property $name is not defined.");
        }
    }

}

If the property has read access only, you can use the @property-read annotation instead.

Of course, you may also just have mistyped another name, in which case you should fix the error.

See also the PhpDoc documentation for @property.

Loading history...
106
        }
107
108
        Tool::buildDIC($this->container, $plugin->getClasses());
109
        Tool::buildDICHelpers($this->container, $plugin->getHelpers());
110
111
        $plugin->initialize();
112
        $this->plugins[$pluginName] = $plugin;
113
    }
114
}
115