Documentation ¶
Overview ¶
Package http provides a general purpose HTTP binding for endpoints.
Index ¶
- Constants
- func DefaultErrorEncoder(_ context.Context, err error, w http.ResponseWriter)
- func EncodeJSONRequest(c context.Context, r *http.Request, request *interface{}) error
- func EncodeJSONResponse[RES any](_ context.Context, w http.ResponseWriter, response RES) error
- func EncodeXMLRequest(c context.Context, r *http.Request, request interface{}) error
- func NopRequestDecoder(ctx context.Context, r *http.Request) (interface{}, error)
- func PopulateRequestContext(ctx context.Context, r *http.Request) context.Context
- type Client
- type ClientFinalizerFunc
- type ClientOption
- func BufferedStream[REQ any, RES any](buffered bool) ClientOption[REQ, RES]
- func ClientAfter[REQ any, RES any](after ...ClientResponseFunc) ClientOption[REQ, RES]
- func ClientBefore[REQ any, RES any](before ...RequestFunc) ClientOption[REQ, RES]
- func ClientFinalizer[REQ any, RES any](f ...ClientFinalizerFunc) ClientOption[REQ, RES]
- func SetClient[REQ any, RES any](client HTTPClient) ClientOption[REQ, RES]
- type ClientResponseFunc
- type CreateRequestFunc
- type DecodeRequestFunc
- type DecodeResponseFunc
- type EncodeRequestFunc
- type EncodeResponseFunc
- type ErrorEncoder
- type HTTPClient
- type Headerer
- type RequestFunc
- type Server
- type ServerFinalizerFunc
- type ServerOption
- func ServerAfter[REQ any, RES any](after ...ServerResponseFunc) ServerOption[REQ, RES]
- func ServerBefore[REQ any, RES any](before ...RequestFunc) ServerOption[REQ, RES]
- func ServerErrorEncoder[REQ any, RES any](ee ErrorEncoder) ServerOption[REQ, RES]
- func ServerErrorHandler[REQ any, RES any](errorHandler transport.ErrorHandler) ServerOption[REQ, RES]
- func ServerErrorLogger[REQ any, RES any](logger log.Logger) ServerOption[REQ, RES]
- func ServerFinalizer[REQ any, RES any](f ...ServerFinalizerFunc) ServerOption[REQ, RES]
- type ServerResponseFunc
- type StatusCoder
Examples ¶
Constants ¶
const ( // ContextKeyRequestMethod is populated in the context by // PopulateRequestContext. Its value is r.Method. ContextKeyRequestMethod contextKey = iota // ContextKeyRequestURI is populated in the context by // PopulateRequestContext. Its value is r.RequestURI. ContextKeyRequestURI // ContextKeyRequestPath is populated in the context by // PopulateRequestContext. Its value is r.URL.Path. ContextKeyRequestPath // ContextKeyRequestProto is populated in the context by // PopulateRequestContext. Its value is r.Proto. ContextKeyRequestProto // ContextKeyRequestHost is populated in the context by // PopulateRequestContext. Its value is r.Host. ContextKeyRequestHost // ContextKeyRequestRemoteAddr is populated in the context by // PopulateRequestContext. Its value is r.RemoteAddr. ContextKeyRequestRemoteAddr // ContextKeyRequestXForwardedFor is populated in the context by // PopulateRequestContext. Its value is r.Header.Get("X-Forwarded-For"). ContextKeyRequestXForwardedFor // ContextKeyRequestXForwardedProto is populated in the context by // PopulateRequestContext. Its value is r.Header.Get("X-Forwarded-Proto"). ContextKeyRequestXForwardedProto // ContextKeyRequestAuthorization is populated in the context by // PopulateRequestContext. Its value is r.Header.Get("Authorization"). ContextKeyRequestAuthorization // ContextKeyRequestReferer is populated in the context by // PopulateRequestContext. Its value is r.Header.Get("Referer"). ContextKeyRequestReferer // ContextKeyRequestUserAgent is populated in the context by // PopulateRequestContext. Its value is r.Header.Get("User-Agent"). ContextKeyRequestUserAgent // ContextKeyRequestXRequestID is populated in the context by // PopulateRequestContext. Its value is r.Header.Get("X-Request-Id"). ContextKeyRequestXRequestID // ContextKeyRequestAccept is populated in the context by // PopulateRequestContext. Its value is r.Header.Get("Accept"). ContextKeyRequestAccept // ContextKeyResponseHeaders is populated in the context whenever a // ServerFinalizerFunc is specified. Its value is of type http.Header, and // is captured only once the entire response has been written. ContextKeyResponseHeaders // ContextKeyResponseSize is populated in the context whenever a // ServerFinalizerFunc is specified. Its value is of type int64. ContextKeyResponseSize )
Variables ¶
This section is empty.
Functions ¶
func DefaultErrorEncoder ¶ added in v0.4.0
func DefaultErrorEncoder(_ context.Context, err error, w http.ResponseWriter)
DefaultErrorEncoder writes the error to the ResponseWriter, by default a content type of text/plain, a body of the plain text of the error, and a status code of 500. If the error implements Headerer, the provided headers will be applied to the response. If the error implements json.Marshaler, and the marshaling succeeds, a content type of application/json and the JSON encoded form of the error will be used. If the error implements StatusCoder, the provided StatusCode will be used instead of 500.
func EncodeJSONRequest ¶ added in v0.4.0
EncodeJSONRequest is an EncodeRequestFunc that serializes the request as a JSON object to the Request body. Many JSON-over-HTTP services can use it as a sensible default. If the request implements Headerer, the provided headers will be applied to the request.
func EncodeJSONResponse ¶ added in v0.4.0
EncodeJSONResponse is a EncodeResponseFunc that serializes the response as a JSON object to the ResponseWriter. Many JSON-over-HTTP services can use it as a sensible default. If the response implements Headerer, the provided headers will be applied to the response. If the response implements StatusCoder, the provided StatusCode will be used instead of 200.
func EncodeXMLRequest ¶ added in v0.4.0
EncodeXMLRequest is an EncodeRequestFunc that serializes the request as a XML object to the Request body. If the request implements Headerer, the provided headers will be applied to the request.
func NopRequestDecoder ¶ added in v0.7.0
NopRequestDecoder is a DecodeRequestFunc that can be used for requests that do not need to be decoded, and simply returns nil, nil.
func PopulateRequestContext ¶ added in v0.4.0
PopulateRequestContext is a RequestFunc that populates several values into the context from the HTTP request. Those values may be extracted using the corresponding ContextKey type in this package.
Example ¶
handler := NewServer( func(ctx context.Context, _ struct{}) (response struct{}, err error) { fmt.Println("Method", ctx.Value(ContextKeyRequestMethod).(string)) fmt.Println("RequestPath", ctx.Value(ContextKeyRequestPath).(string)) fmt.Println("RequestURI", ctx.Value(ContextKeyRequestURI).(string)) fmt.Println("X-Request-ID", ctx.Value(ContextKeyRequestXRequestID).(string)) return struct{}{}, nil }, func(context.Context, *http.Request) (struct{}, error) { return struct{}{}, nil }, func(context.Context, http.ResponseWriter, struct{}) error { return nil }, ServerBefore[struct{}, struct{}](PopulateRequestContext), ) server := httptest.NewServer(handler) defer server.Close() req, _ := http.NewRequest("PATCH", fmt.Sprintf("%s/search?q=sympatico", server.URL), nil) req.Header.Set("X-Request-Id", "a1b2c3d4e5") http.DefaultClient.Do(req)
Output: Method PATCH RequestPath /search RequestURI /search?q=sympatico X-Request-ID a1b2c3d4e5
Types ¶
type Client ¶
Client wraps a URL and provides a method that implements endpoint.Endpoint.
func NewClient ¶
func NewClient[REQ any, RES any](method string, tgt *url.URL, enc EncodeRequestFunc[REQ], dec DecodeResponseFunc[RES], options ...ClientOption[REQ, RES]) *Client[REQ, RES]
NewClient constructs a usable Client for a single remote method.
func NewExplicitClient ¶ added in v0.18.0
func NewExplicitClient[REQ any, RES any](req CreateRequestFunc[REQ], dec DecodeResponseFunc[RES], options ...ClientOption[REQ, RES]) *Client[REQ, RES]
NewExplicitClient is like NewClient but uses a CreateRequestFunc instead of a method, target URL, and EncodeRequestFunc, which allows for more control over the outgoing HTTP request.
type ClientFinalizerFunc ¶ added in v0.5.0
ClientFinalizerFunc can be used to perform work at the end of a client HTTP request, after the response is returned. The principal intended use is for error logging. Additional response parameters are provided in the context under keys with the ContextKeyResponse prefix. Note: err may be nil. There maybe also no additional response parameters depending on when an error occurs.
type ClientOption ¶
ClientOption sets an optional parameter for clients.
func BufferedStream ¶ added in v0.2.0
func BufferedStream[REQ any, RES any](buffered bool) ClientOption[REQ, RES]
BufferedStream sets whether the HTTP response body is left open, allowing it to be read from later. Useful for transporting a file as a buffered stream. That body has to be drained and closed to properly end the request.
func ClientAfter ¶ added in v0.2.0
func ClientAfter[REQ any, RES any](after ...ClientResponseFunc) ClientOption[REQ, RES]
ClientAfter adds one or more ClientResponseFuncs, which are applied to the incoming HTTP response prior to it being decoded. This is useful for obtaining anything off of the response and adding it into the context prior to decoding.
func ClientBefore ¶ added in v0.2.0
func ClientBefore[REQ any, RES any](before ...RequestFunc) ClientOption[REQ, RES]
ClientBefore adds one or more RequestFuncs to be applied to the outgoing HTTP request before it's invoked.
func ClientFinalizer ¶ added in v0.5.0
func ClientFinalizer[REQ any, RES any](f ...ClientFinalizerFunc) ClientOption[REQ, RES]
ClientFinalizer adds one or more ClientFinalizerFuncs to be executed at the end of every HTTP request. Finalizers are executed in the order in which they were added. By default, no finalizer is registered.
func SetClient ¶
func SetClient[REQ any, RES any](client HTTPClient) ClientOption[REQ, RES]
SetClient sets the underlying HTTP client used for requests. By default, http.DefaultClient is used.
type ClientResponseFunc ¶ added in v0.2.0
ClientResponseFunc may take information from an HTTP request and make the response available for consumption. ClientResponseFuncs are only executed in clients, after a request has been made, but prior to it being decoded.
type CreateRequestFunc ¶ added in v0.18.0
CreateRequestFunc creates an outgoing HTTP request based on the passed request object. It's designed to be used in HTTP clients, for client-side endpoints. It's a more powerful version of EncodeRequestFunc, and can be used if more fine-grained control of the HTTP request is required.
type DecodeRequestFunc ¶
DecodeRequestFunc extracts a user-domain request object from an HTTP request object. It's designed to be used in HTTP servers, for server-side endpoints. One straightforward DecodeRequestFunc could be something that JSON decodes from the request body to the concrete request type.
type DecodeResponseFunc ¶
DecodeResponseFunc extracts a user-domain response object from an HTTP response object. It's designed to be used in HTTP clients, for client-side endpoints. One straightforward DecodeResponseFunc could be something that JSON decodes from the response body to the concrete response type.
type EncodeRequestFunc ¶
EncodeRequestFunc encodes the passed request object into the HTTP request object. It's designed to be used in HTTP clients, for client-side endpoints. One straightforward EncodeRequestFunc could be something that JSON encodes the object directly to the request body.
type EncodeResponseFunc ¶
EncodeResponseFunc encodes the passed response object to the HTTP response writer. It's designed to be used in HTTP servers, for server-side endpoints. One straightforward EncodeResponseFunc could be something that JSON encodes the object directly to the response body.
type ErrorEncoder ¶
type ErrorEncoder func(ctx context.Context, err error, w http.ResponseWriter)
ErrorEncoder is responsible for encoding an error to the ResponseWriter. Users are encouraged to use custom ErrorEncoders to encode HTTP errors to their clients, and will likely want to pass and check for their own error types. See the example shipping/handling service.
type HTTPClient ¶ added in v0.8.0
HTTPClient is an interface that models *http.Client.
type Headerer ¶ added in v0.4.0
Headerer is checked by DefaultErrorEncoder. If an error value implements Headerer, the provided headers will be applied to the response writer, after the Content-Type is set.
type RequestFunc ¶
RequestFunc may take information from an HTTP request and put it into a request context. In Servers, RequestFuncs are executed prior to invoking the endpoint. In Clients, RequestFuncs are executed after creating the request but prior to invoking the HTTP client.
func SetRequestHeader ¶
func SetRequestHeader(key, val string) RequestFunc
SetRequestHeader returns a RequestFunc that sets the given header.
type Server ¶
Server wraps an endpoint and implements http.Handler.
func NewServer ¶
func NewServer[REQ any, RES any]( e endpoint.Endpoint[REQ, RES], dec DecodeRequestFunc[REQ], enc EncodeResponseFunc[RES], options ...ServerOption[REQ, RES], ) *Server[REQ, RES]
NewServer constructs a new server, which implements http.Handler and wraps the provided endpoint.
type ServerFinalizerFunc ¶ added in v0.4.0
ServerFinalizerFunc can be used to perform work at the end of an HTTP request, after the response has been written to the client. The principal intended use is for request logging. In addition to the response code provided in the function signature, additional response parameters are provided in the context under keys with the ContextKeyResponse prefix.
type ServerOption ¶
ServerOption sets an optional parameter for servers.
func ServerAfter ¶
func ServerAfter[REQ any, RES any](after ...ServerResponseFunc) ServerOption[REQ, RES]
ServerAfter functions are executed on the HTTP response writer after the endpoint is invoked, but before anything is written to the client.
func ServerBefore ¶
func ServerBefore[REQ any, RES any](before ...RequestFunc) ServerOption[REQ, RES]
ServerBefore functions are executed on the HTTP request object before the request is decoded.
func ServerErrorEncoder ¶
func ServerErrorEncoder[REQ any, RES any](ee ErrorEncoder) ServerOption[REQ, RES]
ServerErrorEncoder is used to encode errors to the http.ResponseWriter whenever they're encountered in the processing of a request. Clients can use this to provide custom error formatting and response codes. By default, errors will be written with the DefaultErrorEncoder.
func ServerErrorHandler ¶ added in v0.9.0
func ServerErrorHandler[REQ any, RES any](errorHandler transport.ErrorHandler) ServerOption[REQ, RES]
ServerErrorHandler is used to handle non-terminal errors. By default, non-terminal errors are ignored. This is intended as a diagnostic measure. Finer-grained control of error handling, including logging in more detail, should be performed in a custom ServerErrorEncoder or ServerFinalizer, both of which have access to the context.
func ServerErrorLogger ¶
func ServerErrorLogger[REQ any, RES any](logger log.Logger) ServerOption[REQ, RES]
ServerErrorLogger is used to log non-terminal errors. By default, no errors are logged. This is intended as a diagnostic measure. Finer-grained control of error handling, including logging in more detail, should be performed in a custom ServerErrorEncoder or ServerFinalizer, both of which have access to the context. Deprecated: Use ServerErrorHandler instead.
func ServerFinalizer ¶ added in v0.4.0
func ServerFinalizer[REQ any, RES any](f ...ServerFinalizerFunc) ServerOption[REQ, RES]
ServerFinalizer is executed at the end of every HTTP request. By default, no finalizer is registered.
type ServerResponseFunc ¶ added in v0.2.0
ServerResponseFunc may take information from a request context and use it to manipulate a ResponseWriter. ServerResponseFuncs are only executed in servers, after invoking the endpoint but prior to writing a response.
func SetContentType ¶
func SetContentType(contentType string) ServerResponseFunc
SetContentType returns a ServerResponseFunc that sets the Content-Type header to the provided value.
func SetResponseHeader ¶
func SetResponseHeader(key, val string) ServerResponseFunc
SetResponseHeader returns a ServerResponseFunc that sets the given header.
type StatusCoder ¶ added in v0.4.0
type StatusCoder interface {
StatusCode() int
}
StatusCoder is checked by DefaultErrorEncoder. If an error value implements StatusCoder, the StatusCode will be used when encoding the error. By default, StatusInternalServerError (500) is used.