Passed
Pull Request — master (#89)
by thomas
02:25
created

AddrSerializer   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 41
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
dl 0
loc 41
ccs 14
cts 14
cp 1
rs 10
c 0
b 0
f 0
wmc 4

4 Methods

Rating   Name   Duplication   Size   Complexity  
A serialize() 0 3 1
A parse() 0 3 1
A __construct() 0 3 1
A fromParser() 0 4 1
1
<?php
2
3
declare(strict_types=1);
4
5
namespace BitWasp\Bitcoin\Networking\Serializer\Message;
6
7
use BitWasp\Bitcoin\Networking\Messages\Addr;
8
use BitWasp\Bitcoin\Networking\Serializer\Structure\NetworkAddressTimestampSerializer;
9
use BitWasp\Bitcoin\Serializer\Types;
10
use BitWasp\Buffertools\Buffer;
11
use BitWasp\Buffertools\BufferInterface;
12
use BitWasp\Buffertools\Parser;
13
14
class AddrSerializer
15
{
16
    /**
17
     * @var \BitWasp\Buffertools\Types\Vector
18
     */
19
    private $vectorNetAddr;
20 96
21
    /**
22 96
     * @param NetworkAddressTimestampSerializer $serializer
23 96
     */
24
    public function __construct(NetworkAddressTimestampSerializer $serializer)
25
    {
26
        $this->vectorNetAddr = Types::vector([$serializer, 'fromParser']);
27
    }
28 5
29
    /**
30 5
     * @param Parser $parser
31 5
     * @return Addr
32 5
     */
33 5
    public function fromParser(Parser $parser): Addr
34 5
    {
35
        $addresses = $this->vectorNetAddr->read($parser);
36
        return new Addr($addresses);
37
    }
38
39
    /**
40
     * @param BufferInterface $data
41 5
     * @return Addr
42
     */
43 5
    public function parse(BufferInterface $data): Addr
44 5
    {
45
        return $this->fromParser(new Parser($data));
46
    }
47
48
    /**
49
     * @param Addr $addr
50
     * @return BufferInterface
51 5
     */
52
    public function serialize(Addr $addr): BufferInterface
53 5
    {
54
        return new Buffer($this->vectorNetAddr->write($addr->getAddresses()));
55
    }
56
}
57