signMessage
Signs an EIP-191 personal sign message via Solady's ERC-1271 PersonalSign format.
This Action is suitable to sign messages for contracts (e.g. ERC-4337 Smart Accounts) that implement (or conform to) Solady's ERC1271.sol.
With the calculated signature, you can use verifyMessage to verify the signature
Usage
import { account, walletClient } from './config'
 
const signature_1 = await walletClient.signMessage({ 
  // Account used for signing.
  account,
  message: 'hello world',
  // Verifying contract address (e.g. ERC-4337 Smart Account).
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2'
})
 
const signature_2 = await walletClient.signMessage({
  // Account used for signing.
  account,
  // Hex data representation of message.
  message: { raw: '0x68656c6c6f20776f726c64' },
  // Verifying contract address (e.g. ERC-4337 Smart Account)
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2'
})Account and/or Verifier Hoisting
If you do not wish to pass an account and/or verifier to every signMessage, you can also hoist the Account and/or Verifier on the Wallet Client (see config.ts).
import { walletClient } from './config'
 
const signature = await walletClient.signMessage({ 
  message: 'hello world',
})Returns
The signed message.
Parameters
account
- Type: Account | Address
Account to used to sign the message.
Accepts a JSON-RPC Account or Local Account (Private Key, etc).
import { walletClient } from './config'
 
const signature = await walletClient.signMessage({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266', 
  message: 'hello world',
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2'
})message
- Type: string | { raw: Hex | ByteArray }
Message to sign.
By default, viem signs the UTF-8 representation of the message.
import { walletClient } from './config'
 
const signature = await walletClient.signMessage({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  message: 'hello world', 
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2',
})To sign the data representation of the message, you can use the raw attribute.
import { walletClient } from './config'
 
const signature = await walletClient.signMessage({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  message: { raw: '0x68656c6c6f20776f726c64' }, 
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2',
})verifier
- Type: Address
The address of the verifying contract (e.g. a ERC-4337 Smart Account). Required if verifierDomain is not passed.
import { walletClient } from './config'
 
const signature = await walletClient.signMessage({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  message: 'hello world',
  verifier: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2', 
})verifierDomain
- Type: TypedDataDomain
Account domain separator. Required if verifier is not passed.
import { walletClient } from './config'
 
const signature = await walletClient.signMessage({
  account: '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266',
  message: 'hello world',
  verifierDomain: { 
    name: 'SoladyAccount', 
    version: '1', 
    chainId: 1, 
    verifyingContract: '0xCB9fA1eA9b8A3bf422a8639f23Df77ea66020eC2'
  }, 
})
