@atomiqlabs/chain-evm 1.0.0-dev.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (146) hide show
  1. package/LICENSE +201 -0
  2. package/dist/chains/citrea/CitreaChainType.d.ts +13 -0
  3. package/dist/chains/citrea/CitreaChainType.js +2 -0
  4. package/dist/chains/citrea/CitreaInitializer.d.ts +30 -0
  5. package/dist/chains/citrea/CitreaInitializer.js +120 -0
  6. package/dist/evm/btcrelay/BtcRelayAbi.d.ts +198 -0
  7. package/dist/evm/btcrelay/BtcRelayAbi.js +261 -0
  8. package/dist/evm/btcrelay/BtcRelayTypechain.d.ts +172 -0
  9. package/dist/evm/btcrelay/BtcRelayTypechain.js +2 -0
  10. package/dist/evm/btcrelay/EVMBtcRelay.d.ts +188 -0
  11. package/dist/evm/btcrelay/EVMBtcRelay.js +419 -0
  12. package/dist/evm/btcrelay/headers/EVMBtcHeader.d.ts +33 -0
  13. package/dist/evm/btcrelay/headers/EVMBtcHeader.js +84 -0
  14. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.d.ts +56 -0
  15. package/dist/evm/btcrelay/headers/EVMBtcStoredHeader.js +123 -0
  16. package/dist/evm/chain/EVMChainInterface.d.ts +51 -0
  17. package/dist/evm/chain/EVMChainInterface.js +90 -0
  18. package/dist/evm/chain/EVMModule.d.ts +9 -0
  19. package/dist/evm/chain/EVMModule.js +13 -0
  20. package/dist/evm/chain/modules/ERC20Abi.d.ts +168 -0
  21. package/dist/evm/chain/modules/ERC20Abi.js +225 -0
  22. package/dist/evm/chain/modules/EVMAddresses.d.ts +9 -0
  23. package/dist/evm/chain/modules/EVMAddresses.js +26 -0
  24. package/dist/evm/chain/modules/EVMBlocks.d.ts +20 -0
  25. package/dist/evm/chain/modules/EVMBlocks.js +64 -0
  26. package/dist/evm/chain/modules/EVMEvents.d.ts +36 -0
  27. package/dist/evm/chain/modules/EVMEvents.js +122 -0
  28. package/dist/evm/chain/modules/EVMFees.d.ts +35 -0
  29. package/dist/evm/chain/modules/EVMFees.js +73 -0
  30. package/dist/evm/chain/modules/EVMSignatures.d.ts +29 -0
  31. package/dist/evm/chain/modules/EVMSignatures.js +68 -0
  32. package/dist/evm/chain/modules/EVMTokens.d.ts +49 -0
  33. package/dist/evm/chain/modules/EVMTokens.js +105 -0
  34. package/dist/evm/chain/modules/EVMTransactions.d.ts +89 -0
  35. package/dist/evm/chain/modules/EVMTransactions.js +216 -0
  36. package/dist/evm/contract/EVMContractBase.d.ts +22 -0
  37. package/dist/evm/contract/EVMContractBase.js +34 -0
  38. package/dist/evm/contract/EVMContractModule.d.ts +8 -0
  39. package/dist/evm/contract/EVMContractModule.js +11 -0
  40. package/dist/evm/contract/modules/EVMContractEvents.d.ts +42 -0
  41. package/dist/evm/contract/modules/EVMContractEvents.js +75 -0
  42. package/dist/evm/events/EVMChainEvents.d.ts +22 -0
  43. package/dist/evm/events/EVMChainEvents.js +67 -0
  44. package/dist/evm/events/EVMChainEventsBrowser.d.ts +86 -0
  45. package/dist/evm/events/EVMChainEventsBrowser.js +294 -0
  46. package/dist/evm/spv_swap/EVMSpvVaultContract.d.ts +64 -0
  47. package/dist/evm/spv_swap/EVMSpvVaultContract.js +410 -0
  48. package/dist/evm/spv_swap/EVMSpvVaultData.d.ts +38 -0
  49. package/dist/evm/spv_swap/EVMSpvVaultData.js +159 -0
  50. package/dist/evm/spv_swap/EVMSpvWithdrawalData.d.ts +19 -0
  51. package/dist/evm/spv_swap/EVMSpvWithdrawalData.js +55 -0
  52. package/dist/evm/spv_swap/SpvVaultContractAbi.d.ts +91 -0
  53. package/dist/evm/spv_swap/SpvVaultContractAbi.js +849 -0
  54. package/dist/evm/spv_swap/SpvVaultContractTypechain.d.ts +450 -0
  55. package/dist/evm/spv_swap/SpvVaultContractTypechain.js +2 -0
  56. package/dist/evm/swaps/EVMSwapContract.d.ts +192 -0
  57. package/dist/evm/swaps/EVMSwapContract.js +373 -0
  58. package/dist/evm/swaps/EVMSwapData.d.ts +64 -0
  59. package/dist/evm/swaps/EVMSwapData.js +254 -0
  60. package/dist/evm/swaps/EVMSwapModule.d.ts +9 -0
  61. package/dist/evm/swaps/EVMSwapModule.js +11 -0
  62. package/dist/evm/swaps/EscrowManagerAbi.d.ts +120 -0
  63. package/dist/evm/swaps/EscrowManagerAbi.js +985 -0
  64. package/dist/evm/swaps/EscrowManagerTypechain.d.ts +475 -0
  65. package/dist/evm/swaps/EscrowManagerTypechain.js +2 -0
  66. package/dist/evm/swaps/handlers/IHandler.d.ts +13 -0
  67. package/dist/evm/swaps/handlers/IHandler.js +2 -0
  68. package/dist/evm/swaps/handlers/claim/ClaimHandlers.d.ts +10 -0
  69. package/dist/evm/swaps/handlers/claim/ClaimHandlers.js +13 -0
  70. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.d.ts +20 -0
  71. package/dist/evm/swaps/handlers/claim/HashlockClaimHandler.js +39 -0
  72. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.d.ts +24 -0
  73. package/dist/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.js +59 -0
  74. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.d.ts +25 -0
  75. package/dist/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.js +51 -0
  76. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.d.ts +21 -0
  77. package/dist/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.js +28 -0
  78. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.d.ts +48 -0
  79. package/dist/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.js +63 -0
  80. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.d.ts +17 -0
  81. package/dist/evm/swaps/handlers/refund/TimelockRefundHandler.js +28 -0
  82. package/dist/evm/swaps/modules/EVMLpVault.d.ts +69 -0
  83. package/dist/evm/swaps/modules/EVMLpVault.js +131 -0
  84. package/dist/evm/swaps/modules/EVMSwapClaim.d.ts +53 -0
  85. package/dist/evm/swaps/modules/EVMSwapClaim.js +101 -0
  86. package/dist/evm/swaps/modules/EVMSwapInit.d.ts +88 -0
  87. package/dist/evm/swaps/modules/EVMSwapInit.js +241 -0
  88. package/dist/evm/swaps/modules/EVMSwapRefund.d.ts +62 -0
  89. package/dist/evm/swaps/modules/EVMSwapRefund.js +132 -0
  90. package/dist/evm/typechain/common.d.ts +50 -0
  91. package/dist/evm/typechain/common.js +2 -0
  92. package/dist/evm/wallet/EVMSigner.d.ts +9 -0
  93. package/dist/evm/wallet/EVMSigner.js +16 -0
  94. package/dist/index.d.ts +37 -0
  95. package/dist/index.js +53 -0
  96. package/dist/utils/Utils.d.ts +15 -0
  97. package/dist/utils/Utils.js +71 -0
  98. package/package.json +37 -0
  99. package/src/chains/citrea/CitreaChainType.ts +28 -0
  100. package/src/chains/citrea/CitreaInitializer.ts +167 -0
  101. package/src/evm/btcrelay/BtcRelayAbi.ts +258 -0
  102. package/src/evm/btcrelay/BtcRelayTypechain.ts +371 -0
  103. package/src/evm/btcrelay/EVMBtcRelay.ts +517 -0
  104. package/src/evm/btcrelay/headers/EVMBtcHeader.ts +110 -0
  105. package/src/evm/btcrelay/headers/EVMBtcStoredHeader.ts +153 -0
  106. package/src/evm/chain/EVMChainInterface.ts +157 -0
  107. package/src/evm/chain/EVMModule.ts +21 -0
  108. package/src/evm/chain/modules/ERC20Abi.ts +222 -0
  109. package/src/evm/chain/modules/EVMAddresses.ts +24 -0
  110. package/src/evm/chain/modules/EVMBlocks.ts +75 -0
  111. package/src/evm/chain/modules/EVMEvents.ts +139 -0
  112. package/src/evm/chain/modules/EVMFees.ts +105 -0
  113. package/src/evm/chain/modules/EVMSignatures.ts +76 -0
  114. package/src/evm/chain/modules/EVMTokens.ts +115 -0
  115. package/src/evm/chain/modules/EVMTransactions.ts +246 -0
  116. package/src/evm/contract/EVMContractBase.ts +63 -0
  117. package/src/evm/contract/EVMContractModule.ts +16 -0
  118. package/src/evm/contract/modules/EVMContractEvents.ts +102 -0
  119. package/src/evm/events/EVMChainEvents.ts +81 -0
  120. package/src/evm/events/EVMChainEventsBrowser.ts +390 -0
  121. package/src/evm/spv_swap/EVMSpvVaultContract.ts +533 -0
  122. package/src/evm/spv_swap/EVMSpvVaultData.ts +201 -0
  123. package/src/evm/spv_swap/EVMSpvWithdrawalData.ts +70 -0
  124. package/src/evm/spv_swap/SpvVaultContractAbi.ts +846 -0
  125. package/src/evm/spv_swap/SpvVaultContractTypechain.ts +685 -0
  126. package/src/evm/swaps/EVMSwapContract.ts +590 -0
  127. package/src/evm/swaps/EVMSwapData.ts +367 -0
  128. package/src/evm/swaps/EVMSwapModule.ts +16 -0
  129. package/src/evm/swaps/EscrowManagerAbi.ts +982 -0
  130. package/src/evm/swaps/EscrowManagerTypechain.ts +723 -0
  131. package/src/evm/swaps/handlers/IHandler.ts +17 -0
  132. package/src/evm/swaps/handlers/claim/ClaimHandlers.ts +20 -0
  133. package/src/evm/swaps/handlers/claim/HashlockClaimHandler.ts +47 -0
  134. package/src/evm/swaps/handlers/claim/btc/BitcoinNoncedOutputClaimHandler.ts +82 -0
  135. package/src/evm/swaps/handlers/claim/btc/BitcoinOutputClaimHandler.ts +76 -0
  136. package/src/evm/swaps/handlers/claim/btc/BitcoinTxIdClaimHandler.ts +46 -0
  137. package/src/evm/swaps/handlers/claim/btc/IBitcoinClaimHandler.ts +115 -0
  138. package/src/evm/swaps/handlers/refund/TimelockRefundHandler.ts +38 -0
  139. package/src/evm/swaps/modules/EVMLpVault.ts +153 -0
  140. package/src/evm/swaps/modules/EVMSwapClaim.ts +141 -0
  141. package/src/evm/swaps/modules/EVMSwapInit.ts +292 -0
  142. package/src/evm/swaps/modules/EVMSwapRefund.ts +198 -0
  143. package/src/evm/typechain/common.ts +131 -0
  144. package/src/evm/wallet/EVMSigner.ts +23 -0
  145. package/src/index.ts +44 -0
  146. package/src/utils/Utils.ts +81 -0
@@ -0,0 +1,25 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { ChainSwapType } from "@atomiqlabs/base";
4
+ import { BitcoinCommitmentData, BitcoinWitnessData, IBitcoinClaimHandler } from "./IBitcoinClaimHandler";
5
+ import { Buffer } from "buffer";
6
+ import { EVMTx } from "../../../../chain/modules/EVMTransactions";
7
+ import { EVMSwapData } from "../../../EVMSwapData";
8
+ export type BitcoinOutputCommitmentData = {
9
+ output: Buffer;
10
+ amount: bigint;
11
+ };
12
+ export type BitcoinOutputWitnessData = BitcoinWitnessData & {
13
+ vout: number;
14
+ };
15
+ export declare class BitcoinOutputClaimHandler extends IBitcoinClaimHandler<BitcoinOutputCommitmentData, BitcoinOutputWitnessData> {
16
+ static readonly type: ChainSwapType;
17
+ static readonly gas: number;
18
+ protected serializeCommitment(data: BitcoinOutputCommitmentData & BitcoinCommitmentData): Buffer;
19
+ getWitness(signer: string, swapData: EVMSwapData, witnessData: BitcoinOutputWitnessData, feeRate?: string): Promise<{
20
+ initialTxns: EVMTx[];
21
+ witness: Buffer;
22
+ }>;
23
+ getGas(data: EVMSwapData): number;
24
+ getType(): ChainSwapType;
25
+ }
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BitcoinOutputClaimHandler = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const IBitcoinClaimHandler_1 = require("./IBitcoinClaimHandler");
6
+ const buffer_1 = require("buffer");
7
+ const ethers_1 = require("ethers");
8
+ const btc_signer_1 = require("@scure/btc-signer");
9
+ class BitcoinOutputClaimHandler extends IBitcoinClaimHandler_1.IBitcoinClaimHandler {
10
+ serializeCommitment(data) {
11
+ const txoHash = (0, ethers_1.solidityPackedKeccak256)(["uint64", "bytes32"], [data.amount, (0, ethers_1.keccak256)(data.output)]);
12
+ return buffer_1.Buffer.concat([
13
+ buffer_1.Buffer.from(txoHash.substring(2), "hex"),
14
+ super.serializeCommitment(data)
15
+ ]);
16
+ }
17
+ async getWitness(signer, swapData, witnessData, feeRate) {
18
+ if (!swapData.isClaimHandler(this.address))
19
+ throw new Error("Invalid claim handler");
20
+ const txBuffer = buffer_1.Buffer.from(witnessData.tx.hex, "hex");
21
+ const parsedBtcTx = btc_signer_1.Transaction.fromRaw(txBuffer);
22
+ const out = parsedBtcTx.getOutput(witnessData.vout);
23
+ const { initialTxns, commitment, blockheader, merkleProof } = await this._getWitness(signer, swapData, witnessData, {
24
+ output: buffer_1.Buffer.from(out.script),
25
+ amount: out.amount
26
+ });
27
+ const voutAndTxData = buffer_1.Buffer.concat([
28
+ base_1.BigIntBufferUtils.toBuffer(BigInt(witnessData.vout), "be", 4),
29
+ base_1.BigIntBufferUtils.toBuffer(BigInt(txBuffer.length), "be", 32),
30
+ txBuffer
31
+ ]);
32
+ return {
33
+ initialTxns,
34
+ witness: buffer_1.Buffer.concat([
35
+ commitment,
36
+ blockheader,
37
+ voutAndTxData,
38
+ merkleProof
39
+ ])
40
+ };
41
+ }
42
+ getGas(data) {
43
+ return BitcoinOutputClaimHandler.gas;
44
+ }
45
+ getType() {
46
+ return BitcoinOutputClaimHandler.type;
47
+ }
48
+ }
49
+ exports.BitcoinOutputClaimHandler = BitcoinOutputClaimHandler;
50
+ BitcoinOutputClaimHandler.type = base_1.ChainSwapType.CHAIN;
51
+ BitcoinOutputClaimHandler.gas = 40000;
@@ -0,0 +1,21 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { ChainSwapType } from "@atomiqlabs/base";
4
+ import { BitcoinCommitmentData, BitcoinWitnessData, IBitcoinClaimHandler } from "./IBitcoinClaimHandler";
5
+ import { Buffer } from "buffer";
6
+ import { EVMSwapData } from "../../../EVMSwapData";
7
+ import { EVMTx } from "../../../../chain/modules/EVMTransactions";
8
+ export type BitcoinTxIdCommitmentData = {
9
+ txId: string;
10
+ };
11
+ export declare class BitcoinTxIdClaimHandler extends IBitcoinClaimHandler<BitcoinTxIdCommitmentData, BitcoinWitnessData> {
12
+ static readonly type: ChainSwapType;
13
+ static readonly gas: number;
14
+ protected serializeCommitment(data: BitcoinTxIdCommitmentData & BitcoinCommitmentData): Buffer;
15
+ getWitness(signer: string, swapData: EVMSwapData, witnessData: BitcoinWitnessData, feeRate?: string): Promise<{
16
+ initialTxns: EVMTx[];
17
+ witness: Buffer;
18
+ }>;
19
+ getGas(data: EVMSwapData): number;
20
+ getType(): ChainSwapType;
21
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.BitcoinTxIdClaimHandler = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const IBitcoinClaimHandler_1 = require("./IBitcoinClaimHandler");
6
+ const buffer_1 = require("buffer");
7
+ class BitcoinTxIdClaimHandler extends IBitcoinClaimHandler_1.IBitcoinClaimHandler {
8
+ serializeCommitment(data) {
9
+ return buffer_1.Buffer.concat([
10
+ buffer_1.Buffer.from(data.txId, "hex").reverse(),
11
+ super.serializeCommitment(data)
12
+ ]);
13
+ }
14
+ getWitness(signer, swapData, witnessData, feeRate) {
15
+ if (!swapData.isClaimHandler(this.address))
16
+ throw new Error("Invalid claim handler");
17
+ return this._getWitness(signer, swapData, witnessData, { txId: witnessData.tx.txid });
18
+ }
19
+ getGas(data) {
20
+ return BitcoinTxIdClaimHandler.gas;
21
+ }
22
+ getType() {
23
+ return BitcoinTxIdClaimHandler.type;
24
+ }
25
+ }
26
+ exports.BitcoinTxIdClaimHandler = BitcoinTxIdClaimHandler;
27
+ BitcoinTxIdClaimHandler.type = base_1.ChainSwapType.CHAIN_TXID;
28
+ BitcoinTxIdClaimHandler.gas = 10000;
@@ -0,0 +1,48 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { IClaimHandler } from "../ClaimHandlers";
4
+ import { ChainSwapType, RelaySynchronizer } from "@atomiqlabs/base";
5
+ import { EVMBtcRelay } from "../../../../btcrelay/EVMBtcRelay";
6
+ import { EVMBtcStoredHeader } from "../../../../btcrelay/headers/EVMBtcStoredHeader";
7
+ import { EVMTx } from "../../../../chain/modules/EVMTransactions";
8
+ import { Buffer } from "buffer";
9
+ import { EVMSwapData } from "../../../EVMSwapData";
10
+ export type BitcoinCommitmentData = {
11
+ btcRelay: EVMBtcRelay<any>;
12
+ confirmations: number;
13
+ };
14
+ export type BitcoinWitnessData = {
15
+ tx: {
16
+ blockhash: string;
17
+ confirmations: number;
18
+ txid: string;
19
+ hex: string;
20
+ height: number;
21
+ };
22
+ requiredConfirmations: number;
23
+ commitedHeader?: EVMBtcStoredHeader;
24
+ btcRelay?: EVMBtcRelay<any>;
25
+ synchronizer?: RelaySynchronizer<EVMBtcStoredHeader, EVMTx, any>;
26
+ };
27
+ export declare abstract class IBitcoinClaimHandler<C, W extends BitcoinWitnessData> implements IClaimHandler<C & BitcoinCommitmentData, W> {
28
+ readonly address: string;
29
+ constructor(address: string);
30
+ static readonly address = "";
31
+ static readonly type: ChainSwapType;
32
+ static readonly gas: number;
33
+ protected serializeCommitment(data: BitcoinCommitmentData): Buffer;
34
+ getCommitment(data: C & BitcoinCommitmentData): string;
35
+ protected _getWitness(signer: string, swapData: EVMSwapData, { tx, btcRelay, commitedHeader, synchronizer, requiredConfirmations }: BitcoinWitnessData, commitment: C, feeRate?: string): Promise<{
36
+ initialTxns: EVMTx[];
37
+ witness: Buffer;
38
+ commitment: Buffer;
39
+ blockheader: Buffer;
40
+ merkleProof: Buffer;
41
+ }>;
42
+ abstract getWitness(signer: string, data: EVMSwapData, witnessData: W, feeRate?: string): Promise<{
43
+ initialTxns: EVMTx[];
44
+ witness: Buffer;
45
+ }>;
46
+ abstract getGas(data: EVMSwapData): number;
47
+ abstract getType(): ChainSwapType;
48
+ }
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.IBitcoinClaimHandler = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const EVMBtcRelay_1 = require("../../../../btcrelay/EVMBtcRelay");
6
+ const Utils_1 = require("../../../../../utils/Utils");
7
+ const ethers_1 = require("ethers");
8
+ const buffer_1 = require("buffer");
9
+ const logger = (0, Utils_1.getLogger)("IBitcoinClaimHandler: ");
10
+ class IBitcoinClaimHandler {
11
+ constructor(address) {
12
+ this.address = address;
13
+ }
14
+ serializeCommitment(data) {
15
+ const buffer = buffer_1.Buffer.alloc(24);
16
+ buffer.writeUint32BE(data.confirmations, 0);
17
+ buffer_1.Buffer.from(data.btcRelay.contractAddress.substring(2), "hex").copy(buffer, 4, 0, 20);
18
+ return buffer;
19
+ }
20
+ getCommitment(data) {
21
+ return (0, ethers_1.keccak256)(this.serializeCommitment(data));
22
+ }
23
+ async _getWitness(signer, swapData, { tx, btcRelay, commitedHeader, synchronizer, requiredConfirmations }, commitment, feeRate) {
24
+ const serializedCommitment = this.serializeCommitment({
25
+ ...commitment,
26
+ btcRelay,
27
+ confirmations: requiredConfirmations
28
+ });
29
+ const commitmentHash = (0, ethers_1.keccak256)(serializedCommitment);
30
+ if (!swapData.isClaimData(commitmentHash))
31
+ throw new Error("Invalid commit data");
32
+ const merkleProof = await btcRelay.bitcoinRpc.getMerkleProof(tx.txid, tx.blockhash);
33
+ logger.debug("getWitness(): merkle proof computed: ", merkleProof);
34
+ const txs = [];
35
+ if (commitedHeader == null) {
36
+ const headers = await EVMBtcRelay_1.EVMBtcRelay.getCommitedHeadersAndSynchronize(signer, btcRelay, [{ blockheight: tx.height, requiredConfirmations, blockhash: tx.blockhash }], txs, synchronizer, feeRate);
37
+ if (headers == null)
38
+ throw new Error("Cannot fetch committed header!");
39
+ commitedHeader = headers[tx.blockhash];
40
+ }
41
+ const serializedHeader = commitedHeader.serialize();
42
+ const serializedMerkleProof = buffer_1.Buffer.concat([
43
+ base_1.BigIntBufferUtils.toBuffer(BigInt(merkleProof.pos), "be", 4),
44
+ base_1.BigIntBufferUtils.toBuffer(BigInt(merkleProof.merkle.length), "be", 32),
45
+ ...merkleProof.merkle
46
+ ]);
47
+ return {
48
+ initialTxns: txs,
49
+ witness: buffer_1.Buffer.concat([
50
+ serializedCommitment,
51
+ serializedHeader,
52
+ serializedMerkleProof
53
+ ]),
54
+ commitment: serializedCommitment,
55
+ blockheader: serializedHeader,
56
+ merkleProof: serializedMerkleProof
57
+ };
58
+ }
59
+ }
60
+ exports.IBitcoinClaimHandler = IBitcoinClaimHandler;
61
+ IBitcoinClaimHandler.address = "";
62
+ IBitcoinClaimHandler.type = base_1.ChainSwapType.CHAIN_TXID;
63
+ IBitcoinClaimHandler.gas = 10000;
@@ -0,0 +1,17 @@
1
+ /// <reference types="node" />
2
+ /// <reference types="node" />
3
+ import { IHandler } from "../IHandler";
4
+ import { EVMSwapData } from "../../EVMSwapData";
5
+ import { EVMTx } from "../../../chain/modules/EVMTransactions";
6
+ export declare class TimelockRefundHandler implements IHandler<bigint, never> {
7
+ readonly address: string;
8
+ static readonly gas: number;
9
+ constructor(address: string);
10
+ getCommitment(data: bigint): string;
11
+ getWitness(signer: string, data: EVMSwapData): Promise<{
12
+ initialTxns: EVMTx[];
13
+ witness: Buffer;
14
+ }>;
15
+ getGas(): number;
16
+ static getExpiry(data: EVMSwapData): bigint;
17
+ }
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TimelockRefundHandler = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ class TimelockRefundHandler {
6
+ constructor(address) {
7
+ this.address = address;
8
+ }
9
+ getCommitment(data) {
10
+ return "0x" + base_1.BigIntBufferUtils.toBuffer(data, "be", 32).toString("hex");
11
+ }
12
+ getWitness(signer, data) {
13
+ const expiry = TimelockRefundHandler.getExpiry(data);
14
+ const currentTimestamp = BigInt(Math.floor(Date.now() / 1000));
15
+ if (expiry > currentTimestamp)
16
+ throw new Error("Not expired yet!");
17
+ return Promise.resolve({ initialTxns: [], witness: Buffer.alloc(0) });
18
+ }
19
+ getGas() {
20
+ return TimelockRefundHandler.gas;
21
+ }
22
+ static getExpiry(data) {
23
+ const expiryDataBuffer = Buffer.from(data.refundData.startsWith("0x") ? data.refundData.substring(2) : data.refundData, "hex");
24
+ return base_1.BigIntBufferUtils.fromBuffer(expiryDataBuffer, "be");
25
+ }
26
+ }
27
+ exports.TimelockRefundHandler = TimelockRefundHandler;
28
+ TimelockRefundHandler.gas = 5000;
@@ -0,0 +1,69 @@
1
+ import { IntermediaryReputationType } from "@atomiqlabs/base";
2
+ import { EVMSwapModule } from "../EVMSwapModule";
3
+ import { EVMTx } from "../../chain/modules/EVMTransactions";
4
+ export declare class EVMLpVault extends EVMSwapModule {
5
+ private static readonly GasCosts;
6
+ /**
7
+ * Action for withdrawing funds from the LP vault
8
+ *
9
+ * @param signer
10
+ * @param token
11
+ * @param amount
12
+ * @param feeRate
13
+ * @private
14
+ */
15
+ private Withdraw;
16
+ /**
17
+ * Action for depositing funds to the LP vault
18
+ *
19
+ * @param signer
20
+ * @param token
21
+ * @param amount
22
+ * @param feeRate
23
+ * @private
24
+ */
25
+ private Deposit;
26
+ /**
27
+ * Returns intermediary's reputation & vault balance for a specific token
28
+ *
29
+ * @param address
30
+ * @param token
31
+ */
32
+ getIntermediaryData(address: string, token: string): Promise<{
33
+ balance: bigint;
34
+ reputation: IntermediaryReputationType;
35
+ }>;
36
+ /**
37
+ * Returns intermediary's reputation for a specific token
38
+ *
39
+ * @param address
40
+ * @param token
41
+ */
42
+ getIntermediaryReputation(address: string, token: string): Promise<IntermediaryReputationType>;
43
+ /**
44
+ * Returns the balance of the token an intermediary has in his LP vault
45
+ *
46
+ * @param address
47
+ * @param token
48
+ */
49
+ getIntermediaryBalance(address: string, token: string): Promise<bigint>;
50
+ /**
51
+ * Creates transactions for withdrawing funds from the LP vault, creates ATA if it doesn't exist and unwraps
52
+ * WSOL to SOL if required
53
+ *
54
+ * @param signer
55
+ * @param token
56
+ * @param amount
57
+ * @param feeRate
58
+ */
59
+ txsWithdraw(signer: string, token: string, amount: bigint, feeRate?: string): Promise<EVMTx[]>;
60
+ /**
61
+ * Creates transaction for depositing funds into the LP vault, wraps SOL to WSOL if required
62
+ *
63
+ * @param signer
64
+ * @param token
65
+ * @param amount
66
+ * @param feeRate
67
+ */
68
+ txsDeposit(signer: string, token: string, amount: bigint, feeRate?: string): Promise<EVMTx[]>;
69
+ }
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMLpVault = void 0;
4
+ const EVMSwapModule_1 = require("../EVMSwapModule");
5
+ const EVMFees_1 = require("../../chain/modules/EVMFees");
6
+ class EVMLpVault extends EVMSwapModule_1.EVMSwapModule {
7
+ /**
8
+ * Action for withdrawing funds from the LP vault
9
+ *
10
+ * @param signer
11
+ * @param token
12
+ * @param amount
13
+ * @param feeRate
14
+ * @private
15
+ */
16
+ async Withdraw(signer, token, amount, feeRate) {
17
+ const tx = await this.swapContract.withdraw.populateTransaction(token, amount, signer);
18
+ tx.from = signer;
19
+ tx.gasLimit = BigInt(EVMLpVault.GasCosts.WITHDRAW);
20
+ EVMFees_1.EVMFees.applyFeeRate(tx, EVMLpVault.GasCosts.WITHDRAW, feeRate);
21
+ return tx;
22
+ }
23
+ /**
24
+ * Action for depositing funds to the LP vault
25
+ *
26
+ * @param signer
27
+ * @param token
28
+ * @param amount
29
+ * @param feeRate
30
+ * @private
31
+ */
32
+ async Deposit(signer, token, amount, feeRate) {
33
+ const tx = await this.swapContract.deposit.populateTransaction(token, amount, {
34
+ value: token.toLowerCase() === this.root.getNativeCurrencyAddress().toLowerCase() ? amount : 0n
35
+ });
36
+ tx.from = signer;
37
+ EVMFees_1.EVMFees.applyFeeRate(tx, EVMLpVault.GasCosts.DEPOSIT, feeRate);
38
+ return tx;
39
+ }
40
+ /**
41
+ * Returns intermediary's reputation & vault balance for a specific token
42
+ *
43
+ * @param address
44
+ * @param token
45
+ */
46
+ async getIntermediaryData(address, token) {
47
+ const [balance, reputation] = await Promise.all([
48
+ this.getIntermediaryBalance(address, token),
49
+ this.getIntermediaryReputation(address, token)
50
+ ]);
51
+ return { balance, reputation };
52
+ }
53
+ /**
54
+ * Returns intermediary's reputation for a specific token
55
+ *
56
+ * @param address
57
+ * @param token
58
+ */
59
+ async getIntermediaryReputation(address, token) {
60
+ const filter = Object.keys(this.contract.claimHandlersByAddress).map(claimHandler => ({ owner: address, token, claimHandler }));
61
+ const resp = await this.swapContract.getReputation(filter);
62
+ if (resp.length !== filter.length)
63
+ throw new Error("getIntermediaryReputation(): Invalid response length");
64
+ const result = {};
65
+ Object.keys(this.contract.claimHandlersByAddress).forEach((address, index) => {
66
+ const handler = this.contract.claimHandlersByAddress[address.toLowerCase()];
67
+ const handlerResp = resp[index];
68
+ result[handler.getType()] = {
69
+ successVolume: handlerResp[0].amount,
70
+ successCount: handlerResp[0].count,
71
+ coopCloseVolume: handlerResp[1].amount,
72
+ coopCloseCount: handlerResp[1].count,
73
+ failVolume: handlerResp[2].amount,
74
+ failCount: handlerResp[2].count,
75
+ };
76
+ });
77
+ return result;
78
+ }
79
+ /**
80
+ * Returns the balance of the token an intermediary has in his LP vault
81
+ *
82
+ * @param address
83
+ * @param token
84
+ */
85
+ async getIntermediaryBalance(address, token) {
86
+ const [balance] = await this.swapContract.getBalance([{ owner: address, token }]);
87
+ this.logger.debug("getIntermediaryBalance(): token LP balance fetched, token: " + token.toString() +
88
+ " address: " + address + " amount: " + (balance == null ? "null" : balance.toString()));
89
+ return balance;
90
+ }
91
+ /**
92
+ * Creates transactions for withdrawing funds from the LP vault, creates ATA if it doesn't exist and unwraps
93
+ * WSOL to SOL if required
94
+ *
95
+ * @param signer
96
+ * @param token
97
+ * @param amount
98
+ * @param feeRate
99
+ */
100
+ async txsWithdraw(signer, token, amount, feeRate) {
101
+ feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
102
+ const withdrawTx = await this.Withdraw(signer, token, amount, feeRate);
103
+ this.logger.debug("txsWithdraw(): withdraw TX created, token: " + token.toString() +
104
+ " amount: " + amount.toString(10));
105
+ return [withdrawTx];
106
+ }
107
+ /**
108
+ * Creates transaction for depositing funds into the LP vault, wraps SOL to WSOL if required
109
+ *
110
+ * @param signer
111
+ * @param token
112
+ * @param amount
113
+ * @param feeRate
114
+ */
115
+ async txsDeposit(signer, token, amount, feeRate) {
116
+ feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
117
+ const txs = [];
118
+ //Approve first
119
+ if (token.toLowerCase() !== this.root.getNativeCurrencyAddress().toLowerCase())
120
+ txs.push(await this.root.Tokens.Approve(signer, token, amount, this.contract.contractAddress, feeRate));
121
+ txs.push(await this.Deposit(signer, token, amount, feeRate));
122
+ this.logger.debug("txsDeposit(): deposit TX created, token: " + token.toString() +
123
+ " amount: " + amount.toString(10));
124
+ return txs;
125
+ }
126
+ }
127
+ exports.EVMLpVault = EVMLpVault;
128
+ EVMLpVault.GasCosts = {
129
+ WITHDRAW: 100000,
130
+ DEPOSIT: 100000
131
+ };
@@ -0,0 +1,53 @@
1
+ import { RelaySynchronizer } from "@atomiqlabs/base";
2
+ import { EVMSwapModule } from "../EVMSwapModule";
3
+ import { EVMSwapData } from "../EVMSwapData";
4
+ import { EVMTx } from "../../chain/modules/EVMTransactions";
5
+ import { EVMBtcStoredHeader } from "../../btcrelay/headers/EVMBtcStoredHeader";
6
+ export declare class EVMSwapClaim extends EVMSwapModule {
7
+ private static readonly GasCosts;
8
+ /**
9
+ * Claim action which uses the provided witness for claiming the swap
10
+ *
11
+ * @param signer
12
+ * @param swapData
13
+ * @param witness
14
+ * @param feeRate
15
+ * @param claimHandlerGas
16
+ * @private
17
+ */
18
+ private Claim;
19
+ /**
20
+ * Creates transactions claiming the swap using a secret (for HTLC swaps)
21
+ *
22
+ * @param signer
23
+ * @param swapData swap to claim
24
+ * @param secret hex encoded secret pre-image to the HTLC hash
25
+ * @param checkExpiry whether to check if the swap is already expired (trying to claim an expired swap with a secret
26
+ * is dangerous because we might end up revealing the secret to the counterparty without being able to claim the swap)
27
+ * @param feeRate fee rate to use for the transaction
28
+ */
29
+ txsClaimWithSecret(signer: string, swapData: EVMSwapData, secret: string, checkExpiry?: boolean, feeRate?: string): Promise<EVMTx[]>;
30
+ /**
31
+ * Creates transaction claiming the swap using a confirmed transaction data (for BTC on-chain swaps)
32
+ *
33
+ * @param signer
34
+ * @param swapData swap to claim
35
+ * @param tx bitcoin transaction that satisfies the swap condition
36
+ * @param requiredConfirmations
37
+ * @param vout vout of the bitcoin transaction that satisfies the swap condition
38
+ * @param commitedHeader commited header data from btc relay (fetched internally if null)
39
+ * @param synchronizer optional synchronizer to use in case we need to sync up the btc relay ourselves
40
+ * @param feeRate fee rate to be used for the transactions
41
+ */
42
+ txsClaimWithTxData(signer: string, swapData: EVMSwapData, tx: {
43
+ blockhash: string;
44
+ confirmations: number;
45
+ txid: string;
46
+ hex: string;
47
+ height: number;
48
+ }, requiredConfirmations: number, vout: number, commitedHeader?: EVMBtcStoredHeader, synchronizer?: RelaySynchronizer<EVMBtcStoredHeader, EVMTx, any>, feeRate?: string): Promise<EVMTx[] | null>;
49
+ /**
50
+ * Get the estimated starknet transaction fee of the claim transaction
51
+ */
52
+ getClaimFee(swapData: EVMSwapData, feeRate?: string): Promise<bigint>;
53
+ }
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EVMSwapClaim = void 0;
4
+ const base_1 = require("@atomiqlabs/base");
5
+ const EVMSwapModule_1 = require("../EVMSwapModule");
6
+ const EVMFees_1 = require("../../chain/modules/EVMFees");
7
+ class EVMSwapClaim extends EVMSwapModule_1.EVMSwapModule {
8
+ /**
9
+ * Claim action which uses the provided witness for claiming the swap
10
+ *
11
+ * @param signer
12
+ * @param swapData
13
+ * @param witness
14
+ * @param feeRate
15
+ * @param claimHandlerGas
16
+ * @private
17
+ */
18
+ async Claim(signer, swapData, witness, feeRate, claimHandlerGas) {
19
+ //TODO: Claim with success action not supported yet!
20
+ const tx = await this.swapContract.claim.populateTransaction(swapData.toEscrowStruct(), witness);
21
+ tx.from = signer;
22
+ EVMFees_1.EVMFees.applyFeeRate(tx, EVMSwapClaim.GasCosts.CLAIM + (claimHandlerGas ?? 0), feeRate);
23
+ return tx;
24
+ }
25
+ /**
26
+ * Creates transactions claiming the swap using a secret (for HTLC swaps)
27
+ *
28
+ * @param signer
29
+ * @param swapData swap to claim
30
+ * @param secret hex encoded secret pre-image to the HTLC hash
31
+ * @param checkExpiry whether to check if the swap is already expired (trying to claim an expired swap with a secret
32
+ * is dangerous because we might end up revealing the secret to the counterparty without being able to claim the swap)
33
+ * @param feeRate fee rate to use for the transaction
34
+ */
35
+ async txsClaimWithSecret(signer, swapData, secret, checkExpiry, feeRate) {
36
+ //We need to be sure that this transaction confirms in time, otherwise we reveal the secret to the counterparty
37
+ // and won't claim the funds
38
+ if (checkExpiry && await this.contract.isExpired(swapData.claimer.toString(), swapData)) {
39
+ throw new base_1.SwapDataVerificationError("Not enough time to reliably pay the invoice");
40
+ }
41
+ const claimHandler = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
42
+ if (claimHandler == null)
43
+ throw new base_1.SwapDataVerificationError("Unknown claim handler!");
44
+ if (claimHandler.getType() !== base_1.ChainSwapType.HTLC)
45
+ throw new base_1.SwapDataVerificationError("Invalid claim handler!");
46
+ feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
47
+ const { initialTxns, witness } = await claimHandler.getWitness(signer, swapData, secret, feeRate);
48
+ const tx = await this.Claim(signer, swapData, witness, feeRate, claimHandler.getGas(swapData));
49
+ this.logger.debug("txsClaimWithSecret(): creating claim transaction, swap: " + swapData.getClaimHash() + " witness: ", witness.toString("hex"));
50
+ return [...initialTxns, tx];
51
+ }
52
+ /**
53
+ * Creates transaction claiming the swap using a confirmed transaction data (for BTC on-chain swaps)
54
+ *
55
+ * @param signer
56
+ * @param swapData swap to claim
57
+ * @param tx bitcoin transaction that satisfies the swap condition
58
+ * @param requiredConfirmations
59
+ * @param vout vout of the bitcoin transaction that satisfies the swap condition
60
+ * @param commitedHeader commited header data from btc relay (fetched internally if null)
61
+ * @param synchronizer optional synchronizer to use in case we need to sync up the btc relay ourselves
62
+ * @param feeRate fee rate to be used for the transactions
63
+ */
64
+ async txsClaimWithTxData(signer, swapData, tx, requiredConfirmations, vout, commitedHeader, synchronizer, feeRate) {
65
+ const claimHandler = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
66
+ if (claimHandler == null)
67
+ throw new base_1.SwapDataVerificationError("Unknown claim handler!");
68
+ if (claimHandler.getType() !== base_1.ChainSwapType.CHAIN_NONCED &&
69
+ claimHandler.getType() !== base_1.ChainSwapType.CHAIN_TXID &&
70
+ claimHandler.getType() !== base_1.ChainSwapType.CHAIN)
71
+ throw new base_1.SwapDataVerificationError("Invalid claim handler!");
72
+ feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
73
+ const { initialTxns, witness } = await claimHandler.getWitness(signer, swapData, {
74
+ tx,
75
+ vout,
76
+ requiredConfirmations,
77
+ commitedHeader,
78
+ btcRelay: this.contract.btcRelay,
79
+ synchronizer,
80
+ }, feeRate);
81
+ const claimTx = await this.Claim(signer, swapData, witness, feeRate, claimHandler.getGas(swapData));
82
+ return [...initialTxns, claimTx];
83
+ }
84
+ /**
85
+ * Get the estimated starknet transaction fee of the claim transaction
86
+ */
87
+ async getClaimFee(swapData, feeRate) {
88
+ feeRate ?? (feeRate = await this.root.Fees.getFeeRate());
89
+ //TODO: Claim with success action not supported yet!
90
+ let gasRequired = EVMSwapClaim.GasCosts.CLAIM;
91
+ const claimHandler = this.contract.claimHandlersByAddress[swapData.claimHandler.toLowerCase()];
92
+ if (claimHandler != null)
93
+ gasRequired += claimHandler.getGas(swapData);
94
+ return EVMFees_1.EVMFees.getGasFee(gasRequired, feeRate);
95
+ }
96
+ }
97
+ exports.EVMSwapClaim = EVMSwapClaim;
98
+ EVMSwapClaim.GasCosts = {
99
+ CLAIM: 120000,
100
+ CLAIM_WITH_SUCCESS_ACTION: 150000
101
+ };