zkverifyjs
Version:
Submit proofs to zkVerify and query proof state with ease using our npm package.
126 lines (125 loc) • 5.17 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.handleTransaction = void 0;
exports.performSignAndSend = performSignAndSend;
const enums_1 = require("../../enums");
const errors_1 = require("./errors");
const helpers_1 = require("../helpers");
const transactionInfo_1 = require("./transactionInfo");
const handlers_1 = require("./handlers");
/**
* Handles transaction execution, signing, and event handling.
*/
const handleTransaction = async (api, submitExtrinsic, account, signer, emitter, options, transactionType, batchCount) => {
const transactionInfo = (0, transactionInfo_1.initializeTransactionInfo)(transactionType, options, batchCount);
return new Promise((resolve, reject) => {
let unsubscribeFn;
const cancelTransaction = (error) => {
if (unsubscribeFn) {
try {
unsubscribeFn();
}
catch (err) {
console.debug('Error during transaction cleanup:', err);
}
unsubscribeFn = undefined;
}
if (transactionInfo.status !== enums_1.TransactionStatus.Error) {
transactionInfo.status = enums_1.TransactionStatus.Error;
try {
const errObj = error instanceof Error ? error : new Error(String(error));
(0, errors_1.handleError)(emitter, api, transactionInfo, errObj, true);
}
catch (err) {
reject(err);
return;
}
}
reject(error);
};
const finalizeTransaction = async (result) => {
if (transactionInfo.status === enums_1.TransactionStatus.Error)
return;
try {
await (0, handlers_1.handleFinalized)(api, transactionInfo, result.dispatchError, emitter, transactionType);
if (unsubscribeFn) {
try {
unsubscribeFn();
}
catch (err) {
console.debug('Error during transaction cleanup:', err);
}
unsubscribeFn = undefined;
}
resolve(transactionInfo);
}
catch (error) {
cancelTransaction(error);
}
};
try {
const unsubscribeResult = performSignAndSend(submitExtrinsic, account, signer ? { signer, nonce: options.nonce } : { nonce: options.nonce }, async (result) => {
if (transactionInfo.status === enums_1.TransactionStatus.Error)
return;
try {
if (result.status.isBroadcast) {
const txHash = result.txHash.toString();
transactionInfo.txHash = txHash;
(0, helpers_1.safeEmit)(emitter, enums_1.ZkVerifyEvents.Broadcast, {
txHash,
});
}
if (result.status.isInBlock) {
if (!transactionInfo.txHash) {
transactionInfo.txHash = result.txHash.toString();
}
transactionInfo.blockHash = result.status.asInBlock.toString();
await (0, handlers_1.handleInBlock)(api, result.events, transactionInfo, emitter, transactionType);
}
if (result.status.isFinalized) {
await finalizeTransaction(result);
}
else if (result.status.isInvalid) {
throw new Error('Transaction is invalid.');
}
}
catch (error) {
cancelTransaction(error);
}
});
if (typeof unsubscribeResult === 'function') {
unsubscribeFn = unsubscribeResult;
}
else if (unsubscribeResult &&
typeof unsubscribeResult.then === 'function') {
unsubscribeResult
.then((fn) => {
if (typeof fn === 'function') {
unsubscribeFn = fn;
}
})
.catch((error) => {
cancelTransaction(error);
});
}
}
catch (error) {
cancelTransaction(error);
}
});
};
exports.handleTransaction = handleTransaction;
/**
* Handles signing and sending transactions.
*/
function performSignAndSend(submitExtrinsic, account, options, callback) {
if (typeof account === 'string' && options?.signer) {
return submitExtrinsic.signAndSend(account, options, callback);
}
else if (typeof account !== 'string') {
return options
? submitExtrinsic.signAndSend(account, options, callback)
: submitExtrinsic.signAndSend(account, callback);
}
throw new Error('Unsupported account or signer type.');
}