Some checks failed
Go Benchmark / Performance Regression Check (push) Has been cancelled
Cerberus Integration / Cerberus Security Stack Integration (push) Has been cancelled
Upload Coverage to Codecov / Backend Codecov Upload (push) Has been cancelled
Upload Coverage to Codecov / Frontend Codecov Upload (push) Has been cancelled
CodeQL - Analyze / CodeQL analysis (go) (push) Has been cancelled
CodeQL - Analyze / CodeQL analysis (javascript-typescript) (push) Has been cancelled
CrowdSec Integration / CrowdSec Bouncer Integration (push) Has been cancelled
Docker Build, Publish & Test / build-and-push (push) Has been cancelled
Quality Checks / Auth Route Protection Contract (push) Has been cancelled
Quality Checks / Codecov Trigger/Comment Parity Guard (push) Has been cancelled
Quality Checks / Backend (Go) (push) Has been cancelled
Quality Checks / Frontend (React) (push) Has been cancelled
Rate Limit integration / Rate Limiting Integration (push) Has been cancelled
Security Scan (PR) / Trivy Binary Scan (push) Has been cancelled
Supply Chain Verification (PR) / Verify Supply Chain (push) Has been cancelled
WAF integration / Coraza WAF Integration (push) Has been cancelled
Docker Build, Publish & Test / Security Scan PR Image (push) Has been cancelled
Repo Health Check / Repo health (push) Has been cancelled
History Rewrite Dry-Run / Dry-run preview for history rewrite (push) Has been cancelled
Prune Renovate Branches / prune (push) Has been cancelled
41 lines
1.1 KiB
Go
Executable File
41 lines
1.1 KiB
Go
Executable File
package middleware
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/Wikid82/charon/backend/internal/logger"
|
|
"github.com/Wikid82/charon/backend/internal/trace"
|
|
"github.com/gin-gonic/gin"
|
|
"github.com/google/uuid"
|
|
"github.com/sirupsen/logrus"
|
|
)
|
|
|
|
const RequestIDHeader = "X-Request-ID"
|
|
|
|
// RequestID generates a uuid per request and places it in context and header.
|
|
func RequestID() gin.HandlerFunc {
|
|
return func(c *gin.Context) {
|
|
rid := uuid.New().String()
|
|
c.Set(string(trace.RequestIDKey), rid)
|
|
c.Writer.Header().Set(RequestIDHeader, rid)
|
|
// Add to logger fields for this request
|
|
entry := logger.WithFields(map[string]any{"request_id": rid})
|
|
c.Set("logger", entry)
|
|
// Propagate into the request context so it can be used by services
|
|
ctx := context.WithValue(c.Request.Context(), trace.RequestIDKey, rid)
|
|
c.Request = c.Request.WithContext(ctx)
|
|
c.Next()
|
|
}
|
|
}
|
|
|
|
// GetRequestLogger retrieves the request-scoped logger from context or the global logger
|
|
func GetRequestLogger(c *gin.Context) *logrus.Entry {
|
|
if v, ok := c.Get("logger"); ok {
|
|
if entry, ok := v.(*logrus.Entry); ok {
|
|
return entry
|
|
}
|
|
}
|
|
// fallback
|
|
return logger.Log()
|
|
}
|