AssertionFailedException   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 48
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 1

Importance

Changes 0
Metric Value
wmc 4
lcom 0
cbo 1
dl 0
loc 48
rs 10
c 0
b 0
f 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 7 1
A getPropertyPath() 0 4 1
A getValue() 0 4 1
A getConstraints() 0 4 1
1
<?php
2
3
/**
4
 * Copyright 2015 SURFnet B.V.
5
 *
6
 * Licensed under the Apache License, Version 2.0 (the "License");
7
 * you may not use this file except in compliance with the License.
8
 * You may obtain a copy of the License at
9
 *
10
 *     http://www.apache.org/licenses/LICENSE-2.0
11
 *
12
 * Unless required by applicable law or agreed to in writing, software
13
 * distributed under the License is distributed on an "AS IS" BASIS,
14
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
 * See the License for the specific language governing permissions and
16
 * limitations under the License.
17
 */
18
19
namespace OpenConext\Profile\Exception;
20
21
use Assert\AssertionFailedException as AssertAssertionFailedException;
22
23
class AssertionFailedException extends InvalidArgumentException implements AssertAssertionFailedException
24
{
25
    private $propertyPath;
26
    private $value;
27
    private $constraints;
28
29
    // @codingStandardsIgnoreStart
30
    public function __construct($message, $code, $propertyPath = null, $value, array $constraints = array())
31
    {
32
        parent::__construct($message, $code);
33
        $this->propertyPath = $propertyPath;
34
        $this->value        = $value;
35
        $this->constraints  = $constraints;
36
    }
37
    // @codingStandardsIgnoreEnd
38
    /**
39
     * User controlled way to define a sub-property causing
40
     * the failure of a currently asserted objects.
41
     *
42
     * Useful to transport information about the nature of the error
43
     * back to higher layers.
44
     *
45
     * @return string
46
     */
47
    public function getPropertyPath()
48
    {
49
        return $this->propertyPath;
50
    }
51
52
    /**
53
     * Get the value that caused the assertion to fail.
54
     *
55
     * @return mixed
56
     */
57
    public function getValue()
58
    {
59
        return $this->value;
60
    }
61
    /**
62
     * Get the constraints that applied to the failed assertion.
63
     *
64
     * @return array
65
     */
66
    public function getConstraints()
67
    {
68
        return $this->constraints;
69
    }
70
}
71