Documentation ¶
Overview ¶
Package gogo_compat is a generated protocol buffer package.
Test to make sure that Twirp plays well with code generated with github.com/gogo/protobuf/protoc-gen-gofast.
It is generated from these files:
service.proto
It has these top-level messages:
Msg
Package gogo_compat is a generated twirp stub package. This code was generated with github.com/twitchtv/twirp/protoc-gen-twirp v5.0.0.
Test to make sure that Twirp plays well with code generated with github.com/gogo/protobuf/protoc-gen-gofast.
It is generated from these files:
service.proto
Index ¶
Constants ¶
const SvcPathPrefix = "/twirp/twirp.internal.twirptest.gogo_compat.Svc/"
SvcPathPrefix is used for all URL paths on a twirp Svc server. Requests are always: POST SvcPathPrefix/method It can be used in an HTTP mux to route twirp requests along with non-twirp requests on other routes.
Variables ¶
Functions ¶
func WriteError ¶
func WriteError(resp http.ResponseWriter, err error)
WriteError writes an HTTP response with a valid Twirp error format. If err is not a twirp.Error, it will get wrapped with twirp.InternalErrorWith(err)
Types ¶
type Msg ¶
type Msg struct { }
type Svc ¶
func NewSvcJSONClient ¶
NewSvcJSONClient creates a JSON client that implements the Svc interface. It communicates using JSON requests and responses instead of protobuf messages.
type TwirpServer ¶
type TwirpServer interface { http.Handler // ServiceDescriptor returns gzipped bytes describing the .proto file that // this service was generated from. Once unzipped, the bytes can be // unmarshaled as a // github.com/golang/protobuf/protoc-gen-go/descriptor.FileDescriptorProto. // // The returned integer is the index of this particular service within that // FileDescriptorProto's 'Service' slice of ServiceDescriptorProtos. This is a // low-level field, expected to be used for reflection. ServiceDescriptor() ([]byte, int) // ProtocGenTwirpVersion is the semantic version string of the version of // twirp used to generate this file. ProtocGenTwirpVersion() string }
TwirpServer is the interface generated server structs will support: they're HTTP handlers with additional methods for accessing metadata about the service. Those accessors are a low-level API for building reflection tools. Most people can think of TwirpServers as just http.Handlers.
func NewSvcServer ¶
func NewSvcServer(svc Svc, hooks *twirp.ServerHooks) TwirpServer