-
Notifications
You must be signed in to change notification settings - Fork 7
/
KPSSoapClient.php
415 lines (324 loc) · 35.8 KB
/
KPSSoapClient.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
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
<?php
/**
* KPSSOapCLient
*
* @copyright Copyright (c) Engin Aygen <[email protected]>
* @license http://opensource.org/licenses/gpl-license.php GNU General Public License, Version 3
* @version 1.0
*/
class KPSSoapClient extends SoapClient
{
/**
* XML Templates
*/
const STS_TEMPLATE = "PHM6RW52ZWxvcGUgeG1sbnM6cz0iaHR0cDovL3d3dy53My5vcmcvMjAwMy8wNS9zb2FwLWVudmVsb3BlIiB4bWxuczphPSJodHRwOi8vd3d3LnczLm9yZy8yMDA1LzA4L2FkZHJlc3NpbmciIHhtbG5zOnU9Imh0dHA6Ly9kb2NzLm9hc2lzLW9wZW4ub3JnL3dzcy8yMDA0LzAxL29hc2lzLTIwMDQwMS13c3Mtd3NzZWN1cml0eS11dGlsaXR5LTEuMC54c2QiPgogICAgPHM6SGVhZGVyPgogICAgICAgIDxhOkFjdGlvbiBzOm11c3RVbmRlcnN0YW5kPSIxIj5odHRwOi8vZG9jcy5vYXNpcy1vcGVuLm9yZy93cy1zeC93cy10cnVzdC8yMDA1MTIvUlNUL0lzc3VlPC9hOkFjdGlvbj4KICAgICAgICA8YTpNZXNzYWdlSUQ+PC9hOk1lc3NhZ2VJRD4KICAgICAgICA8YTpSZXBseVRvPgogICAgICAgICAgICA8YTpBZGRyZXNzPmh0dHA6Ly93d3cudzMub3JnLzIwMDUvMDgvYWRkcmVzc2luZy9hbm9ueW1vdXM8L2E6QWRkcmVzcz4KICAgICAgICA8L2E6UmVwbHlUbz4KICAgICAgICA8YTpUbyBzOm11c3RVbmRlcnN0YW5kPSIxIj48L2E6VG8+CiAgICAgICAgPG86U2VjdXJpdHkgczptdXN0VW5kZXJzdGFuZD0iMSIgeG1sbnM6bz0iaHR0cDovL2RvY3Mub2FzaXMtb3Blbi5vcmcvd3NzLzIwMDQvMDEvb2FzaXMtMjAwNDAxLXdzcy13c3NlY3VyaXR5LXNlY2V4dC0xLjAueHNkIj4KICAgICAgICAgICAgPHU6VGltZXN0YW1wIHU6SWQ9Il8xIj4KICAgICAgICAgICAgICAgIDx1OkNyZWF0ZWQ+PC91OkNyZWF0ZWQ+CiAgICAgICAgICAgICAgICA8dTpFeHBpcmVzPjwvdTpFeHBpcmVzPgogICAgICAgICAgICA8L3U6VGltZXN0YW1wPgogICAgICAgICAgICA8bzpVc2VybmFtZVRva2VuIHU6SWQ9Il8yIj4KICAgICAgICAgICAgICAgIDxvOlVzZXJuYW1lPjwvbzpVc2VybmFtZT4KICAgICAgICAgICAgICAgIDxvOlBhc3N3b3JkIFR5cGU9Imh0dHA6Ly9kb2NzLm9hc2lzLW9wZW4ub3JnL3dzcy8yMDA0LzAxL29hc2lzLTIwMDQwMS13c3MtdXNlcm5hbWUtdG9rZW4tcHJvZmlsZS0xLjAjUGFzc3dvcmRUZXh0Ij48L286UGFzc3dvcmQ+CiAgICAgICAgICAgIDwvbzpVc2VybmFtZVRva2VuPgogICAgICAgIDwvbzpTZWN1cml0eT4KICAgIDwvczpIZWFkZXI+CiAgICA8czpCb2R5PgogICAgICAgIDx0cnVzdDpSZXF1ZXN0U2VjdXJpdHlUb2tlbiB4bWxuczp0cnVzdD0iaHR0cDovL2RvY3Mub2FzaXMtb3Blbi5vcmcvd3Mtc3gvd3MtdHJ1c3QvMjAwNTEyIj4KICAgICAgICAgICAgPHdzcDpBcHBsaWVzVG8geG1sbnM6d3NwPSJodHRwOi8vc2NoZW1hcy54bWxzb2FwLm9yZy93cy8yMDA0LzA5L3BvbGljeSI+CiAgICAgICAgICAgICAgICA8YTpFbmRwb2ludFJlZmVyZW5jZT4KICAgICAgICAgICAgICAgICAgICA8YTpBZGRyZXNzPjwvYTpBZGRyZXNzPgogICAgICAgICAgICAgICAgPC9hOkVuZHBvaW50UmVmZXJlbmNlPgogICAgICAgICAgICA8L3dzcDpBcHBsaWVzVG8+CiAgICAgICAgICAgIDx0cnVzdDpSZXF1ZXN0VHlwZT5odHRwOi8vZG9jcy5vYXNpcy1vcGVuLm9yZy93cy1zeC93cy10cnVzdC8yMDA1MTIvSXNzdWU8L3RydXN0OlJlcXVlc3RUeXBlPgogICAgICAgIDwvdHJ1c3Q6UmVxdWVzdFNlY3VyaXR5VG9rZW4+CiAgICA8L3M6Qm9keT4KPC9zOkVudmVsb3BlPg==";
const KPS_TEMPLATE = "﻿
<s:Envelope xmlns:s="http://www.w3.org/2003/05/soap-envelope" xmlns:a="http://www.w3.org/2005/08/addressing" xmlns:u="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd">
    <s:Header>
        <a:Action s:mustUnderstand="1"></a:Action>
        <a:MessageID></a:MessageID>
        <a:ReplyTo>
            <a:Address>http://www.w3.org/2005/08/addressing/anonymous</a:Address>
        </a:ReplyTo>
        <a:To s:mustUnderstand="1"></a:To>
        <o:Security s:mustUnderstand="1" xmlns:o="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
            <u:Timestamp u:Id="_0">
                <u:Created></u:Created>
                <u:Expires></u:Expires>
            </u:Timestamp>
            <xenc:EncryptedData Type="http://www.w3.org/2001/04/xmlenc#Element" xmlns:xenc="http://www.w3.org/2001/04/xmlenc#">
                <xenc:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#aes256-cbc"/>
                <KeyInfo xmlns="http://www.w3.org/2000/09/xmldsig#">
                    <e:EncryptedKey xmlns:e="http://www.w3.org/2001/04/xmlenc#">
                        <e:EncryptionMethod Algorithm="http://www.w3.org/2001/04/xmlenc#rsa-oaep-mgf1p">
                            <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/>
                        </e:EncryptionMethod>
                        <KeyInfo>
                            <o:SecurityTokenReference>
                                <X509Data>
                                    <X509IssuerSerial>
                                        <X509IssuerName></X509IssuerName>
                                        <X509SerialNumber></X509SerialNumber>
                                    </X509IssuerSerial>
                                </X509Data>
                            </o:SecurityTokenReference>
                        </KeyInfo>
                        <e:CipherData>
                            <e:CipherValue></e:CipherValue>
                        </e:CipherData>
                    </e:EncryptedKey>
                </KeyInfo>
                <xenc:CipherData>
                    <xenc:CipherValue>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</xenc:CipherValue>
                </xenc:CipherData>
            </xenc:EncryptedData>
            <Signature xmlns="http://www.w3.org/2000/09/xmldsig#">
                <SignedInfo>
                    <CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
                    <SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#hmac-sha1"/>
                    <Reference URI="#_0">
                        <Transforms>
                            <Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/>
                        </Transforms>
                        <DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/>
                        <DigestValue>XD2Q/UIavQ4ZLOsiHKdba4YG0OQ=</DigestValue>
                    </Reference>
                </SignedInfo>
                <SignatureValue>l4TpFXhwwKBgFAjB11NfJ9nAwXU=</SignatureValue>
                <KeyInfo>
                    <o:SecurityTokenReference k:TokenType="http://docs.oasis-open.org/wss/oasis-wss-saml-token-profile-1.1#SAMLV1.1" xmlns:k="http://docs.oasis-open.org/wss/oasis-wss-wssecurity-secext-1.1.xsd">
                        <o:KeyIdentifier ValueType="http://docs.oasis-open.org/wss/oasis-wss-saml-token-profile-1.0#SAMLAssertionID">_c7fc78ef-0305-49cf-b680-24d520a11d81</o:KeyIdentifier>
                    </o:SecurityTokenReference>
                </KeyInfo>
            </Signature>
        </o:Security>
    </s:Header>
</s:Envelope>";
/**
* Namespaces
*/
const S11 = "http://schemas.xmlsoap.org/soap/envelope/";
const S12 = "http://www.w3.org/2003/05/soap-envelope";
const WSU = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd";
const WSSE = "http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd";
const WSSE11 = "http://docs.oasis-open.org/wss/oasis-wss-wsecurity-secext-1.1.xsd";
const WST = "http://docs.oasis-open.org/ws-sx/ws-trust/200512";
const DS = "http://www.w3.org/2000/09/xmldsig#";
const XENC = "http://www.w3.org/2001/04/xmlenc#";
const WSP = "http://schemas.xmlsoap.org/ws/2004/09/policy";
const WSA = "http://www.w3.org/2005/08/addressing";
const XS = "http://www.w3.org/2001/XMLSchema";
const WSDL = "http://schemas.xmlsoap.org/wsdl/";
const SP = "http://docs.oasis-open.org/ws-sx/ws-securitypolicy/200702";
/**
* Certificate
*/
protected $certificate;
/**
* STS Properties
*/
protected $stsHostName;
protected $stsEndpoint;
protected $stsUsername;
protected $stsPassword;
/**
* RSTR Properties
*/
protected $rstrKeySize;
protected $rstrCreated;
protected $rstrExpires;
protected $rstrKeyInfoX509IssuerName;
protected $rstrKeyInfoX509SerialNumber;
protected $rstrKeyInfoCipherValue;
protected $rstrCipherValue;
protected $rstrBinarySecret;
protected $rstrKeyIdentifier;
function __construct($username, $password, $wsdl, array $options = array())
{
date_default_timezone_set("Europe/Istanbul");
$this->setStsUsername($username);
$this->setStsPassword($password);
if (isset($options['local_cert']))
{
if (is_readable($options['local_cert']) === true)
{
$this->certificate = $options['local_cert'];
}
else {
throw new Exception("Could not load local certificate.");
}
}
$wsdlXml = @file_get_contents($wsdl);
if ($wsdlXml === false)
{
throw new Exception("Could not load WSDL.");
}
$wsdlDom = new DOMDocument("1.0", "utf-8");
$wsdlDom->preserveWhiteSpace = false;
$wsdlDom->loadXML($wsdlXml);
$wsdlXpath = new DOMXPath($wsdlDom);
$wsdlXpath->registerNamespace('WSDL', static::WSDL);
$wsdlXpath->registerNamespace('WSA', static::WSA);
$wsdlXpath->registerNamespace('WSP', static::WSP);
$wsdlXpath->registerNamespace('SP', static::SP);
$addressPath = $wsdlXpath->query("//WSDL:definitions/WSP:Policy/WSP:ExactlyOne/WSP:All/SP:EndorsingSupportingTokens/WSP:Policy/SP:IssuedToken/SP:Issuer/WSA:Address");
if ($addressPath->length === 0)
{
throw new Exception("WSDL has no policy.");
}
$address = $addressPath->item(0)->nodeValue;
$this->stsHostName = parse_url($address, PHP_URL_HOST);
$this->stsEndpoint = $address;
$wsdlData = sprintf("data://text/plain;base64,%s", base64_encode($wsdlXml));
parent::__construct($wsdlData, array_merge($options, array('soap_version' => SOAP_1_2)));
}
function __doRequest($request, $location, $action, $version, $oneWay = 0)
{
$this->stsRequest($location);
$kpsXml = base64_decode(static::KPS_TEMPLATE);
$kpsDom = new DOMDocument("1.0", "utf-8");
$kpsDom->preserveWhiteSpace = false;
$kpsDom->loadXML($kpsXml);
$kpsXpath = new DOMXPath($kpsDom);
$kpsXpath->registerNamespace('S12', static::S12);
$kpsXpath->registerNamespace('WSA', static::WSA);
$kpsXpath->registerNamespace('WSU', static::WSU);
$kpsXpath->registerNamespace('WSSE', static::WSSE);
$kpsXpath->registerNamespace('XENC', static::XENC);
$kpsXpath->registerNamespace('DS', static::DS);
// Addressing
$uuid = $this->uuid();
$actionPath = $kpsXpath->query("//S12:Envelope/S12:Header/WSA:Action");
$messageIDPath = $kpsXpath->query("//S12:Envelope/S12:Header/WSA:MessageID");
$toPath = $kpsXpath->query("//S12:Envelope/S12:Header/WSA:To");
$actionPath->item(0)->nodeValue = $action;
$messageIDPath->item(0)->nodeValue = sprintf("urn:uuid:%s", $uuid);
$toPath->item(0)->nodeValue = $location;
// Timestamp
$time = time();
$dateCreated = gmdate('Y-m-d\TH:i:s\Z', $time);
$dateExpires = gmdate('Y-m-d\TH:i:s\Z', $time + (5 * 60));
$timestampPath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/WSU:Timestamp");
$timestampDateCreatedPath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/WSU:Timestamp/WSU:Created");
$timestampDateExpiresPath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/WSU:Timestamp/WSU:Expires");
$timestampDateCreatedPath->item(0)->nodeValue = $dateCreated;
$timestampDateExpiresPath->item(0)->nodeValue = $dateExpires;
$timestampC14N = $timestampPath->item(0)->C14N(true, false);
// DigestValue
$digestValue = base64_encode(hash('sha1', $timestampC14N, true));
// Issuer
$keyInfoX509IssuerNamePath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/XENC:EncryptedData/DS:KeyInfo/XENC:EncryptedKey/DS:KeyInfo/WSSE:SecurityTokenReference/DS:X509Data/DS:X509IssuerSerial/DS:X509IssuerName");
$keyInfoX509SerialNumberPath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/XENC:EncryptedData/DS:KeyInfo/XENC:EncryptedKey/DS:KeyInfo/WSSE:SecurityTokenReference/DS:X509Data/DS:X509IssuerSerial/DS:X509SerialNumber");
$keyInfoCipherValuePath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/XENC:EncryptedData/DS:KeyInfo/XENC:EncryptedKey/XENC:CipherData/XENC:CipherValue");
$cipherValuePath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/XENC:EncryptedData/XENC:CipherData/XENC:CipherValue");
$keyInfoX509IssuerNamePath->item(0)->nodeValue = $this->rstrKeyInfoX509IssuerName;
$keyInfoX509SerialNumberPath->item(0)->nodeValue = $this->rstrKeyInfoX509SerialNumber;
$keyInfoCipherValuePath->item(0)->nodeValue = $this->rstrKeyInfoCipherValue;
$cipherValuePath->item(0)->nodeValue = $this->rstrCipherValue;
// DigestValue
$digestValuePath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/DS:Signature/DS:SignedInfo/DS:Reference/DS:DigestValue");
$digestValuePath->item(0)->nodeValue = $digestValue;
// Signature
$signaturePath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/DS:Signature/DS:SignedInfo");
$signatureValuePath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/DS:Signature/DS:SignatureValue");
$signatureC14N = $signaturePath->item(0)->C14N(true, false);
$signatureValue = base64_encode(hash_hmac("sha1", $signatureC14N, $this->rstrBinarySecret, true));
$signatureValuePath->item(0)->nodeValue = $signatureValue;
// SAML Assertion
$keyIdentifierPath = $kpsXpath->query("//S12:Envelope/S12:Header/WSSE:Security/DS:Signature/DS:KeyInfo/WSSE:SecurityTokenReference/WSSE:KeyIdentifier");
$keyIdentifierPath->item(0)->nodeValue = $this->rstrKeyIdentifier;
// Message
$domRequest = new DOMDocument("1.0", "utf-8");
$domRequest->preserveWhiteSpace = false;
$domRequest->loadXML($request);
$xpathRequest = new DOMXPath($domRequest);
$xpathRequest->registerNamespace('S12', static::S12);
$bodyPath = $xpathRequest->query("//S12:Envelope/S12:Body");
$bodyItem = $bodyPath->item(0);
$bodyElement = $kpsDom->importNode($bodyItem, true);
$kpsDom->documentElement->appendChild($bodyElement);
$kpsRequest = $kpsDom->saveXML();
return parent::__doRequest($kpsRequest, $location, $action, $version, $oneWay);
}
/**
* Set STS username
*
* @param string $username API user
*/
public function setStsUsername($username)
{
$this->stsUsername = $username;
}
/**
* Returns STS username
*
* @return string STS username
*/
public function getStsUsername()
{
return $this->stsUsername;
}
/**
* Set STS password
*
* @param string $password API password
*/
public function setStsPassword($password)
{
$this->stsPassword = $password;
}
/**
* Returns STS password
*
* @return string STS password
*/
public function getStsPassword()
{
return $this->stsPassword;
}
/**
* Returns STS endpoint
*
* @return string STS endpoint
*/
public function getStsEndpoint()
{
return $this->stsEndpoint;
}
/**
* Performs a STS request
*
* @param string $location Request location
*/
protected function stsRequest($location)
{
$rstXml = base64_decode(static::STS_TEMPLATE);
$rstDom = new DOMDocument("1.0", "utf-8");
$rstDom->preserveWhiteSpace = false;
$rstDom->loadXML($rstXml);
$rstXpath = new DOMXPath($rstDom);
$rstXpath->registerNamespace('S12', static::S12);
$rstXpath->registerNamespace('WSA', static::WSA);
$rstXpath->registerNamespace('WSU', static::WSU);
$rstXpath->registerNamespace('WSSE', static::WSSE);
$rstXpath->registerNamespace('XENC', static::XENC);
$rstXpath->registerNamespace('DS', static::DS);
$rstXpath->registerNamespace('WST', static::WST);
$rstXpath->registerNamespace('WSP', static::WSP);
// Addressing
$uuid = $this->uuid();
$messageIDPath = $rstXpath->query("//S12:Envelope/S12:Header/WSA:MessageID");
$toPath = $rstXpath->query("//S12:Envelope/S12:Header/WSA:To");
$messageIDPath->item(0)->nodeValue = sprintf("urn:uuid:%s", $uuid);
$toPath->item(0)->nodeValue = $this->stsEndpoint;
// Timestamp
$time = time();
$dateCreated = gmdate('Y-m-d\TH:i:s\Z', $time);
$dateExpires = gmdate('Y-m-d\TH:i:s\Z', $time + (10 * 60));
$timestampDateCreatedPath = $rstXpath->query("//S12:Envelope/S12:Header/WSSE:Security/WSU:Timestamp/WSU:Created");
$timestampDateExpiresPath = $rstXpath->query("//S12:Envelope/S12:Header/WSSE:Security/WSU:Timestamp/WSU:Expires");
$timestampDateCreatedPath->item(0)->nodeValue = $dateCreated;
$timestampDateExpiresPath->item(0)->nodeValue = $dateExpires;
// Credentials
$usernamePath = $rstXpath->query("//S12:Envelope/S12:Header/WSSE:Security/WSSE:UsernameToken/WSSE:Username");
$passwordPath = $rstXpath->query("//S12:Envelope/S12:Header/WSSE:Security/WSSE:UsernameToken/WSSE:Password");
$usernamePath->item(0)->nodeValue = $this->stsUsername;
$passwordPath->item(0)->nodeValue = $this->stsPassword;
// Endpoint
$addressPath = $rstXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityToken/WSP:AppliesTo/WSA:EndpointReference/WSA:Address");
$addressPath->item(0)->nodeValue = $location;
$stsRequest = $rstDom->saveXML();
// Request
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $this->stsEndpoint);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, true);
if (isset($this->certificate))
{
curl_setopt($ch, CURLOPT_CAINFO, $this->certificate);
}
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
"Host: " . $this->stsHostName,
"Content-Type: application/soap+xml; charset=utf-8",
"Content-Length: " . strlen($stsRequest),
));
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, $stsRequest);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
$stsResponse = curl_exec($ch);
if ($stsResponse === false)
{
throw new Exception(curl_error($ch));
}
curl_close($ch);
$rstrDom = new DOMDocument("1.0", "utf-8");
$rstrDom->preserveWhiteSpace = false;
$rstrDom->loadXML($stsResponse);
$rstrXpath = new DOMXPath($rstrDom);
$rstrXpath->registerNamespace('S12', static::S12);
$rstrXpath->registerNamespace('WSA', static::WSA);
$rstrXpath->registerNamespace('WSU', static::WSU);
$rstrXpath->registerNamespace('WSSE', static::WSSE);
$rstrXpath->registerNamespace('XENC', static::XENC);
$rstrXpath->registerNamespace('DS', static::DS);
$rstrXpath->registerNamespace('WST', static::WST);
$rstrXpath->registerNamespace('WSP', static::WSP);
$keySizePath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:KeySize");
$createdPath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:Lifetime/WSU:Created");
$expiresPath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:Lifetime/WSU:Expires");
$endpointPath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WSP:AppliesTo/WSA:EndpointReference/WSA:Address");
$keyInfoX509IssuerNamePath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:RequestedSecurityToken/XENC:EncryptedData/DS:KeyInfo/XENC:EncryptedKey/DS:KeyInfo/WSSE:SecurityTokenReference/DS:X509Data/DS:X509IssuerSerial/DS:X509IssuerName");
$keyInfoX509SerialNumberPath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:RequestedSecurityToken/XENC:EncryptedData/DS:KeyInfo/XENC:EncryptedKey/DS:KeyInfo/WSSE:SecurityTokenReference/DS:X509Data/DS:X509IssuerSerial/DS:X509SerialNumber");
$keyInfoCipherValuePath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:RequestedSecurityToken/XENC:EncryptedData/DS:KeyInfo/XENC:EncryptedKey/XENC:CipherData/XENC:CipherValue");
$cipherValuePath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:RequestedSecurityToken/XENC:EncryptedData/XENC:CipherData/XENC:CipherValue");
$binarySecretPath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:RequestedProofToken/WST:BinarySecret");
$keyIdentifierPath = $rstrXpath->query("//S12:Envelope/S12:Body/WST:RequestSecurityTokenResponseCollection/WST:RequestSecurityTokenResponse/WST:RequestedUnattachedReference/WSSE:SecurityTokenReference/WSSE:KeyIdentifier");
$this->rstrKeySize = $keySizePath->item(0)->nodeValue;
$this->rstrCreated = $createdPath->item(0)->nodeValue;
$this->rstrExpires = $expiresPath->item(0)->nodeValue;
$this->rstrEndpoint = $endpointPath->item(0)->nodeValue;
$this->rstrKeyInfoX509IssuerName = $keyInfoX509IssuerNamePath->item(0)->nodeValue;
$this->rstrKeyInfoX509SerialNumber = $keyInfoX509SerialNumberPath->item(0)->nodeValue;
$this->rstrKeyInfoCipherValue = $keyInfoCipherValuePath->item(0)->nodeValue;
$this->rstrCipherValue = $cipherValuePath->item(0)->nodeValue;
$this->rstrBinarySecret = base64_decode($binarySecretPath->item(0)->nodeValue);
$this->rstrKeyIdentifier = $keyIdentifierPath->item(0)->nodeValue;
}
/**
* Generates UUID
*
* @return string UUID
*/
protected function uuid()
{
return sprintf('%04x%04x-%04x-%04x-%04x-%04x%04x%04x', //
mt_rand(0, 0xffff), //
mt_rand(0, 0xffff), //
mt_rand(0, 0xffff), //
mt_rand(0, 0x0fff) | 0x4000, //
mt_rand(0, 0x3fff) | 0x8000, //
mt_rand(0, 0xffff), //
mt_rand(0, 0xffff), //
mt_rand(0, 0xffff) //
);
}
}