package livekit
import context "context"
import fmt "fmt"
import http "net/http"
import io "io"
import json "encoding/json"
import strconv "strconv"
import strings "strings"
import protojson "google.golang.org/protobuf/encoding/protojson"
import proto "google.golang.org/protobuf/proto"
import twirp "github.com/twitchtv/twirp"
import ctxsetters "github.com/twitchtv/twirp/ctxsetters"
import bytes "bytes"
import errors "errors"
import path "path"
import url "net/url"
const _ = twirp.TwirpPackageMinVersion_8_1_0
type AgentDispatchService interface {
CreateDispatch(context.Context, *CreateAgentDispatchRequest) (*AgentDispatch, error)
DeleteDispatch(context.Context, *DeleteAgentDispatchRequest) (*AgentDispatch, error)
ListDispatch(context.Context, *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error)
}
type agentDispatchServiceProtobufClient struct {
client HTTPClient
urls [3]string
interceptor twirp.Interceptor
opts twirp.ClientOptions
}
func NewAgentDispatchServiceProtobufClient(baseURL string, client HTTPClient, opts ...twirp.ClientOption) AgentDispatchService {
if c, ok := client.(*http.Client); ok {
client = withoutRedirects(c)
}
clientOpts := twirp.ClientOptions{}
for _, o := range opts {
o(&clientOpts)
}
literalURLs := false
_ = clientOpts.ReadOpt("literalURLs", &literalURLs)
var pathPrefix string
if ok := clientOpts.ReadOpt("pathPrefix", &pathPrefix); !ok {
pathPrefix = "/twirp" }
serviceURL := sanitizeBaseURL(baseURL)
serviceURL += baseServicePath(pathPrefix, "livekit", "AgentDispatchService")
urls := [3]string{
serviceURL + "CreateDispatch",
serviceURL + "DeleteDispatch",
serviceURL + "ListDispatch",
}
return &agentDispatchServiceProtobufClient{
client: client,
urls: urls,
interceptor: twirp.ChainInterceptors(clientOpts.Interceptors...),
opts: clientOpts,
}
}
func (c *agentDispatchServiceProtobufClient) CreateDispatch(ctx context.Context, in *CreateAgentDispatchRequest) (*AgentDispatch, error) {
ctx = ctxsetters.WithPackageName(ctx, "livekit")
ctx = ctxsetters.WithServiceName(ctx, "AgentDispatchService")
ctx = ctxsetters.WithMethodName(ctx, "CreateDispatch")
caller := c.callCreateDispatch
if c.interceptor != nil {
caller = func(ctx context.Context, req *CreateAgentDispatchRequest) (*AgentDispatch, error) {
resp, err := c.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*CreateAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*CreateAgentDispatchRequest) when calling interceptor")
}
return c.callCreateDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*AgentDispatch)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*AgentDispatch) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
return caller(ctx, in)
}
func (c *agentDispatchServiceProtobufClient) callCreateDispatch(ctx context.Context, in *CreateAgentDispatchRequest) (*AgentDispatch, error) {
out := new(AgentDispatch)
ctx, err := doProtobufRequest(ctx, c.client, c.opts.Hooks, c.urls[0], in, out)
if err != nil {
twerr, ok := err.(twirp.Error)
if !ok {
twerr = twirp.InternalErrorWith(err)
}
callClientError(ctx, c.opts.Hooks, twerr)
return nil, err
}
callClientResponseReceived(ctx, c.opts.Hooks)
return out, nil
}
func (c *agentDispatchServiceProtobufClient) DeleteDispatch(ctx context.Context, in *DeleteAgentDispatchRequest) (*AgentDispatch, error) {
ctx = ctxsetters.WithPackageName(ctx, "livekit")
ctx = ctxsetters.WithServiceName(ctx, "AgentDispatchService")
ctx = ctxsetters.WithMethodName(ctx, "DeleteDispatch")
caller := c.callDeleteDispatch
if c.interceptor != nil {
caller = func(ctx context.Context, req *DeleteAgentDispatchRequest) (*AgentDispatch, error) {
resp, err := c.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*DeleteAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*DeleteAgentDispatchRequest) when calling interceptor")
}
return c.callDeleteDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*AgentDispatch)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*AgentDispatch) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
return caller(ctx, in)
}
func (c *agentDispatchServiceProtobufClient) callDeleteDispatch(ctx context.Context, in *DeleteAgentDispatchRequest) (*AgentDispatch, error) {
out := new(AgentDispatch)
ctx, err := doProtobufRequest(ctx, c.client, c.opts.Hooks, c.urls[1], in, out)
if err != nil {
twerr, ok := err.(twirp.Error)
if !ok {
twerr = twirp.InternalErrorWith(err)
}
callClientError(ctx, c.opts.Hooks, twerr)
return nil, err
}
callClientResponseReceived(ctx, c.opts.Hooks)
return out, nil
}
func (c *agentDispatchServiceProtobufClient) ListDispatch(ctx context.Context, in *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error) {
ctx = ctxsetters.WithPackageName(ctx, "livekit")
ctx = ctxsetters.WithServiceName(ctx, "AgentDispatchService")
ctx = ctxsetters.WithMethodName(ctx, "ListDispatch")
caller := c.callListDispatch
if c.interceptor != nil {
caller = func(ctx context.Context, req *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error) {
resp, err := c.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*ListAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*ListAgentDispatchRequest) when calling interceptor")
}
return c.callListDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*ListAgentDispatchResponse)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*ListAgentDispatchResponse) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
return caller(ctx, in)
}
func (c *agentDispatchServiceProtobufClient) callListDispatch(ctx context.Context, in *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error) {
out := new(ListAgentDispatchResponse)
ctx, err := doProtobufRequest(ctx, c.client, c.opts.Hooks, c.urls[2], in, out)
if err != nil {
twerr, ok := err.(twirp.Error)
if !ok {
twerr = twirp.InternalErrorWith(err)
}
callClientError(ctx, c.opts.Hooks, twerr)
return nil, err
}
callClientResponseReceived(ctx, c.opts.Hooks)
return out, nil
}
type agentDispatchServiceJSONClient struct {
client HTTPClient
urls [3]string
interceptor twirp.Interceptor
opts twirp.ClientOptions
}
func NewAgentDispatchServiceJSONClient(baseURL string, client HTTPClient, opts ...twirp.ClientOption) AgentDispatchService {
if c, ok := client.(*http.Client); ok {
client = withoutRedirects(c)
}
clientOpts := twirp.ClientOptions{}
for _, o := range opts {
o(&clientOpts)
}
literalURLs := false
_ = clientOpts.ReadOpt("literalURLs", &literalURLs)
var pathPrefix string
if ok := clientOpts.ReadOpt("pathPrefix", &pathPrefix); !ok {
pathPrefix = "/twirp" }
serviceURL := sanitizeBaseURL(baseURL)
serviceURL += baseServicePath(pathPrefix, "livekit", "AgentDispatchService")
urls := [3]string{
serviceURL + "CreateDispatch",
serviceURL + "DeleteDispatch",
serviceURL + "ListDispatch",
}
return &agentDispatchServiceJSONClient{
client: client,
urls: urls,
interceptor: twirp.ChainInterceptors(clientOpts.Interceptors...),
opts: clientOpts,
}
}
func (c *agentDispatchServiceJSONClient) CreateDispatch(ctx context.Context, in *CreateAgentDispatchRequest) (*AgentDispatch, error) {
ctx = ctxsetters.WithPackageName(ctx, "livekit")
ctx = ctxsetters.WithServiceName(ctx, "AgentDispatchService")
ctx = ctxsetters.WithMethodName(ctx, "CreateDispatch")
caller := c.callCreateDispatch
if c.interceptor != nil {
caller = func(ctx context.Context, req *CreateAgentDispatchRequest) (*AgentDispatch, error) {
resp, err := c.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*CreateAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*CreateAgentDispatchRequest) when calling interceptor")
}
return c.callCreateDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*AgentDispatch)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*AgentDispatch) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
return caller(ctx, in)
}
func (c *agentDispatchServiceJSONClient) callCreateDispatch(ctx context.Context, in *CreateAgentDispatchRequest) (*AgentDispatch, error) {
out := new(AgentDispatch)
ctx, err := doJSONRequest(ctx, c.client, c.opts.Hooks, c.urls[0], in, out)
if err != nil {
twerr, ok := err.(twirp.Error)
if !ok {
twerr = twirp.InternalErrorWith(err)
}
callClientError(ctx, c.opts.Hooks, twerr)
return nil, err
}
callClientResponseReceived(ctx, c.opts.Hooks)
return out, nil
}
func (c *agentDispatchServiceJSONClient) DeleteDispatch(ctx context.Context, in *DeleteAgentDispatchRequest) (*AgentDispatch, error) {
ctx = ctxsetters.WithPackageName(ctx, "livekit")
ctx = ctxsetters.WithServiceName(ctx, "AgentDispatchService")
ctx = ctxsetters.WithMethodName(ctx, "DeleteDispatch")
caller := c.callDeleteDispatch
if c.interceptor != nil {
caller = func(ctx context.Context, req *DeleteAgentDispatchRequest) (*AgentDispatch, error) {
resp, err := c.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*DeleteAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*DeleteAgentDispatchRequest) when calling interceptor")
}
return c.callDeleteDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*AgentDispatch)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*AgentDispatch) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
return caller(ctx, in)
}
func (c *agentDispatchServiceJSONClient) callDeleteDispatch(ctx context.Context, in *DeleteAgentDispatchRequest) (*AgentDispatch, error) {
out := new(AgentDispatch)
ctx, err := doJSONRequest(ctx, c.client, c.opts.Hooks, c.urls[1], in, out)
if err != nil {
twerr, ok := err.(twirp.Error)
if !ok {
twerr = twirp.InternalErrorWith(err)
}
callClientError(ctx, c.opts.Hooks, twerr)
return nil, err
}
callClientResponseReceived(ctx, c.opts.Hooks)
return out, nil
}
func (c *agentDispatchServiceJSONClient) ListDispatch(ctx context.Context, in *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error) {
ctx = ctxsetters.WithPackageName(ctx, "livekit")
ctx = ctxsetters.WithServiceName(ctx, "AgentDispatchService")
ctx = ctxsetters.WithMethodName(ctx, "ListDispatch")
caller := c.callListDispatch
if c.interceptor != nil {
caller = func(ctx context.Context, req *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error) {
resp, err := c.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*ListAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*ListAgentDispatchRequest) when calling interceptor")
}
return c.callListDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*ListAgentDispatchResponse)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*ListAgentDispatchResponse) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
return caller(ctx, in)
}
func (c *agentDispatchServiceJSONClient) callListDispatch(ctx context.Context, in *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error) {
out := new(ListAgentDispatchResponse)
ctx, err := doJSONRequest(ctx, c.client, c.opts.Hooks, c.urls[2], in, out)
if err != nil {
twerr, ok := err.(twirp.Error)
if !ok {
twerr = twirp.InternalErrorWith(err)
}
callClientError(ctx, c.opts.Hooks, twerr)
return nil, err
}
callClientResponseReceived(ctx, c.opts.Hooks)
return out, nil
}
type agentDispatchServiceServer struct {
AgentDispatchService
interceptor twirp.Interceptor
hooks *twirp.ServerHooks
pathPrefix string jsonSkipDefaults bool jsonCamelCase bool }
func NewAgentDispatchServiceServer(svc AgentDispatchService, opts ...interface{}) TwirpServer {
serverOpts := newServerOpts(opts)
jsonSkipDefaults := false
_ = serverOpts.ReadOpt("jsonSkipDefaults", &jsonSkipDefaults)
jsonCamelCase := false
_ = serverOpts.ReadOpt("jsonCamelCase", &jsonCamelCase)
var pathPrefix string
if ok := serverOpts.ReadOpt("pathPrefix", &pathPrefix); !ok {
pathPrefix = "/twirp" }
return &agentDispatchServiceServer{
AgentDispatchService: svc,
hooks: serverOpts.Hooks,
interceptor: twirp.ChainInterceptors(serverOpts.Interceptors...),
pathPrefix: pathPrefix,
jsonSkipDefaults: jsonSkipDefaults,
jsonCamelCase: jsonCamelCase,
}
}
func (s *agentDispatchServiceServer) writeError(ctx context.Context, resp http.ResponseWriter, err error) {
writeError(ctx, resp, err, s.hooks)
}
func (s *agentDispatchServiceServer) handleRequestBodyError(ctx context.Context, resp http.ResponseWriter, msg string, err error) {
if context.Canceled == ctx.Err() {
s.writeError(ctx, resp, twirp.NewError(twirp.Canceled, "failed to read request: context canceled"))
return
}
if context.DeadlineExceeded == ctx.Err() {
s.writeError(ctx, resp, twirp.NewError(twirp.DeadlineExceeded, "failed to read request: deadline exceeded"))
return
}
s.writeError(ctx, resp, twirp.WrapError(malformedRequestError(msg), err))
}
const AgentDispatchServicePathPrefix = "/twirp/livekit.AgentDispatchService/"
func (s *agentDispatchServiceServer) ServeHTTP(resp http.ResponseWriter, req *http.Request) {
ctx := req.Context()
ctx = ctxsetters.WithPackageName(ctx, "livekit")
ctx = ctxsetters.WithServiceName(ctx, "AgentDispatchService")
ctx = ctxsetters.WithResponseWriter(ctx, resp)
var err error
ctx, err = callRequestReceived(ctx, s.hooks)
if err != nil {
s.writeError(ctx, resp, err)
return
}
if req.Method != "POST" {
msg := fmt.Sprintf("unsupported method %q (only POST is allowed)", req.Method)
s.writeError(ctx, resp, badRouteError(msg, req.Method, req.URL.Path))
return
}
prefix, pkgService, method := parseTwirpPath(req.URL.Path)
if pkgService != "livekit.AgentDispatchService" {
msg := fmt.Sprintf("no handler for path %q", req.URL.Path)
s.writeError(ctx, resp, badRouteError(msg, req.Method, req.URL.Path))
return
}
if prefix != s.pathPrefix {
msg := fmt.Sprintf("invalid path prefix %q, expected %q, on path %q", prefix, s.pathPrefix, req.URL.Path)
s.writeError(ctx, resp, badRouteError(msg, req.Method, req.URL.Path))
return
}
switch method {
case "CreateDispatch":
s.serveCreateDispatch(ctx, resp, req)
return
case "DeleteDispatch":
s.serveDeleteDispatch(ctx, resp, req)
return
case "ListDispatch":
s.serveListDispatch(ctx, resp, req)
return
default:
msg := fmt.Sprintf("no handler for path %q", req.URL.Path)
s.writeError(ctx, resp, badRouteError(msg, req.Method, req.URL.Path))
return
}
}
func (s *agentDispatchServiceServer) serveCreateDispatch(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
header := req.Header.Get("Content-Type")
i := strings.Index(header, ";")
if i == -1 {
i = len(header)
}
switch strings.TrimSpace(strings.ToLower(header[:i])) {
case "application/json":
s.serveCreateDispatchJSON(ctx, resp, req)
case "application/protobuf":
s.serveCreateDispatchProtobuf(ctx, resp, req)
default:
msg := fmt.Sprintf("unexpected Content-Type: %q", req.Header.Get("Content-Type"))
twerr := badRouteError(msg, req.Method, req.URL.Path)
s.writeError(ctx, resp, twerr)
}
}
func (s *agentDispatchServiceServer) serveCreateDispatchJSON(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
var err error
ctx = ctxsetters.WithMethodName(ctx, "CreateDispatch")
ctx, err = callRequestRouted(ctx, s.hooks)
if err != nil {
s.writeError(ctx, resp, err)
return
}
d := json.NewDecoder(req.Body)
rawReqBody := json.RawMessage{}
if err := d.Decode(&rawReqBody); err != nil {
s.handleRequestBodyError(ctx, resp, "the json request could not be decoded", err)
return
}
reqContent := new(CreateAgentDispatchRequest)
unmarshaler := protojson.UnmarshalOptions{DiscardUnknown: true}
if err = unmarshaler.Unmarshal(rawReqBody, reqContent); err != nil {
s.handleRequestBodyError(ctx, resp, "the json request could not be decoded", err)
return
}
handler := s.AgentDispatchService.CreateDispatch
if s.interceptor != nil {
handler = func(ctx context.Context, req *CreateAgentDispatchRequest) (*AgentDispatch, error) {
resp, err := s.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*CreateAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*CreateAgentDispatchRequest) when calling interceptor")
}
return s.AgentDispatchService.CreateDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*AgentDispatch)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*AgentDispatch) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
var respContent *AgentDispatch
func() {
defer ensurePanicResponses(ctx, resp, s.hooks)
respContent, err = handler(ctx, reqContent)
}()
if err != nil {
s.writeError(ctx, resp, err)
return
}
if respContent == nil {
s.writeError(ctx, resp, twirp.InternalError("received a nil *AgentDispatch and nil error while calling CreateDispatch. nil responses are not supported"))
return
}
ctx = callResponsePrepared(ctx, s.hooks)
marshaler := &protojson.MarshalOptions{UseProtoNames: !s.jsonCamelCase, EmitUnpopulated: !s.jsonSkipDefaults}
respBytes, err := marshaler.Marshal(respContent)
if err != nil {
s.writeError(ctx, resp, wrapInternal(err, "failed to marshal json response"))
return
}
ctx = ctxsetters.WithStatusCode(ctx, http.StatusOK)
resp.Header().Set("Content-Type", "application/json")
resp.Header().Set("Content-Length", strconv.Itoa(len(respBytes)))
resp.WriteHeader(http.StatusOK)
if n, err := resp.Write(respBytes); err != nil {
msg := fmt.Sprintf("failed to write response, %d of %d bytes written: %s", n, len(respBytes), err.Error())
twerr := twirp.NewError(twirp.Unknown, msg)
ctx = callError(ctx, s.hooks, twerr)
}
callResponseSent(ctx, s.hooks)
}
func (s *agentDispatchServiceServer) serveCreateDispatchProtobuf(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
var err error
ctx = ctxsetters.WithMethodName(ctx, "CreateDispatch")
ctx, err = callRequestRouted(ctx, s.hooks)
if err != nil {
s.writeError(ctx, resp, err)
return
}
buf, err := io.ReadAll(req.Body)
if err != nil {
s.handleRequestBodyError(ctx, resp, "failed to read request body", err)
return
}
reqContent := new(CreateAgentDispatchRequest)
if err = proto.Unmarshal(buf, reqContent); err != nil {
s.writeError(ctx, resp, malformedRequestError("the protobuf request could not be decoded"))
return
}
handler := s.AgentDispatchService.CreateDispatch
if s.interceptor != nil {
handler = func(ctx context.Context, req *CreateAgentDispatchRequest) (*AgentDispatch, error) {
resp, err := s.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*CreateAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*CreateAgentDispatchRequest) when calling interceptor")
}
return s.AgentDispatchService.CreateDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*AgentDispatch)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*AgentDispatch) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
var respContent *AgentDispatch
func() {
defer ensurePanicResponses(ctx, resp, s.hooks)
respContent, err = handler(ctx, reqContent)
}()
if err != nil {
s.writeError(ctx, resp, err)
return
}
if respContent == nil {
s.writeError(ctx, resp, twirp.InternalError("received a nil *AgentDispatch and nil error while calling CreateDispatch. nil responses are not supported"))
return
}
ctx = callResponsePrepared(ctx, s.hooks)
respBytes, err := proto.Marshal(respContent)
if err != nil {
s.writeError(ctx, resp, wrapInternal(err, "failed to marshal proto response"))
return
}
ctx = ctxsetters.WithStatusCode(ctx, http.StatusOK)
resp.Header().Set("Content-Type", "application/protobuf")
resp.Header().Set("Content-Length", strconv.Itoa(len(respBytes)))
resp.WriteHeader(http.StatusOK)
if n, err := resp.Write(respBytes); err != nil {
msg := fmt.Sprintf("failed to write response, %d of %d bytes written: %s", n, len(respBytes), err.Error())
twerr := twirp.NewError(twirp.Unknown, msg)
ctx = callError(ctx, s.hooks, twerr)
}
callResponseSent(ctx, s.hooks)
}
func (s *agentDispatchServiceServer) serveDeleteDispatch(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
header := req.Header.Get("Content-Type")
i := strings.Index(header, ";")
if i == -1 {
i = len(header)
}
switch strings.TrimSpace(strings.ToLower(header[:i])) {
case "application/json":
s.serveDeleteDispatchJSON(ctx, resp, req)
case "application/protobuf":
s.serveDeleteDispatchProtobuf(ctx, resp, req)
default:
msg := fmt.Sprintf("unexpected Content-Type: %q", req.Header.Get("Content-Type"))
twerr := badRouteError(msg, req.Method, req.URL.Path)
s.writeError(ctx, resp, twerr)
}
}
func (s *agentDispatchServiceServer) serveDeleteDispatchJSON(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
var err error
ctx = ctxsetters.WithMethodName(ctx, "DeleteDispatch")
ctx, err = callRequestRouted(ctx, s.hooks)
if err != nil {
s.writeError(ctx, resp, err)
return
}
d := json.NewDecoder(req.Body)
rawReqBody := json.RawMessage{}
if err := d.Decode(&rawReqBody); err != nil {
s.handleRequestBodyError(ctx, resp, "the json request could not be decoded", err)
return
}
reqContent := new(DeleteAgentDispatchRequest)
unmarshaler := protojson.UnmarshalOptions{DiscardUnknown: true}
if err = unmarshaler.Unmarshal(rawReqBody, reqContent); err != nil {
s.handleRequestBodyError(ctx, resp, "the json request could not be decoded", err)
return
}
handler := s.AgentDispatchService.DeleteDispatch
if s.interceptor != nil {
handler = func(ctx context.Context, req *DeleteAgentDispatchRequest) (*AgentDispatch, error) {
resp, err := s.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*DeleteAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*DeleteAgentDispatchRequest) when calling interceptor")
}
return s.AgentDispatchService.DeleteDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*AgentDispatch)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*AgentDispatch) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
var respContent *AgentDispatch
func() {
defer ensurePanicResponses(ctx, resp, s.hooks)
respContent, err = handler(ctx, reqContent)
}()
if err != nil {
s.writeError(ctx, resp, err)
return
}
if respContent == nil {
s.writeError(ctx, resp, twirp.InternalError("received a nil *AgentDispatch and nil error while calling DeleteDispatch. nil responses are not supported"))
return
}
ctx = callResponsePrepared(ctx, s.hooks)
marshaler := &protojson.MarshalOptions{UseProtoNames: !s.jsonCamelCase, EmitUnpopulated: !s.jsonSkipDefaults}
respBytes, err := marshaler.Marshal(respContent)
if err != nil {
s.writeError(ctx, resp, wrapInternal(err, "failed to marshal json response"))
return
}
ctx = ctxsetters.WithStatusCode(ctx, http.StatusOK)
resp.Header().Set("Content-Type", "application/json")
resp.Header().Set("Content-Length", strconv.Itoa(len(respBytes)))
resp.WriteHeader(http.StatusOK)
if n, err := resp.Write(respBytes); err != nil {
msg := fmt.Sprintf("failed to write response, %d of %d bytes written: %s", n, len(respBytes), err.Error())
twerr := twirp.NewError(twirp.Unknown, msg)
ctx = callError(ctx, s.hooks, twerr)
}
callResponseSent(ctx, s.hooks)
}
func (s *agentDispatchServiceServer) serveDeleteDispatchProtobuf(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
var err error
ctx = ctxsetters.WithMethodName(ctx, "DeleteDispatch")
ctx, err = callRequestRouted(ctx, s.hooks)
if err != nil {
s.writeError(ctx, resp, err)
return
}
buf, err := io.ReadAll(req.Body)
if err != nil {
s.handleRequestBodyError(ctx, resp, "failed to read request body", err)
return
}
reqContent := new(DeleteAgentDispatchRequest)
if err = proto.Unmarshal(buf, reqContent); err != nil {
s.writeError(ctx, resp, malformedRequestError("the protobuf request could not be decoded"))
return
}
handler := s.AgentDispatchService.DeleteDispatch
if s.interceptor != nil {
handler = func(ctx context.Context, req *DeleteAgentDispatchRequest) (*AgentDispatch, error) {
resp, err := s.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*DeleteAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*DeleteAgentDispatchRequest) when calling interceptor")
}
return s.AgentDispatchService.DeleteDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*AgentDispatch)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*AgentDispatch) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
var respContent *AgentDispatch
func() {
defer ensurePanicResponses(ctx, resp, s.hooks)
respContent, err = handler(ctx, reqContent)
}()
if err != nil {
s.writeError(ctx, resp, err)
return
}
if respContent == nil {
s.writeError(ctx, resp, twirp.InternalError("received a nil *AgentDispatch and nil error while calling DeleteDispatch. nil responses are not supported"))
return
}
ctx = callResponsePrepared(ctx, s.hooks)
respBytes, err := proto.Marshal(respContent)
if err != nil {
s.writeError(ctx, resp, wrapInternal(err, "failed to marshal proto response"))
return
}
ctx = ctxsetters.WithStatusCode(ctx, http.StatusOK)
resp.Header().Set("Content-Type", "application/protobuf")
resp.Header().Set("Content-Length", strconv.Itoa(len(respBytes)))
resp.WriteHeader(http.StatusOK)
if n, err := resp.Write(respBytes); err != nil {
msg := fmt.Sprintf("failed to write response, %d of %d bytes written: %s", n, len(respBytes), err.Error())
twerr := twirp.NewError(twirp.Unknown, msg)
ctx = callError(ctx, s.hooks, twerr)
}
callResponseSent(ctx, s.hooks)
}
func (s *agentDispatchServiceServer) serveListDispatch(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
header := req.Header.Get("Content-Type")
i := strings.Index(header, ";")
if i == -1 {
i = len(header)
}
switch strings.TrimSpace(strings.ToLower(header[:i])) {
case "application/json":
s.serveListDispatchJSON(ctx, resp, req)
case "application/protobuf":
s.serveListDispatchProtobuf(ctx, resp, req)
default:
msg := fmt.Sprintf("unexpected Content-Type: %q", req.Header.Get("Content-Type"))
twerr := badRouteError(msg, req.Method, req.URL.Path)
s.writeError(ctx, resp, twerr)
}
}
func (s *agentDispatchServiceServer) serveListDispatchJSON(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
var err error
ctx = ctxsetters.WithMethodName(ctx, "ListDispatch")
ctx, err = callRequestRouted(ctx, s.hooks)
if err != nil {
s.writeError(ctx, resp, err)
return
}
d := json.NewDecoder(req.Body)
rawReqBody := json.RawMessage{}
if err := d.Decode(&rawReqBody); err != nil {
s.handleRequestBodyError(ctx, resp, "the json request could not be decoded", err)
return
}
reqContent := new(ListAgentDispatchRequest)
unmarshaler := protojson.UnmarshalOptions{DiscardUnknown: true}
if err = unmarshaler.Unmarshal(rawReqBody, reqContent); err != nil {
s.handleRequestBodyError(ctx, resp, "the json request could not be decoded", err)
return
}
handler := s.AgentDispatchService.ListDispatch
if s.interceptor != nil {
handler = func(ctx context.Context, req *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error) {
resp, err := s.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*ListAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*ListAgentDispatchRequest) when calling interceptor")
}
return s.AgentDispatchService.ListDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*ListAgentDispatchResponse)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*ListAgentDispatchResponse) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
var respContent *ListAgentDispatchResponse
func() {
defer ensurePanicResponses(ctx, resp, s.hooks)
respContent, err = handler(ctx, reqContent)
}()
if err != nil {
s.writeError(ctx, resp, err)
return
}
if respContent == nil {
s.writeError(ctx, resp, twirp.InternalError("received a nil *ListAgentDispatchResponse and nil error while calling ListDispatch. nil responses are not supported"))
return
}
ctx = callResponsePrepared(ctx, s.hooks)
marshaler := &protojson.MarshalOptions{UseProtoNames: !s.jsonCamelCase, EmitUnpopulated: !s.jsonSkipDefaults}
respBytes, err := marshaler.Marshal(respContent)
if err != nil {
s.writeError(ctx, resp, wrapInternal(err, "failed to marshal json response"))
return
}
ctx = ctxsetters.WithStatusCode(ctx, http.StatusOK)
resp.Header().Set("Content-Type", "application/json")
resp.Header().Set("Content-Length", strconv.Itoa(len(respBytes)))
resp.WriteHeader(http.StatusOK)
if n, err := resp.Write(respBytes); err != nil {
msg := fmt.Sprintf("failed to write response, %d of %d bytes written: %s", n, len(respBytes), err.Error())
twerr := twirp.NewError(twirp.Unknown, msg)
ctx = callError(ctx, s.hooks, twerr)
}
callResponseSent(ctx, s.hooks)
}
func (s *agentDispatchServiceServer) serveListDispatchProtobuf(ctx context.Context, resp http.ResponseWriter, req *http.Request) {
var err error
ctx = ctxsetters.WithMethodName(ctx, "ListDispatch")
ctx, err = callRequestRouted(ctx, s.hooks)
if err != nil {
s.writeError(ctx, resp, err)
return
}
buf, err := io.ReadAll(req.Body)
if err != nil {
s.handleRequestBodyError(ctx, resp, "failed to read request body", err)
return
}
reqContent := new(ListAgentDispatchRequest)
if err = proto.Unmarshal(buf, reqContent); err != nil {
s.writeError(ctx, resp, malformedRequestError("the protobuf request could not be decoded"))
return
}
handler := s.AgentDispatchService.ListDispatch
if s.interceptor != nil {
handler = func(ctx context.Context, req *ListAgentDispatchRequest) (*ListAgentDispatchResponse, error) {
resp, err := s.interceptor(
func(ctx context.Context, req interface{}) (interface{}, error) {
typedReq, ok := req.(*ListAgentDispatchRequest)
if !ok {
return nil, twirp.InternalError("failed type assertion req.(*ListAgentDispatchRequest) when calling interceptor")
}
return s.AgentDispatchService.ListDispatch(ctx, typedReq)
},
)(ctx, req)
if resp != nil {
typedResp, ok := resp.(*ListAgentDispatchResponse)
if !ok {
return nil, twirp.InternalError("failed type assertion resp.(*ListAgentDispatchResponse) when calling interceptor")
}
return typedResp, err
}
return nil, err
}
}
var respContent *ListAgentDispatchResponse
func() {
defer ensurePanicResponses(ctx, resp, s.hooks)
respContent, err = handler(ctx, reqContent)
}()
if err != nil {
s.writeError(ctx, resp, err)
return
}
if respContent == nil {
s.writeError(ctx, resp, twirp.InternalError("received a nil *ListAgentDispatchResponse and nil error while calling ListDispatch. nil responses are not supported"))
return
}
ctx = callResponsePrepared(ctx, s.hooks)
respBytes, err := proto.Marshal(respContent)
if err != nil {
s.writeError(ctx, resp, wrapInternal(err, "failed to marshal proto response"))
return
}
ctx = ctxsetters.WithStatusCode(ctx, http.StatusOK)
resp.Header().Set("Content-Type", "application/protobuf")
resp.Header().Set("Content-Length", strconv.Itoa(len(respBytes)))
resp.WriteHeader(http.StatusOK)
if n, err := resp.Write(respBytes); err != nil {
msg := fmt.Sprintf("failed to write response, %d of %d bytes written: %s", n, len(respBytes), err.Error())
twerr := twirp.NewError(twirp.Unknown, msg)
ctx = callError(ctx, s.hooks, twerr)
}
callResponseSent(ctx, s.hooks)
}
func (s *agentDispatchServiceServer) ServiceDescriptor() ([]byte, int) {
return twirpFileDescriptor0, 0
}
func (s *agentDispatchServiceServer) ProtocGenTwirpVersion() string {
return "v8.1.3"
}
func (s *agentDispatchServiceServer) PathPrefix() string {
return baseServicePath(s.pathPrefix, "livekit", "AgentDispatchService")
}
type HTTPClient interface {
Do(req *http.Request) (*http.Response, error)
}
type TwirpServer interface {
http.Handler
ServiceDescriptor() ([]byte, int)
ProtocGenTwirpVersion() string
PathPrefix() string
}
func newServerOpts(opts []interface{}) *twirp.ServerOptions {
serverOpts := &twirp.ServerOptions{}
for _, opt := range opts {
switch o := opt.(type) {
case twirp.ServerOption:
o(serverOpts)
case *twirp.ServerHooks: twirp.WithServerHooks(o)(serverOpts)
case nil: continue
default:
panic(fmt.Sprintf("Invalid option type %T, please use a twirp.ServerOption", o))
}
}
return serverOpts
}
func WriteError(resp http.ResponseWriter, err error) {
writeError(context.Background(), resp, err, nil)
}
func writeError(ctx context.Context, resp http.ResponseWriter, err error, hooks *twirp.ServerHooks) {
var twerr twirp.Error
if !errors.As(err, &twerr) {
twerr = twirp.InternalErrorWith(err)
}
statusCode := twirp.ServerHTTPStatusFromErrorCode(twerr.Code())
ctx = ctxsetters.WithStatusCode(ctx, statusCode)
ctx = callError(ctx, hooks, twerr)
respBody := marshalErrorToJSON(twerr)
resp.Header().Set("Content-Type", "application/json") resp.Header().Set("Content-Length", strconv.Itoa(len(respBody)))
resp.WriteHeader(statusCode)
_, writeErr := resp.Write(respBody)
if writeErr != nil {
_ = writeErr
}
callResponseSent(ctx, hooks)
}
func sanitizeBaseURL(baseURL string) string {
u, err := url.Parse(baseURL)
if err != nil {
return baseURL }
if u.Scheme == "" {
u.Scheme = "http"
}
return u.String()
}
func baseServicePath(prefix, pkg, service string) string {
fullServiceName := service
if pkg != "" {
fullServiceName = pkg + "." + service
}
return path.Join("/", prefix, fullServiceName) + "/"
}
func parseTwirpPath(path string) (string, string, string) {
parts := strings.Split(path, "/")
if len(parts) < 2 {
return "", "", ""
}
method := parts[len(parts)-1]
pkgService := parts[len(parts)-2]
prefix := strings.Join(parts[0:len(parts)-2], "/")
return prefix, pkgService, method
}
func getCustomHTTPReqHeaders(ctx context.Context) http.Header {
header, ok := twirp.HTTPRequestHeaders(ctx)
if !ok || header == nil {
return nil
}
copied := make(http.Header)
for k, vv := range header {
if vv == nil {
copied[k] = nil
continue
}
copied[k] = make([]string, len(vv))
copy(copied[k], vv)
}
return copied
}
func newRequest(ctx context.Context, url string, reqBody io.Reader, contentType string) (*http.Request, error) {
req, err := http.NewRequest("POST", url, reqBody)
if err != nil {
return nil, err
}
req = req.WithContext(ctx)
if customHeader := getCustomHTTPReqHeaders(ctx); customHeader != nil {
req.Header = customHeader
}
req.Header.Set("Accept", contentType)
req.Header.Set("Content-Type", contentType)
req.Header.Set("Twirp-Version", "v8.1.3")
return req, nil
}
type twerrJSON struct {
Code string `json:"code"`
Msg string `json:"msg"`
Meta map[string]string `json:"meta,omitempty"`
}
func marshalErrorToJSON(twerr twirp.Error) []byte {
msg := twerr.Msg()
if len(msg) > 1e6 {
msg = msg[:1e6]
}
tj := twerrJSON{
Code: string(twerr.Code()),
Msg: msg,
Meta: twerr.MetaMap(),
}
buf, err := json.Marshal(&tj)
if err != nil {
buf = []byte("{\"type\": \"" + twirp.Internal + "\", \"msg\": \"There was an error but it could not be serialized into JSON\"}") }
return buf
}
func errorFromResponse(resp *http.Response) twirp.Error {
statusCode := resp.StatusCode
statusText := http.StatusText(statusCode)
if isHTTPRedirect(statusCode) {
location := resp.Header.Get("Location")
msg := fmt.Sprintf("unexpected HTTP status code %d %q received, Location=%q", statusCode, statusText, location)
return twirpErrorFromIntermediary(statusCode, msg, location)
}
respBodyBytes, err := io.ReadAll(resp.Body)
if err != nil {
return wrapInternal(err, "failed to read server error response body")
}
var tj twerrJSON
dec := json.NewDecoder(bytes.NewReader(respBodyBytes))
dec.DisallowUnknownFields()
if err := dec.Decode(&tj); err != nil || tj.Code == "" {
msg := fmt.Sprintf("Error from intermediary with HTTP status code %d %q", statusCode, statusText)
return twirpErrorFromIntermediary(statusCode, msg, string(respBodyBytes))
}
errorCode := twirp.ErrorCode(tj.Code)
if !twirp.IsValidErrorCode(errorCode) {
msg := "invalid type returned from server error response: " + tj.Code
return twirp.InternalError(msg).WithMeta("body", string(respBodyBytes))
}
twerr := twirp.NewError(errorCode, tj.Msg)
for k, v := range tj.Meta {
twerr = twerr.WithMeta(k, v)
}
return twerr
}
func twirpErrorFromIntermediary(status int, msg string, bodyOrLocation string) twirp.Error {
var code twirp.ErrorCode
if isHTTPRedirect(status) { code = twirp.Internal
} else {
switch status {
case 400: code = twirp.Internal
case 401: code = twirp.Unauthenticated
case 403: code = twirp.PermissionDenied
case 404: code = twirp.BadRoute
case 429: code = twirp.ResourceExhausted
case 502, 503, 504: code = twirp.Unavailable
default: code = twirp.Unknown
}
}
twerr := twirp.NewError(code, msg)
twerr = twerr.WithMeta("http_error_from_intermediary", "true") twerr = twerr.WithMeta("status_code", strconv.Itoa(status))
if isHTTPRedirect(status) {
twerr = twerr.WithMeta("location", bodyOrLocation)
} else {
twerr = twerr.WithMeta("body", bodyOrLocation)
}
return twerr
}
func isHTTPRedirect(status int) bool {
return status >= 300 && status <= 399
}
func wrapInternal(err error, prefix string) twirp.Error {
return twirp.InternalErrorWith(&wrappedError{prefix: prefix, cause: err})
}
type wrappedError struct {
prefix string
cause error
}
func (e *wrappedError) Error() string { return e.prefix + ": " + e.cause.Error() }
func (e *wrappedError) Unwrap() error { return e.cause } func (e *wrappedError) Cause() error { return e.cause }
func ensurePanicResponses(ctx context.Context, resp http.ResponseWriter, hooks *twirp.ServerHooks) {
if r := recover(); r != nil {
err := errFromPanic(r)
twerr := &internalWithCause{msg: "Internal service panic", cause: err}
writeError(ctx, resp, twerr, hooks)
f, ok := resp.(http.Flusher)
if ok {
f.Flush()
}
panic(r)
}
}
func errFromPanic(p interface{}) error {
if err, ok := p.(error); ok {
return err
}
return fmt.Errorf("panic: %v", p)
}
type internalWithCause struct {
msg string
cause error
}
func (e *internalWithCause) Unwrap() error { return e.cause } func (e *internalWithCause) Cause() error { return e.cause } func (e *internalWithCause) Error() string { return e.msg + ": " + e.cause.Error() }
func (e *internalWithCause) Code() twirp.ErrorCode { return twirp.Internal }
func (e *internalWithCause) Msg() string { return e.msg }
func (e *internalWithCause) Meta(key string) string { return "" }
func (e *internalWithCause) MetaMap() map[string]string { return nil }
func (e *internalWithCause) WithMeta(key string, val string) twirp.Error { return e }
func malformedRequestError(msg string) twirp.Error {
return twirp.NewError(twirp.Malformed, msg)
}
func badRouteError(msg string, method, url string) twirp.Error {
err := twirp.NewError(twirp.BadRoute, msg)
err = err.WithMeta("twirp_invalid_route", method+" "+url)
return err
}
func withoutRedirects(in *http.Client) *http.Client {
copy := *in
copy.CheckRedirect = func(req *http.Request, via []*http.Request) error {
if in.CheckRedirect != nil {
err := in.CheckRedirect(req, via)
_ = err }
return http.ErrUseLastResponse
}
return ©
}
func doProtobufRequest(ctx context.Context, client HTTPClient, hooks *twirp.ClientHooks, url string, in, out proto.Message) (_ context.Context, err error) {
reqBodyBytes, err := proto.Marshal(in)
if err != nil {
return ctx, wrapInternal(err, "failed to marshal proto request")
}
reqBody := bytes.NewBuffer(reqBodyBytes)
if err = ctx.Err(); err != nil {
return ctx, wrapInternal(err, "aborted because context was done")
}
req, err := newRequest(ctx, url, reqBody, "application/protobuf")
if err != nil {
return ctx, wrapInternal(err, "could not build request")
}
ctx, err = callClientRequestPrepared(ctx, hooks, req)
if err != nil {
return ctx, err
}
req = req.WithContext(ctx)
resp, err := client.Do(req)
if err != nil {
return ctx, wrapInternal(err, "failed to do request")
}
defer func() { _ = resp.Body.Close() }()
if err = ctx.Err(); err != nil {
return ctx, wrapInternal(err, "aborted because context was done")
}
if resp.StatusCode != 200 {
return ctx, errorFromResponse(resp)
}
respBodyBytes, err := io.ReadAll(resp.Body)
if err != nil {
return ctx, wrapInternal(err, "failed to read response body")
}
if err = ctx.Err(); err != nil {
return ctx, wrapInternal(err, "aborted because context was done")
}
if err = proto.Unmarshal(respBodyBytes, out); err != nil {
return ctx, wrapInternal(err, "failed to unmarshal proto response")
}
return ctx, nil
}
func doJSONRequest(ctx context.Context, client HTTPClient, hooks *twirp.ClientHooks, url string, in, out proto.Message) (_ context.Context, err error) {
marshaler := &protojson.MarshalOptions{UseProtoNames: true}
reqBytes, err := marshaler.Marshal(in)
if err != nil {
return ctx, wrapInternal(err, "failed to marshal json request")
}
if err = ctx.Err(); err != nil {
return ctx, wrapInternal(err, "aborted because context was done")
}
req, err := newRequest(ctx, url, bytes.NewReader(reqBytes), "application/json")
if err != nil {
return ctx, wrapInternal(err, "could not build request")
}
ctx, err = callClientRequestPrepared(ctx, hooks, req)
if err != nil {
return ctx, err
}
req = req.WithContext(ctx)
resp, err := client.Do(req)
if err != nil {
return ctx, wrapInternal(err, "failed to do request")
}
defer func() {
cerr := resp.Body.Close()
if err == nil && cerr != nil {
err = wrapInternal(cerr, "failed to close response body")
}
}()
if err = ctx.Err(); err != nil {
return ctx, wrapInternal(err, "aborted because context was done")
}
if resp.StatusCode != 200 {
return ctx, errorFromResponse(resp)
}
d := json.NewDecoder(resp.Body)
rawRespBody := json.RawMessage{}
if err := d.Decode(&rawRespBody); err != nil {
return ctx, wrapInternal(err, "failed to unmarshal json response")
}
unmarshaler := protojson.UnmarshalOptions{DiscardUnknown: true}
if err = unmarshaler.Unmarshal(rawRespBody, out); err != nil {
return ctx, wrapInternal(err, "failed to unmarshal json response")
}
if err = ctx.Err(); err != nil {
return ctx, wrapInternal(err, "aborted because context was done")
}
return ctx, nil
}
func callRequestReceived(ctx context.Context, h *twirp.ServerHooks) (context.Context, error) {
if h == nil || h.RequestReceived == nil {
return ctx, nil
}
return h.RequestReceived(ctx)
}
func callRequestRouted(ctx context.Context, h *twirp.ServerHooks) (context.Context, error) {
if h == nil || h.RequestRouted == nil {
return ctx, nil
}
return h.RequestRouted(ctx)
}
func callResponsePrepared(ctx context.Context, h *twirp.ServerHooks) context.Context {
if h == nil || h.ResponsePrepared == nil {
return ctx
}
return h.ResponsePrepared(ctx)
}
func callResponseSent(ctx context.Context, h *twirp.ServerHooks) {
if h == nil || h.ResponseSent == nil {
return
}
h.ResponseSent(ctx)
}
func callError(ctx context.Context, h *twirp.ServerHooks, err twirp.Error) context.Context {
if h == nil || h.Error == nil {
return ctx
}
return h.Error(ctx, err)
}
func callClientResponseReceived(ctx context.Context, h *twirp.ClientHooks) {
if h == nil || h.ResponseReceived == nil {
return
}
h.ResponseReceived(ctx)
}
func callClientRequestPrepared(ctx context.Context, h *twirp.ClientHooks, req *http.Request) (context.Context, error) {
if h == nil || h.RequestPrepared == nil {
return ctx, nil
}
return h.RequestPrepared(ctx, req)
}
func callClientError(ctx context.Context, h *twirp.ClientHooks, err twirp.Error) {
if h == nil || h.Error == nil {
return
}
h.Error(ctx, err)
}
var twirpFileDescriptor0 = []byte{
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xb4, 0x54, 0xc1, 0x6e, 0xd3, 0x40,
0x10, 0x95, 0xed, 0x14, 0xc8, 0xa4, 0x0d, 0xb0, 0x54, 0xc8, 0x18, 0x90, 0x8c, 0x7b, 0xc9, 0xa1,
0x72, 0x44, 0xb8, 0xf5, 0x96, 0x10, 0x21, 0x01, 0x05, 0x21, 0x03, 0x17, 0x0e, 0x58, 0x1b, 0x7b,
0x94, 0x2e, 0xc4, 0xd9, 0xd4, 0x3b, 0xcd, 0x37, 0x20, 0xf1, 0x07, 0xfc, 0x00, 0x12, 0x9f, 0x86,
0xfa, 0x11, 0xc8, 0xbb, 0xb6, 0x89, 0xc1, 0x86, 0x53, 0x6f, 0xde, 0xf7, 0x66, 0xdf, 0xcc, 0xee,
0x7b, 0x6b, 0x78, 0xb0, 0x12, 0x5b, 0xfc, 0x2c, 0x28, 0xe6, 0x4b, 0x5c, 0x53, 0x9c, 0x0a, 0xb5,
0xe1, 0x94, 0x9c, 0x85, 0x9b, 0x5c, 0x92, 0x64, 0xd7, 0x4b, 0xd6, 0xbb, 0xd3, 0x28, 0x33, 0xac,
0x77, 0xb8, 0x92, 0xcb, 0x25, 0xe6, 0x63, 0xb9, 0x21, 0x21, 0xd7, 0xca, 0xa0, 0xc1, 0x39, 0x78,
0x4f, 0x73, 0xe4, 0x84, 0xd3, 0xa2, 0x74, 0x5e, 0x0a, 0x46, 0x78, 0x7e, 0x81, 0x8a, 0xd8, 0x43,
0x00, 0xd3, 0x69, 0xcd, 0x33, 0x74, 0x2d, 0xdf, 0x1a, 0xf5, 0xa3, 0xbe, 0x46, 0x5e, 0xf3, 0x0c,
0x19, 0x83, 0x5e, 0x2e, 0x65, 0xe6, 0xda, 0x9a, 0xd0, 0xdf, 0xcc, 0x87, 0x1b, 0x19, 0x12, 0x4f,
0x39, 0x71, 0xd7, 0x29, 0xf0, 0x59, 0xef, 0xcb, 0xe5, 0xb1, 0x15, 0xd5, 0x68, 0xf0, 0x0e, 0x6e,
0x47, 0x52, 0x66, 0x8d, 0x86, 0xff, 0xeb, 0xb4, 0xab, 0x6a, 0xb7, 0xaa, 0x72, 0xf0, 0xe6, 0xb8,
0xc2, 0x8e, 0x83, 0x8c, 0x61, 0x50, 0x5d, 0x56, 0x2c, 0x52, 0xa3, 0x3f, 0x1b, 0x7e, 0xbb, 0x3c,
0x86, 0x0a, 0x7e, 0x3e, 0x8f, 0x7e, 0x7f, 0xa7, 0x6d, 0x47, 0x0b, 0x62, 0x70, 0x4f, 0x85, 0xa2,
0xab, 0x6b, 0xf0, 0x11, 0xee, 0xb5, 0x34, 0x50, 0x1b, 0xb9, 0x56, 0xc8, 0xa6, 0x70, 0xab, 0xe9,
0x3a, 0x2a, 0xd7, 0xf2, 0x9d, 0xd1, 0x60, 0x72, 0x37, 0x2c, 0xfd, 0x0e, 0x9b, 0x3b, 0x6f, 0xf2,
0xdd, 0x25, 0xaa, 0xe0, 0xbb, 0x05, 0x07, 0xcd, 0x6b, 0x1f, 0x82, 0x5d, 0x4d, 0x1b, 0xd9, 0x22,
0xfd, 0xc3, 0x06, 0xbb, 0xcb, 0x70, 0xa7, 0xc3, 0xf0, 0x5e, 0x9b, 0x35, 0xec, 0x31, 0xec, 0x29,
0xe2, 0x84, 0xee, 0x9e, 0x6f, 0x8d, 0x06, 0x93, 0xfb, 0xed, 0xe3, 0xbe, 0x2d, 0x4a, 0x22, 0x53,
0x19, 0x10, 0xb0, 0xbf, 0x49, 0xe6, 0x43, 0xef, 0x93, 0x5c, 0x54, 0xc7, 0xde, 0xaf, 0x75, 0x5e,
0xc8, 0x45, 0xa4, 0x99, 0x62, 0xfe, 0x44, 0xc7, 0x39, 0x8d, 0x39, 0xe9, 0xf9, 0x9d, 0xa8, 0x5f,
0x22, 0x53, 0x9d, 0xe7, 0x54, 0x87, 0x44, 0xd3, 0x8e, 0xa1, 0x4b, 0x64, 0x4a, 0x93, 0xaf, 0x36,
0x1c, 0x36, 0xdb, 0x62, 0xbe, 0x15, 0x09, 0xb2, 0x57, 0x30, 0x34, 0xaf, 0xa4, 0xbe, 0xb8, 0xa3,
0xba, 0x79, 0xf7, 0xf3, 0xf1, 0x3a, 0x8c, 0x29, 0xe4, 0x4c, 0x56, 0x5b, 0xe4, 0xba, 0x43, 0xdc,
0x29, 0xf7, 0x1e, 0xf6, 0x8b, 0xd8, 0xd4, 0xeb, 0x47, 0x75, 0x5d, 0x57, 0x5c, 0xbd, 0xe0, 0x5f,
0x25, 0x26, 0x70, 0xb3, 0x67, 0x1f, 0x8e, 0x96, 0x82, 0xce, 0x2e, 0x16, 0x61, 0x22, 0xb3, 0x71,
0x59, 0x3f, 0xd6, 0xbf, 0x8d, 0x44, 0xae, 0x2a, 0xe0, 0x87, 0x7d, 0x70, 0x2a, 0xb6, 0xf8, 0x52,
0x50, 0xf8, 0xa6, 0xa0, 0x7e, 0xda, 0xc3, 0x72, 0x7d, 0x72, 0xa2, 0x81, 0xc5, 0x35, 0xbd, 0xe5,
0xc9, 0xaf, 0x00, 0x00, 0x00, 0xff, 0xff, 0x24, 0xfb, 0xd3, 0x31, 0xbd, 0x04, 0x00, 0x00,
}