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
      • OAuth
      • Observability
      • Organization
      • Presets
      • Providers
      • Rerank
      • Beta.Responses
      • Transcriptions
      • Speech
      • VideoGeneration
      • Workspaces
  • DevTools
    • Overview
    • Migrating to @openrouter/agent
LogoLogo
ModelsChatRankingsDocs
On this page
  • Overview
  • Available Operations
  • Send
  • Example Usage: guardrail-blocked
  • Example Usage: insufficient-permissions
  • Parameters
  • Response
  • Errors
Go SDKAPI Reference

Beta.Responses - Go SDK

Beta.Responses method reference
Was this page helpful?
Previous

Transcriptions - Go SDK

Transcriptions method reference
Next
Built with

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

Overview

beta.responses endpoints

Available Operations

  • Send - Create a response

Send

Creates a streaming or non-streaming response using OpenResponses API format

Example Usage: guardrail-blocked

1package main
2
3import(
4 "context"
5 "os"
6 openrouter "github.com/OpenRouterTeam/go-sdk"
7 "github.com/OpenRouterTeam/go-sdk/models/components"
8 "log"
9)
10
11func main() {
12 ctx := context.Background()
13
14 s := openrouter.New(
15 openrouter.WithSecurity(os.Getenv("OPENROUTER_API_KEY")),
16 )
17
18 res, err := s.Beta.Responses.Send(ctx, components.ResponsesRequest{}, nil)
19 if err != nil {
20 log.Fatal(err)
21 }
22 if res != nil {
23 defer res.ResponsesStreamingResponse.Close()
24
25 for res.ResponsesStreamingResponse.Next() {
26 event := res.ResponsesStreamingResponse.Value()
27 log.Print(event)
28 // Handle the event
29 }
30 }
31}

Example Usage: insufficient-permissions

1package main
2
3import(
4 "context"
5 "os"
6 openrouter "github.com/OpenRouterTeam/go-sdk"
7 "github.com/OpenRouterTeam/go-sdk/models/components"
8 "log"
9)
10
11func main() {
12 ctx := context.Background()
13
14 s := openrouter.New(
15 openrouter.WithSecurity(os.Getenv("OPENROUTER_API_KEY")),
16 )
17
18 res, err := s.Beta.Responses.Send(ctx, components.ResponsesRequest{}, nil)
19 if err != nil {
20 log.Fatal(err)
21 }
22 if res != nil {
23 defer res.ResponsesStreamingResponse.Close()
24
25 for res.ResponsesStreamingResponse.Next() {
26 event := res.ResponsesStreamingResponse.Value()
27 log.Print(event)
28 // Handle the event
29 }
30 }
31}

Parameters

ParameterTypeRequiredDescriptionExample
ctxcontext.Context✔️The context to use for the request.
responsesRequestcomponents.ResponsesRequest✔️N/A{"input": [{"content": "Hello, how are you?","role": "user","type": "message"}
],
“model”: “anthropic/claude-4.5-sonnet-20250929”,
“temperature”: 0.7,
“tools”: [
{"description": "Get the current weather in a given location","name": "get_current_weather","parameters": {"properties": {"location": {"type": "string"}
},
“type”: “object”
},
“type”: “function”
}
],
“top_p”: 0.9
}
xOpenRouterExperimentalMetadata*components.MetadataLevel➖Opt-in to surface routing metadata on the response under openrouter_metadata. Defaults to disabled.enabled
opts[]operations.Option➖The options for this request.

Response

*operations.CreateResponsesResponse, error

Errors

Error TypeStatus CodeContent Type
sdkerrors.BadRequestResponseError400application/json
sdkerrors.UnauthorizedResponseError401application/json
sdkerrors.PaymentRequiredResponseError402application/json
sdkerrors.ForbiddenResponseError403application/json
sdkerrors.NotFoundResponseError404application/json
sdkerrors.RequestTimeoutResponseError408application/json
sdkerrors.PayloadTooLargeResponseError413application/json
sdkerrors.UnprocessableEntityResponseError422application/json
sdkerrors.TooManyRequestsResponseError429application/json
sdkerrors.InternalServerResponseError500application/json
sdkerrors.BadGatewayResponseError502application/json
sdkerrors.ServiceUnavailableResponseError503application/json
sdkerrors.EdgeNetworkTimeoutResponseError524application/json
sdkerrors.ProviderOverloadedResponseError529application/json
sdkerrors.APIError4XX, 5XX*/*