mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-24 22:31:35 +00:00
refactor Address dialog (QR code on left button click), use checksum for Ethereum addresses
This commit is contained in:
parent
7ca4b11c3a
commit
5b66c0b956
@ -29,6 +29,7 @@
|
|||||||
#include "crypto.h"
|
#include "crypto.h"
|
||||||
#include "secp256k1.h"
|
#include "secp256k1.h"
|
||||||
#include "sha3.h"
|
#include "sha3.h"
|
||||||
|
#include "address.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "gettext.h"
|
#include "gettext.h"
|
||||||
#include "ethereum_tokens.h"
|
#include "ethereum_tokens.h"
|
||||||
@ -249,16 +250,16 @@ static void layoutEthereumConfirmTx(const uint8_t *to, uint32_t to_len, const ui
|
|||||||
ethereumFormatAmount(&val, token, amount, sizeof(amount));
|
ethereumFormatAmount(&val, token, amount, sizeof(amount));
|
||||||
}
|
}
|
||||||
|
|
||||||
static char _to1[17] = {0};
|
char _to1[] = "to 0x__________";
|
||||||
static char _to2[17] = {0};
|
char _to2[] = "_______________";
|
||||||
static char _to3[17] = {0};
|
char _to3[] = "_______________?";
|
||||||
|
|
||||||
if (to_len) {
|
if (to_len) {
|
||||||
strcpy(_to1, _("to "));
|
char to_str[41];
|
||||||
data2hex(to, 6, _to1 + 3);
|
ethereum_address_checksum(to, to_str);
|
||||||
data2hex(to + 6, 7, _to2);
|
memcpy(_to1 + 5, to_str, 10);
|
||||||
data2hex(to + 13, 7, _to3);
|
memcpy(_to2, to_str + 10, 15);
|
||||||
_to3[14] = '?'; _to3[15] = 0;
|
memcpy(_to3, to_str + 25, 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));
|
||||||
|
@ -652,11 +652,13 @@ void fsm_msgGetAddress(GetAddress *msg)
|
|||||||
} else {
|
} else {
|
||||||
strlcpy(desc, _("Address:"), sizeof(desc));
|
strlcpy(desc, _("Address:"), sizeof(desc));
|
||||||
}
|
}
|
||||||
layoutAddress(resp->address, desc);
|
bool qrcode = false;
|
||||||
if (!protectButton(ButtonRequestType_ButtonRequest_Address, true)) {
|
for (;;) {
|
||||||
fsm_sendFailure(FailureType_Failure_ActionCancelled, NULL);
|
layoutAddress(resp->address, desc, qrcode);
|
||||||
layoutHome();
|
if (protectButton(ButtonRequestType_ButtonRequest_Address, false)) {
|
||||||
return;
|
break;
|
||||||
|
}
|
||||||
|
qrcode = !qrcode;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -684,14 +686,16 @@ void fsm_msgEthereumGetAddress(EthereumGetAddress *msg)
|
|||||||
char desc[16];
|
char desc[16];
|
||||||
strlcpy(desc, "Address:", sizeof(desc));
|
strlcpy(desc, "Address:", sizeof(desc));
|
||||||
|
|
||||||
char address[41];
|
char address[43] = { '0', 'x' };
|
||||||
data2hex(resp->address.bytes, 20, address);
|
ethereum_address_checksum(resp->address.bytes, address + 2);
|
||||||
|
|
||||||
layoutAddress(address, desc);
|
bool qrcode = false;
|
||||||
if (!protectButton(ButtonRequestType_ButtonRequest_Address, true)) {
|
for (;;) {
|
||||||
fsm_sendFailure(FailureType_Failure_ActionCancelled, NULL);
|
layoutAddress(address, desc, qrcode);
|
||||||
layoutHome();
|
if (protectButton(ButtonRequestType_ButtonRequest_Address, false)) {
|
||||||
return;
|
break;
|
||||||
|
}
|
||||||
|
qrcode = !qrcode;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -225,21 +225,24 @@ void layoutDecryptMessage(const uint8_t *msg, uint32_t len, const char *address)
|
|||||||
str[0], str[1], str[2], str[3], NULL, NULL);
|
str[0], str[1], str[2], str[3], NULL, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void layoutAddress(const char *address, const char *desc)
|
void layoutAddress(const char *address, const char *desc, bool qrcode)
|
||||||
{
|
{
|
||||||
|
if (layoutLast != layoutAddress) {
|
||||||
oledSwipeLeft();
|
oledSwipeLeft();
|
||||||
|
} else {
|
||||||
|
oledClear();
|
||||||
|
}
|
||||||
layoutLast = layoutAddress;
|
layoutLast = layoutAddress;
|
||||||
|
|
||||||
|
if (qrcode) {
|
||||||
static unsigned char bitdata[QR_MAX_BITDATA];
|
static unsigned char bitdata[QR_MAX_BITDATA];
|
||||||
int a, i, j;
|
|
||||||
int side = qr_encode(QR_LEVEL_M, 0, address, 0, bitdata);
|
int side = qr_encode(QR_LEVEL_M, 0, address, 0, bitdata);
|
||||||
int startx;
|
|
||||||
|
|
||||||
if (side > 0 && side <= 29) {
|
if (side > 0 && side <= 29) {
|
||||||
oledInvert(0, 0, (side + 2) * 2, (side + 2) * 2);
|
oledInvert(0, 0, (side + 2) * 2, (side + 2) * 2);
|
||||||
for (i = 0; i < side; i++) {
|
for (int i = 0; i < side; i++) {
|
||||||
for (j = 0; j< side; j++) {
|
for (int j = 0; j< side; j++) {
|
||||||
a = j * side + i;
|
int a = j * side + i;
|
||||||
if (bitdata[a / 8] & (1 << (7 - a % 8))) {
|
if (bitdata[a / 8] & (1 << (7 - a % 8))) {
|
||||||
oledClearPixel(2 + i * 2, 2 + j * 2);
|
oledClearPixel(2 + i * 2, 2 + j * 2);
|
||||||
oledClearPixel(3 + i * 2, 2 + j * 2);
|
oledClearPixel(3 + i * 2, 2 + j * 2);
|
||||||
@ -248,34 +251,36 @@ void layoutAddress(const char *address, const char *desc)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
startx = 68;
|
|
||||||
} else if (side > 0 && side <= 60) {
|
} else if (side > 0 && side <= 60) {
|
||||||
oledInvert(0, 0, (side + 3), (side + 3));
|
oledInvert(0, 0, (side + 3), (side + 3));
|
||||||
for (i = 0; i < side; i++) {
|
for (int i = 0; i < side; i++) {
|
||||||
for (j = 0; j< side; j++) {
|
for (int j = 0; j< side; j++) {
|
||||||
a = j * side + i;
|
int a = j * side + i;
|
||||||
if (bitdata[a / 8] & (1 << (7 - a % 8))) {
|
if (bitdata[a / 8] & (1 << (7 - a % 8))) {
|
||||||
oledClearPixel(2 + i, 2 + j);
|
oledClearPixel(2 + i, 2 + j);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
startx = side + 6;
|
|
||||||
} else {
|
|
||||||
startx = 0;
|
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
uint32_t addrlen = strlen(address);
|
uint32_t addrlen = strlen(address);
|
||||||
uint32_t rowlen = addrlen / 4;
|
uint32_t rowlen = addrlen / 2;
|
||||||
if (addrlen % 4) {
|
if (addrlen % 2) {
|
||||||
rowlen++;
|
rowlen++;
|
||||||
}
|
}
|
||||||
const char **str = split_message((const uint8_t *)address, addrlen, rowlen);
|
const char **str = split_message((const uint8_t *)address, addrlen, rowlen);
|
||||||
|
|
||||||
if (desc) {
|
if (desc) {
|
||||||
oledDrawString(startx, 0 * 9, desc);
|
oledDrawString(0, 0 * 9, desc);
|
||||||
}
|
}
|
||||||
for (i = 0; i < 4; i++) {
|
for (int i = 0; i < 4; i++) {
|
||||||
oledDrawString(startx, (i+1) * 9 + 4, str[i]);
|
oledDrawString(0, (i + 1) * 9 + 4, str[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!qrcode) {
|
||||||
|
static const char *btnNo = _("QR Code");
|
||||||
|
oledDrawString(2, OLED_HEIGHT - 8, btnNo);
|
||||||
|
oledInvert(0, OLED_HEIGHT - 9, oledStringWidth(btnNo) + 3, OLED_HEIGHT - 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *btnYes = _("Continue");
|
static const char *btnYes = _("Continue");
|
||||||
|
@ -40,7 +40,7 @@ void layoutVerifyMessage(const uint8_t *msg, uint32_t len);
|
|||||||
void layoutCipherKeyValue(bool encrypt, const char *key);
|
void layoutCipherKeyValue(bool encrypt, const char *key);
|
||||||
void layoutEncryptMessage(const uint8_t *msg, uint32_t len, bool signing);
|
void layoutEncryptMessage(const uint8_t *msg, uint32_t len, bool signing);
|
||||||
void layoutDecryptMessage(const uint8_t *msg, uint32_t len, const char *address);
|
void layoutDecryptMessage(const uint8_t *msg, uint32_t len, const char *address);
|
||||||
void layoutAddress(const char *address, const char *desc);
|
void layoutAddress(const char *address, const char *desc, bool qrcode);
|
||||||
void layoutPublicKey(const uint8_t *pubkey);
|
void layoutPublicKey(const uint8_t *pubkey);
|
||||||
void layoutSignIdentity(const IdentityType *identity, const char *challenge);
|
void layoutSignIdentity(const IdentityType *identity, const char *challenge);
|
||||||
void layoutDecryptIdentity(const IdentityType *identity);
|
void layoutDecryptIdentity(const IdentityType *identity);
|
||||||
|
2
vendor/trezor-crypto
vendored
2
vendor/trezor-crypto
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 533193562601780c8705ecb80c908916bb80b427
|
Subproject commit f49fe75e15eafaa69ab687857c4ffd0c9410a0e1
|
Loading…
Reference in New Issue
Block a user