Passed
Pull Request — master (#9)
by thomas
03:43 queued 01:53
created

GetEntropyService::call()   A

Complexity

Conditions 3
Paths 4

Size

Total Lines 15
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 7
CRAP Score 3

Importance

Changes 0
Metric Value
dl 0
loc 15
ccs 7
cts 7
cp 1
rs 9.4285
c 0
b 0
f 0
cc 3
eloc 6
nc 4
nop 2
crap 3
1
<?php
2
3
declare(strict_types=1);
4
5
namespace BitWasp\Trezor\Device\Command;
6
7
use BitWasp\Trezor\Bridge\Session;
8
use BitWasp\Trezor\Device\Exception\UnexpectedResultException;
9
use BitWasp\Trezor\Device\Message;
10
use BitWasp\TrezorProto\ButtonRequest;
11
use BitWasp\TrezorProto\ButtonRequestType;
12
use BitWasp\TrezorProto\Entropy;
13
use BitWasp\TrezorProto\GetEntropy;
14
15
class GetEntropyService extends DeviceService
16
{
17 2
    public function call(
18
        Session $session,
19
        GetEntropy $getEntropy
20
    ): Entropy {
21
22 2
        $proto = $session->sendMessage(Message::getEntropy($getEntropy));
23 2
        if ($proto instanceof ButtonRequest) {
24 1
            $proto = $session->sendMessage($this->confirmWithButton($proto, ButtonRequestType::ButtonRequest_ProtectCall()));
25
        }
26
27 2
        if (!($proto instanceof Entropy)) {
28 1
            throw new UnexpectedResultException("Unexpected message returned, expecting Entropy");
29
        }
30
31 1
        return $proto;
32
    }
33
}
34