mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 21:35:52 +00:00
f4f62b5da6
* feat: handle panic in rpc rate limit interceptor * test: additional test cases to rpc rate limiting interceptor * refactor: remove unused listener
25 lines
602 B
Go
25 lines
602 B
Go
package middleware
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/hashicorp/go-hclog"
|
|
)
|
|
|
|
// NewPanicHandler returns a RecoveryHandlerFunc type function
|
|
// to handle panic in RPC server's handlers.
|
|
func NewPanicHandler(logger hclog.Logger) RecoveryHandlerFunc {
|
|
return func(p interface{}) (err error) {
|
|
// Log the panic and the stack trace of the Goroutine that caused the panic.
|
|
stacktrace := hclog.Stacktrace()
|
|
logger.Error("panic serving rpc request",
|
|
"panic", p,
|
|
"stack", stacktrace,
|
|
)
|
|
|
|
return fmt.Errorf("rpc: panic serving request")
|
|
}
|
|
}
|
|
|
|
type RecoveryHandlerFunc func(p interface{}) (err error)
|