For AI agents: a documentation index is available at the root level at /llms.txt and /llms-full.txt. Append /llms.txt to any URL for a page-level index, or .md for the markdown version of any page.
ModelsChatRankingsDocs
DocsAPI ReferenceClient SDKsAgent SDKCookbookChangelog
DocsAPI ReferenceClient SDKsAgent SDKCookbookChangelog
    • Overview
    • Usage for Agents
  • TypeScript SDK
    • Overview
  • Python SDK
    • Overview
  • Go SDK
      • Analytics
      • APIKeys
      • Byok
      • Chat
      • Credits
      • Embeddings
      • Endpoints
      • Generations
      • Guardrails
        • Models
        • ResponseFormat
      • OAuth
      • Observability
      • Organization
      • Presets
      • Providers
      • Rerank
      • Beta.Responses
      • Transcriptions
      • Speech
      • VideoGeneration
      • Workspaces
  • DevTools
    • Overview
    • Migrating to @openrouter/agent
LogoLogo
ModelsChatRankingsDocs
On this page
  • Supported Types
  • ChatFormatGrammarConfig
  • FormatJSONObjectConfig
  • ChatFormatJSONSchemaConfig
  • ChatFormatPythonConfig
  • ChatFormatTextConfig
  • Union Discrimination
Go SDKAPI ReferenceModels

ResponseFormat - Go SDK

ResponseFormat type definition
Was this page helpful?
Previous

OAuth - Go SDK

OAuth method reference
Next
Built with

The Go SDK and docs are currently in beta. Report issues on GitHub.

Response format configuration

Supported Types

ChatFormatGrammarConfig

1responseFormat := components.CreateResponseFormatGrammar(components.ChatFormatGrammarConfig{/* values here */})

FormatJSONObjectConfig

1responseFormat := components.CreateResponseFormatJSONObject(components.FormatJSONObjectConfig{/* values here */})

ChatFormatJSONSchemaConfig

1responseFormat := components.CreateResponseFormatJSONSchema(components.ChatFormatJSONSchemaConfig{/* values here */})

ChatFormatPythonConfig

1responseFormat := components.CreateResponseFormatPython(components.ChatFormatPythonConfig{/* values here */})

ChatFormatTextConfig

1responseFormat := components.CreateResponseFormatText(components.ChatFormatTextConfig{/* values here */})

Union Discrimination

Use the Type field to determine which variant is active, then access the corresponding field:

1switch responseFormat.Type {
2 case components.ResponseFormatTypeGrammar:
3 // responseFormat.ChatFormatGrammarConfig is populated
4 case components.ResponseFormatTypeJSONObject:
5 // responseFormat.FormatJSONObjectConfig is populated
6 case components.ResponseFormatTypeJSONSchema:
7 // responseFormat.ChatFormatJSONSchemaConfig is populated
8 case components.ResponseFormatTypePython:
9 // responseFormat.ChatFormatPythonConfig is populated
10 case components.ResponseFormatTypeText:
11 // responseFormat.ChatFormatTextConfig is populated
12}