You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
trezor-firmware/src/apps/common/signverify.py

32 lines
778 B

from ubinascii import hexlify
from trezor.crypto.hashlib import blake256, sha256
from trezor.utils import HashWriter
from apps.wallet.sign_tx.writers import write_varint
def message_digest(coin, message):
if coin.decred:
h = HashWriter(blake256())
else:
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 = "hex(%s)" % hexlify(message).decode()
words = [m]
return words