from trezor.crypto.curve import secp256k1 from trezor.crypto.hashlib import sha3_256 from trezor.messages.EthereumMessageSignature import EthereumMessageSignature from trezor.ui.text import Text from trezor.utils import HashWriter from apps.common import seed from apps.common.confirm import require_confirm from apps.common.signverify import split_message def message_digest(message): h = HashWriter(sha3_256, keccak=True) signed_message_header = "\x19Ethereum Signed Message:\n" h.extend(signed_message_header) h.extend(str(len(message))) h.extend(message) return h.get_digest() async def sign_message(ctx, msg): await require_confirm_sign_message(ctx, msg.message) address_n = msg.address_n or () node = await seed.derive_node(ctx, address_n) signature = secp256k1.sign(node.private_key(), message_digest(msg.message), False) sig = EthereumMessageSignature() sig.address = node.ethereum_pubkeyhash() sig.signature = signature[1:] + bytearray([signature[0]]) return sig async def require_confirm_sign_message(ctx, message): message = split_message(message) text = Text("Sign ETH message") text.normal(*message) await require_confirm(ctx, text)