UNPKG

@biconomy/abstractjs

Version:

SDK for Biconomy integration with support for account abstraction, smart accounts, ERC-4337.

57 lines 2.18 kB
import { sendUserOperation, waitForUserOperationReceipt } from "viem/account-abstraction"; import { getAction, parseAccount } from "viem/utils"; import { AccountNotFoundError } from "../../../account/utils/AccountNotFound.js"; /** * Creates, signs, and sends a new transaction to the network using a smart account. * This function also allows you to sponsor this transaction if the sender is a smart account. * * @param client - The client instance. * @param args - Parameters for sending the transaction or user operation. * @returns The transaction hash as a hexadecimal string. * @throws {AccountNotFoundError} If the account is not found. * * @example * import { sendTransaction } from '@biconomy/abstractjs' * * const hash = await sendTransaction(nexusClient, { * to: '0x...', * value: parseEther('0.1'), * data: '0x...' * }) * console.log(hash) // '0x...' */ export async function sendTransaction(client, args) { let userOpHash; if ("to" in args) { const { account: account_ = client.account, data, maxFeePerGas, maxPriorityFeePerGas, to, value, nonce } = args; if (!account_) { throw new AccountNotFoundError({ docsPath: "/nexus-client/methods#sendtransaction" }); } const account = parseAccount(account_); if (!to) throw new Error("Missing to address"); userOpHash = await getAction(client, sendUserOperation, "sendUserOperation")({ calls: [ { to, value: value || BigInt(0), data: data || "0x" } ], account, maxFeePerGas, maxPriorityFeePerGas, nonce: nonce ? BigInt(nonce) : undefined }); } else { userOpHash = await getAction(client, sendUserOperation, "sendUserOperation")({ ...args }); } const userOperationReceipt = await getAction(client, waitForUserOperationReceipt, "waitForUserOperationReceipt")({ hash: userOpHash }); return userOperationReceipt?.receipt.transactionHash; } //# sourceMappingURL=sendTransaction.js.map