Passed
Push — develop ( 4cc33e...7d04c7 )
by nguereza
02:48
created

FeaturePermissionPolicy::origins()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 15
Code Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 7
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 15
rs 10
1
<?php
2
3
/**
4
 * Platine Framework
5
 *
6
 * Platine Framework is a lightweight, high-performance, simple and elegant PHP
7
 * Web framework
8
 *
9
 * This content is released under the MIT License (MIT)
10
 *
11
 * Copyright (c) 2020 Platine Framework
12
 * Copyright (c) 2015 - 2023 Paragon Initiative Enterprises
13
 *
14
 * Permission is hereby granted, free of charge, to any person obtaining a copy
15
 * of this software and associated documentation files (the "Software"), to deal
16
 * in the Software without restriction, including without limitation the rights
17
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
18
 * copies of the Software, and to permit persons to whom the Software is
19
 * furnished to do so, subject to the following conditions:
20
 *
21
 * The above copyright notice and this permission notice shall be included in all
22
 * copies or substantial portions of the Software.
23
 *
24
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
25
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
26
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
27
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
28
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
29
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30
 * SOFTWARE.
31
 */
32
33
/**
34
 *  @file FeaturePermissionPolicy.php
35
 *
36
 *  The Feature Security Policy class
37
 *
38
 *  @package    Platine\Framework\Security\Policy
39
 *  @author Platine Developers team
40
 *  @copyright  Copyright (c) 2020
41
 *  @license    http://opensource.org/licenses/MIT  MIT License
42
 *  @link   https://www.platine-php.com
43
 *  @version 1.0.0
44
 *  @filesource
45
 */
46
47
declare(strict_types=1);
48
49
namespace Platine\Framework\Security\Policy;
50
51
/**
52
 * @class FeaturePermissionPolicy
53
 * @package Platine\Framework\Security\Policy
54
 */
55
class FeaturePermissionPolicy extends AbstractPolicy
56
{
57
    /**
58
     * {@inheritdoc}
59
     */
60
    public function headers(): string
61
    {
62
        $headers = [];
63
        foreach ($this->configurations as $name => $config) {
64
            if ($name === 'enable') {
65
                continue;
66
            }
67
68
            $value = $this->directive($config);
69
70
            $headers[] = sprintf('%s=%s', $name, $value);
71
        }
72
73
        return implode(', ', $headers);
74
    }
75
76
    /**
77
     * Parse specific policy value
78
     * @param array<string, mixed> $config
79
     * @return string
80
     */
81
    public function directive(array $config): string
82
    {
83
        if ($config['none'] ?? false) {
84
            return '()';
85
        } elseif ($config['*'] ?? false) {
86
            return '*';
87
        }
88
89
        $origins = $this->origins($config['origins'] ?? []);
90
        if ($config['self'] ?? false) {
91
            array_unshift($origins, 'self');
92
        }
93
94
        return sprintf('(%s)', implode(' ', $origins));
95
    }
96
97
    /**
98
     * Get valid origins
99
     * @param array<string> $config
100
     * @return array<string>
101
     */
102
    public function origins(array $origins): array
103
    {
104
        // prevent user leave spaces by mistake
105
        $cleanOrigins = array_map('trim', $origins);
106
107
        $filters = filter_var_array($cleanOrigins, FILTER_VALIDATE_URL);
108
109
        $values = array_filter($filters);
110
111
        // ensure indexes are numerically
112
        $urls = array_values($values);
113
114
        return array_map(function (string $url) {
115
            return sprintf('"%s"', $url);
116
        }, $urls);
117
    }
118
}
119