UNPKG

@atomiqlabs/sdk-lib

Version:

Basic SDK functionality library for atomiq

59 lines (52 loc) 2.21 kB
import {BitcoinRpc, BtcBlock, BtcTx} from "@atomiqlabs/base"; import {Buffer} from "buffer"; export type BtcTxWithBlockheight = BtcTx & { blockheight?: number }; export interface BitcoinRpcWithTxoListener<T extends BtcBlock> extends BitcoinRpc<T> { getTransaction(txId: string): Promise<BtcTxWithBlockheight>; /** * Returns an estimate after which time the tx will confirm with the required amount of confirmations, * confirmationDelay of -1 means the transaction won't confirm in the near future * * @param tx * @param requiredConfirmations * @private * * @returns estimated confirmation delay, -1 if the transaction won't confirm in the near future, null if the * transaction was replaced or was confirmed in the meantime */ getConfirmationDelay(tx: BtcTx, requiredConfirmations: number): Promise<number | null> /** * Checks if an address received the transaction with the required txoHash, returns info about that * specific transaction if found, or null if not found * * @param address Address that should receive the transaction * @param txoHash Required output txoHash */ checkAddressTxos(address: string, txoHash: Buffer): Promise<{ tx: BtcTxWithBlockheight, vout: number } | null>; /** * Waits till the address receives a transaction containing a specific txoHash * * @param address Address that should receive the transaction * @param txoHash Required output txoHash * @param requiredConfirmations Required confirmations of the transaction * @param stateUpdateCbk Callback for transaction state updates * @param abortSignal Abort signal * @param intervalSeconds How often to check new transaction */ waitForAddressTxo( address: string, txoHash: Buffer, requiredConfirmations: number, stateUpdateCbk:(confirmations: number, txId: string, vout: number, txEtaMS: number) => void, abortSignal?: AbortSignal, intervalSeconds?: number ): Promise<{ tx: BtcTxWithBlockheight, vout: number }>; }