-
Notifications
You must be signed in to change notification settings - Fork 146
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
BED-5301/5298: PenTest Result: Internal IP Address Disclosure AND Rate limit Bypass #1163
base: main
Are you sure you want to change the base?
Conversation
…ementing our current rate limiting middleware logic
… I need to fix (maybe even add)
ipGetter := stdlib.WithKeyGetter( | ||
func(r *http.Request) string { | ||
if xff := r.Header.Get("X-Forwarded-For"); xff == "" { | ||
slog.DebugContext(r.Context(), "No data found in X-Forwarded-For header") | ||
return r.RemoteAddr | ||
} else { | ||
ips := strings.Split(xff, ",") | ||
rightMostIP := strings.TrimSpace(ips[len(ips)-1]) | ||
|
||
return rightMostIP | ||
} | ||
}, | ||
) | ||
|
||
middleware := stdlib.NewMiddleware(limiter, ipGetter) | ||
|
||
return middleware.Handler | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I was trying to figure out why we couldn't use the reference X Forwarded For implementation from limiter
but stumbled on the fact that you'd expect the leftmost to be the IP, but because we don't have multiple reverse proxies and the loadbalancer doesn't strip incoming X Forwarded For (in our case, almost always spoofed IPs), we can't rely on it. However, this puts us in a weird position because if someone is self hosting BloodHound, this will make it so anyone hosting with multiple reverse proxies/load balancers in front of them will end up detecting internal IPs for rate limiting.
I don't know if there's a one size fits all solution here, but we should probably consider the consequences before moving forward.
Description
/api/v2/login
endpoint in order to address part of the requirements for BED-5300Motivation and Context
This PR addresses:
Why is this change required? What problem does it solve?
How Has This Been Tested?
Screenshots (optional):
UI
data:image/s3,"s3://crabby-images/8ce92/8ce92e7de570f00a1e58a854a941b6f7760d72e5" alt="Screenshot 2025-02-21 at 2 43 23 PM"
Terminal
data:image/s3,"s3://crabby-images/27800/278001bcbe817a411bd2c69ba4adb00b89aa80ad" alt="Screenshot 2025-02-21 at 2 40 26 PM"
Types of changes
Checklist: