This repository provides a way to share your Iris' specific middleware with the rest of us. You can view the @go-siris supported middleware by pressing here.
The only requirement is the Go Programming Language, at least version 1.8
$ go get github.com/go-siris/middleware/...
Explore these questions or navigate to the community chat.
The Community.
Middleware are just handlers which can be served before or after the main handler, can transfer data between handlers and communicate with third-party libraries, they are just functions.
$ go get -u github.com/go-siris/middleware/$FOLDERNAME
NOTE: When you install one middleware you will have all of them downloaded & installed, no need to re-run the go get foreach middeware.
To a single route
app := siris.New()
app.Get("/mypath",myMiddleware1,myMiddleware2,func(ctx context.Context){}, func(ctx context.Context){},myMiddleware5,myMainHandlerLast)
To a party of routes or subdomain
myparty := app.Party("/myparty", myMiddleware1,func(ctx context.Context){},myMiddleware3)
{
//....
}
To all routes
app.Use(func(ctx context.Context){}, myMiddleware2)
To global, all routes on all subdomains on all parties
app.UseGlobal(func(ctx context.Context){}, myMiddleware2)
Yes you can, just pass the Handler inside the handlerconv.FromStd
in order to be converted into siris.HandlerFunc and register it as you saw before.
package main
import (
"github.com/go-siris/siris"
"github.com/go-siris/siris/context"
"github.com/go-siris/siris/core/handlerconv"
)
func main() {
app := siris.New()
sillyHTTPHandler := http.HandlerFunc(func(w http.ResponseWriter, r *http.Request){
println(r.RequestURI)
})
sillyConvertedToSiris := handlerconv.FromStd(sillyHTTPHandler)
// FromStd can take (http.ResponseWriter, *http.Request, next http.Handler) too!
app.Use(sillyConvertedToSiris)
app.Run(siris.Addr(":8080"))
}