// // Created by artem on 24.01.18. // #include #include #include #include #include #include "etomiclib.h" #include "etomiccurl.h" char* bobContractAddress = "0x9387Fd3a016bB0205e4e131Dde886B9d2BC000A2"; char* aliceAddress = "0x485d2cc2d13a9e12E4b53D606DB1c8adc884fB8a"; char* bobAddress = "0xbAB36286672fbdc7B250804bf6D14Be0dF69fa29"; char* tokenAddress = "0xc0eb7AeD740E1796992A08962c15661bDEB58003"; int main(int argc, char** argv) { enum { BOB_ETH_DEPOSIT, BOB_ERC20_DEPOSIT, BOB_CLAIMS_DEPOSIT, ALICE_CLAIMS_DEPOSIT, BOB_ETH_PAYMENT, BOB_ERC20_PAYMENT, BOB_CLAIMS_PAYMENT, ALICE_CLAIMS_PAYMENT, BOB_APPROVES_ERC20, BOB_ETH_BALANCE, BOB_ERC20_BALANCE, TX_RECEIPT, TX_DATA }; if (argc < 2) { return 1; } int action = atoi(argv[1]); BasicTxData txData; char* result; switch (action) { case BOB_ETH_DEPOSIT: strcpy(txData.amount, "1000000000000000000"); strcpy(txData.from, bobAddress); strcpy(txData.to, bobContractAddress); strcpy(txData.secretKey, getenv("BOB_PK")); BobSendsEthDepositInput input; strcpy(input.aliceAddress, aliceAddress); strcpy(input.depositId, argv[2]); strcpy(input.bobHash, argv[3]); result = bobSendsEthDeposit(input, txData); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } break; case BOB_ERC20_DEPOSIT: strcpy(txData.amount, "0"); strcpy(txData.from, bobAddress); strcpy(txData.to, bobContractAddress); strcpy(txData.secretKey, getenv("BOB_PK")); BobSendsErc20DepositInput input1 = { .amount = "1000000000000000000" }; strcpy(input1.depositId, argv[2]); strcpy(input1.aliceAddress, aliceAddress); strcpy(input1.bobHash, argv[3]); strcpy(input1.tokenAddress, tokenAddress); result = bobSendsErc20Deposit(input1, txData); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } free(result); break; case BOB_CLAIMS_DEPOSIT: strcpy(txData.amount, "0"); strcpy(txData.from, bobAddress); strcpy(txData.to, bobContractAddress); strcpy(txData.secretKey, getenv("BOB_PK")); BobRefundsDepositInput input2; strcpy(input2.depositId, argv[2]); strcpy(input2.amount, "1000000000000000000"); strcpy(input2.aliceAddress, aliceAddress); strcpy(input2.tokenAddress, argv[3]); strcpy(input2.aliceCanClaimAfter, argv[4]); strcpy(input2.bobSecret, argv[5]); result = bobRefundsDeposit(input2, txData); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } free(result); break; case ALICE_CLAIMS_DEPOSIT: strcpy(txData.amount, "0"); strcpy(txData.from, aliceAddress); strcpy(txData.to, bobContractAddress); strcpy(txData.secretKey, getenv("ALICE_PK")); AliceClaimsBobDepositInput input3; strcpy(input3.depositId, argv[2]); strcpy(input3.amount, "1000000000000000000"); strcpy(input3.bobAddress, bobAddress); strcpy(input3.tokenAddress, argv[3]); strcpy(input3.aliceCanClaimAfter, argv[4]); strcpy(input3.bobHash, argv[5]); result = aliceClaimsBobDeposit(input3, txData); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } free(result); break; case BOB_ETH_PAYMENT: strcpy(txData.amount, "1000000000000000000"); strcpy(txData.from, bobAddress); strcpy(txData.to, bobContractAddress); strcpy(txData.secretKey, getenv("BOB_PK")); BobSendsEthPaymentInput input4; strcpy(input4.paymentId, argv[2]); strcpy(input4.aliceHash, argv[3]); strcpy(input4.aliceAddress, aliceAddress); result = bobSendsEthPayment(input4, txData); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } free(result); break; case BOB_ERC20_PAYMENT: strcpy(txData.amount, "0"); strcpy(txData.from, bobAddress); strcpy(txData.to, bobContractAddress); strcpy(txData.secretKey, getenv("BOB_PK")); BobSendsErc20PaymentInput input5; strcpy(input5.paymentId, argv[2]); strcpy(input5.amount, "1000000000000000000"); strcpy(input5.tokenAddress, tokenAddress); strcpy(input5.aliceAddress, aliceAddress); strcpy(input5.aliceHash, argv[3]); result = bobSendsErc20Payment(input5, txData); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } free(result); break; case BOB_CLAIMS_PAYMENT: strcpy(txData.amount, "0"); strcpy(txData.from, bobAddress); strcpy(txData.to, bobContractAddress); strcpy(txData.secretKey, getenv("BOB_PK")); BobReclaimsBobPaymentInput input6; strcpy(input6.paymentId, argv[2]); strcpy(input6.aliceAddress, aliceAddress); strcpy(input6.amount, "1000000000000000000"); strcpy(input6.tokenAddress, argv[3]); strcpy(input6.bobCanClaimAfter, argv[4]); strcpy(input6.aliceHash, argv[5]); result = bobReclaimsBobPayment(input6, txData); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } free(result); break; case ALICE_CLAIMS_PAYMENT: strcpy(txData.amount, "0"); strcpy(txData.from, aliceAddress); strcpy(txData.to, bobContractAddress); strcpy(txData.secretKey, getenv("ALICE_PK")); AliceSpendsBobPaymentInput input7; strcpy(input7.paymentId, argv[2]); strcpy(input7.bobAddress, bobAddress); strcpy(input7.amount, "1000000000000000000"); strcpy(input7.tokenAddress, argv[3]); strcpy(input7.bobCanClaimAfter, argv[4]); strcpy(input7.aliceSecret, argv[5]); result = aliceSpendsBobPayment(input7, txData); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } break; case BOB_APPROVES_ERC20: printf("approving erc20\n"); ApproveErc20Input input8; strcpy(input8.amount, "0"); strcpy(input8.spender, bobContractAddress); strcpy(input8.owner, bobAddress); strcpy(input8.tokenAddress, tokenAddress); strcpy(input8.secret, getenv("BOB_PK")); result = approveErc20(input8); if (result != NULL) { printf("%s\n", result); free(result); } else { printf("Tx send result was NULL\n"); } break; case BOB_ETH_BALANCE: printf("%" PRIu64 "\n", getEthBalance(bobAddress)); break; case BOB_ERC20_BALANCE: printf("%" PRIu64 "\n", getErc20BalanceSatoshi(bobAddress, tokenAddress)); break; case TX_RECEIPT: printf("getTxReceipt\n"); EthTxReceipt txReceipt; txReceipt = getEthTxReceipt("0xc337b9cfe76aaa9022d9399a9e4ecdc1b7044d65ef74e8911a4b47874bee60c6"); printf("blockNumber: %" PRIu64 "\n", txReceipt.blockNumber); printf("blockHash: %s\n", txReceipt.blockHash); printf("status: %s\n", txReceipt.status); printf("confirmations: %" PRIu64 "\n", txReceipt.confirmations); break; case TX_DATA: printf("getTxData\n"); EthTxData ethTxData; ethTxData = getEthTxData("0xc337b9cfe76aaa9022d9399a9e4ecdc1b7044d65ef74e8911a4b47874bee60c6"); printf("from : %s\n", ethTxData.from); printf("to: %s\n", ethTxData.to); printf("value: %s\n", ethTxData.valueHex); printf("input: %s\n", ethTxData.input); printf("exists: %d\n", ethTxData.exists); break; default: return 1; } char *pubkey = getPubKeyFromPriv(getenv("BOB_PK")); printf("pubkey: %s\n", pubkey); free(pubkey); uint64_t satoshis = 100000000; char weiBuffer[100]; satoshisToWei(weiBuffer, satoshis); printf("wei: %s\n", weiBuffer); uint8_t decimals = getErc20Decimals(tokenAddress); printf("decimals: %d\n", decimals); uint64_t tokenAllowance = getErc20Allowance(bobAddress, bobContractAddress, tokenAddress); printf("allowance: %" PRIu64 "\n", tokenAllowance); char *sendEthTx = sendEth(bobAddress, "100000000000000", getenv("BOB_PK")); printf("sent ETH: %s\n", sendEthTx); free(sendEthTx); char *sendErc20Tx = sendErc20(tokenAddress, bobAddress, "100000000000000", getenv("BOB_PK")); printf("sent Erc20: %s\n", sendErc20Tx); free(sendErc20Tx); return 0; }