ParameterCollection   A
last analyzed

Complexity

Total Complexity 8

Size/Duplication

Total Lines 77
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 14
c 1
b 0
f 0
dl 0
loc 77
rs 10
wmc 8

6 Methods

Rating   Name   Duplication   Size   Complexity  
A add() 0 4 1
A get() 0 5 2
A delete() 0 4 1
A has() 0 3 1
A all() 0 3 1
A __construct() 0 4 2
1
<?php
2
3
/**
4
 * Platine Router
5
 *
6
 * Platine Router is the a lightweight and simple router using middleware
7
 *  to match and dispatch the request.
8
 *
9
 * This content is released under the MIT License (MIT)
10
 *
11
 * Copyright (c) 2020 Platine Router
12
 * Copyright (c) 2020 Evgeniy Zyubin
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 ParameterCollection.php
35
 *
36
 *  This class represent the collection of matched route parameters
37
 *
38
 *  @package    Platine\Route
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\Route;
50
51
/**
52
 * @class ParameterCollection
53
 * @package Platine\Route
54
 */
55
class ParameterCollection
56
{
57
    /**
58
     * The array of parameters
59
     * @var array<string, ParameterInterface>
60
     */
61
    protected array $parameters = [];
62
63
    /**
64
     * The array of all of the route parameters
65
     * @var ParameterInterface[]
66
     */
67
    protected array $all = [];
68
69
    /**
70
     * Create new collection of parameters
71
     *
72
     * @param ParameterInterface[] $parameters  the route parameters
73
     */
74
    public function __construct(array $parameters = [])
75
    {
76
        foreach ($parameters as $parameter) {
77
            $this->add($parameter);
78
        }
79
    }
80
81
    /**
82
     * Add new parameter to the collection
83
     * @param ParameterInterface $parameter
84
     */
85
    public function add(ParameterInterface $parameter): ParameterInterface
86
    {
87
        $this->all[] = $parameter;
88
        return $this->parameters[$parameter->getName()] = $parameter;
89
    }
90
91
    /**
92
     * Return all array of route parameters
93
     * @return ParameterInterface[] the collection of parameters
94
     */
95
    public function all(): array
96
    {
97
        return $this->all;
98
    }
99
100
    /**
101
     * Check whether the collection contains the parameter for the
102
     * given name
103
     * @param  string  $name the name of the parameter
104
     * @return bool
105
     */
106
    public function has(string $name): bool
107
    {
108
        return array_key_exists($name, $this->parameters);
109
    }
110
111
    /**
112
     * Get the route parameter for the given name from the collection
113
     * @param  string  $name the name of the parameter
114
     * @return ParameterInterface
115
     */
116
    public function get(string $name): ?ParameterInterface
117
    {
118
        return array_key_exists($name, $this->parameters)
119
                ? $this->parameters[$name]
120
                : null;
121
    }
122
123
    /**
124
     * Delete from collection the route parameter for the given name
125
     * @param  string  $name the name of the parameter
126
     * @return ParameterCollection
127
     */
128
    public function delete(string $name): self
129
    {
130
        unset($this->parameters[$name]);
131
        return $this;
132
    }
133
}
134