package webutility import ( "net/http" "time" "git.to-net.rs/marko.tikvic/gologger" ) var reqLogger *gologger.Logger func WithSetHeaders(h http.HandlerFunc) http.HandlerFunc { return func(w http.ResponseWriter, req *http.Request) { SetDefaultHeaders(w) if req.Method == http.MethodOptions { return } h(w, req) } } func WithParseForm(h http.HandlerFunc) http.HandlerFunc { return func(w http.ResponseWriter, req *http.Request) { err := req.ParseForm() if err != nil { BadRequest(w, req, err.Error()) return } h(w, req) } } func EnableLogging(log string) error { var err error reqLogger, err = gologger.New(log, gologger.MaxLogSize5MB) return err } func WithLog(h http.HandlerFunc) http.HandlerFunc { return func(w http.ResponseWriter, req *http.Request) { reqLogger.LogRequest(req, "") t1 := time.Now() h(w, req) t2 := time.Now() reqLogger.LogResponse(w, t2.Sub(t1)) } } func WithAuth(authorizedRoles []string, h http.HandlerFunc) http.HandlerFunc { return func(w http.ResponseWriter, req *http.Request) { if _, ok := AuthCheck(req, authorizedRoles); !ok { Unauthorized(w, req, "") return } h(w, req) } }