UsernameAmbiguous   A
last analyzed

Complexity

Total Complexity 2

Size/Duplication

Total Lines 29
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
dl 0
loc 29
c 0
b 0
f 0
wmc 2
lcom 0
cbo 0
ccs 6
cts 6
cp 1
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 5 1
A getUsername() 0 4 1
1
<?php
2
declare(strict_types=1);
3
/**
4
 * Caridea
5
 *
6
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
7
 * use this file except in compliance with the License. You may obtain a copy of
8
 * 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, WITHOUT
14
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
15
 * License for the specific language governing permissions and limitations under
16
 * the License.
17
 *
18
 * @copyright 2015-2018 LibreWorks contributors
19
 * @license   Apache-2.0
20
 */
21
namespace Caridea\Auth\Exception;
22
23
/**
24
 * Exception for when a provided username matches multiple accounts.
25
 *
26
 * @copyright 2015-2018 LibreWorks contributors
27
 * @license   Apache-2.0
28
 */
29
class UsernameAmbiguous extends \UnexpectedValueException implements \Caridea\Auth\Exception
30
{
31
    /**
32
     * @var string The username
33
     */
34
    private $username;
35
    
36
    /**
37
     * Creates a new exception.
38
     *
39
     * @param string $username The ambiguous username
40
     * @param \Exception $previous Optional preceding exception
41
     */
42 2
    public function __construct(string $username, \Exception $previous = null)
43
    {
44 2
        parent::__construct("There are multiple accounts with the username: $username", 0, $previous);
45 2
        $this->username = $username;
46 2
    }
47
    
48
    /**
49
     * Gets the username.
50
     *
51
     * @return string The username
52
     */
53 1
    public function getUsername(): string
54
    {
55 1
        return $this->username;
56
    }
57
}
58