mirror of
https://github.com/kataras/iris.git
synced 2025-01-23 18:51:03 +01:00
120 lines
3.5 KiB
Go
120 lines
3.5 KiB
Go
package iris
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/valyala/fasthttp"
|
|
"github.com/valyala/fasthttp/fasthttpadaptor"
|
|
)
|
|
|
|
type (
|
|
|
|
// Handler the main Iris Handler interface.
|
|
Handler interface {
|
|
Serve(ctx *Context)
|
|
}
|
|
|
|
// HandlerFunc type is an adapter to allow the use of
|
|
// ordinary functions as HTTP handlers. If f is a function
|
|
// with the appropriate signature, HandlerFunc(f) is a
|
|
// Handler that calls f.
|
|
HandlerFunc func(*Context)
|
|
|
|
// HandlerAPI allow the use of a custom struct as API handler(s) for a particular request path
|
|
// It's just an interface {}, we keep it here to make things more readable.
|
|
HandlerAPI interface {
|
|
// we don't use context.IContext because of some methods as Get() is already inside the IContext interface and conficts with the Get()
|
|
// we want to use for API.
|
|
// a valid controller has this form:
|
|
/*
|
|
type index struct {
|
|
*iris.Context
|
|
}
|
|
|
|
// OR
|
|
type index struct {
|
|
Context *iris.Context
|
|
}
|
|
|
|
func (i index) Get() {
|
|
i.Write("Hello from /")
|
|
}
|
|
|
|
func (i index) GetBy(id string) {} // /:namedParameter
|
|
//POST,PUT,DELETE...
|
|
|
|
*/
|
|
}
|
|
|
|
//IMiddlewareSupporter is an interface which all routers must implement
|
|
IMiddlewareSupporter interface {
|
|
Use(handlers ...Handler)
|
|
UseFunc(handlersFn ...HandlerFunc)
|
|
}
|
|
|
|
// Middleware is just a slice of Handler []func(c *Context)
|
|
Middleware []Handler
|
|
)
|
|
|
|
// Serve serves the handler, is like ServeHTTP for Iris
|
|
func (h HandlerFunc) Serve(ctx *Context) {
|
|
h(ctx)
|
|
}
|
|
|
|
// ToHandler converts an http.Handler or http.HandlerFunc to an iris.Handler
|
|
func ToHandler(handler interface{}) Handler {
|
|
//this is not the best way to do it, but I dont have any options right now.
|
|
switch handler.(type) {
|
|
case Handler:
|
|
//it's already an iris handler
|
|
return handler.(Handler)
|
|
case http.Handler:
|
|
//it's http.Handler
|
|
h := fasthttpadaptor.NewFastHTTPHandlerFunc(handler.(http.Handler).ServeHTTP)
|
|
|
|
return ToHandlerFastHTTP(h)
|
|
case func(http.ResponseWriter, *http.Request):
|
|
//it's http.HandlerFunc
|
|
h := fasthttpadaptor.NewFastHTTPHandlerFunc(handler.(func(http.ResponseWriter, *http.Request)))
|
|
return ToHandlerFastHTTP(h)
|
|
default:
|
|
panic(ErrHandler.Format(handler, handler))
|
|
}
|
|
}
|
|
|
|
// ToHandlerFunc converts an http.Handler or http.HandlerFunc to an iris.HandlerFunc
|
|
func ToHandlerFunc(handler interface{}) HandlerFunc {
|
|
return ToHandler(handler).Serve
|
|
}
|
|
|
|
// ToHandlerFastHTTP converts an fasthttp.RequestHandler to an iris.Handler
|
|
func ToHandlerFastHTTP(h fasthttp.RequestHandler) Handler {
|
|
return HandlerFunc((func(ctx *Context) {
|
|
h(ctx.RequestCtx)
|
|
}))
|
|
}
|
|
|
|
// ConvertToHandlers accepts list of HandlerFunc and returns list of Handler
|
|
// this can be renamed to convertToMiddleware also because it returns a list of []Handler which is what Middleware is
|
|
func ConvertToHandlers(handlersFn []HandlerFunc) []Handler {
|
|
hlen := len(handlersFn)
|
|
mlist := make([]Handler, hlen)
|
|
for i := 0; i < hlen; i++ {
|
|
mlist[i] = Handler(handlersFn[i])
|
|
}
|
|
return mlist
|
|
}
|
|
|
|
// JoinMiddleware uses to create a copy of all middleware and return them in order to use inside the node
|
|
func JoinMiddleware(middleware1 Middleware, middleware2 Middleware) Middleware {
|
|
nowLen := len(middleware1)
|
|
totalLen := nowLen + len(middleware2)
|
|
// create a new slice of middleware in order to store all handlers, the already handlers(middleware) and the new
|
|
newMiddleware := make(Middleware, totalLen)
|
|
//copy the already middleware to the just created
|
|
copy(newMiddleware, middleware1)
|
|
//start from there we finish, and store the new middleware too
|
|
copy(newMiddleware[nowLen:], middleware2)
|
|
return newMiddleware
|
|
}
|