Skip to content
On this page

writeSendMessage

Executes a sendMessage call to the L1CrossDomainMessenger contract. This is a fairly low level function and generally it will be more convenient to use writeContractDeposit.

WARNING

From Viem writeContract, which this function uses internally.

The writeContract internally sends a transaction – it does not validate if the contract write will succeed (the contract may throw an error). It is highly recommended to simulate the contract write with simulateContract before you execute it.

In this case, you can use simulateSendMessage.

ts
import { SendMessageParameters } from 'op-viem'
import { baseAddresses } from 'op-viem/chains'
import { account, opStackL1WalletClient } from './config'

const args: SendMessageParameters = {
  target: '0x00008453e27e8e88f305f13cf27c30d724fdd055',
  minGasLimit: 85000,
  message: '0x8c874ebd0021fb3f',
}

const hash = await opStackL1WalletClient.writeSendMessage({
  args,
  ...baseAddresses,
  value: 1n,
})
ts
import { createWalletClient, custom } from 'viem'
import { privateKeyToAccount } from 'viem/accounts'
import { mainnet } from 'viem/chains'
import { walletL1OpStackActions } from 'op-viem'

export const opStackL1WalletClient = createWalletClient({
  chain: mainnet,
  transport: custom(window.ethereum)
}).extend(walletL1OpStackActions)

// JSON-RPC Account
export const [account] = await walletClient.getAddresses()
// Local Account
export const account = privateKeyToAccount(...)

Return Value

Hash

A Transaction Hash.

writeContract only returns a Transaction Hash. If you would like to retrieve the return data of a write function, you can use the [simulatSendMessage action] – this action does not execute a transaction, and does not require gas.

Parameters

args

  • target

    • Type: Address
    • The to address of the L2 transaction.
  • minGasLimit

    • Type: number
    • The minimum gas limit for the L2 transaction. This will be padded to account for some overhead on the OPStack contract calls.
  • message (optional)

    • Type: Hex
    • Default: 0x
    • The calldata of the L2 transaction
ts
await walletClient.writeSendMessage({
  args: { 
    target: '0x00008453e27e8e88f305f13cf27c30d724fdd055',
    minGasLimit: 85000,
    message: '0x8c874ebd0021fb3f',
  }
  ...baseAddresses
})

l1CrossDomainMessenger

The L1CrossDomainMessenger contract where the sendMessage call should be made.

ts
await walletClient.writeSendMessage({
  args,
  l1CrossDomainMessengerAddress: messenger, 
})

value (optional)

  • Type: number

Value in wei sent with this transaction. This value will be credited to the balance of the caller address on L2 before the L2 transaction created by this transaction is made.

ts
await walletClient.writeSendMessage({
  args,
  l1CrossDomainMessengerAddress: messenger,
  value: parseEther(1), 
})

TIP

account, accessList, chain, dataSuffix, gasPrice, maxFeePerGas, maxPriorityFeePerGas, and nonce can all also be passed and behave as with any viem writeContract call. See their documentation for more details.