UNPKG

@atomiqlabs/chain-starknet

Version:

Starknet specific base implementation

68 lines (53 loc) 2.47 kB
import {StarknetSwapData} from "../../../StarknetSwapData"; import {StarknetGas} from "../../../../base/StarknetAction"; import {ChainSwapType} from "@atomiqlabs/base"; import {BigNumberish, hash} from "starknet"; import {StarknetTx} from "../../../../base/modules/StarknetTransactions"; import {bufferToByteArray, getLogger, poseidonHashRange, toBigInt} from "../../../../../utils/Utils"; import {BitcoinCommitmentData, BitcoinWitnessData, IBitcoinClaimHandler} from "./IBitcoinClaimHandler"; import {Transaction} from "@scure/btc-signer"; import {Buffer} from "buffer"; export type BitcoinOutputCommitmentData = { output: Buffer, amount: bigint }; export type BitcoinOutputWitnessData = BitcoinWitnessData & { vout: number }; const logger = getLogger("BitcoinOutputClaimHandler: "); export class BitcoinOutputClaimHandler extends IBitcoinClaimHandler<BitcoinOutputCommitmentData, BitcoinOutputWitnessData> { public static readonly type: ChainSwapType = ChainSwapType.CHAIN; public static readonly gas: StarknetGas = {l1: 20000}; protected serializeCommitment(data: BitcoinOutputCommitmentData & BitcoinCommitmentData): BigNumberish[] { return [ hash.computePoseidonHashOnElements([toBigInt(data.amount), poseidonHashRange(data.output)]), ...super.serializeCommitment(data) ]; } async getWitness( signer: string, swapData: StarknetSwapData, witnessData: BitcoinOutputWitnessData, feeRate?: string ): Promise<{ initialTxns: StarknetTx[]; witness: BigNumberish[] }> { if(!swapData.isClaimHandler(this.address)) throw new Error("Invalid claim handler"); const parsedBtcTx = Transaction.fromRaw(Buffer.from(witnessData.tx.hex, "hex")); const out = parsedBtcTx.getOutput(witnessData.vout); const {initialTxns, witness} = await this._getWitness(signer, swapData, witnessData, { output: Buffer.from(out.script), amount: out.amount }); witness.push(...bufferToByteArray(Buffer.from(witnessData.tx.hex, "hex"))); witness.push(BigInt(witnessData.vout)); return {initialTxns, witness}; } getGas(data: StarknetSwapData): StarknetGas { return BitcoinOutputClaimHandler.gas; } getType(): ChainSwapType { return BitcoinOutputClaimHandler.type; } }