PDOAwareTrait   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 34
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 0

Test Coverage

Coverage 36.36%

Importance

Changes 0
Metric Value
wmc 4
lcom 1
cbo 0
dl 0
loc 34
ccs 4
cts 11
cp 0.3636
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A setPdo() 0 9 2
A getPdo() 0 8 2
1
<?php
2
declare(strict_types = 1);
3
/**
4
 * Contains trait PDOAwareTrait.
5
 *
6
 * PHP version 7.0+
7
 *
8
 * LICENSE:
9
 * This file is part of Yet Another Php Eve Api Library also know as Yapeal
10
 * which can be used to access the Eve Online API data and place it into a
11
 * database.
12
 * Copyright (C) 2016-2017 Michael Cummings
13
 *
14
 * This program is free software: you can redistribute it and/or modify it
15
 * under the terms of the GNU Lesser General Public License as published by the
16
 * Free Software Foundation, either version 3 of the License, or (at your
17
 * option) any later version.
18
 *
19
 * This program is distributed in the hope that it will be useful, but WITHOUT
20
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
21
 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
22
 * for more details.
23
 *
24
 * You should have received a copy of the GNU Lesser General Public License
25
 * along with this program. If not, see
26
 * <http://spdx.org/licenses/LGPL-3.0.html>.
27
 *
28
 * You should be able to find a copy of this license in the COPYING-LESSER.md
29
 * file. A copy of the GNU GPL should also be available in the COPYING.md file.
30
 *
31
 * @author    Michael Cummings <[email protected]>
32
 * @copyright 2016-2017 Michael Cummings
33
 * @license   LGPL-3.0+
34
 */
35
namespace Yapeal\Sql;
36
37
/**
38
 * Trait PDOAwareTrait.
39
 */
40
trait PDOAwareTrait
41
{
42
    /**
43
     * @param ConnectionInterface $value
0 ignored issues
show
Documentation introduced by
Should the type for parameter $value not be null|ConnectionInterface?

This check looks for @param annotations where the type inferred by our type inference engine differs from the declared type.

It makes a suggestion as to what type it considers more descriptive.

Most often this is a case of a parameter that can be null in addition to its declared types.

Loading history...
44
     *
45
     * @return static Fluent interface.
46
     * @throws \InvalidArgumentException
47
     */
48 3
    public function setPdo(ConnectionInterface $value = null)
49
    {
50 3
        if (!$value->isSql92Mode()) {
0 ignored issues
show
Bug introduced by
It seems like $value is not always an object, but can also be of type null. Maybe add an additional type check?

If a variable is not always an object, we recommend to add an additional type check to ensure your method call is safe:

function someFunction(A $objectMaybe = null)
{
    if ($objectMaybe instanceof A) {
        $objectMaybe->doSomething();
    }
}
Loading history...
51
            $mess = 'Connection must be already initialized for SQL-92 mode';
52
            throw new \InvalidArgumentException($mess);
53
        }
54 3
        $this->pdo = $value;
55 3
        return $this;
56
    }
57
    /**
58
     * @return ConnectionInterface
59
     * @throws \LogicException
60
     */
61
    protected function getPdo(): ConnectionInterface
62
    {
63
        if (null === $this->pdo) {
64
            $mess = 'Tried to use pdo before it was set';
65
            throw new \LogicException($mess, 1);
66
        }
67
        return $this->pdo;
68
    }
69
    /**
70
     * @var ConnectionInterface $pdo
71
     */
72
    private $pdo;
73
}
74