1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2024-12-01 20:08:26 +00:00

stellar: check return value for stellar_deriveNode

This commit is contained in:
Pavol Rusnak 2018-10-23 14:15:26 +02:00
parent 5cbeb970c9
commit cc630a1ebb
No known key found for this signature in database
GPG Key ID: 91F3B339B9A02A3D
3 changed files with 26 additions and 16 deletions

View File

@ -25,7 +25,7 @@ void fsm_msgStellarGetAddress(const StellarGetAddress *msg)
CHECK_PIN CHECK_PIN
HDNode *node = stellar_deriveNode(msg->address_n, msg->address_n_count); const HDNode *node = stellar_deriveNode(msg->address_n, msg->address_n_count);
if (!node) { if (!node) {
fsm_sendFailure(FailureType_Failure_ProcessError, _("Failed to derive private key")); fsm_sendFailure(FailureType_Failure_ProcessError, _("Failed to derive private key"));
return; return;
@ -60,7 +60,11 @@ void fsm_msgStellarSignTx(const StellarSignTx *msg)
CHECK_INITIALIZED CHECK_INITIALIZED
CHECK_PIN CHECK_PIN
stellar_signingInit(msg); if (!stellar_signingInit(msg)) {
fsm_sendFailure(FailureType_Failure_ProcessError, _("Failed to derive private key"));
layoutHome();
return;
}
// Confirm transaction basics // Confirm transaction basics
stellar_layoutTransactionSummary(msg); stellar_layoutTransactionSummary(msg);

View File

@ -52,7 +52,7 @@ static StellarTransaction stellar_activeTx;
/* /*
* Starts the signing process and parses the transaction header * Starts the signing process and parses the transaction header
*/ */
void stellar_signingInit(const StellarSignTx *msg) bool stellar_signingInit(const StellarSignTx *msg)
{ {
memset(&stellar_activeTx, 0, sizeof(StellarTransaction)); memset(&stellar_activeTx, 0, sizeof(StellarTransaction));
stellar_signing = true; stellar_signing = true;
@ -78,10 +78,9 @@ void stellar_signingInit(const StellarSignTx *msg)
stellar_hashupdate_bytes(tx_type_bytes, sizeof(tx_type_bytes)); stellar_hashupdate_bytes(tx_type_bytes, sizeof(tx_type_bytes));
// Public key comes from deriving the specified account path // Public key comes from deriving the specified account path
HDNode *node = stellar_deriveNode(msg->address_n, msg->address_n_count); const HDNode *node = stellar_deriveNode(msg->address_n, msg->address_n_count);
if (!node) { if (!node) {
// TODO: bail on error return false;
return;
} }
memcpy(&(stellar_activeTx.signing_pubkey), node->public_key + 1, sizeof(stellar_activeTx.signing_pubkey)); memcpy(&(stellar_activeTx.signing_pubkey), node->public_key + 1, sizeof(stellar_activeTx.signing_pubkey));
@ -153,6 +152,8 @@ void stellar_signingInit(const StellarSignTx *msg)
else { else {
stellar_activeTx.network_type = 3; stellar_activeTx.network_type = 3;
} }
return true;
} }
bool stellar_confirmSourceAccount(bool has_source_account, const char *str_account) bool stellar_confirmSourceAccount(bool has_source_account, const char *str_account)
@ -1229,7 +1230,12 @@ bool stellar_allOperationsConfirmed()
*/ */
void stellar_getSignatureForActiveTx(uint8_t *out_signature) void stellar_getSignatureForActiveTx(uint8_t *out_signature)
{ {
HDNode *node = stellar_deriveNode(stellar_activeTx.address_n, stellar_activeTx.address_n_count); const HDNode *node = stellar_deriveNode(stellar_activeTx.address_n, stellar_activeTx.address_n_count);
if (!node) {
// return empty signature when we can't derive node
memset(out_signature, 0, 64);
return;
}
// Signature is the ed25519 detached signature of the sha256 of all the bytes // Signature is the ed25519 detached signature of the sha256 of all the bytes
// that have been read so far // that have been read so far
@ -1497,7 +1503,7 @@ uint16_t stellar_crc16(uint8_t *bytes, uint32_t length)
* *
* All paths must be hardened * All paths must be hardened
*/ */
HDNode *stellar_deriveNode(const uint32_t *address_n, size_t address_n_count) const HDNode *stellar_deriveNode(const uint32_t *address_n, size_t address_n_count)
{ {
static CONFIDENTIAL HDNode node; static CONFIDENTIAL HDNode node;
const char *curve = "ed25519"; const char *curve = "ed25519";
@ -1564,7 +1570,7 @@ void stellar_hashupdate_bool(bool value)
} }
} }
void stellar_hashupdate_string(uint8_t *data, size_t len) void stellar_hashupdate_string(const uint8_t *data, size_t len)
{ {
// Hash the length of the string // Hash the length of the string
stellar_hashupdate_uint32((uint32_t)len); stellar_hashupdate_uint32((uint32_t)len);
@ -1583,7 +1589,7 @@ void stellar_hashupdate_string(uint8_t *data, size_t len)
} }
} }
void stellar_hashupdate_address(uint8_t *address_bytes) void stellar_hashupdate_address(const uint8_t *address_bytes)
{ {
// First 4 bytes of an address are the type. There's only one type (0) // First 4 bytes of an address are the type. There's only one type (0)
stellar_hashupdate_uint32(0); stellar_hashupdate_uint32(0);
@ -1799,9 +1805,9 @@ void stellar_layoutSigningDialog(const char *line1, const char *line2, const cha
int offset_y = 1; int offset_y = 1;
int line_height = 9; int line_height = 9;
HDNode *node = stellar_deriveNode(address_n, address_n_count); const HDNode *node = stellar_deriveNode(address_n, address_n_count);
if (!node) { if (!node) {
// TODO: bail on error // abort on error
return; return;
} }

View File

@ -53,7 +53,7 @@ typedef struct {
} StellarTransaction; } StellarTransaction;
// Signing process // Signing process
void stellar_signingInit(const StellarSignTx *tx); bool stellar_signingInit(const StellarSignTx *tx);
void stellar_signingAbort(const char *reason); void stellar_signingAbort(const char *reason);
bool stellar_confirmSourceAccount(bool has_source_account, const char *str_account); bool stellar_confirmSourceAccount(bool has_source_account, const char *str_account);
bool stellar_confirmCreateAccountOp(const StellarCreateAccountOp *msg); bool stellar_confirmCreateAccountOp(const StellarCreateAccountOp *msg);
@ -74,7 +74,7 @@ void stellar_layoutTransactionSummary(const StellarSignTx *msg);
void stellar_layoutSigningDialog(const char *line1, const char *line2, const char *line3, const char *line4, const char *line5, uint32_t *address_n, size_t address_n_count, const char *warning, bool is_final_step); void stellar_layoutSigningDialog(const char *line1, const char *line2, const char *line3, const char *line4, const char *line5, uint32_t *address_n, size_t address_n_count, const char *warning, bool is_final_step);
// Helpers // Helpers
HDNode *stellar_deriveNode(const uint32_t *address_n, size_t address_n_count); const HDNode *stellar_deriveNode(const uint32_t *address_n, size_t address_n_count);
size_t stellar_publicAddressAsStr(const uint8_t *bytes, char *out, size_t outlen); size_t stellar_publicAddressAsStr(const uint8_t *bytes, char *out, size_t outlen);
const char **stellar_lineBreakAddress(const uint8_t *addrbytes); const char **stellar_lineBreakAddress(const uint8_t *addrbytes);
@ -82,8 +82,8 @@ const char **stellar_lineBreakAddress(const uint8_t *addrbytes);
void stellar_hashupdate_uint32(uint32_t value); void stellar_hashupdate_uint32(uint32_t value);
void stellar_hashupdate_uint64(uint64_t value); void stellar_hashupdate_uint64(uint64_t value);
void stellar_hashupdate_bool(bool value); void stellar_hashupdate_bool(bool value);
void stellar_hashupdate_string(uint8_t *data, size_t len); void stellar_hashupdate_string(const uint8_t *data, size_t len);
void stellar_hashupdate_address(uint8_t *address_bytes); void stellar_hashupdate_address(const uint8_t *address_bytes);
void stellar_hashupdate_asset(const StellarAssetType *asset); void stellar_hashupdate_asset(const StellarAssetType *asset);
void stellar_hashupdate_bytes(const uint8_t *data, size_t len); void stellar_hashupdate_bytes(const uint8_t *data, size_t len);