mirror of
https://github.com/trezor/trezor-firmware.git
synced 2024-12-17 03:48:09 +00:00
fsm: Add NEMGetAddress
This commit is contained in:
parent
c331d7e8f0
commit
3057f78837
@ -50,6 +50,7 @@
|
|||||||
#include "secp256k1.h"
|
#include "secp256k1.h"
|
||||||
#include <libopencm3/stm32/flash.h>
|
#include <libopencm3/stm32/flash.h>
|
||||||
#include "ethereum.h"
|
#include "ethereum.h"
|
||||||
|
#include "nem.h"
|
||||||
#include "gettext.h"
|
#include "gettext.h"
|
||||||
|
|
||||||
// message methods
|
// message methods
|
||||||
@ -1104,6 +1105,45 @@ void fsm_msgSetU2FCounter(SetU2FCounter *msg)
|
|||||||
layoutHome();
|
layoutHome();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void fsm_msgNEMGetAddress(NEMGetAddress *msg)
|
||||||
|
{
|
||||||
|
if (!msg->has_network) {
|
||||||
|
msg->network = NEM_NETWORK_MAINNET;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *network;
|
||||||
|
CHECK_PARAM((network = nem_network_name(msg->network)), _("Invalid NEM network"));
|
||||||
|
|
||||||
|
CHECK_INITIALIZED
|
||||||
|
CHECK_PIN
|
||||||
|
|
||||||
|
RESP_INIT(NEMAddress);
|
||||||
|
|
||||||
|
HDNode *node = fsm_getDerivedNode(ED25519_KECCAK_NAME, msg->address_n, msg->address_n_count);
|
||||||
|
if (!node) return;
|
||||||
|
|
||||||
|
if (!hdnode_get_nem_address(node, msg->network, resp->address))
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (msg->has_show_display && msg->show_display) {
|
||||||
|
char desc[16];
|
||||||
|
strlcpy(desc, network, sizeof(desc));
|
||||||
|
strlcat(desc, ":", sizeof(desc));
|
||||||
|
|
||||||
|
bool qrcode = false;
|
||||||
|
for (;;) {
|
||||||
|
layoutAddress(resp->address, desc, qrcode);
|
||||||
|
if (protectButton(ButtonRequestType_ButtonRequest_Address, false)) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
qrcode = !qrcode;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
msg_write(MessageType_MessageType_NEMAddress, resp);
|
||||||
|
layoutHome();
|
||||||
|
}
|
||||||
|
|
||||||
#if DEBUG_LINK
|
#if DEBUG_LINK
|
||||||
|
|
||||||
void fsm_msgDebugLinkGetState(DebugLinkGetState *msg)
|
void fsm_msgDebugLinkGetState(DebugLinkGetState *msg)
|
||||||
|
@ -66,6 +66,8 @@ void fsm_msgEthereumTxAck(EthereumTxAck *msg);
|
|||||||
void fsm_msgEthereumSignMessage(EthereumSignMessage *msg);
|
void fsm_msgEthereumSignMessage(EthereumSignMessage *msg);
|
||||||
void fsm_msgEthereumVerifyMessage(EthereumVerifyMessage *msg);
|
void fsm_msgEthereumVerifyMessage(EthereumVerifyMessage *msg);
|
||||||
|
|
||||||
|
void fsm_msgNEMGetAddress(NEMGetAddress *msg);
|
||||||
|
|
||||||
// debug message functions
|
// debug message functions
|
||||||
#if DEBUG_LINK
|
#if DEBUG_LINK
|
||||||
//void fsm_msgDebugLinkDecision(DebugLinkDecision *msg);
|
//void fsm_msgDebugLinkDecision(DebugLinkDecision *msg);
|
||||||
|
Loading…
Reference in New Issue
Block a user