Passed
Branch master (10fdc5)
by Beniamin
02:43
created

ContainerFactory::createQueryFactory()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 4
ccs 2
cts 2
cp 1
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 1
crap 1
1
<?php
2
3
/**
4
 * This file is part of Phuria SQL Builder package.
5
 *
6
 * Copyright (c) 2016 Beniamin Jonatan Šimko
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 Phuria\UnderQuery\DependencyInjection;
13
14
use Interop\Container\ContainerInterface;
15
use Phuria\UnderQuery\Connection\ConnectionManager;
16
use Phuria\UnderQuery\Parameter\ParameterCollection;
17
use Phuria\UnderQuery\Query\QueryFactory;
18
use Phuria\UnderQuery\QueryCompiler\ConcreteCompiler\DeleteCompiler;
19
use Phuria\UnderQuery\QueryCompiler\ConcreteCompiler\InsertCompiler;
20
use Phuria\UnderQuery\QueryCompiler\ConcreteCompiler\SelectCompiler;
21
use Phuria\UnderQuery\QueryCompiler\ConcreteCompiler\UpdateCompiler;
22
use Phuria\UnderQuery\QueryCompiler\QueryCompiler;
23
use Phuria\UnderQuery\Reference\ReferenceCollection;
24
use Phuria\UnderQuery\TableFactory\TableFactory;
25
use Phuria\UnderQuery\TableRegistry;
26
use Pimple\Container;
27
28
/**
29
 * @author Beniamin Jonatan Šimko <[email protected]>
30
 */
31
class ContainerFactory
32
{
33
    /**
34
     * @return ContainerInterface
35
     */
36 2
    public function create()
37
    {
38 2
        $pimple = new Container();
39 2
        $container = new PimpleContainer($pimple);
40
41 2
        $container->setParameter('phuria.sql_builder.parameter_collection.class', ParameterCollection::class);
42 2
        $container->setParameter('phuria.sql_builder.reference_collection.class', ReferenceCollection::class);
43
44 2
        $container->setServiceFromCallback('phuria.sql_builder.table_registry', [$this, 'createTableRegistry']);
45 2
        $container->setServiceFromCallback('phuria.sql_builder.table_factory', [$this, 'createTableFactory']);
46 2
        $container->setServiceFromCallback('phuria.sql_builder.query_compiler', [$this, 'createTableCompiler']);
47 2
        $container->setServiceFromCallback('phuria.sql_builder.connection_manager', [$this, 'createConnectionManager']);
48 2
        $container->setServiceFromCallback('phuria.sql_builder.query_factory', [$this, 'createQueryFactory']);
49
50 2
        return $container;
51
    }
52
53
    /**
54
     * @internal
55
     * @return TableRegistry
56
     */
57 1
    public function createTableRegistry()
58
    {
59 1
        return new TableRegistry();
60
    }
61
62
    /**
63
     * @internal
64
     * @param Container $container
65
     *
66
     * @return TableFactory
67
     */
68 1
    public function createTableFactory(Container $container)
69
    {
70 1
        return new TableFactory($container['phuria.sql_builder.table_registry']);
71
    }
72
73
    /**
74
     * @internal
75
     * @return QueryCompiler
76
     */
77 1
    public function createTableCompiler()
78
    {
79 1
        $queryCompiler = new QueryCompiler();
80 1
        $queryCompiler->addConcreteCompiler(new SelectCompiler());
81 1
        $queryCompiler->addConcreteCompiler(new InsertCompiler());
82 1
        $queryCompiler->addConcreteCompiler(new DeleteCompiler());
83 1
        $queryCompiler->addConcreteCompiler(new UpdateCompiler());
84
85 1
        return $queryCompiler;
86
    }
87
88
    /**
89
     * @internal
90
     * @return ConnectionManager
91
     */
92 1
    public function createConnectionManager()
93
    {
94 1
        return new ConnectionManager();
95
    }
96
97
    /**
98
     * @internal
99
     * @param Container $container
100
     *
101
     * @return QueryFactory
102
     */
103 1
    public function createQueryFactory(Container $container)
104
    {
105 1
        return new QueryFactory($container['phuria.sql_builder.connection_manager']);
106
    }
107
}