ParameterCollection   A
last analyzed

Complexity

Total Complexity 9

Size/Duplication

Total Lines 84
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 18
c 1
b 0
f 0
dl 0
loc 84
rs 10
wmc 9

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 11 3
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
use InvalidArgumentException;
52
53
/**
54
 * @class ParameterCollection
55
 * @package Platine\Route
56
 */
57
class ParameterCollection
58
{
59
    /**
60
     * The array of parameters
61
     * @var array<string, ParameterInterface>
62
     */
63
    protected array $parameters = [];
64
65
    /**
66
     * The array of all of the route parameters
67
     * @var ParameterInterface[]
68
     */
69
    protected array $all = [];
70
71
    /**
72
     * Create new collection of parameters
73
     *
74
     * @param ParameterInterface[] $parameters  the route parameters
75
     */
76
    public function __construct(array $parameters = [])
77
    {
78
        foreach ($parameters as $parameter) {
79
            if (!$parameter instanceof ParameterInterface) {
80
                throw new InvalidArgumentException(sprintf(
81
                    'The route parameter must be an instance of %s',
82
                    ParameterInterface::class
83
                ));
84
            }
85
86
            $this->add($parameter);
87
        }
88
    }
89
90
    /**
91
     * Add new parameter to the collection
92
     * @param ParameterInterface $parameter
93
     */
94
    public function add(ParameterInterface $parameter): ParameterInterface
95
    {
96
        $this->all[] = $parameter;
97
        return $this->parameters[$parameter->getName()] = $parameter;
98
    }
99
100
    /**
101
     * Return all array of route parameters
102
     * @return ParameterInterface[] the collection of parameters
103
     */
104
    public function all(): array
105
    {
106
        return $this->all;
107
    }
108
109
    /**
110
     * Check whether the collection contains the parameter for the
111
     * given name
112
     * @param  string  $name the name of the parameter
113
     * @return bool
114
     */
115
    public function has(string $name): bool
116
    {
117
        return array_key_exists($name, $this->parameters);
118
    }
119
120
    /**
121
     * Get the route parameter for the given name from the collection
122
     * @param  string  $name the name of the parameter
123
     * @return ParameterInterface
124
     */
125
    public function get(string $name): ?ParameterInterface
126
    {
127
        return array_key_exists($name, $this->parameters)
128
                ? $this->parameters[$name]
129
                : null;
130
    }
131
132
    /**
133
     * Delete from collection the route parameter for the given name
134
     * @param  string  $name the name of the parameter
135
     * @return ParameterCollection
136
     */
137
    public function delete(string $name): self
138
    {
139
        unset($this->parameters[$name]);
140
        return $this;
141
    }
142
}
143