|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
namespace Bunq\Test\Middleware; |
|
4
|
|
|
|
|
5
|
|
|
use Bunq\Certificate\DefaultCertificate; |
|
6
|
|
|
use Bunq\Middleware\RequestSignatureMiddleware; |
|
7
|
|
|
use GuzzleHttp\Psr7\Request; |
|
8
|
|
|
use PHPUnit\Framework\TestCase; |
|
9
|
|
|
|
|
10
|
|
|
final class RequestSignatureMiddlewareTest extends TestCase |
|
11
|
|
|
{ |
|
12
|
|
|
/** |
|
13
|
|
|
* @var RequestSignatureMiddleware |
|
14
|
|
|
*/ |
|
15
|
|
|
private $middleware; |
|
16
|
|
|
|
|
17
|
|
|
public function setUp() |
|
18
|
|
|
{ |
|
19
|
|
|
$privKey = '-----BEGIN PRIVATE KEY----- |
|
20
|
|
|
MIICdgIBADANBgkqhkiG9w0BAQEFAASCAmAwggJcAgEAAoGBAMFTIP07VOb/jeax |
|
21
|
|
|
cScI/Mnp9wv0Q03kTCCPcaPoOI0nXM8jMJyu4JuLcLX8OnITJhsrNj2ff3lwDsc6 |
|
22
|
|
|
KgejUbcGMJp6xPgALXdkztOPEWNYxCIyb9Pj8KctwUlu679pD6WoD60JMh88lL2o |
|
23
|
|
|
A8VWJkLShBHaA0yqEWHfiPBGfnCfAgMBAAECgYAZzuwvgjUyZVlfO778VBHTLr3B |
|
24
|
|
|
RcmaY2jaS+wC0qSCC4gzSuJZeGsZuMLCOLrgsbe7lsg1784HuzLt29DylhX5WpN3 |
|
25
|
|
|
7oJ7j6/GxElrgx4945N7syqMgrSfu+B8MiemFJqWrMNv5WXSIG/bA+O/nS1bGhLb |
|
26
|
|
|
MkmCtGYca2XL674v0QJBAOdppnzV11n2pG8D7J2dwPRCOFhHQnfU6vkamY+RUETN |
|
27
|
|
|
+jEIRO3GLp59S52Lb/W1FWdr+CIurynJnSvHary+1ncCQQDV3X+BrpOq09KT8Kdu |
|
28
|
|
|
oqBhA7vz5oHgph/aK9lu0mytJZJR5OOmVFcygFTCNBzRgWiog1yLeu6dIvbH/3Tu |
|
29
|
|
|
fTkZAkA0y73YLVF8jPDnAxYwv5UOJS2FtnxLqqARRShTwOt3RycVmLVhKh3out1N |
|
30
|
|
|
jEp23GGNvuxVoCEGf6EEI/MOLNvxAkBMnybnl1xgf7OaPUY/ZRSArY3RPGybx+jx |
|
31
|
|
|
iXRFOC6neiaKIK9PEDiNZ1z2lyUcCnkspqOpdUm4EqbH0MZcC5FBAkEA5Y1FKMSq |
|
32
|
|
|
VfRE5LPsqFeT4lPFUX8EP20ucM86v1KtG4ywZxLOLOZ80e0V9SxZN17VDBwh5tVd |
|
33
|
|
|
BxZd7SRnxYD9TQ== |
|
34
|
|
|
-----END PRIVATE KEY-----'; |
|
35
|
|
|
|
|
36
|
|
|
$certificate = DefaultCertificate::fromString($privKey); |
|
37
|
|
|
$this->middleware = new RequestSignatureMiddleware($certificate); |
|
38
|
|
|
} |
|
39
|
|
|
|
|
40
|
|
|
/** |
|
41
|
|
|
* @test |
|
42
|
|
|
*/ |
|
43
|
|
|
public function itSignsARequest() |
|
44
|
|
|
{ |
|
45
|
|
|
$headers = [ |
|
46
|
|
|
'X-Bunq-Client-Request-Id' => '253e0f90-8842-4731-91dd-0191816e6a28', |
|
47
|
|
|
'X-Bunq-Client-Authentication' => 'session-token', |
|
48
|
|
|
'Cache-Control' => 'no-cache', |
|
49
|
|
|
'X-Bunq-Geolocation' => '52.3 4.89 12 100 NL', |
|
50
|
|
|
'X-Bunq-Language' => 'nl_NL', |
|
51
|
|
|
'X-Bunq-Region' => 'nl_NL', |
|
52
|
|
|
'other-existing-header' => 'value', |
|
53
|
|
|
]; |
|
54
|
|
|
$request = new Request('GET', 'uri', $headers); |
|
55
|
|
|
|
|
56
|
|
|
$result = $this->middleware->__invoke($request); |
|
57
|
|
|
|
|
58
|
|
|
$expectedHeaders = [ |
|
59
|
|
|
'X-Bunq-Client-Request-Id' => '253e0f90-8842-4731-91dd-0191816e6a28', |
|
60
|
|
|
'X-Bunq-Client-Authentication' => 'session-token', |
|
61
|
|
|
'Cache-Control' => 'no-cache', |
|
62
|
|
|
'X-Bunq-Geolocation' => '52.3 4.89 12 100 NL', |
|
63
|
|
|
'X-Bunq-Language' => 'nl_NL', |
|
64
|
|
|
'X-Bunq-Region' => 'nl_NL', |
|
65
|
|
|
'other-existing-header' => 'value', |
|
66
|
|
|
'X-Bunq-Client-Signature' => 'UdNaWrEGs9KqY33r3YSf4KpayASnT6WIgIRt98TWmhZ4qcG+a1N641K39ao9lZkNRuBYC2wH4FHthCWeE7qZlUMDazLh2fgC3+YkqMz5wZe26dRbQUWOK+8uR3OodaGAVfGxt4elwPy50nMjMvCgbH0DQuo8lMCrHwkhamBznJw=' |
|
67
|
|
|
]; |
|
68
|
|
|
$expectedRequest = new Request('GET', 'uri', $expectedHeaders, $request->getBody()); |
|
69
|
|
|
|
|
70
|
|
|
$this->assertEquals($expectedRequest, $result); |
|
71
|
|
|
} |
|
72
|
|
|
} |
|
73
|
|
|
|
|
74
|
|
|
|