Files
app-ethereum/src/shared_context.h

197 lines
4.3 KiB
C
Raw Normal View History

2020-06-27 13:24:04 +02:00
#ifndef __SHARED_CONTEXT_H__
#define __SHARED_CONTEXT_H__
#include <stdbool.h>
#include <stdint.h>
#include <string.h>
#include "os.h"
#include "cx.h"
#include "os_io_seproxyhal.h"
#include "ethUstream.h"
#include "ethUtils.h"
#include "uint256.h"
#include "tokens.h"
#include "chainConfig.h"
2020-09-22 09:22:49 +02:00
#include "eth_plugin_interface.h"
2020-06-27 13:24:04 +02:00
#define MAX_BIP32_PATH 10
#define MAX_TOKEN 2
#define WEI_TO_ETHER 18
2020-12-01 16:20:13 +01:00
#define N_storage (*(volatile internalStorage_t *) PIC(&N_storage_real))
2020-06-27 13:24:04 +02:00
typedef struct internalStorage_t {
2020-12-01 16:20:13 +01:00
unsigned char dataAllowed;
unsigned char contractDetails;
unsigned char displayNonce;
2020-12-01 16:20:13 +01:00
uint8_t initialized;
2020-06-27 13:24:04 +02:00
} internalStorage_t;
2020-11-24 00:11:55 +01:00
#ifdef HAVE_STARKWARE
typedef enum starkQuantumType_e {
2020-12-01 16:20:13 +01:00
STARK_QUANTUM_LEGACY = 0x00,
STARK_QUANTUM_ETH,
STARK_QUANTUM_ERC20,
STARK_QUANTUM_ERC721,
STARK_QUANTUM_MINTABLE_ERC20,
STARK_QUANTUM_MINTABLE_ERC721
2020-11-24 00:11:55 +01:00
} starkQuantumType_e;
#endif
2020-06-27 13:24:04 +02:00
typedef struct tokenContext_t {
2020-09-22 09:22:49 +02:00
char pluginName[PLUGIN_ID_LENGTH];
2020-12-01 16:20:13 +01:00
uint8_t pluginAvailable;
2020-09-22 09:22:49 +02:00
uint8_t data[32];
uint8_t fieldIndex;
2020-12-01 16:20:13 +01:00
uint8_t fieldOffset;
2020-09-22 09:22:49 +02:00
uint8_t pluginUiMaxItems;
uint8_t pluginUiCurrentItem;
uint8_t pluginUiState;
uint8_t pluginContext[3 * 32];
2020-06-27 13:24:04 +02:00
#ifdef HAVE_STARKWARE
uint8_t quantum[32];
2020-11-24 00:11:55 +01:00
uint8_t mintingBlob[32];
2020-06-27 13:24:04 +02:00
uint8_t quantumIndex;
2020-11-24 00:11:55 +01:00
uint8_t quantumType;
2020-06-27 13:24:04 +02:00
#endif
2020-09-22 09:22:49 +02:00
} tokenContext_t;
2020-06-27 13:24:04 +02:00
typedef struct publicKeyContext_t {
cx_ecfp_public_key_t publicKey;
uint8_t address[41];
uint8_t chainCode[32];
bool getChaincode;
} publicKeyContext_t;
typedef struct transactionContext_t {
uint8_t pathLength;
uint32_t bip32Path[MAX_BIP32_PATH];
uint8_t hash[32];
tokenDefinition_t tokens[MAX_TOKEN];
uint8_t tokenSet[MAX_TOKEN];
uint8_t currentTokenIndex;
} transactionContext_t;
typedef struct messageSigningContext_t {
uint8_t pathLength;
uint32_t bip32Path[MAX_BIP32_PATH];
uint8_t hash[32];
uint32_t remainingLength;
} messageSigningContext_t;
2020-09-26 15:49:36 +02:00
typedef struct messageSigningContext712_t {
uint8_t pathLength;
uint32_t bip32Path[MAX_BIP32_PATH];
uint8_t domainHash[32];
uint8_t messageHash[32];
} messageSigningContext712_t;
2020-06-27 13:24:04 +02:00
typedef union {
publicKeyContext_t publicKeyContext;
transactionContext_t transactionContext;
messageSigningContext_t messageSigningContext;
2020-09-26 15:49:36 +02:00
messageSigningContext712_t messageSigningContext712;
2020-06-27 13:24:04 +02:00
} tmpCtx_t;
typedef union {
2020-12-01 16:20:13 +01:00
txContent_t txContent;
cx_sha256_t sha2;
char tmp[100];
2020-06-27 13:24:04 +02:00
} tmpContent_t;
#ifdef HAVE_STARKWARE
typedef struct starkContext_t {
2020-12-01 16:20:13 +01:00
uint8_t w1[32];
uint8_t w2[32];
uint8_t w3[32];
uint8_t w4[32];
uint8_t conditional;
uint8_t transferDestination[32];
uint8_t fact[32];
uint8_t conditionAddress[20];
2020-06-27 13:24:04 +02:00
} starkContext_t;
#endif
typedef union {
tokenContext_t tokenContext;
#ifdef HAVE_STARKWARE
starkContext_t starkContext;
#endif
} dataContext_t;
2020-12-01 16:20:13 +01:00
typedef enum { APP_STATE_IDLE, APP_STATE_SIGNING_TX, APP_STATE_SIGNING_MESSAGE } app_state_t;
2020-06-27 13:24:04 +02:00
typedef enum {
2020-12-01 16:20:13 +01:00
CONTRACT_NONE,
CONTRACT_ERC20,
CONTRACT_ALLOWANCE,
2020-06-27 13:24:04 +02:00
#ifdef HAVE_STARKWARE
2020-12-01 16:20:13 +01:00
CONTRACT_STARKWARE_REGISTER,
CONTRACT_STARKWARE_DEPOSIT_TOKEN,
CONTRACT_STARKWARE_DEPOSIT_ETH,
CONTRACT_STARKWARE_WITHDRAW,
CONTRACT_STARKWARE_DEPOSIT_CANCEL,
CONTRACT_STARKWARE_DEPOSIT_RECLAIM,
CONTRACT_STARKWARE_FULL_WITHDRAWAL,
CONTRACT_STARKWARE_FREEZE,
CONTRACT_STARKWARE_ESCAPE,
CONTRACT_STARKWARE_VERIFY_ESCAPE
2020-06-27 13:24:04 +02:00
#endif
} contract_call_t;
2020-06-29 15:43:02 +02:00
typedef struct txStringProperties_t {
2020-06-27 13:24:04 +02:00
char fullAddress[43];
char fullAmount[50];
char maxFee[50];
char nonce[8]; // 10M tx per account ought to be enough for everybody
2020-06-29 15:43:02 +02:00
} txStringProperties_t;
2020-06-27 13:24:04 +02:00
typedef struct strDataTmp_t {
char tmp[100];
char tmp2[40];
} strDataTmp_t;
typedef union {
2020-06-29 15:43:02 +02:00
txStringProperties_t common;
2020-06-27 13:24:04 +02:00
strDataTmp_t tmp;
} strings_t;
extern chain_config_t *chainConfig;
extern tmpCtx_t tmpCtx;
extern txContext_t txContext;
extern tmpContent_t tmpContent;
extern dataContext_t dataContext;
extern strings_t strings;
2020-06-29 15:43:02 +02:00
extern cx_sha3_t global_sha3;
2020-06-27 13:24:04 +02:00
extern const internalStorage_t N_storage_real;
2020-06-29 15:43:02 +02:00
extern bool called_from_swap;
2020-06-27 13:24:04 +02:00
extern bool dataPresent;
extern uint8_t appState;
#ifdef HAVE_STARKWARE
extern bool quantumSet;
#endif
2020-10-27 11:16:50 +01:00
#ifdef HAVE_ETH2
extern uint32_t eth2WithdrawalIndex;
#endif
2020-06-27 13:24:04 +02:00
void reset_app_context(void);
2020-12-01 16:20:13 +01:00
#endif // __SHARED_CONTEXT_H__