* First draft for erc721 token allowance * Split ui and provide parameters into their own files * Print txtype when not supported * fix compilation for erc721 * Use pluginType * Add debug statement in compound plugin * add debug error msg in plugin error * Add parameter parsing for all methods * Remove debug logs * Add SET_APPROVAL_FOR_ALL; Add correct parsing method on contract init * Add dst_size parameter to copy functions * Add query contract id code * format * Add UIs * update ethapp.asc * Change setExternalPlugin to setPlugin; Add support for ERC721 * clang-format * Fix typo Unconsistent -> Inconsistent * Add support for 721; use extraInfo * Add extraInfo to ethpluginQueryConractUI * Rename extraInfo to item * Add txFromEtherscan to tests * Add nft key and temp padding * Remove comments around HAVE_BYPASS_SIGNATURES * Rename TESTING_KEY to NFT_TESTING_KEY * Add comments regarding value of queryContractUI->item * Fix comment regarding method selector * Rename provideToken to provideInfo; Update plugin doc * fix caps of eth_plugin_prepare_provide_info * fix caps of handle_provide_info * Use verificationFn insead of hardcoded cx_ecdsa_verify * Add comments about nftInfo_t and tokenDefinition_t * Add erc721 test * Remove comment from plugin interface version * Fix network_ticker duplicate * Add setPlugin and provideNFTInfo to doc.asc * Add back setExternalPlugin; implement new setPlugin * Update plugin sdk * Call setPlugin instead of setExternalPlugin * setPlugin work without checking sig * Remove printf of displayed fees * Add working 721 test * Finalize ERC721 and add simple test * Display NFT address on set approval and operator * Support set approval for all for erc721 * Finish UI for set approval for all erc721 * Move copy_parameter and copy_address to eth_plugin_internal; Add tests for erc721 * update plugin sdk * Add erc1155 plugin and 1155 tests placeholder * Add restriction for AWS key and setPlugin * Add NOT_OLD_INTERNAL variant; Add erc_1155_plugin_call * Fixed compilation warnings (function pointer casting) Co-authored-by: pscott <scott.piriou@ledger.fr>
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_ITEMS; i++) {
|
|
currentToken = &tmpCtx.transactionContext.extraInfo[i].token;
|
|
if (tmpCtx.transactionContext.tokenSet[i] &&
|
|
(memcmp(currentToken->address, dataBuffer, 20) == 0)) {
|
|
break;
|
|
}
|
|
}
|
|
if (i == MAX_ITEMS) {
|
|
PRINTF("Associated token not found\n");
|
|
THROW(0x6A80);
|
|
}
|
|
} else {
|
|
i = MAX_ITEMS;
|
|
}
|
|
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
|