Completed
Push — master ( eb0cd0...7cc4c3 )
by Dmitry
03:19
created

Application::dispatch()   B

Complexity

Conditions 5
Paths 6

Size

Total Lines 16
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 7.1941

Importance

Changes 0
Metric Value
c 0
b 0
f 0
dl 0
loc 16
ccs 5
cts 9
cp 0.5556
rs 8.8571
cc 5
eloc 9
nc 6
nop 3
crap 7.1941
1
<?php
2
3
namespace Basis;
4
5
use League\Container\Container;
6
use League\Container\ReflectionContainer;
7
use Tarantool\Mapper\Mapper;
8
use Tarantool\Mapper\Plugin\Annotation;
9
use Tarantool\Mapper\Repository;
10
11
class Application extends Container
12
{
13 15
    public function __construct($root)
14
    {
15 15
        parent::__construct();
16
17 15
        $fs = new Filesystem($this, $root);
18
19 15
        $this->share(Application::class, $this);
20 15
        $this->share(Container::class, $this);
21 15
        $this->share(Filesystem::class, $fs);
22
23 15
        $this->addServiceProvider(Provider\CoreProvider::class);
24 15
        $this->addServiceProvider(Provider\ServiceProvider::class);
25 15
        $this->addServiceProvider(Provider\TarantoolProvider::class);
26
27 15
        foreach ($fs->listClasses('Provider') as $provider) {
28 15
            $this->addServiceProvider($provider);
29
        }
30
31 15
        $this->delegate(new ReflectionContainer());
32 15
    }
33
34 8
    public function dispatch($job, $params = [], $service = null)
35
    {
36 8
        if ($service) {
37
            if ($this->get(Service::class)->getName() == $service) {
38
                $service = null;
39
            }
40
        }
41
42 8
        $runner = $this->get(Runner::class);
43 8
        if (!$service && $runner->hasJob($job)) {
44 8
            return $runner->dispatch($job, $params);
45
        }
46
47
        $dispatcher = $this->get(Dispatcher::class);
48
        return $dispatcher->dispatch($job, $params, $service);
49
    }
50
51 15
    public function get($alias, array $args = [])
52
    {
53 15
        if (!$this->hasShared($alias, true) && is_subclass_of($alias, Repository::class)) {
0 ignored issues
show
Bug introduced by
Due to PHP Bug #53727, is_subclass_of might return inconsistent results on some PHP versions if \Tarantool\Mapper\Repository::class can be an interface. If so, you could instead use ReflectionClass::implementsInterface.
Loading history...
54 1
            $spaceName = $this->get(Mapper::class)
55 1
                ->getPlugin(Annotation::class)
56 1
                ->getRepositorySpaceName($alias);
57
58 1
            if ($spaceName) {
59 1
                $instance = $this->get(Mapper::class)->getRepository($spaceName);
60 1
                $this->share($alias, $instance);
61
            }
62
        }
63 15
        return parent::get($alias, $args);
64
    }
65
}
66