Passed
Push — develop ( b729b4...acdfb2 )
by nguereza
42:48
created

HttpException   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 86
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
wmc 6
eloc 13
dl 0
loc 86
rs 10
c 0
b 0
f 0

6 Methods

Rating   Name   Duplication   Size   Complexity  
A getRequest() 0 3 1
A __construct() 0 8 1
A setDescription() 0 5 1
A getDescription() 0 3 1
A setTitle() 0 5 1
A getTitle() 0 3 1
1
<?php
2
3
/**
4
 * Platine Framework
5
 *
6
 * Platine Framework is a lightweight, high-performance, simple and elegant
7
 * PHP Web framework
8
 *
9
 * This content is released under the MIT License (MIT)
10
 *
11
 * Copyright (c) 2020 Platine Framework
12
 *
13
 * Permission is hereby granted, free of charge, to any person obtaining a copy
14
 * of this software and associated documentation files (the "Software"), to deal
15
 * in the Software without restriction, including without limitation the rights
16
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
17
 * copies of the Software, and to permit persons to whom the Software is
18
 * furnished to do so, subject to the following conditions:
19
 *
20
 * The above copyright notice and this permission notice shall be included in all
21
 * copies or substantial portions of the Software.
22
 *
23
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
24
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
26
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
28
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
29
 * SOFTWARE.
30
 */
31
32
declare(strict_types=1);
33
34
namespace Platine\Framework\Http\Exception;
35
36
use Exception;
37
use Platine\Http\ServerRequestInterface;
38
use Throwable;
39
40
/**
41
 * HttpException
42
 * @package Platine\Framework\Http\Exception
43
 */
44
class HttpException extends Exception
45
{
46
    /**
47
     * The instance of server request that throw this exception
48
     * @var ServerRequestInterface
49
     */
50
    protected ServerRequestInterface $request;
51
52
    /**
53
     * The exception title
54
     * @var string
55
     */
56
    protected string $title = '';
57
58
    /**
59
     * The exception description
60
     * @var string
61
     */
62
    protected string $description = '';
63
64
    /**
65
     * Create new instance
66
     * @param ServerRequestInterface $request
67
     * @param string $message
68
     * @param int $code
69
     * @param Throwable|null $previous
70
     */
71
    public function __construct(
72
        ServerRequestInterface $request,
73
        string $message = '',
74
        int $code = 0,
75
        ?Throwable $previous = null
76
    ) {
77
        parent::__construct($message, $code, $previous);
78
        $this->request = $request;
79
    }
80
81
    /**
82
     * Return the server request
83
     * @return ServerRequestInterface
84
     */
85
    public function getRequest(): ServerRequestInterface
86
    {
87
        return $this->request;
88
    }
89
90
    /**
91
     * Return the title
92
     * @return string
93
     */
94
    public function getTitle(): string
95
    {
96
        return $this->title;
97
    }
98
99
    /**
100
     * Return the description
101
     * @return string
102
     */
103
    public function getDescription(): string
104
    {
105
        return $this->description;
106
    }
107
108
    /**
109
     *
110
     * @param string $title
111
     * @return $this
112
     */
113
    public function setTitle(string $title): self
114
    {
115
        $this->title = $title;
116
117
        return $this;
118
    }
119
120
    /**
121
     *
122
     * @param string $description
123
     * @return $this
124
     */
125
    public function setDescription(string $description): self
126
    {
127
        $this->description = $description;
128
129
        return $this;
130
    }
131
}
132