useSignTypedData ​
Hook for signing typed data and calculating an Ethereum-specific EIP-712 signature.
Import ​
import { useSignTypedData } from 'wagmi'
import { useSignTypedData } from 'wagmi'
Usage ​
import { useSignTypedData } from 'wagmi'
function App() {
const { signTypedData } = useSignTypedData()
return (
<button
onClick={() =>
signTypedData({
types: {
Person: [
{ name: 'name', type: 'string' },
{ name: 'wallet', type: 'address' },
],
Mail: [
{ name: 'from', type: 'Person' },
{ name: 'to', type: 'Person' },
{ name: 'contents', type: 'string' },
],
},
primaryType: 'Mail',
message: {
from: {
name: 'Cow',
wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
},
to: {
name: 'Bob',
wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
},
contents: 'Hello, Bob!',
},
})
}
>
Sign message
</button>
)
}
import { useSignTypedData } from 'wagmi'
function App() {
const { signTypedData } = useSignTypedData()
return (
<button
onClick={() =>
signTypedData({
types: {
Person: [
{ name: 'name', type: 'string' },
{ name: 'wallet', type: 'address' },
],
Mail: [
{ name: 'from', type: 'Person' },
{ name: 'to', type: 'Person' },
{ name: 'contents', type: 'string' },
],
},
primaryType: 'Mail',
message: {
from: {
name: 'Cow',
wallet: '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',
},
to: {
name: 'Bob',
wallet: '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',
},
contents: 'Hello, Bob!',
},
})
}
>
Sign message
</button>
)
}
import { http, createConfig } from 'wagmi'
import { mainnet, sepolia } from 'wagmi/chains'
export const config = createConfig({
chains: [mainnet, sepolia],
transports: {
[mainnet.id]: http(),
[sepolia.id]: http(),
},
})
import { http, createConfig } from 'wagmi'
import { mainnet, sepolia } from 'wagmi/chains'
export const config = createConfig({
chains: [mainnet, sepolia],
transports: {
[mainnet.id]: http(),
[sepolia.id]: http(),
},
})
Parameters ​
import { type UseSignTypedDataParameters } from 'wagmi'
import { type UseSignTypedDataParameters } from 'wagmi'
config ​
Config | undefined
Config
to use instead of retrieving from the from nearest WagmiProvider
.
import { useSignTypedData } from 'wagmi'
import { config } from './config'
function App() {
const result = useSignTypedData({
config,
})
}
import { useSignTypedData } from 'wagmi'
import { config } from './config'
function App() {
const result = useSignTypedData({
config,
})
}
import { http, createConfig } from 'wagmi'
import { mainnet, sepolia } from 'wagmi/chains'
export const config = createConfig({
chains: [mainnet, sepolia],
transports: {
[mainnet.id]: http(),
[sepolia.id]: http(),
},
})
import { http, createConfig } from 'wagmi'
import { mainnet, sepolia } from 'wagmi/chains'
export const config = createConfig({
chains: [mainnet, sepolia],
transports: {
[mainnet.id]: http(),
[sepolia.id]: http(),
},
})
mutation ​
TanStack Query parameters. See the TanStack Query mutation docs for more info.
gcTime ​
number | Infinity | undefined
- The time in milliseconds that unused/inactive cache data remains in memory. When a mutation's cache becomes unused or inactive, that cache data will be garbage collected after this duration. When different cache times are specified, the longest one will be used.
- If set to
Infinity
, will disable garbage collection
meta ​
Record<string, unknown> | undefined
If set, stores additional information on the mutation cache entry that can be used as needed. It will be accessible wherever signTypedData
is available (e.g. onError
, onSuccess
functions).
networkMode ​
'online' | 'always' | 'offlineFirst' | undefined
- defaults to
'online'
- see Network Mode for more information.
onError ​
((error: SignTypedDataErrorType, variables: SignTypedDataVariables, context?: context | undefined) => Promise<unknown> | unknown) | undefined
This function will fire if the mutation encounters an error and will be passed the error.
onMutate ​
((variables: SignTypedDataVariables) => Promise<context | void> | context | void) | undefined
- This function will fire before the mutation function is fired and is passed the same variables the mutation function would receive
- Useful to perform optimistic updates to a resource in hopes that the mutation succeeds
- The value returned from this function will be passed to both the
onError
andonSettled
functions in the event of a mutation failure and can be useful for rolling back optimistic updates.
onSuccess ​
((data: SignTypedDataData, variables: SignTypedDataVariables, context?: context | undefined) => Promise<unknown> | unknown) | undefined
This function will fire when the mutation is successful and will be passed the mutation's result.
onSettled ​
((data: SignTypedDataData, error: SignTypedDataErrorType, variables: SignTypedDataVariables, context?: context | undefined) => Promise<unknown> | unknown) | undefined
This function will fire when the mutation is either successfully fetched or encounters an error and be passed either the data or error
queryClient ​
QueryClient
Use this to use a custom QueryClient
. Otherwise, the one from the nearest context will be used.
retry ​
boolean | number | ((failureCount: number, error: SignTypedDataErrorType) => boolean) | undefined
- Defaults to
0
. - If
false
, failed mutations will not retry. - If
true
, failed mutations will retry infinitely. - If set to an
number
, e.g.3
, failed mutations will retry until the failed mutations count meets that number.
retryDelay ​
number | ((retryAttempt: number, error: SignTypedDataErrorType) => number) | undefined
- This function receives a
retryAttempt
integer and the actual Error and returns the delay to apply before the next attempt in milliseconds. - A function like
attempt => Math.min(attempt > 1 ? 2 ** attempt * 1000 : 1000, 30 * 1000)
applies exponential backoff. - A function like
attempt => attempt * 1000
applies linear backoff.
Return Type ​
import { type UseSignTypedDataReturnType } from 'wagmi'
import { type UseSignTypedDataReturnType } from 'wagmi'
signTypedData ​
(variables: SignTypedDataVariables, { onSuccess, onSettled, onError }) => void
The mutation function you can call with variables to trigger the mutation and optionally hooks on additional callback options.
variables ​
SignTypedDataVariables
The variables object to pass to the
signTypedData
action.onSuccess ​
(data: SignTypedDataData, variables: SignTypedDataVariables, context: TContext) => void
This function will fire when the mutation is successful and will be passed the mutation's result.
onError ​
(error: SignTypedDataErrorType, variables: SignTypedDataVariables, context: TContext | undefined) => void
This function will fire if the mutation encounters an error and will be passed the error.
onSettled ​
(data: SignTypedDataData | undefined, error: SignTypedDataErrorType | null, variables: SignTypedDataVariables, context: TContext | undefined) => void
- This function will fire when the mutation is either successfully fetched or encounters an error and be passed either the data or error
- If you make multiple requests,
onSuccess
will fire only after the latest call you've made.
signTypedDataAsync ​
(variables: SignTypedDataVariables, { onSuccess, onSettled, onError }) => Promise<SignTypedDataData>
Similar to signTypedData
but returns a promise which can be awaited.
data ​
SignTypedDataData | undefined
- Defaults to
undefined
- The last successfully resolved data for the mutation.
error ​
SignTypedDataErrorType | null
The error object for the mutation, if an error was encountered.
failureCount ​
number
- The failure count for the mutation.
- Incremented every time the mutation fails.
- Reset to
0
when the mutation succeeds.
failureReason ​
SignTypedDataErrorType | null
- The failure reason for the mutation retry.
- Reset to
null
when the mutation succeeds.
isError / isIdle / isPending / isSuccess ​
boolean
Boolean variables derived from status
.
isPaused ​
boolean
- will be
true
if the mutation has beenpaused
. - see Network Mode for more information.
reset ​
() => void
A function to clean the mutation internal state (e.g. it resets the mutation to its initial state).
status ​
'idle' | 'pending' | 'error' | 'success'
'idle'
initial status prior to the mutation function executing.'pending'
if the mutation is currently executing.'error'
if the last mutation attempt resulted in an error.'success'
if the last mutation attempt was successful.
submittedAt ​
number
- The timestamp for when the mutation was submitted.
- Defaults to
0
.
variables ​
SignTypedDataVariables | undefined
- The variables object passed to
signTypedData
. - Defaults to
undefined
.
Type Inference ​
With types
setup correctly, TypeScript will infer the correct types for domain
, message
, and primaryType
. See the Wagmi TypeScript docs for more information.
ts
const {signTypedData } =useSignTypedData ()ÂsignTypedData ({types : {Person : [{name : 'name',type : 'string' },{name : 'wallet',type : 'address' },],{name : 'from',type : 'Person' },{name : 'to',type : 'Person' },{name : 'contents',type : 'string' },],},primaryType : 'Mail',message : {from : {name : 'Cow',wallet : '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',},to : {name : 'Bob',wallet : '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',},contents : 'Hello, Bob!',},})
ts
const {signTypedData } =useSignTypedData ()ÂsignTypedData ({types : {Person : [{name : 'name',type : 'string' },{name : 'wallet',type : 'address' },],{name : 'from',type : 'Person' },{name : 'to',type : 'Person' },{name : 'contents',type : 'string' },],},primaryType : 'Mail',message : {from : {name : 'Cow',wallet : '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',},to : {name : 'Bob',wallet : '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',},contents : 'Hello, Bob!',},})
ts
consttypes = {Person : [{name : 'name',type : 'string' },{name : 'wallet',type : 'address' },],{name : 'from',type : 'Person' },{name : 'to',type : 'Person' },{name : 'contents',type : 'string' },],} asconst Âconst {signTypedData } =useSignTypedData ()ÂsignTypedData ({types ,primaryType : 'Mail',message : {from : {name : 'Cow',wallet : '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',},to : {name : 'Bob',wallet : '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',},contents : 'Hello, Bob!',},})
ts
consttypes = {Person : [{name : 'name',type : 'string' },{name : 'wallet',type : 'address' },],{name : 'from',type : 'Person' },{name : 'to',type : 'Person' },{name : 'contents',type : 'string' },],} asconst Âconst {signTypedData } =useSignTypedData ()ÂsignTypedData ({types ,primaryType : 'Mail',message : {from : {name : 'Cow',wallet : '0xCD2a3d9F938E13CD947Ec05AbC7FE734Df8DD826',},to : {name : 'Bob',wallet : '0xbBbBBBBbbBBBbbbBbbBbbbbBBbBbbbbBbBbbBBbB',},contents : 'Hello, Bob!',},})
TanStack Query ​
import {
type SignTypedDataData,
type SignTypedDataVariables,
type SignTypedDataMutate,
type SignTypedDataMutateAsync,
signTypedDataMutationOptions,
} from 'wagmi/query'
import {
type SignTypedDataData,
type SignTypedDataVariables,
type SignTypedDataMutate,
type SignTypedDataMutateAsync,
signTypedDataMutationOptions,
} from 'wagmi/query'