2018-06-21 14:28:34 +00:00
|
|
|
# This file is part of the Trezor project.
|
2017-01-03 18:40:05 +00:00
|
|
|
#
|
2018-06-21 14:28:34 +00:00
|
|
|
# Copyright (C) 2012-2018 SatoshiLabs and contributors
|
2017-01-03 18:40:05 +00:00
|
|
|
#
|
|
|
|
# This library is free software: you can redistribute it and/or modify
|
2018-06-21 14:28:34 +00:00
|
|
|
# it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
# as published by the Free Software Foundation.
|
2017-01-03 18:40:05 +00:00
|
|
|
#
|
|
|
|
# This library is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU Lesser General Public License for more details.
|
|
|
|
#
|
2018-06-21 14:28:34 +00:00
|
|
|
# You should have received a copy of the License along with this library.
|
|
|
|
# If not, see <https://www.gnu.org/licenses/lgpl-3.0.html>.
|
2016-05-20 20:27:20 +00:00
|
|
|
|
2015-10-20 16:12:39 +00:00
|
|
|
import struct
|
2018-05-11 12:53:51 +00:00
|
|
|
from binascii import hexlify, unhexlify
|
|
|
|
|
|
|
|
from .common import TrezorTest
|
2015-02-20 17:50:53 +00:00
|
|
|
|
2017-12-12 15:40:11 +00:00
|
|
|
from trezorlib import messages as proto
|
2015-02-20 17:50:53 +00:00
|
|
|
|
2017-06-23 19:31:42 +00:00
|
|
|
|
2015-10-20 16:12:39 +00:00
|
|
|
def check_path(identity):
|
2017-12-23 20:20:49 +00:00
|
|
|
from hashlib import sha256
|
|
|
|
m = sha256()
|
2015-10-20 16:12:39 +00:00
|
|
|
m.update(struct.pack("<I", identity.index))
|
|
|
|
uri = ''
|
2017-06-23 19:31:42 +00:00
|
|
|
if identity.proto:
|
|
|
|
uri += identity.proto + '://'
|
|
|
|
if identity.user:
|
|
|
|
uri += identity.user + '@'
|
|
|
|
if identity.host:
|
|
|
|
uri += identity.host
|
|
|
|
if identity.port:
|
|
|
|
uri += ':' + identity.port
|
|
|
|
if identity.path:
|
|
|
|
uri += identity.path
|
2015-10-20 16:12:39 +00:00
|
|
|
m.update(uri)
|
2016-05-05 01:16:17 +00:00
|
|
|
print('hash:', m.hexdigest())
|
2015-10-20 16:12:39 +00:00
|
|
|
(a, b, c, d, _, _, _, _) = struct.unpack('<8I', m.digest())
|
|
|
|
address_n = [0x80000000 | 13, 0x80000000 | a, 0x80000000 | b, 0x80000000 | c, 0x80000000 | d]
|
2016-05-05 01:16:17 +00:00
|
|
|
print('path:', 'm/' + '/'.join([str(x) for x in address_n]))
|
2015-10-20 16:12:39 +00:00
|
|
|
|
2017-06-23 19:31:42 +00:00
|
|
|
|
2017-12-23 20:20:49 +00:00
|
|
|
class TestMsgSignidentity(TrezorTest):
|
2015-02-20 17:50:53 +00:00
|
|
|
|
|
|
|
def test_sign(self):
|
|
|
|
self.setup_mnemonic_nopin_nopassphrase()
|
|
|
|
|
2017-12-23 20:20:49 +00:00
|
|
|
hidden = unhexlify('cd8552569d6e4509266ef137584d1e62c7579b5b8ed69bbafa4b864c6521e7c2')
|
2015-08-21 13:16:27 +00:00
|
|
|
visual = '2015-03-23 17:39:22'
|
|
|
|
|
2015-10-20 16:12:39 +00:00
|
|
|
# URI : https://satoshi@bitcoin.org/login
|
|
|
|
# hash : d0e2389d4c8394a9f3e32de01104bf6e8db2d9e2bb0905d60fffa5a18fd696db
|
|
|
|
# path : m/2147483661/2637750992/2845082444/3761103859/4005495825
|
2017-12-12 15:40:11 +00:00
|
|
|
identity = proto.IdentityType(proto='https', user='satoshi', host='bitcoin.org', port='', path='/login', index=0)
|
2015-08-21 13:16:27 +00:00
|
|
|
sig = self.client.sign_identity(identity, hidden, visual)
|
2017-12-23 20:20:49 +00:00
|
|
|
assert sig.address == '17F17smBTX9VTZA9Mj8LM5QGYNZnmziCjL'
|
|
|
|
assert hexlify(sig.public_key) == b'023a472219ad3327b07c18273717bb3a40b39b743756bf287fbd5fa9d263237f45'
|
|
|
|
assert hexlify(sig.signature) == b'20f2d1a42d08c3a362be49275c3ffeeaa415fc040971985548b9f910812237bb41770bf2c8d488428799fbb7e52c11f1a3404011375e4080e077e0e42ab7a5ba02'
|
2015-02-20 17:50:53 +00:00
|
|
|
|
2015-10-20 16:12:39 +00:00
|
|
|
# URI : ftp://satoshi@bitcoin.org:2323/pub
|
|
|
|
# hash : 79a6b53831c6ff224fb283587adc4ebae8fb0d734734a46c876838f52dff53f3
|
|
|
|
# path : m/2147483661/3098912377/2734671409/3632509519/3125730426
|
2017-12-12 15:40:11 +00:00
|
|
|
identity = proto.IdentityType(proto='ftp', user='satoshi', host='bitcoin.org', port='2323', path='/pub', index=3)
|
2015-08-21 13:16:27 +00:00
|
|
|
sig = self.client.sign_identity(identity, hidden, visual)
|
2017-12-23 20:20:49 +00:00
|
|
|
assert sig.address == '1KAr6r5qF2kADL8bAaRQBjGKYEGxn9WrbS'
|
|
|
|
assert hexlify(sig.public_key) == b'0266cf12d2ba381c5fd797da0d64f59c07a6f1b034ad276cca6bf2729e92b20d9c'
|
|
|
|
assert hexlify(sig.signature) == b'20bbd12dc657d534fc0f7e40186e22c447e0866a016f654f380adffa9a84e9faf412a1bb0ae908296537838cf91145e77da08681c63d07b7dca40728b9e6cb17cf'
|
2015-02-20 17:50:53 +00:00
|
|
|
|
2015-10-20 16:12:39 +00:00
|
|
|
# URI : ssh://satoshi@bitcoin.org
|
|
|
|
# hash : 5fa612f558a1a3b1fb7f010b2ea0a25cb02520a0ffa202ce74a92fc6145da5f3
|
|
|
|
# path : m/2147483661/4111640159/2980290904/2332131323/3701645358
|
2017-12-12 15:40:11 +00:00
|
|
|
identity = proto.IdentityType(proto='ssh', user='satoshi', host='bitcoin.org', port='', path='', index=47)
|
2016-05-20 13:28:52 +00:00
|
|
|
sig = self.client.sign_identity(identity, hidden, visual, ecdsa_curve_name='nist256p1')
|
2017-12-23 20:20:49 +00:00
|
|
|
assert sig.address is None
|
|
|
|
assert hexlify(sig.public_key) == b'0373f21a3da3d0e96fc2189f81dd826658c3d76b2d55bd1da349bc6c3573b13ae4'
|
|
|
|
assert hexlify(sig.signature) == b'005122cebabb852cdd32103b602662afa88e54c0c0c1b38d7099c64dcd49efe908288114e66ed2d8c82f23a70b769a4db723173ec53840c08aafb840d3f09a18d3'
|
2016-05-20 13:28:52 +00:00
|
|
|
|
|
|
|
# URI : ssh://satoshi@bitcoin.org
|
|
|
|
# hash : 5fa612f558a1a3b1fb7f010b2ea0a25cb02520a0ffa202ce74a92fc6145da5f3
|
|
|
|
# path : m/2147483661/4111640159/2980290904/2332131323/3701645358
|
2017-12-12 15:40:11 +00:00
|
|
|
identity = proto.IdentityType(proto='ssh', user='satoshi', host='bitcoin.org', port='', path='', index=47)
|
2016-05-20 13:28:52 +00:00
|
|
|
sig = self.client.sign_identity(identity, hidden, visual, ecdsa_curve_name='ed25519')
|
2017-12-23 20:20:49 +00:00
|
|
|
assert sig.address is None
|
|
|
|
assert hexlify(sig.public_key) == b'000fac2a491e0f5b871dc48288a4cae551bac5cb0ed19df0764d6e721ec5fade18'
|
|
|
|
assert hexlify(sig.signature) == b'00f05e5085e666429de397c70a081932654369619c0bd2a6579ea6c1ef2af112ef79998d6c862a16b932d44b1ac1b83c8cbcd0fbda228274fde9e0d0ca6e9cb709'
|