deployContract
Deploys a contract to the network, given bytecode & constructor arguments by using EIP712 transaction.
Usage
example.ts
import { wagmiAbi } from './abi'
import { account, walletClient } from './config'
const hash = await walletClient.deployContract({
abi,
account,
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
})
Deploying with Constructor Args
example.ts
import { deployContract } from 'viem'
import { wagmiAbi } from './abi'
import { account, walletClient } from './config'
const hash = await walletClient.deployContract({
abi,
account,
args: [69420],
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
})
Deploying with Factory Deps
example.ts
import { deployContract } from 'viem'
import { wagmiAbi } from './abi'
import { account, walletClient } from './config'
const hash = await walletClient.deployContract({
abi,
account,
args: [69420],
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
factoryDeps: [
'0x702040405260405161083e38038061083e833981016040819123456...',
'0x102030405260405161083e38038061083e833981016040819112233...'
]
})
Returns
The Transaction hash.
Parameters
abi
- Type:
Abi
The contract's ABI.
const hash = await walletClient.deployContract({
abi: wagmiAbi,
account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
})
account
- Type:
Account | Address
The Account to deploy the contract from.
Accepts a JSON-RPC Account or Local Account (Private Key, etc).
const hash = await walletClient.deployContract({
abi: wagmiAbi,
account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
})
bytecode
- Type:
Hex
The contract's bytecode.
const hash = await walletClient.deployContract({
abi: wagmiAbi,
account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
})
args
- Type: Inferred from ABI.
Constructor arguments to call upon deployment.
const hash = await walletClient.deployContract({
abi: wagmiAbi,
account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
args: [69]
})
deploymentType (optional)
- Type:
'create' | 'create2' | 'createAccount' | 'create2Account'
Specifies the type of contract deployment. Defaults to 'create'.
const hash = await walletClient.deployContract({
abi: wagmiAbi,
account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
args: [69],
deploymentType: 'create2'
})
salt (optional)
- Type:
Hash
Specifies a unique identifier for the contract deployment.
const hash = await walletClient.deployContract({
abi: wagmiAbi,
account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
bytecode: '0x608060405260405161083e38038061083e833981016040819052610...',
args: [69],
salt: '0x201050...'
})
gasPerPubdata (optional)
- Type:
bigint
The amount of gas for publishing one byte of data on Ethereum.
const hash = await walletClient.sendTransaction({
account,
to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
gasPerPubdata: 50000,
nonce: 69,
value: 1000000000000000000n
})
paymaster (optional)
- Type:
Account | Address
Address of the paymaster account that will pay the fees. The paymasterInput
field is required with this one.
const hash = await walletClient.sendTransaction({
account,
to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
paymaster: '0x4B5DF730c2e6b28E17013A1485E5d9BC41Efe021',
paymasterInput: '0x8c5a...'
nonce: 69,
value: 1000000000000000000n
})
paymasterInput (optional)
- Type:
0x${string}
Input data to the paymaster. The paymaster
field is required with this one.
const hash = await walletClient.sendTransaction({
account,
to: '0x70997970c51812dc3a010c7d01b50e0d17dc79c8',
paymaster: '0x4B5DF730c2e6b28E17013A1485E5d9BC41Efe021',
paymasterInput: '0x8c5a...'
nonce: 69,
value: 1000000000000000000n
})