1
0

auth.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package middleware
  2. import (
  3. "context"
  4. "log"
  5. "net/http"
  6. "aws-sts-mock/internal/kvdb"
  7. "aws-sts-mock/pkg/sigv4"
  8. )
  9. // UserValidationMiddleware creates a middleware that validates users against the KV database
  10. func UserValidationMiddleware(db kvdb.KVDB) func(http.Handler) http.Handler {
  11. return func(next http.Handler) http.Handler {
  12. return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
  13. // Extract credentials from context (set by SigV4 middleware)
  14. creds, ok := r.Context().Value(sigv4.CredentialsContextKey).(sigv4.AWSCredentials)
  15. if !ok {
  16. http.Error(w, "Unauthorized", http.StatusUnauthorized)
  17. return
  18. }
  19. // Validate user exists in database
  20. user, err := db.GetUser(creds.AccessKeyID)
  21. if err != nil {
  22. if err == kvdb.ErrUserNotFound {
  23. log.Printf("User not found: %s", creds.AccessKeyID)
  24. http.Error(w, "Access Denied: User not found", http.StatusForbidden)
  25. return
  26. }
  27. log.Printf("Error validating user: %v", err)
  28. http.Error(w, "Internal Server Error", http.StatusInternalServerError)
  29. return
  30. }
  31. // Validate secret key matches
  32. if user.SecretAccessKey != creds.SecretAccessKey {
  33. log.Printf("Invalid credentials for user: %s", creds.AccessKeyID)
  34. http.Error(w, "Access Denied: Invalid credentials", http.StatusForbidden)
  35. return
  36. }
  37. // Update context with validated user information
  38. ctx := context.WithValue(r.Context(), sigv4.CredentialsContextKey, sigv4.AWSCredentials{
  39. AccessKeyID: user.AccessKeyID,
  40. SecretAccessKey: user.SecretAccessKey,
  41. AccountID: user.AccountID,
  42. })
  43. log.Printf("User validated: %s (Account: %s)", user.Username, user.AccountID)
  44. // Continue to next handler
  45. next.ServeHTTP(w, r.WithContext(ctx))
  46. })
  47. }
  48. }
  49. // ChainMiddleware chains multiple middleware functions
  50. func ChainMiddleware(middlewares ...func(http.Handler) http.Handler) func(http.Handler) http.Handler {
  51. return func(final http.Handler) http.Handler {
  52. for i := len(middlewares) - 1; i >= 0; i-- {
  53. final = middlewares[i](final)
  54. }
  55. return final
  56. }
  57. }