Documentation ¶
Index ¶
- Constants
- type Catcher
- type Handler
- type Middleware
- type Mutator
- type Resource
- func (r Resource) Catch(prefix string, handler Handler, mwares ...Middleware) Resource
- func (r Resource) Connect(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Delete(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Get(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Head(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Options(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Patch(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Post(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Put(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Route(method method.Method, fun Handler, mwares ...Middleware) Resource
- func (r Resource) Static(prefix, root string) Resource
- func (r Resource) Trace(handler Handler, mwares ...Middleware) Resource
- func (r Resource) Use(middlewares ...Middleware) Resource
- type Router
- func (r *Router) Alias(from, to string) *Router
- func (r *Router) Catch(prefix string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Connect(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Delete(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Get(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Group(prefix string) *Router
- func (r *Router) Head(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Mutator(mutator Mutator) *Router
- func (r *Router) OnError(request *http.Request, err error) *http.Response
- func (r *Router) OnRequest(request *http.Request) *http.Response
- func (r *Router) OnStart() error
- func (r *Router) Options(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Patch(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Post(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Put(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Resource(path string) Resource
- func (r *Router) Route(method method.Method, path string, handlerFunc Handler, ...) *Router
- func (r *Router) RouteError(handler Handler, codes ...status.Code) *Router
- func (r *Router) Static(prefix, root string, mwares ...Middleware) *Router
- func (r *Router) Trace(path string, handler Handler, middlewares ...Middleware) *Router
- func (r *Router) Use(middlewares ...Middleware) *Router
Constants ¶
const AllErrors = status.Code(0)
AllErrors is used to be passed into Router.RouteError, indicating by that, that the handler must handle ALL errors (if concrete error's handler won't override it)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Catcher ¶ added in v0.13.0
Catcher is used to catch requests, if no other handlers are available. This is used, for example, for static files distribution
type Middleware ¶ added in v0.13.0
Middleware works like a chain of nested calls, next may be even directly handler. But if we are not a closing middleware, we will call next middleware that is simply a partial middleware with already provided next
type Mutator ¶ added in v0.15.0
Mutator is kind of pre-middleware. It's being called at the moment, when a request arrives to the router, but before the routing will be done. So by that, the request may be mutated. For example, mutator may normalize requests' paths, log them, make invisible redirects, etc.
type Resource ¶
type Resource struct {
// contains filtered or unexported fields
}
Resource is just a wrapper of a group for some resource, allowing to attach multiple methods (and pointed-applied middlewares) to some single resource in a bit more convenient way than ordinary groups do. Actually, the only point of this object is to wrap a group to bypass an empty string into it as a path
func (Resource) Catch ¶ added in v0.10.5
func (r Resource) Catch(prefix string, handler Handler, mwares ...Middleware) Resource
Catch registers a catcher. A catcher is a handler, that is being called if requested path is not found, and it starts with a defined prefix
func (Resource) Connect ¶
func (r Resource) Connect(handler Handler, mwares ...Middleware) Resource
Connect registers a handler for CONNECT-requests
func (Resource) Delete ¶
func (r Resource) Delete(handler Handler, mwares ...Middleware) Resource
Delete registers a handler for DELETE-requests
func (Resource) Get ¶
func (r Resource) Get(handler Handler, mwares ...Middleware) Resource
Get registers a handler for GET-requests
func (Resource) Head ¶
func (r Resource) Head(handler Handler, mwares ...Middleware) Resource
Head registers a handler for HEAD-requests
func (Resource) Options ¶
func (r Resource) Options(handler Handler, mwares ...Middleware) Resource
Options registers a handler for OPTIONS-requests
func (Resource) Patch ¶
func (r Resource) Patch(handler Handler, mwares ...Middleware) Resource
Patch registers a handler for PATCH-requests
func (Resource) Post ¶
func (r Resource) Post(handler Handler, mwares ...Middleware) Resource
Post registers a handler for POST-requests
func (Resource) Put ¶
func (r Resource) Put(handler Handler, mwares ...Middleware) Resource
Put registers a handler for PUT-requests
func (Resource) Route ¶
Route is a shortcut to group.Route, providing the extra empty path to the call
func (Resource) Static ¶ added in v0.10.5
Static adds a catcher of prefix, that automatically returns files from defined root directory
func (Resource) Trace ¶
func (r Resource) Trace(handler Handler, mwares ...Middleware) Resource
Trace registers a handler for TRACE-requests
func (Resource) Use ¶
func (r Resource) Use(middlewares ...Middleware) Resource
Use applies middlewares to the resource, wrapping all the already registered and registered in future handlers
type Router ¶
type Router struct {
// contains filtered or unexported fields
}
Router is a built-in implementation of router.Router interface that provides some basic router features like middlewares, groups, dynamic routing, error handlers, and some implicit things like calling GET-handlers for HEAD-requests, or rendering TRACE-responses automatically in case no handler is registered
func (*Router) Alias ¶ added in v0.13.1
Alias makes an implicitly redirects to other endpoint by changing request path before a handler is called. In case of implicit redirect, original path is stored in Request.Env.AliasFrom
func (*Router) Catch ¶ added in v0.10.5
func (r *Router) Catch(prefix string, handler Handler, middlewares ...Middleware) *Router
Catch registers a catcher. A catcher is a handler, that is being called if requested path is not found, and it starts with a defined prefix
func (*Router) Connect ¶
func (r *Router) Connect(path string, handler Handler, middlewares ...Middleware) *Router
Connect is a shortcut for registering CONNECT-requests
func (*Router) Delete ¶
func (r *Router) Delete(path string, handler Handler, middlewares ...Middleware) *Router
Delete is a shortcut for registering DELETE-requests
func (*Router) Get ¶
func (r *Router) Get(path string, handler Handler, middlewares ...Middleware) *Router
Get is a shortcut for registering GET-requests
func (*Router) Group ¶
Group creates a new router with pre-defined prefix for all paths. It'll automatically be merged into the head router on server start. Middlewares, applied on this router, will not affect the head router, but initially head router's middlewares will be inherited and will be called in the first order. Registering new error handlers will result in affecting error handlers among ALL the existing groups, including head router
func (*Router) Head ¶
func (r *Router) Head(path string, handler Handler, middlewares ...Middleware) *Router
Head is a shortcut for registering HEAD-requests
func (*Router) Mutator ¶ added in v0.15.0
Mutator adds a new mutator.
NOTE: registering them on groups will affect only the order of execution
func (*Router) OnError ¶
OnError tries to find a handler for the error, in case it can't - simply request.Respond().WithError(...) will be returned
func (*Router) Options ¶
func (r *Router) Options(path string, handler Handler, middlewares ...Middleware) *Router
Options is a shortcut for registering OPTIONS-requests
func (*Router) Patch ¶
func (r *Router) Patch(path string, handler Handler, middlewares ...Middleware) *Router
Patch is a shortcut for registering PATCH-requests
func (*Router) Post ¶
func (r *Router) Post(path string, handler Handler, middlewares ...Middleware) *Router
Post is a shortcut for registering POST-requests
func (*Router) Put ¶
func (r *Router) Put(path string, handler Handler, middlewares ...Middleware) *Router
Put is a shortcut for registering PUT-requests
func (*Router) Route ¶
func (r *Router) Route( method method.Method, path string, handlerFunc Handler, middlewares ...Middleware, ) *Router
Route is a base method for registering handlers
func (*Router) RouteError ¶
RouteError adds an error handler for a corresponding HTTP error code.
The following error codes may be registered:
- AllErrors (called only if no other error handlers found)
- status.BadRequest
- status.NotFound
- status.MethodNotAllowed
- status.RequestEntityTooLarge
- status.CloseConnection
- status.RequestURITooLong
- status.HeaderFieldsTooLarge
- status.HTTPVersionNotSupported
- status.UnsupportedMediaType
- status.NotImplemented
- status.RequestTimeout
Note: if handler returned one of error codes above, error handler WON'T be called. Also, global middlewares, applied to the root router, will also be used for error handlers. However, global middlewares defined on groups won't be used.
WARNING: calling this method from groups will affect ALL routers, including root
func (*Router) Static ¶ added in v0.10.5
func (r *Router) Static(prefix, root string, mwares ...Middleware) *Router
Static adds a catcher of prefix, that automatically returns files from defined root directory
func (*Router) Trace ¶
func (r *Router) Trace(path string, handler Handler, middlewares ...Middleware) *Router
Trace is a shortcut for registering TRACE-requests
func (*Router) Use ¶
func (r *Router) Use(middlewares ...Middleware) *Router
Use adds middlewares into the global list of a group's middlewares. But they will be applied only after the server will be started