Total Complexity | 3 |
Total Lines | 35 |
Duplicated Lines | 0 % |
Coverage | 87.5% |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php |
||
10 | class WsseAuthMiddleware implements MiddlewareInterface |
||
11 | { |
||
12 | private $username; |
||
13 | private $password; |
||
14 | |||
15 | 1 | public function __construct(string $username, string $password) |
|
19 | 1 | } |
|
20 | |||
21 | 1 | public function handleRequest(RequestInterface $request, callable $next) |
|
22 | { |
||
23 | 1 | $nonce = substr(sha1(uniqid('', true)), 0, 16); |
|
24 | 1 | $created = date('c'); |
|
25 | 1 | $digest = base64_encode(sha1(base64_decode($nonce).$created.$this->password, true)); |
|
26 | |||
27 | 1 | $wsse = sprintf( |
|
28 | 1 | 'UsernameToken Username="%s", PasswordDigest="%s", Nonce="%s", Created="%s"', |
|
29 | 1 | $this->username, |
|
30 | $digest, |
||
31 | $nonce, |
||
32 | $created |
||
33 | ); |
||
34 | |||
35 | $request = $request |
||
36 | 1 | ->withHeader('Authorization', 'WSSE profile="UsernameToken"') |
|
37 | 1 | ->withHeader('X-WSSE', $wsse); |
|
38 | |||
39 | 1 | return $next($request); |
|
40 | } |
||
41 | |||
42 | public function handleResponse(RequestInterface $request, ResponseInterface $response, callable $next) |
||
45 | } |
||
46 | } |
||
47 |