Completed
Push — feature/ra-locations-model ( d07346 )
by A.
05:06
created

InstitutionConfigurationId::equals()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 2
Bugs 0 Features 0
Metric Value
c 2
b 0
f 0
dl 0
loc 4
rs 10
cc 1
eloc 2
nc 1
nop 1
1
<?php
2
3
/**
4
 * Copyright 2016 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 Surfnet\Stepup\Configuration\Value;
20
21
use Rhumsaa\Uuid\Uuid;
22
23
final class InstitutionConfigurationId
24
{
25
    const UUID_NAMESPACE = '09876543-abcd-0987-abcd-098765432109';
26
27
    private $institutionConfigurationId;
28
29
    /**
30
     * @param Institution $institution
31
     * @return InstitutionConfigurationId
32
     */
33
    public static function from(Institution $institution)
34
    {
35
        return new self(Uuid::uuid5(self::UUID_NAMESPACE, $institution->getInstitution()));
36
    }
37
38
    private function __construct($institutionConfigurationId)
39
    {
40
        $this->institutionConfigurationId = $institutionConfigurationId;
41
    }
42
43
    /**
44
     * @param InstitutionConfigurationId $otherInstitutionConfigurationId
45
     * @return bool
46
     */
47
    public function equals(InstitutionConfigurationId $otherInstitutionConfigurationId)
0 ignored issues
show
Comprehensibility Naming introduced by
The variable name $otherInstitutionConfigurationId exceeds the maximum configured length of 30.

Very long variable names usually make code harder to read. It is therefore recommended not to make variable names too verbose.

Loading history...
48
    {
49
        return $this->institutionConfigurationId === $otherInstitutionConfigurationId->institutionConfigurationId;
50
    }
51
52
    /**
53
     * @return string
54
     */
55
    public function getInstitutionConfigurationId()
56
    {
57
        return $this->institutionConfigurationId;
58
    }
59
60
    public function jsonSerialize()
61
    {
62
        return (string) $this;
63
    }
64
65
    public function __toString()
0 ignored issues
show
Documentation introduced by
The return type could not be reliably inferred; please add a @return annotation.

Our type inference engine in quite powerful, but sometimes the code does not provide enough clues to go by. In these cases we request you to add a @return annotation as described here.

Loading history...
66
    {
67
        return $this->institutionConfigurationId;
68
    }
69
}
70