PdoSettings   A
last analyzed

Complexity

Total Complexity 2

Size/Duplication

Total Lines 27
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
wmc 2
lcom 0
cbo 0
dl 0
loc 27
ccs 7
cts 7
cp 1
rs 10
c 0
b 0
f 0

2 Methods

Rating   Name   Duplication   Size   Complexity  
A get() 0 9 1
A getSettings() 0 8 1
1
<?php declare(strict_types=1);
2
3
namespace Limoncello\Application\Packages\PDO;
4
5
/**
6
 * Copyright 2015-2020 [email protected]
7
 *
8
 * Licensed under the Apache License, Version 2.0 (the "License");
9
 * you may not use this file except in compliance with the License.
10
 * You may obtain a copy of the License at
11
 *
12
 * http://www.apache.org/licenses/LICENSE-2.0
13
 *
14
 * Unless required by applicable law or agreed to in writing, software
15
 * distributed under the License is distributed on an "AS IS" BASIS,
16
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
 * See the License for the specific language governing permissions and
18
 * limitations under the License.
19
 */
20
21
use Limoncello\Contracts\Settings\Packages\PdoSettingsInterface;
22
use PDO;
23
use function assert;
24
25
/**
26
 * @package Limoncello\Application
27
 */
28
class PdoSettings implements PdoSettingsInterface
29
{
30 1
    /**
31
     * @inheritdoc
32 1
     */
33
    final public function get(array $appConfig): array
34 1
    {
35 1
        $defaults = $this->getSettings();
36
37 1
        $connectionString = $defaults[static::KEY_CONNECTION_STRING] ?? null;
38
        assert(empty($connectionString) === false, "Invalid connection string `$connectionString`.");
39
40
        return $defaults;
41
    }
42
43 1
    /**
44
     * @return array
45
     */
46 1
    protected function getSettings(): array
47
    {
48
        return [
49
            static::KEY_OPTIONS => [
50
                PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
51
            ],
52
        ];
53
    }
54
}
55