Completed
Pull Request — master (#12)
by thomas
19:02 queued 01:07
created

LoadDeviceService::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 3
rs 10
c 0
b 0
f 0
cc 1
eloc 1
nc 1
nop 1
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\Button\ButtonAck;
9
use BitWasp\Trezor\Device\Exception\UnexpectedResultException;
10
use BitWasp\Trezor\Device\Message;
11
use BitWasp\TrezorProto;
12
13
class LoadDeviceService extends DeviceService
14
{
15
    /**
16
     * @var ButtonAck
17
     */
18
    private $ack;
19
20
    public function __construct(ButtonAck $buttonAck)
21
    {
22
        $this->ack = $buttonAck;
23
    }
24
25
    public function call(
26
        Session $session,
27
        TrezorProto\LoadDevice $loadDevice
28
    ): TrezorProto\Success {
29
        $proto = $session->sendMessage(Message::loadDevice($loadDevice));
30
31
        if ($proto instanceof TrezorProto\ButtonRequest) {
32
            $proto = $this->ack->acknowledge($session, $proto, TrezorProto\ButtonRequestType::ButtonRequest_ProtectCall());
33
        }
34
35
        if (!($proto instanceof TrezorProto\Success)) {
36
            throw new UnexpectedResultException("Unexpected response, expecting Success, got " . get_class($proto));
37
        }
38
39
        return $proto;
40
    }
41
}
42