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
        • ChatMessages
      • 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
  • ChatAssistantMessage
  • ChatDeveloperMessage
  • ChatSystemMessage
  • ChatToolMessage
  • ChatUserMessage
  • Union Discrimination
Go SDKAPI ReferenceModels

ChatMessages - Go SDK

ChatMessages 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.

Chat completion message with role-based discrimination

Supported Types

ChatAssistantMessage

1chatMessages := components.CreateChatMessagesAssistant(components.ChatAssistantMessage{/* values here */})

ChatDeveloperMessage

1chatMessages := components.CreateChatMessagesDeveloper(components.ChatDeveloperMessage{/* values here */})

ChatSystemMessage

1chatMessages := components.CreateChatMessagesSystem(components.ChatSystemMessage{/* values here */})

ChatToolMessage

1chatMessages := components.CreateChatMessagesTool(components.ChatToolMessage{/* values here */})

ChatUserMessage

1chatMessages := components.CreateChatMessagesUser(components.ChatUserMessage{/* values here */})

Union Discrimination

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

1switch chatMessages.Type {
2 case components.ChatMessagesTypeAssistant:
3 // chatMessages.ChatAssistantMessage is populated
4 case components.ChatMessagesTypeDeveloper:
5 // chatMessages.ChatDeveloperMessage is populated
6 case components.ChatMessagesTypeSystem:
7 // chatMessages.ChatSystemMessage is populated
8 case components.ChatMessagesTypeTool:
9 // chatMessages.ChatToolMessage is populated
10 case components.ChatMessagesTypeUser:
11 // chatMessages.ChatUserMessage is populated
12}