forked from acmephp/ssl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDistinguishedName.php
152 lines (131 loc) · 3.86 KB
/
DistinguishedName.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
<?php
/*
* This file is part of the Acme PHP project.
*
* (c) Titouan Galopin <galopintitouan@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace AcmePhp\Ssl;
use Webmozart\Assert\Assert;
/**
* Represent a Distinguished Name.
*
* @author Jérémy Derussé <jeremy@derusse.com>
*/
class DistinguishedName
{
/** @var string */
private $commonName;
/** @var string */
private $countryName;
/** @var string */
private $stateOrProvinceName;
/** @var string */
private $localityName;
/** @var string */
private $organizationName;
/** @var string */
private $organizationalUnitName;
/** @var string */
private $emailAddress;
/** @var array */
private $subjectAlternativeNames;
/**
* @param string $commonName
* @param string $countryName
* @param string $stateOrProvinceName
* @param string $localityName
* @param string $organizationName
* @param string $organizationalUnitName
* @param string $emailAddress
* @param array $subjectAlternativeNames
*/
public function __construct(
$commonName,
$countryName = null,
$stateOrProvinceName = null,
$localityName = null,
$organizationName = null,
$organizationalUnitName = null,
$emailAddress = null,
array $subjectAlternativeNames = []
) {
//Assert::stringNotEmpty($commonName, __CLASS__.'::$commonName expected a non empty string. Got: %s');
Assert::nullOrString($countryName, __CLASS__.'::$countryName expected a string. Got: %s');
Assert::nullOrString($stateOrProvinceName, __CLASS__.'::$stateOrProvinceName expected a string. Got: %s');
Assert::nullOrString($localityName, __CLASS__.'::$localityName expected a string. Got: %s');
Assert::nullOrString($organizationName, __CLASS__.'::$organizationName expected a string. Got: %s');
Assert::nullOrString($organizationalUnitName, __CLASS__.'::$organizationalUnitName expected a string. Got: %s');
Assert::nullOrString($emailAddress, __CLASS__.'::$emailAddress expected a string. Got: %s');
Assert::allStringNotEmpty(
$subjectAlternativeNames,
__CLASS__.'::$subjectAlternativeNames expected an array of non empty string. Got: %s'
);
$this->commonName = $commonName;
$this->countryName = $countryName;
$this->stateOrProvinceName = $stateOrProvinceName;
$this->localityName = $localityName;
$this->organizationName = $organizationName;
$this->organizationalUnitName = $organizationalUnitName;
$this->emailAddress = $emailAddress;
$this->subjectAlternativeNames = array_diff(array_unique($subjectAlternativeNames), [$commonName]);
}
/**
* @return string
*/
public function getCommonName()
{
return $this->commonName;
}
/**
* @return string
*/
public function getCountryName()
{
return $this->countryName;
}
/**
* @return string
*/
public function getStateOrProvinceName()
{
return $this->stateOrProvinceName;
}
/**
* @return string
*/
public function getLocalityName()
{
return $this->localityName;
}
/**
* @return string
*/
public function getOrganizationName()
{
return $this->organizationName;
}
/**
* @return string
*/
public function getOrganizationalUnitName()
{
return $this->organizationalUnitName;
}
/**
* @return string
*/
public function getEmailAddress()
{
return $this->emailAddress;
}
/**
* @return array
*/
public function getSubjectAlternativeNames()
{
return $this->subjectAlternativeNames;
}
}