UNPKG

zkverifyjs

Version:

Submit proofs to zkVerify and query proof state with ease using our npm package.

43 lines (42 loc) 2.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.verify = void 0; const transactions_1 = require("../../utils/transactions"); const enums_1 = require("../../enums"); const format_1 = require("../format"); const extrinsic_1 = require("../extrinsic"); const helpers_1 = require("../../utils/helpers"); const verify = async (connection, options, emitter, input) => { const { api } = connection; try { const selectedAccount = (0, helpers_1.getKeyringAccountIfAvailable)(connection, options.accountAddress); if (input.domainId != null) { options.domainId = input.domainId; } const transaction = (() => { if ('proofData' in input && input.proofData) { const { proof, publicSignals, vk } = input.proofData; const formatted = (0, format_1.format)(options.proofOptions, proof, publicSignals, vk, options.registeredVk); return (0, extrinsic_1.createSubmitProofExtrinsic)(api, options.proofOptions.proofType, formatted, input.domainId); } if ('extrinsic' in input && input.extrinsic) { return (0, helpers_1.toSubmittableExtrinsic)(input.extrinsic, api); } throw new Error('Invalid input: Either proofData or extrinsic must be provided.'); })(); const result = selectedAccount ? await (0, transactions_1.handleTransaction)(api, transaction, selectedAccount, undefined, emitter, options, enums_1.TransactionType.Verify) : 'injector' in connection ? await (0, transactions_1.handleTransaction)(api, transaction, connection.accountAddress, connection.injector.signer, emitter, options, enums_1.TransactionType.Verify) : (() => { throw new Error('Unsupported connection type.'); })(); return result; } catch (error) { emitter.emit(enums_1.ZkVerifyEvents.ErrorEvent, error); emitter.removeAllListeners(); throw error; } }; exports.verify = verify;