Url::ensureIsValidUrl()   A
last analyzed

Complexity

Conditions 2
Paths 2

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 6

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 2
c 1
b 0
f 0
nc 2
nop 1
dl 0
loc 4
ccs 0
cts 3
cp 0
crap 6
rs 10
1
<?php
2
/**
3
 * This file is part of Phiremock.
4
 *
5
 * Phiremock is free software: you can redistribute it and/or modify
6
 * it under the terms of the GNU Lesser General Public License as published by
7
 * the Free Software Foundation, either version 3 of the License, or
8
 * (at your option) any later version.
9
 *
10
 * Phiremock is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with Phiremock.  If not, see <http://www.gnu.org/licenses/>.
17
 */
18
19
namespace Mcustiel\Phiremock\Domain\Http;
20
21
class Url
22
{
23
    const URL_PATH_REGEX = '~^/(?:[^/?#]*)?(?:[^?#]*)(?:\?(?:[^#]*))?~';
24
25
    /** @var string * */
26
    private $url;
27
28
    public function __construct(string $url)
29
    {
30
        $this->ensureIsValidUrl($url);
31
        $this->url = $url;
32
    }
33
34
    public function asString(): string
35
    {
36
        return $this->url;
37
    }
38
39
    public function equals(self $other): bool
40
    {
41
        return $this->asString() === $other->asString();
42
    }
43
44
    private function ensureIsValidUrl(string $url)
45
    {
46
        if (!preg_match(self::URL_PATH_REGEX, $url)) {
47
            throw new \InvalidArgumentException(sprintf('Invalid http url: %s', var_export($url, true)));
48
        }
49
    }
50
}
51