Documentation ¶
Index ¶
Constants ¶
const (
// ExternalProcessorName is the fully-qualified name of the ExternalProcessor service.
ExternalProcessorName = "envoy.service.ext_proc.v3.ExternalProcessor"
)
const ( // ExternalProcessorProcessProcedure is the fully-qualified name of the ExternalProcessor's Process // RPC. ExternalProcessorProcessProcedure = "/envoy.service.ext_proc.v3.ExternalProcessor/Process" )
These constants are the fully-qualified names of the RPCs defined in this package. They're exposed at runtime as Spec.Procedure and as the final two segments of the HTTP route.
Note that these are different from the fully-qualified method names used by google.golang.org/protobuf/reflect/protoreflect. To convert from these constants to reflection-formatted method names, remove the leading slash and convert the remaining slash to a period.
Variables ¶
This section is empty.
Functions ¶
func NewExternalProcessorHandler ¶
func NewExternalProcessorHandler(svc ExternalProcessorHandler, opts ...connect_go.HandlerOption) (string, http.Handler)
NewExternalProcessorHandler builds an HTTP handler from the service implementation. It returns the path on which to mount the handler and the handler itself.
By default, handlers support the Connect, gRPC, and gRPC-Web protocols with the binary Protobuf and JSON codecs. They also support gzip compression.
Types ¶
type ExternalProcessorClient ¶
type ExternalProcessorClient interface { // This begins the bidirectional stream that Envoy will use to // give the server control over what the filter does. The actual // protocol is described by the ProcessingRequest and ProcessingResponse // messages below. Process(context.Context) *connect_go.BidiStreamForClient[v3.ProcessingRequest, v3.ProcessingResponse] }
ExternalProcessorClient is a client for the envoy.service.ext_proc.v3.ExternalProcessor service.
func NewExternalProcessorClient ¶
func NewExternalProcessorClient(httpClient connect_go.HTTPClient, baseURL string, opts ...connect_go.ClientOption) ExternalProcessorClient
NewExternalProcessorClient constructs a client for the envoy.service.ext_proc.v3.ExternalProcessor service. By default, it uses the Connect protocol with the binary Protobuf Codec, asks for gzipped responses, and sends uncompressed requests. To use the gRPC or gRPC-Web protocols, supply the connect.WithGRPC() or connect.WithGRPCWeb() options.
The URL supplied here should be the base URL for the Connect or gRPC server (for example, http://api.acme.com or https://acme.com/grpc).
type ExternalProcessorHandler ¶
type ExternalProcessorHandler interface { // This begins the bidirectional stream that Envoy will use to // give the server control over what the filter does. The actual // protocol is described by the ProcessingRequest and ProcessingResponse // messages below. Process(context.Context, *connect_go.BidiStream[v3.ProcessingRequest, v3.ProcessingResponse]) error }
ExternalProcessorHandler is an implementation of the envoy.service.ext_proc.v3.ExternalProcessor service.
type UnimplementedExternalProcessorHandler ¶
type UnimplementedExternalProcessorHandler struct{}
UnimplementedExternalProcessorHandler returns CodeUnimplemented from all methods.
func (UnimplementedExternalProcessorHandler) Process ¶
func (UnimplementedExternalProcessorHandler) Process(context.Context, *connect_go.BidiStream[v3.ProcessingRequest, v3.ProcessingResponse]) error