FeeFilterSerializer::fromParser()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 1
CRAP Score 1

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 1
dl 0
loc 3
ccs 1
cts 1
cp 1
crap 1
rs 10
c 0
b 0
f 0
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