1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-11-13 19:18:56 +00:00
trezor-firmware/src/apps/common/signverify.py

29 lines
676 B
Python
Raw Normal View History

2018-07-03 14:20:26 +00:00
from ubinascii import hexlify
2018-02-27 15:35:21 +00:00
from trezor.crypto.hashlib import sha256
from trezor.utils import HashWriter
2018-07-03 14:20:26 +00:00
from apps.wallet.sign_tx.signing import write_varint
2017-06-13 17:35:14 +00:00
def message_digest(coin, message):
h = HashWriter(sha256)
write_varint(h, len(coin.signed_message_header))
h.extend(coin.signed_message_header)
write_varint(h, len(message))
h.extend(message)
ret = h.get_digest()
if coin.sign_hash_double:
ret = sha256(ret).digest()
return ret
def split_message(message):
try:
m = bytes(message).decode()
words = m.split(" ")
except UnicodeError:
m = hexlify(message)
words = [m]
return words