Coverage for ledger/hsm2dongle_tcp.py: 52%
27 statements
« prev ^ index » next coverage.py v7.5.3, created at 2025-07-10 13:43 +0000
« prev ^ index » next coverage.py v7.5.3, created at 2025-07-10 13:43 +0000
1# The MIT License (MIT)
2#
3# Copyright (c) 2021 RSK Labs Ltd
4#
5# Permission is hereby granted, free of charge, to any person obtaining a copy of
6# this software and associated documentation files (the "Software"), to deal in
7# the Software without restriction, including without limitation the rights to
8# use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
9# of the Software, and to permit persons to whom the Software is furnished to do
10# so, subject to the following conditions:
11#
12# The above copyright notice and this permission notice shall be included in all
13# copies or substantial portions of the Software.
14#
15# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21# SOFTWARE.
23from ledgerblue.commTCP import getDongle
24from ledgerblue.commException import CommException
25from .hsm2dongle import HSM2Dongle, HSM2DongleCommError
28class HSM2DongleTCP(HSM2Dongle):
29 def __init__(self, host, port, debug):
30 self.host = host
31 self.port = port
32 super().__init__(debug)
34 # Connect to the TCP "dongle"
35 def connect(self):
36 try:
37 self.logger.info(f"Connecting to {self.host}:{self.port}")
38 self.dongle = getDongle(self.host, self.port, self.debug)
39 self.logger.info("Connected")
40 except CommException as e:
41 msg = "Error connecting: %s" % e.message
42 self.logger.error(msg)
43 raise HSM2DongleCommError(msg)
45 # Disconnect from the TCP "dongle"
46 def disconnect(self):
47 try:
48 self.logger.info("Disconnecting")
49 if self.dongle and self.dongle.opened:
50 self.dongle.close()
51 self.logger.info("Disconnected")
52 except CommException as e:
53 msg = "Error disconnecting: %s" % e.message
54 self.logger.error(msg)
55 raise HSM2DongleCommError(msg)