Frog.signature Context
The c object is the parameter of the route handlers. It contains context for the signature route.
import { Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  return c.signTypedData({/* ... */})
})address
- Type: string | undefined
The address of the wallet connected by the user after pressing the button to do the signature.
This is the wallet address the user executes the signature with.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  const { address } = c
  return c.signTypedData({/* ... */})
})buttonIndex
- Type: number
The index of the button that was previously clicked.
For example, if the user clicked "Banana", then buttonIndex will be 2.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.frame('/', (c) => {
  return c.res({
    image: (
      <div style={{ color: 'white', display: 'flex', fontSize: 60 }}>
        Select a fruit.
      </div>
    ),
    intents: [
      <Button.Signature
        target="/sign"
        value="apple"
      >
        Apple
      </Button.Signature>,
      <Button.Signature
        target="/sign"
        value="banana"
      >
        Banana
      </Button.Signature>,
    ]
  })
})
 
app.signature('/sign', (c) => {
  const { buttonIndex } = c
  return c.signTypedData({/* ... */})
})buttonValue
- Type: string
The value of the button that was previously clicked.
For example, if the user clicked "Banana", then buttonValue will be "banana".
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.frame('/', (c) => {
  return c.res({
    image: (
      <div style={{ color: 'white', display: 'flex', fontSize: 60 }}>
        Select a fruit.
      </div>
    ),
    intents: [
      <Button.Signature
        target="/sign"
        value="apple"
      >
        Apple
      </Button.Signature>,
      <Button.Signature
        target="/sign"
        value="banana"
      >
        Banana
      </Button.Signature>,
    ]
  })
})
 
app.signature('/sign', (c) => {
  const { buttonValue } = c
  return c.signTypedData({/* ... */})
})contract
- Type: SignatureResponseFn<ContractSignatureParameters>
Contract signature response. See more.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/mint', (c) => {
  return c.contract({/* ... */})
})error
- Type:  (error: BaseError) => TypedResponse
Error response.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/', (c) => {
  return c.error({/* ... */})
})frameData
- Type: FrameData
Data from the frame that was passed via the POST body from a Farcaster Client. See more.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  const { frameData } = c
  const { castId, fid, messageHash, network, timestamp, url } = frameData
  return c.signTypedData({/* ... */})
})initialPath
- Type: string
Initial/start path of the frame set.
If the user clicks <Button.Reset>, they will be directed to this URL.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  const { initialPath } = c
  return c.signTypedData({/* ... */})
})inputText
- Type: string
The value of the input that was previously interacted with.
For example, if the user typed "Banana", then inputText will be "Banana".
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.frame('/', (c) => {
  return c.res({
    image: (
      <div style={{ color: 'white', display: 'flex', fontSize: 60 }}>
        Sign
      </div>
    ),
    intents: [
      <Button target="/sign">Sign</Button>,
    ]
  })
})
 
app.signature('/sign', (c) => {
  return c.signTypedData({/* ... */})
})previousButtonValues
- Type: string[]
The data of the previous intents.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.frame('/', (c) => {
  return c.res({
    image: (
      <div style={{ color: 'white', display: 'flex', fontSize: 60 }}>
        Select your fruit
      </div>
    ),
    intents: [
      <Button.Signature
        target="/sign"
        value="apple"
      >
        Apple
      </Button.Signature>,
      <Button.Signature
        target="/sign"
        value="banana"
      >
        Banana
      </Button.Signature>,
    ]
  })
})
 
app.signature('/sign', (c) => {
  const { buttonValue, previousButtonValues } = c
  console.log(previousButtonValues)
  ['apple', 'banana']  return c.signTypedData({/* ... */})})previousState
- Type: State
The state of the previous frame.
import { Button, Frog } from 'frog'
 
type State = {     
  values: string[] 
} 
 
export const app = new Frog<{ State: State }>({ 
  initialState: { 
    values: [] 
  } 
}) 
 
app.frame('/', (c) => {
  const { buttonValue, deriveState } = c
  const state = deriveState(previousState => { 
    if (buttonValue) previousState.values.push(buttonValue)
  })
  return c.res({
    image: (
      <div style={{ color: 'white', display: 'flex', fontSize: 60 }}>
        {values.map(value => <div>{value}</div>)}
      </div>
    ),
    intents: [
      <Button value="apple">Apple</Button>, 
      <Button value="banana">Banana</Button>,
      <Button.Signature target="/sign">Sign</Button.Signature>,
    ]
  })
})
 
app.signature('/sign', (c) => {
  const { previousState } = c
  return c.signTypedData({/* ... */})
})req
- Type: Request
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  const { req } = c
  return c.res({/* ... */})
})res
- Type: SignatureResponseFn<SignatureParameters>
Raw signature response. See more.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  return c.res({/* ... */})
})signTypedData
- Type: SignTypedDataResponseFn
Sign Typed Data response. See more.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  return c.signTypedData({/* ... */})
})var
- Type: HonoContext['var']
Extract a context value that was previously set via set in Middleware.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.use(async (c, next) => {
  c.set('message', 'Frog is cool!!')
  await next()
})
 
app.signature('/sign', (c) => {
  const message = c.var.message
  return c.signTypedData({/* ... */})
})verified
- Type: boolean
Whether or not the frameData (and buttonIndex, buttonValue, inputText) was verified by the Farcaster Hub API.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  const { verified } = c
  return c.signTypedData({/* ... */})
})url
- Type: string
Current URL.
import { Button, Frog } from 'frog'
 
export const app = new Frog({ title: 'Frog Frame' })
 
app.signature('/sign', (c) => {
  const { url } = c
  return c.signTypedData({/* ... */})
})