ArrayParserTrait   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 20
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
wmc 3
lcom 0
cbo 0
dl 0
loc 20
ccs 4
cts 4
cp 1
rs 10
c 0
b 0
f 0

1 Method

Rating   Name   Duplication   Size   Complexity  
A parseArray() 0 12 3
1
<?php declare(strict_types=1);
2
3
namespace Limoncello\Passport\Adaptors\PostgreSql;
4
5
/**
6
 * Copyright 2015-2019 [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 function assert;
22
use function explode;
23
use function strlen;
24
use function substr;
25
26
/**
27
 * @package Limoncello\Passport
28
 */
29
trait ArrayParserTrait
30
{
31
    /**
32
     * @param string $values
33
     *
34
     * @return string[]
35
     */
36 3
    protected function parseArray(string $values): array
37
    {
38
        // PostgreSql arrays represented as strings
39
        // '{}' - empty array
40
        // '{scope1}' or '{scope1,scope2}' - non-empty array
41
        // so it should always start with '{' and end with '}'.
42 3
        assert(substr($values, 0, 1) === '{' && substr($values, -1) === '}');
43
44 3
        $parsed = strlen($values) === 2 ? [] : explode(',', substr($values, 1, -1));
45
46 3
        return $parsed;
47
    }
48
}
49