mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-12 00:10:58 +00:00
fix(crypto): refactor ethereum_address_checksum to prepend "0x" (#2029)
[no changelog]
This commit is contained in:
parent
8bcd52fc1b
commit
2880a2fa33
@ -60,11 +60,13 @@ bool address_check_prefix(const uint8_t *addr, uint32_t address_type) {
|
|||||||
void ethereum_address_checksum(const uint8_t *addr, char *address, bool rskip60,
|
void ethereum_address_checksum(const uint8_t *addr, char *address, bool rskip60,
|
||||||
uint64_t chain_id) {
|
uint64_t chain_id) {
|
||||||
const char *hex = "0123456789abcdef";
|
const char *hex = "0123456789abcdef";
|
||||||
|
address[0] = '0';
|
||||||
|
address[1] = 'x';
|
||||||
for (int i = 0; i < 20; i++) {
|
for (int i = 0; i < 20; i++) {
|
||||||
address[i * 2] = hex[(addr[i] >> 4) & 0xF];
|
address[2 + i * 2] = hex[(addr[i] >> 4) & 0xF];
|
||||||
address[i * 2 + 1] = hex[addr[i] & 0xF];
|
address[2 + i * 2 + 1] = hex[addr[i] & 0xF];
|
||||||
}
|
}
|
||||||
address[40] = 0;
|
address[42] = 0;
|
||||||
|
|
||||||
SHA3_CTX ctx = {0};
|
SHA3_CTX ctx = {0};
|
||||||
uint8_t hash[32] = {0};
|
uint8_t hash[32] = {0};
|
||||||
@ -75,16 +77,17 @@ void ethereum_address_checksum(const uint8_t *addr, char *address, bool rskip60,
|
|||||||
prefix, sizeof(prefix));
|
prefix, sizeof(prefix));
|
||||||
keccak_Update(&ctx, (const uint8_t *)prefix, prefix_size);
|
keccak_Update(&ctx, (const uint8_t *)prefix, prefix_size);
|
||||||
}
|
}
|
||||||
keccak_Update(&ctx, (const uint8_t *)address, 40);
|
keccak_Update(&ctx, (const uint8_t *)(address + 2), 40);
|
||||||
keccak_Final(&ctx, hash);
|
keccak_Final(&ctx, hash);
|
||||||
|
|
||||||
for (int i = 0; i < 20; i++) {
|
for (int i = 0; i < 20; i++) {
|
||||||
if (hash[i] & 0x80 && address[i * 2] >= 'a' && address[i * 2] <= 'f') {
|
if ((hash[i] & 0x80) && address[2 + i * 2] >= 'a' &&
|
||||||
address[i * 2] -= 0x20;
|
address[2 + i * 2] <= 'f') {
|
||||||
|
address[2 + i * 2] -= 0x20;
|
||||||
}
|
}
|
||||||
if (hash[i] & 0x08 && address[i * 2 + 1] >= 'a' &&
|
if ((hash[i] & 0x08) && address[2 + i * 2 + 1] >= 'a' &&
|
||||||
address[i * 2 + 1] <= 'f') {
|
address[2 + i * 2 + 1] <= 'f') {
|
||||||
address[i * 2 + 1] -= 0x20;
|
address[2 + i * 2 + 1] -= 0x20;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7322,25 +7322,25 @@ START_TEST(test_ethereum_pubkeyhash) {
|
|||||||
END_TEST
|
END_TEST
|
||||||
|
|
||||||
START_TEST(test_ethereum_address) {
|
START_TEST(test_ethereum_address) {
|
||||||
static const char *vectors[] = {"52908400098527886E0F7030069857D2E4169EE7",
|
static const char *vectors[] = {"0x52908400098527886E0F7030069857D2E4169EE7",
|
||||||
"8617E340B3D01FA5F11F306F4090FD50E238070D",
|
"0x8617E340B3D01FA5F11F306F4090FD50E238070D",
|
||||||
"de709f2102306220921060314715629080e2fb77",
|
"0xde709f2102306220921060314715629080e2fb77",
|
||||||
"27b1fdb04752bbc536007a920d24acb045561c26",
|
"0x27b1fdb04752bbc536007a920d24acb045561c26",
|
||||||
"5aAeb6053F3E94C9b9A09f33669435E7Ef1BeAed",
|
"0x5aAeb6053F3E94C9b9A09f33669435E7Ef1BeAed",
|
||||||
"fB6916095ca1df60bB79Ce92cE3Ea74c37c5d359",
|
"0xfB6916095ca1df60bB79Ce92cE3Ea74c37c5d359",
|
||||||
"dbF03B407c01E7cD3CBea99509d93f8DDDC8C6FB",
|
"0xdbF03B407c01E7cD3CBea99509d93f8DDDC8C6FB",
|
||||||
"D1220A0cf47c7B9Be7A2E6BA89F429762e7b9aDb",
|
"0xD1220A0cf47c7B9Be7A2E6BA89F429762e7b9aDb",
|
||||||
"5A4EAB120fB44eb6684E5e32785702FF45ea344D",
|
"0x5A4EAB120fB44eb6684E5e32785702FF45ea344D",
|
||||||
"5be4BDC48CeF65dbCbCaD5218B1A7D37F58A0741",
|
"0x5be4BDC48CeF65dbCbCaD5218B1A7D37F58A0741",
|
||||||
"a7dD84573f5ffF821baf2205745f768F8edCDD58",
|
"0xa7dD84573f5ffF821baf2205745f768F8edCDD58",
|
||||||
"027a49d11d118c0060746F1990273FcB8c2fC196",
|
"0x027a49d11d118c0060746F1990273FcB8c2fC196",
|
||||||
"CD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826",
|
"0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826",
|
||||||
0};
|
0};
|
||||||
uint8_t addr[20];
|
uint8_t addr[20];
|
||||||
char address[41];
|
char address[43];
|
||||||
const char **vec = vectors;
|
const char **vec = vectors;
|
||||||
while (*vec) {
|
while (*vec) {
|
||||||
memcpy(addr, fromhex(*vec), 20);
|
memcpy(addr, fromhex(*vec + 2), 20);
|
||||||
ethereum_address_checksum(addr, address, false, 0);
|
ethereum_address_checksum(addr, address, false, 0);
|
||||||
ck_assert_str_eq(address, *vec);
|
ck_assert_str_eq(address, *vec);
|
||||||
vec++;
|
vec++;
|
||||||
@ -7352,29 +7352,29 @@ END_TEST
|
|||||||
// https://github.com/rsksmart/RSKIPs/blob/master/IPs/RSKIP60.md
|
// https://github.com/rsksmart/RSKIPs/blob/master/IPs/RSKIP60.md
|
||||||
START_TEST(test_rsk_address) {
|
START_TEST(test_rsk_address) {
|
||||||
uint8_t addr[20];
|
uint8_t addr[20];
|
||||||
char address[41];
|
char address[43];
|
||||||
|
|
||||||
static const char *rskip60_chain30[] = {
|
static const char *rskip60_chain30[] = {
|
||||||
"5aaEB6053f3e94c9b9a09f33669435E7ef1bEAeD",
|
"0x5aaEB6053f3e94c9b9a09f33669435E7ef1bEAeD",
|
||||||
"Fb6916095cA1Df60bb79ce92cE3EA74c37c5d359",
|
"0xFb6916095cA1Df60bb79ce92cE3EA74c37c5d359",
|
||||||
"DBF03B407c01E7CD3cBea99509D93F8Dddc8C6FB",
|
"0xDBF03B407c01E7CD3cBea99509D93F8Dddc8C6FB",
|
||||||
"D1220A0Cf47c7B9BE7a2e6ba89F429762E7B9adB", 0};
|
"0xD1220A0Cf47c7B9BE7a2e6ba89F429762E7B9adB", 0};
|
||||||
const char **vec = rskip60_chain30;
|
const char **vec = rskip60_chain30;
|
||||||
while (*vec) {
|
while (*vec) {
|
||||||
memcpy(addr, fromhex(*vec), 20);
|
memcpy(addr, fromhex(*vec + 2), 20);
|
||||||
ethereum_address_checksum(addr, address, true, 30);
|
ethereum_address_checksum(addr, address, true, 30);
|
||||||
ck_assert_str_eq(address, *vec);
|
ck_assert_str_eq(address, *vec);
|
||||||
vec++;
|
vec++;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *rskip60_chain31[] = {
|
static const char *rskip60_chain31[] = {
|
||||||
"5aAeb6053F3e94c9b9A09F33669435E7EF1BEaEd",
|
"0x5aAeb6053F3e94c9b9A09F33669435E7EF1BEaEd",
|
||||||
"Fb6916095CA1dF60bb79CE92ce3Ea74C37c5D359",
|
"0xFb6916095CA1dF60bb79CE92ce3Ea74C37c5D359",
|
||||||
"dbF03B407C01E7cd3cbEa99509D93f8dDDc8C6fB",
|
"0xdbF03B407C01E7cd3cbEa99509D93f8dDDc8C6fB",
|
||||||
"d1220a0CF47c7B9Be7A2E6Ba89f429762E7b9adB", 0};
|
"0xd1220a0CF47c7B9Be7A2E6Ba89f429762E7b9adB", 0};
|
||||||
vec = rskip60_chain31;
|
vec = rskip60_chain31;
|
||||||
while (*vec) {
|
while (*vec) {
|
||||||
memcpy(addr, fromhex(*vec), 20);
|
memcpy(addr, fromhex(*vec + 2), 20);
|
||||||
ethereum_address_checksum(addr, address, true, 31);
|
ethereum_address_checksum(addr, address, true, 31);
|
||||||
ck_assert_str_eq(address, *vec);
|
ck_assert_str_eq(address, *vec);
|
||||||
vec++;
|
vec++;
|
||||||
|
@ -354,12 +354,12 @@ static void layoutEthereumConfirmTx(const uint8_t *to, uint32_t to_len,
|
|||||||
ethereumFormatAmount(&val, token, amount, sizeof(amount));
|
ethereumFormatAmount(&val, token, amount, sizeof(amount));
|
||||||
}
|
}
|
||||||
|
|
||||||
char _to1[] = "to 0x__________";
|
char _to1[] = "to ____________";
|
||||||
char _to2[] = "_______________";
|
char _to2[] = "_______________";
|
||||||
char _to3[] = "_______________?";
|
char _to3[] = "_______________?";
|
||||||
|
|
||||||
if (to_len) {
|
if (to_len) {
|
||||||
char to_str[41] = {0};
|
char to_str[43] = {0};
|
||||||
|
|
||||||
bool rskip60 = false;
|
bool rskip60 = false;
|
||||||
// constants from trezor-common/defs/ethereum/networks.json
|
// constants from trezor-common/defs/ethereum/networks.json
|
||||||
@ -373,9 +373,9 @@ static void layoutEthereumConfirmTx(const uint8_t *to, uint32_t to_len,
|
|||||||
}
|
}
|
||||||
|
|
||||||
ethereum_address_checksum(to, to_str, rskip60, chain_id);
|
ethereum_address_checksum(to, to_str, rskip60, chain_id);
|
||||||
memcpy(_to1 + 5, to_str, 10);
|
memcpy(_to1 + 3, to_str, 12);
|
||||||
memcpy(_to2, to_str + 10, 15);
|
memcpy(_to2, to_str + 12, 15);
|
||||||
memcpy(_to3, to_str + 25, 15);
|
memcpy(_to3, to_str + 27, 15);
|
||||||
} else {
|
} else {
|
||||||
strlcpy(_to1, _("to new contract?"), sizeof(_to1));
|
strlcpy(_to1, _("to new contract?"), sizeof(_to1));
|
||||||
strlcpy(_to2, "", sizeof(_to2));
|
strlcpy(_to2, "", sizeof(_to2));
|
||||||
|
@ -126,9 +126,7 @@ void fsm_msgEthereumGetAddress(const EthereumGetAddress *msg) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
resp->has_address = true;
|
resp->has_address = true;
|
||||||
resp->address[0] = '0';
|
ethereum_address_checksum(pubkeyhash, resp->address, rskip60, chain_id);
|
||||||
resp->address[1] = 'x';
|
|
||||||
ethereum_address_checksum(pubkeyhash, resp->address + 2, rskip60, chain_id);
|
|
||||||
// ethereum_address_checksum adds trailing zero
|
// ethereum_address_checksum adds trailing zero
|
||||||
|
|
||||||
if (msg->has_show_display && msg->show_display) {
|
if (msg->has_show_display && msg->show_display) {
|
||||||
@ -161,9 +159,7 @@ void fsm_msgEthereumSignMessage(const EthereumSignMessage *msg) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
resp->address[0] = '0';
|
ethereum_address_checksum(pubkeyhash, resp->address, false, 0);
|
||||||
resp->address[1] = 'x';
|
|
||||||
ethereum_address_checksum(pubkeyhash, resp->address + 2, false, 0);
|
|
||||||
// ethereum_address_checksum adds trailing zero
|
// ethereum_address_checksum adds trailing zero
|
||||||
|
|
||||||
layoutVerifyAddress(NULL, resp->address);
|
layoutVerifyAddress(NULL, resp->address);
|
||||||
@ -243,9 +239,7 @@ void fsm_msgEthereumSignTypedHash(const EthereumSignTypedHash *msg) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
resp->address[0] = '0';
|
ethereum_address_checksum(pubkeyhash, resp->address, false, 0);
|
||||||
resp->address[1] = 'x';
|
|
||||||
ethereum_address_checksum(pubkeyhash, resp->address + 2, false, 0);
|
|
||||||
// ethereum_address_checksum adds trailing zero
|
// ethereum_address_checksum adds trailing zero
|
||||||
|
|
||||||
layoutVerifyAddress(NULL, resp->address);
|
layoutVerifyAddress(NULL, resp->address);
|
||||||
|
Loading…
Reference in New Issue
Block a user