* Fix easy warnings for sdk 2.0 * Add attribute unused to bagl_elemt_t in callback functions * Add attribute unused to io_event function * Clang-format * Use elfs from CI in tests (#167) * Add Nano X build * Use CI's build artifacts for CI's tests * Add network display (#152) * Add network name display instead of chainID * Add display of correct ticker along with network * Add FTM * Clang-format * Add comment in python script * Rename SIZE_MAX to MAX_SIZE * Change %u to %d in printf * Remove needless PIC * Update comment about get_chain_id() * Update example script to follow EIP155 * Remove unused PIC calls * Add whitespace between ticker and amount when using EIP155 * Remove decimal config per network, set back 18 everywhere * Adapt u32_from_BE to swith cases * Remove chainid from signTx.py * Switch to switch in stead of if in get_chain_id * Revert "Remove chainid from signTx.py" This reverts commit 454e09f280ec3e3ec1c7d7cc0027247ef4390088. * Change Ethereum chainid to 1 * Rename chainid_step to network_step * Adapt finalizeParsing to new chainid for Ethereum * Update snapshots * clang-format * Fix network display logic for clones * Fix tests * Add clone tests Co-authored-by: TamtamHero <10632523+TamtamHero@users.noreply.github.com> Co-authored-by: Jean P <10632523+TamtamHero@users.noreply.github.com>
85 lines
3.1 KiB
C
85 lines
3.1 KiB
C
#include "shared_context.h"
|
|
#include "ui_callbacks.h"
|
|
|
|
static const uint8_t EIP_712_MAGIC[] = {0x19, 0x01};
|
|
|
|
unsigned int io_seproxyhal_touch_signMessage712_v0_ok(__attribute__((unused))
|
|
const bagl_element_t *e) {
|
|
uint8_t privateKeyData[INT256_LENGTH];
|
|
uint8_t hash[INT256_LENGTH];
|
|
uint8_t signature[100];
|
|
uint8_t signatureLength;
|
|
cx_ecfp_private_key_t privateKey;
|
|
uint32_t tx = 0;
|
|
io_seproxyhal_io_heartbeat();
|
|
cx_keccak_init(&global_sha3, 256);
|
|
cx_hash((cx_hash_t *) &global_sha3,
|
|
0,
|
|
(uint8_t *) EIP_712_MAGIC,
|
|
sizeof(EIP_712_MAGIC),
|
|
NULL,
|
|
0);
|
|
cx_hash((cx_hash_t *) &global_sha3,
|
|
0,
|
|
tmpCtx.messageSigningContext712.domainHash,
|
|
sizeof(tmpCtx.messageSigningContext712.domainHash),
|
|
NULL,
|
|
0);
|
|
cx_hash((cx_hash_t *) &global_sha3,
|
|
CX_LAST,
|
|
tmpCtx.messageSigningContext712.messageHash,
|
|
sizeof(tmpCtx.messageSigningContext712.messageHash),
|
|
hash,
|
|
sizeof(hash));
|
|
PRINTF("EIP712 hash to sign %.*H\n", 32, hash);
|
|
io_seproxyhal_io_heartbeat();
|
|
os_perso_derive_node_bip32(CX_CURVE_256K1,
|
|
tmpCtx.messageSigningContext712.bip32Path,
|
|
tmpCtx.messageSigningContext712.pathLength,
|
|
privateKeyData,
|
|
NULL);
|
|
io_seproxyhal_io_heartbeat();
|
|
cx_ecfp_init_private_key(CX_CURVE_256K1, privateKeyData, 32, &privateKey);
|
|
explicit_bzero(privateKeyData, sizeof(privateKeyData));
|
|
unsigned int info = 0;
|
|
io_seproxyhal_io_heartbeat();
|
|
signatureLength = cx_ecdsa_sign(&privateKey,
|
|
CX_RND_RFC6979 | CX_LAST,
|
|
CX_SHA256,
|
|
hash,
|
|
sizeof(hash),
|
|
signature,
|
|
sizeof(signature),
|
|
&info);
|
|
explicit_bzero(&privateKey, sizeof(privateKey));
|
|
G_io_apdu_buffer[0] = 27;
|
|
if (info & CX_ECCINFO_PARITY_ODD) {
|
|
G_io_apdu_buffer[0]++;
|
|
}
|
|
if (info & CX_ECCINFO_xGTn) {
|
|
G_io_apdu_buffer[0] += 2;
|
|
}
|
|
format_signature_out(signature);
|
|
tx = 65;
|
|
G_io_apdu_buffer[tx++] = 0x90;
|
|
G_io_apdu_buffer[tx++] = 0x00;
|
|
reset_app_context();
|
|
// Send back the response, do not restart the event loop
|
|
io_exchange(CHANNEL_APDU | IO_RETURN_AFTER_TX, tx);
|
|
// Display back the original UX
|
|
ui_idle();
|
|
return 0; // do not redraw the widget
|
|
}
|
|
|
|
unsigned int io_seproxyhal_touch_signMessage712_v0_cancel(__attribute__((unused))
|
|
const bagl_element_t *e) {
|
|
reset_app_context();
|
|
G_io_apdu_buffer[0] = 0x69;
|
|
G_io_apdu_buffer[1] = 0x85;
|
|
// Send back the response, do not restart the event loop
|
|
io_exchange(CHANNEL_APDU | IO_RETURN_AFTER_TX, 2);
|
|
// Display back the original UX
|
|
ui_idle();
|
|
return 0; // do not redraw the widget
|
|
}
|