FilterAddSerializer   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 39
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 7
dl 0
loc 39
ccs 13
cts 13
cp 1
rs 10
c 0
b 0
f 0
wmc 4

4 Methods

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