@bsv/wallet-toolbox-client
Version:
Client only Wallet Storage
41 lines • 1.88 kB
TypeScript
import { Beef } from '@bsv/sdk';
import { StorageProvider } from '../StorageProvider';
import { EntityProvenTxReq } from '../schema/entities';
import * as sdk from '../../sdk';
/**
* Attempt to post one or more `ProvenTxReq` with status 'unsent'
* to the bitcoin network.
*
* @param reqs
*/
export declare function attemptToPostReqsToNetwork(storage: StorageProvider, reqs: EntityProvenTxReq[], trx?: sdk.TrxToken): Promise<PostReqsToNetworkResult>;
/**
* Indicates status of a new Action following a `createAction` or `signAction` in immediate mode:
* When `acceptDelayedBroadcast` is falses.
*
* 'success': The action has been broadcast and accepted by the bitcoin processing network.
* 'doulbeSpend': The action has been confirmed to double spend one or more inputs, and by the "first-seen-rule" is the loosing transaction.
* 'invalidTx': The action was rejected by the processing network as an invalid bitcoin transaction.
* 'serviceError': The broadcast services are currently unable to reach the bitcoin network. The action is now queued for delayed retries.
*
* 'invalid': The action was in an invalid state for processing, this status should never be seen by user code.
* 'unknown': An internal processing error has occured, this status should never be seen by user code.
*
*/
export type PostReqsToNetworkDetailsStatus = 'success' | 'doubleSpend' | 'unknown' | 'invalid' | 'serviceError' | 'invalidTx';
export interface PostReqsToNetworkDetails {
txid: string;
req: EntityProvenTxReq;
status: PostReqsToNetworkDetailsStatus;
/**
* Any competing double spend txids reported for this txid
*/
competingTxs?: string[];
}
export interface PostReqsToNetworkResult {
status: 'success' | 'error';
beef: Beef;
details: PostReqsToNetworkDetails[];
log: string;
}
//# sourceMappingURL=attemptToPostReqsToNetwork.d.ts.map