|
|
|
//
|
|
|
|
// Created by artem on 24.01.18.
|
|
|
|
//
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef ETOMIC_TESTNET
|
|
|
|
#define ETOMIC_ALICECONTRACT "0xe1d4236c5774d35dc47dcc2e5e0ccfc463a3289c"
|
|
|
|
#define ETOMIC_BOBCONTRACT "0x9387fd3a016bb0205e4e131dde886b9d2bc000a2"
|
|
|
|
#else
|
|
|
|
#define ETOMIC_ALICECONTRACT "0x9bc5418ceded51db08467fc4b62f32c5d9ebda55"
|
|
|
|
#define ETOMIC_BOBCONTRACT "0xb1ad803ea4f57401639c123000c75f5b66e4d123"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define EMPTY_ETH_TX_ID "0x0000000000000000000000000000000000000000000000000000000000000000"
|
|
|
|
#define ETH_FEE_ACCEPTOR "0x485d2cc2d13a9e12e4b53d606db1c8adc884fb8a"
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char from[65];
|
|
|
|
char to[65];
|
|
|
|
char amount[100];
|
|
|
|
char secretKey[70];
|
|
|
|
} BasicTxData;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char dealId[70];
|
|
|
|
char bobAddress[65];
|
|
|
|
char aliceHash[65];
|
|
|
|
char bobHash[65];
|
|
|
|
} AliceSendsEthPaymentInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char dealId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char bobAddress[65];
|
|
|
|
char aliceHash[65];
|
|
|
|
char bobHash[65];
|
|
|
|
} AliceSendsErc20PaymentInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char dealId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char bobAddress[65];
|
|
|
|
char aliceHash[65];
|
|
|
|
char bobSecret[70];
|
|
|
|
} AliceReclaimsAlicePaymentInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char dealId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char aliceAddress[65];
|
|
|
|
char aliceSecret[70];
|
|
|
|
char bobHash[65];
|
|
|
|
} BobSpendsAlicePaymentInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char depositId[70];
|
|
|
|
char aliceAddress[65];
|
|
|
|
char bobHash[65];
|
|
|
|
} BobSendsEthDepositInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char depositId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char aliceAddress[65];
|
|
|
|
char bobHash[65];
|
|
|
|
} BobSendsErc20DepositInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char depositId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char aliceAddress[65];
|
|
|
|
char bobSecret[70];
|
|
|
|
char aliceCanClaimAfter[100];
|
|
|
|
} BobRefundsDepositInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char depositId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char bobAddress[65];
|
|
|
|
char bobHash[65];
|
|
|
|
char aliceCanClaimAfter[100];
|
|
|
|
} AliceClaimsBobDepositInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char paymentId[70];
|
|
|
|
char aliceAddress[65];
|
|
|
|
char aliceHash[65];
|
|
|
|
} BobSendsEthPaymentInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char paymentId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char aliceAddress[65];
|
|
|
|
char aliceHash[65];
|
|
|
|
} BobSendsErc20PaymentInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char paymentId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char aliceAddress[65];
|
|
|
|
char aliceHash[65];
|
|
|
|
char bobCanClaimAfter[100];
|
|
|
|
} BobReclaimsBobPaymentInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char paymentId[70];
|
|
|
|
char amount[100];
|
|
|
|
char tokenAddress[65];
|
|
|
|
char aliceSecret[70];
|
|
|
|
char bobAddress[65];
|
|
|
|
char bobCanClaimAfter[100];
|
|
|
|
} AliceSpendsBobPaymentInput;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
char tokenAddress[65];
|
|
|
|
char owner[65];
|
|
|
|
char spender[65];
|
|
|
|
char amount[100];
|
|
|
|
char secret[70];
|
|
|
|
} ApproveErc20Input;
|
|
|
|
|
|
|
|
char *approveErc20(ApproveErc20Input input);
|
|
|
|
|
|
|
|
char* aliceSendsEthPayment(AliceSendsEthPaymentInput input, BasicTxData txData);
|
|
|
|
uint8_t verifyAliceEthPaymentData(AliceSendsEthPaymentInput input, char *data);
|
|
|
|
|
|
|
|
char* aliceSendsErc20Payment(AliceSendsErc20PaymentInput input, BasicTxData txData);
|
|
|
|
uint8_t verifyAliceErc20PaymentData(AliceSendsErc20PaymentInput input, char *data);
|
|
|
|
|
|
|
|
char* aliceReclaimsAlicePayment(AliceReclaimsAlicePaymentInput input, BasicTxData txData);
|
|
|
|
char* bobSpendsAlicePayment(BobSpendsAlicePaymentInput input, BasicTxData txData);
|
|
|
|
|
|
|
|
char* bobSendsEthDeposit(BobSendsEthDepositInput input, BasicTxData txData);
|
|
|
|
uint8_t verifyBobEthDepositData(BobSendsEthDepositInput input, char *data);
|
|
|
|
|
|
|
|
char* bobSendsErc20Deposit(BobSendsErc20DepositInput input, BasicTxData txData);
|
|
|
|
uint8_t verifyBobErc20DepositData(BobSendsErc20DepositInput input, char *data);
|
|
|
|
|
|
|
|
char* bobRefundsDeposit(BobRefundsDepositInput input, BasicTxData txData);
|
|
|
|
char* aliceClaimsBobDeposit(AliceClaimsBobDepositInput input, BasicTxData txData);
|
|
|
|
|
|
|
|
char* bobSendsEthPayment(BobSendsEthPaymentInput input, BasicTxData txData);
|
|
|
|
uint8_t verifyBobEthPaymentData(BobSendsEthPaymentInput input, char *data);
|
|
|
|
|
|
|
|
char* bobSendsErc20Payment(BobSendsErc20PaymentInput input, BasicTxData txData);
|
|
|
|
uint8_t verifyBobErc20PaymentData(BobSendsErc20PaymentInput input, char *data);
|
|
|
|
|
|
|
|
char* bobReclaimsBobPayment(BobReclaimsBobPaymentInput input, BasicTxData txData);
|
|
|
|
char* aliceSpendsBobPayment(AliceSpendsBobPaymentInput input, BasicTxData txData);
|
|
|
|
|
|
|
|
char* privKey2Addr(char* privKey);
|
|
|
|
char* pubKey2Addr(char* pubKey);
|
|
|
|
char* getPubKeyFromPriv(char* privKey);
|
|
|
|
|
|
|
|
// returns satoshis, not wei!
|
|
|
|
uint64_t getEthBalance(char* address);
|
|
|
|
uint64_t getErc20BalanceSatoshi(char* address, char tokenAddress[65]);
|
|
|
|
char *getErc20BalanceHexWei(char* address, char tokenAddress[65]);
|
|
|
|
|
|
|
|
uint8_t getErc20Decimals(char *tokenAddress);
|
|
|
|
|
|
|
|
// returns satoshis, not wei!
|
|
|
|
uint64_t getErc20Allowance(char *owner, char *spender, char *tokenAddress);
|
|
|
|
|
|
|
|
void uint8arrayToHex(char *dest, uint8_t *input, int len);
|
|
|
|
void satoshisToWei(char *dest, uint64_t input);
|
|
|
|
uint64_t weiToSatoshi(char *wei);
|
|
|
|
|
|
|
|
char *sendEth(char *to, char *amount, char *privKey);
|
|
|
|
char *sendErc20(char *tokenAddress, char *to, char *amount, char *privKey);
|
|
|
|
|
|
|
|
uint8_t verifyAliceErc20FeeData(char* tokenAddress, char *to, char *amount, char *data);
|
|
|
|
// Your prototype or Definition
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|