Shielded Write Contract
Executes a shielded write function on a contract, where the calldata is encrypted, with the same API as viem's writeContract.
What is a shielded write?
A shielded write is a function unique to Seismic's blockchain. It allows you to write to a contract with encrypted calldata.
A ShieldedWalletClient will perform this encryption automatically. Under the hood, what happens:
When you instantiate the client, it will:
- request a public key from Seismic's TEE
- generate an ephemeral private key
- create a shared secret & AES key from those two keys
When you build a shielded transaction:
- The client will encrypt calldata with the AES key
- It then includes the public key of the ephemerally generated key into the transaction payload
- The user will be prompted to sign the transaction
- The client sends the signed transaction to a Seismic node
- Seismic's blockchain will decrypt the calldata inside the TEE and execute the transaction
Import
import { shieldedWriteContract } from 'seismic-viem'Usage
Executes a shielded write function on a contract, where the calldata is encrypted. The API for this is the same as viem's writeContract.
import {
  createShieldedWalletClient,
  seismicDevnet,
  shieldedWriteContract,
} from 'seismic-viem'
import { custom, parseAbi } from 'viem'
 
const client = createShieldedWalletClient({
  chain: seismicDevnet,
  transport: custom(window.ethereum),
})
 
const hash = await shieldedWriteContract(client, {
  address: '0xFBA3912Ca04dd458c843e2EE08967fC04f3579c2',
  abi: parseAbi(['function mint(uint32 tokenId) nonpayable']),
  functionName: 'mint',
  args: [69420],
})Return Value
Promise<'0x${string}'> - A promise that resolves to a transaction hash.
Parameters
client
- Type: ShieldedWalletClient
The shielded wallet client to use for the transaction.
const hash = await shieldedWriteContract(client, {
  address: '0xFBA3912Ca04dd458c843e2EE08967fC04f3579c2',
  abi: parseAbi(['function mint(uint32 tokenId) nonpayable']),
  functionName: 'mint',
  args: [69420],
})parameters
- Type: WriteContractParameters
The configuration object for the write operation.
const hash = await shieldedWriteContract(client, {
  address: '0xFBA3912Ca04dd458c843e2EE08967fC04f3579c2', 
  abi: parseAbi(['function mint(uint32 tokenId) nonpayable']), 
  functionName: 'mint', 
  args: [69420], 
  // Optional parameters below
  gas: 100000n,
  gasPrice: 10000000000n,
  value: 0n,
})address
- Type: Address
The address of the contract.
abi
- Type: Abi
The contract's ABI.
functionName
- Type: string
The name of the contract function to call.
args
- Type: array
The arguments to pass to the contract function.
gas (optional)
- Type: bigint
Gas limit for the transaction.
gasPrice (optional)
- Type: bigint
Gas price for the transaction.
value (optional)
- Type: bigint
Value (native token amount) to send with the transaction.