UNPKG

viem

Version:

TypeScript Interface for Ethereum

54 lines 2.06 kB
import { contract2FactoryAddress, contractDeployerAddress, } from '../constants/address.js'; import { encodeDeployData, } from '../utils/abi/encodeDeployData.js'; import { sendEip712Transaction, } from './sendEip712Transaction.js'; /** * Deploys a contract to the network, given bytecode and constructor arguments using EIP712 transaction. * * - Docs: https://viem.sh/docs/contract/deployContract * * @param walletClient - Client to use * @param parameters - {@link DeployContractParameters} * @returns The [Transaction](https://viem.sh/docs/glossary/terms#transaction) hash. {@link DeployContractReturnType} * * @example * import { createWalletClient, custom } from 'viem' * import { privateKeyToAccount } from 'viem/accounts' * import { zksync } from 'viem/chains' * import { deployContract } from 'viem/zksync' * * const client = createWalletClient({ * account: privateKeyToAccount('0x…'), * chain: zksync, * transport: custom(provider), * }) * const hash = await deployContract(client, { * abi: [], * account: '0x…, * deploymentType: 'create', * bytecode: '0x608060405260405161083e38038061083e833981016040819052610...', * factoryDeps: ['0x608060405260405161083e38038061083e833981016040819052610...'], * gasPerPubdata: 50000n * }) */ export function deployContract(walletClient, parameters) { const { abi, args, bytecode, deploymentType, salt, ...request } = parameters; const data = encodeDeployData({ abi, args, bytecode, deploymentType, salt, }); // Add the bytecode to the factoryDeps if it's not already there request.factoryDeps = request.factoryDeps || []; if (!request.factoryDeps.includes(bytecode)) request.factoryDeps.push(bytecode); return sendEip712Transaction(walletClient, { ...request, data, to: deploymentType === 'create2' || deploymentType === 'create2Account' ? contract2FactoryAddress : contractDeployerAddress, }); } //# sourceMappingURL=deployContract.js.map