diff options
author | tjpcc <tjp@ctrl-c.club> | 2023-08-12 09:40:39 -0600 |
---|---|---|
committer | tjpcc <tjp@ctrl-c.club> | 2023-08-12 09:40:39 -0600 |
commit | 23bc5f4fb7542e64c94eaa7fe2c7a6aa55010898 (patch) | |
tree | ec8113d3aa2379e3ca9cb3c6e13a5531895ea8c0 /internal/types/handler.go | |
parent | 57a31a9b2cd549174d839b9b91b47db337f174cc (diff) |
move common types to an internal package
This helps avoid import cycles.
Diffstat (limited to 'internal/types/handler.go')
-rw-r--r-- | internal/types/handler.go | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/internal/types/handler.go b/internal/types/handler.go new file mode 100644 index 0000000..4805c57 --- /dev/null +++ b/internal/types/handler.go @@ -0,0 +1,28 @@ +package types + +import "context" + +// Handler is a type which can turn a request into a response. +// +// Handle may return a nil response, in which case the Server is expected +// to build the protocol-appropriate "Not Found" response. +type Handler interface { + Handle(context.Context, *Request) *Response +} + +// Middleware is a handler decorator. +// +// It returns a handler which may call the passed-in handler or not, or may +// transform the request or response in some way. +type Middleware func(Handler) Handler + +func HandlerFunc(f func(context.Context, *Request) *Response) Handler { + return handlerFunc(f) +} + +// Handle implements Handler. +func (f handlerFunc) Handle(ctx context.Context, request *Request) *Response { + return f(ctx, request) +} + +type handlerFunc func(context.Context, *Request) *Response |