Completed
Pull Request — master (#3)
by Márk
03:50
created

Wsse   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 38
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 1
Metric Value
c 1
b 0
f 1
dl 0
loc 38
wmc 2
lcom 1
cbo 2
ccs 17
cts 17
cp 1
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 5 1
A authenticate() 0 20 1
1
<?php
2
3
namespace Http\Message\Authentication;
4
5
use Http\Message\Authentication;
6
use Psr\Http\Message\RequestInterface;
7
8
/**
9
 * Authenticate a PSR-7 Request using WSSE.
10
 *
11
 * @author Márk Sági-Kazár <[email protected]>
12
 */
13
final class Wsse implements Authentication
14
{
15
    use UserPasswordPair;
16
17
    /**
18
     * @param string $username
19
     * @param string $password
20
     */
21 7
    public function __construct($username, $password)
22
    {
23 7
        $this->username = $username;
24 7
        $this->password = $password;
25 7
    }
26
27
    /**
28
     * {@inheritdoc}
29
     */
30 1
    public function authenticate(RequestInterface $request)
31
    {
32
        // TODO: generate better nonce?
33 1
        $nonce = substr(md5(uniqid(uniqid().'_', true)), 0, 16);
34 1
        $created = date('c');
35 1
        $digest = base64_encode(sha1(base64_decode($nonce).$created.$this->password, true));
36
37 1
        $wsse = sprintf(
38 1
            'UsernameToken Username="%s", PasswordDigest="%s", Nonce="%s", Created="%s"',
39 1
            $this->username,
40 1
            $digest,
41 1
            $nonce,
42
            $created
43 1
        );
44
45
        return $request
46 1
            ->withHeader('Authorization', 'WSSE profile="UsernameToken"')
47 1
            ->withHeader('X-WSSE', $wsse)
48 1
        ;
49
    }
50
}
51