Cors handler for fasthttp server
Read First |
Installation |
Usage |
License
Handling CORS in fasthttp
- This handler is heavily "inspired" by this work https://github.com/rs/cors/
- This handler comply to w3c spec of CORS (even in case-insensitive comparison) https://www.w3.org/TR/cors/
- go get github.com/adhityaramadhanus/fasthttpcors
package main
import (
"log"
cors "github.com/AdhityaRamadhanus/fasthttpcors"
"github.com/valyala/fasthttp"
)
func main() {
withCors := cors.NewCorsHandler(cors.Options{
// if you leave allowedOrigins empty then fasthttpcors will treat it as "*"
AllowedOrigins: []string{"http://example.com"}, // Only allow example.com to access the resource
// if you leave allowedHeaders empty then fasthttpcors will accept any non-simple headers
AllowedHeaders: []string{"x-something-client", "Content-Type"}, // only allow x-something-client and Content-Type in actual request
// if you leave this empty, only simple method will be accepted
AllowedMethods: []string{"GET", "POST"}, // only allow get or post to resource
AllowCredentials: false, // resource doesn't support credentials
AllowMaxAge: 5600, // cache the preflight result
Debug: true,
})
if err := fasthttp.ListenAndServe(":8080", withCors.CorsMiddleware(RequestHandler)); err != nil {
log.Fatalf("Error in ListenAndServe: %s", err)
}
}
func RequestHandler(ctx *fasthttp.RequestCtx) {
ctx.SetContentType("plain/text")
ctx.SetStatusCode(200)
ctx.SetBodyString("OK")
}
- add test
MIT © [Adhitya Ramadhanus]