Add per-IP rate limiting and Unix socket support for gRPC admin API
Rate limiting: per-source-IP connection rate limiter in the firewall layer with configurable limit and sliding window. Blocklisted IPs are rejected before rate limit evaluation to avoid wasting quota. Unix socket: the gRPC admin API can now listen on a Unix domain socket (no TLS required), secured by file permissions (0600), as a simpler alternative for local-only access. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -28,7 +28,7 @@ func echoServer(t *testing.T, ln net.Listener) {
|
||||
// newTestServer creates a Server with the given listener data and no firewall rules.
|
||||
func newTestServer(t *testing.T, listeners []ListenerData) *Server {
|
||||
t.Helper()
|
||||
fw, err := firewall.New("", nil, nil, nil)
|
||||
fw, err := firewall.New("", nil, nil, nil, 0, 0)
|
||||
if err != nil {
|
||||
t.Fatalf("creating firewall: %v", err)
|
||||
}
|
||||
@@ -195,7 +195,7 @@ func TestFirewallBlocks(t *testing.T) {
|
||||
proxyLn.Close()
|
||||
|
||||
// Create a firewall that blocks 127.0.0.1 (the test client).
|
||||
fw, err := firewall.New("", []string{"127.0.0.1"}, nil, nil)
|
||||
fw, err := firewall.New("", []string{"127.0.0.1"}, nil, nil, 0, 0)
|
||||
if err != nil {
|
||||
t.Fatalf("creating firewall: %v", err)
|
||||
}
|
||||
@@ -599,7 +599,7 @@ func TestGracefulShutdown(t *testing.T) {
|
||||
proxyAddr := proxyLn.Addr().String()
|
||||
proxyLn.Close()
|
||||
|
||||
fw, err := firewall.New("", nil, nil, nil)
|
||||
fw, err := firewall.New("", nil, nil, nil, 0, 0)
|
||||
if err != nil {
|
||||
t.Fatalf("creating firewall: %v", err)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user