package webserver import ( "log" "github.com/buaazp/fasthttprouter" "github.com/mgerb/go-discord-bot/server/config" "github.com/mgerb/go-discord-bot/server/webserver/handlers" "github.com/valyala/fasthttp" ) func logger(next fasthttp.RequestHandler) fasthttp.RequestHandler { return func(ctx *fasthttp.RequestCtx) { logger := ctx.Logger() logger.Printf(ctx.RemoteAddr().String()) next(ctx) } } func applyMiddleware(handler fasthttp.RequestHandler) fasthttp.RequestHandler { newHandler := logger(handler) return newHandler } func registerRoutes(router *fasthttprouter.Router) { router.GET("/soundlist", handlers.SoundList) router.PUT("/upload", handlers.FileUpload) router.ServeFiles("/static/*filepath", "./dist/static") router.ServeFiles("/sounds/*filepath", config.Config.SoundsPath) router.NotFound = func(ctx *fasthttp.RequestCtx) { fasthttp.ServeFile(ctx, "./dist/index.html") } } func Start() { router := fasthttprouter.New() registerRoutes(router) // apply our middleware handlers := applyMiddleware(router.Handler) // start web server log.Fatal(fasthttp.ListenAndServe(config.Config.ServerAddr, handlers)) }