Scheme::createHttp()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
eloc 1
dl 0
loc 3
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 0
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\Client\Connection;
20
21
use InvalidArgumentException;
22
23
class Scheme
24
{
25
    public const HTTP = 'http';
26
    public const HTTPS = 'https';
27
28
    /** @var string */
29
    private $scheme;
30
31
    public function __construct(string $scheme)
32
    {
33
        $this->ensureIsValidScheme($scheme);
34
        $this->scheme = $scheme;
35
    }
36
37
    public static function createHttp(): Scheme
38
    {
39
        return new self(self::HTTP);
40
    }
41
42
    public static function createHttps(): Scheme
43
    {
44
        return new self(self::HTTPS);
45
    }
46
47
    public function asString(): string
48
    {
49
        return $this->scheme;
50
    }
51
52
    private function ensureIsValidScheme(string $scheme): void
53
    {
54
        if (preg_match('/^https?$/', $scheme) !== 1) {
55
            throw new InvalidArgumentException(sprintf('Invalid scheme %s', $scheme));
56
        }
57
    }
58
}
59