FeeFilterSerializer   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 37
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 6
dl 0
loc 37
ccs 11
cts 11
cp 1
rs 10
c 0
b 0
f 0
wmc 4

4 Methods

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