Skip to content

Commit

Permalink
feat(BUX-421): replace router logger
Browse files Browse the repository at this point in the history
  • Loading branch information
pawellewandowski98 committed Dec 19, 2023
1 parent 70699ef commit 40e3988
Showing 1 changed file with 40 additions and 5 deletions.
45 changes: 40 additions & 5 deletions actions/middleware.go
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
package actions

import (
"context"
"net/http"
"time"

"github.com/BuxOrg/bux"
"github.com/BuxOrg/bux-server/config"
"github.com/BuxOrg/bux-server/dictionary"
"github.com/gofrs/uuid"
"github.com/julienschmidt/httprouter"
apirouter "github.com/mrz1836/go-api-router"
"github.com/mrz1836/go-parameters"
)

// Action is the configuration for the actions and related services
Expand Down Expand Up @@ -71,11 +75,8 @@ func (a *Action) RequireAdminAuthentication(fn httprouter.Handle) httprouter.Han
}

// Request will process the request in the router
func (a *Action) Request(router *apirouter.Router, h httprouter.Handle) httprouter.Handle {
if a.AppConfig.RequestLogging {
return router.Request(h)
}
return router.RequestNoLogging(h)
func (a *Action) Request(_ *apirouter.Router, h httprouter.Handle) httprouter.Handle {
return Request(h, a)
}

// CheckAuthentication will check the authentication
Expand All @@ -101,3 +102,37 @@ func CheckAuthentication(appConfig *config.AppConfig, bux bux.ClientInterface, r
// Return an empty error message
return req, dictionary.ErrorMessage{}
}

// Request will write the request to the logs before and after calling the handler
func Request(h httprouter.Handle, a *Action) httprouter.Handle {
return parameters.MakeHTTPRouterParsedReq(func(w http.ResponseWriter, req *http.Request, ps httprouter.Params) {
// Start the custom response writer
guid, _ := uuid.NewV4()
writer := &apirouter.APIResponseWriter{
IPAddress: apirouter.GetClientIPAddress(req),
Method: req.Method,
RequestID: guid.String(),
ResponseWriter: w,
Status: 0, // future use with E-tags
URL: req.URL.String(),
UserAgent: req.UserAgent(),
}

// Store key information into the request that can be used by other methods
req.WithContext(context.WithValue(req.Context(), "ip_address", writer.IPAddress))

Check failure on line 122 in actions/middleware.go

View workflow job for this annotation

GitHub Actions / test (1.19.x, ubuntu-latest)

context-keys-type: should not use basic type string as key in context.WithValue (revive)

Check failure on line 122 in actions/middleware.go

View workflow job for this annotation

GitHub Actions / test (1.19.x, ubuntu-latest)

context-keys-type: should not use basic type string as key in context.WithValue (revive)
req.WithContext(context.WithValue(req.Context(), "request_id", writer.RequestID))

Check failure on line 123 in actions/middleware.go

View workflow job for this annotation

GitHub Actions / test (1.19.x, ubuntu-latest)

context-keys-type: should not use basic type string as key in context.WithValue (revive)

Check failure on line 123 in actions/middleware.go

View workflow job for this annotation

GitHub Actions / test (1.19.x, ubuntu-latest)

context-keys-type: should not use basic type string as key in context.WithValue (revive)

// Start the log (timer)
start := time.Now()

// Fire the request
h(writer, req, ps)

// Complete the timer and final log
elapsed := time.Since(start)

if a.AppConfig.RequestLogging {
a.Services.Logger.Debug().Msgf("%d | %s | %s | %s | %s ", writer.Status, elapsed, req.RemoteAddr, req.Method, req.URL)
}
})
}

0 comments on commit 40e3988

Please sign in to comment.