* 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>
65 lines
2.0 KiB
C
65 lines
2.0 KiB
C
#ifdef HAVE_STARKWARE
|
|
|
|
#include "shared_context.h"
|
|
#include "apdu_constants.h"
|
|
#include "ui_flow.h"
|
|
|
|
void handleStarkwareProvideQuantum(uint8_t p1,
|
|
__attribute__((unused)) uint8_t p2,
|
|
uint8_t *dataBuffer,
|
|
uint16_t dataLength,
|
|
__attribute__((unused)) unsigned int *flags,
|
|
__attribute__((unused)) unsigned int *tx) {
|
|
size_t i = 0;
|
|
uint8_t expectedDataSize = 20 + 32;
|
|
uint8_t addressZero = 0;
|
|
tokenDefinition_t *currentToken = NULL;
|
|
if (appState != APP_STATE_IDLE) {
|
|
reset_app_context();
|
|
}
|
|
switch (p1) {
|
|
case STARK_QUANTUM_LEGACY:
|
|
break;
|
|
case STARK_QUANTUM_ETH:
|
|
case STARK_QUANTUM_ERC20:
|
|
case STARK_QUANTUM_ERC721:
|
|
case STARK_QUANTUM_MINTABLE_ERC20:
|
|
case STARK_QUANTUM_MINTABLE_ERC721:
|
|
expectedDataSize += 32;
|
|
break;
|
|
default:
|
|
THROW(0x6B00);
|
|
}
|
|
if (dataLength != expectedDataSize) {
|
|
THROW(0x6700);
|
|
}
|
|
if (p1 == STARK_QUANTUM_LEGACY) {
|
|
addressZero = allzeroes(dataBuffer, 20);
|
|
}
|
|
if ((p1 != STARK_QUANTUM_ETH) && !addressZero) {
|
|
for (i = 0; i < MAX_TOKEN; i++) {
|
|
currentToken = &tmpCtx.transactionContext.tokens[i];
|
|
if (tmpCtx.transactionContext.tokenSet[i] &&
|
|
(memcmp(currentToken->address, dataBuffer, 20) == 0)) {
|
|
break;
|
|
}
|
|
}
|
|
if (i == MAX_TOKEN) {
|
|
PRINTF("Associated token not found\n");
|
|
THROW(0x6A80);
|
|
}
|
|
} else {
|
|
i = MAX_TOKEN;
|
|
}
|
|
memmove(dataContext.tokenContext.quantum, dataBuffer + 20, 32);
|
|
if (p1 != STARK_QUANTUM_LEGACY) {
|
|
memmove(dataContext.tokenContext.mintingBlob, dataBuffer + 20 + 32, 32);
|
|
}
|
|
dataContext.tokenContext.quantumIndex = i;
|
|
dataContext.tokenContext.quantumType = p1;
|
|
quantumSet = true;
|
|
THROW(0x9000);
|
|
}
|
|
|
|
#endif
|