use key type
This commit is contained in:
parent
4c51e4ccda
commit
ea51732163
@ -19,6 +19,10 @@ import (
|
||||
"golang.org/x/time/rate"
|
||||
)
|
||||
|
||||
type perConnLimiterKeyType string
|
||||
|
||||
const perConnLimiterKey = "limiter"
|
||||
|
||||
// Handler returns a gateway http.Handler, to be mounted as-is on the server.
|
||||
func Handler(gwapi lapi.Gateway, api lapi.FullNode, rateLimit int64, connPerMinute int64, opts ...jsonrpc.ServerOption) (http.Handler, error) {
|
||||
m := mux.NewRouter()
|
||||
@ -75,7 +79,7 @@ type RateLimiterHandler struct {
|
||||
}
|
||||
|
||||
func (h RateLimiterHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
|
||||
r2 := r.WithContext(context.WithValue(r.Context(), "limiter", h.limiter))
|
||||
r2 := r.WithContext(context.WithValue(r.Context(), perConnLimiterKey, h.limiter))
|
||||
h.handler.ServeHTTP(w, r2)
|
||||
}
|
||||
|
||||
|
@ -166,7 +166,7 @@ func (gw *Node) checkTimestamp(at time.Time) error {
|
||||
func (gw *Node) limit(ctx context.Context, tokens int) error {
|
||||
ctx2, cancel := context.WithTimeout(ctx, gw.rateLimitTimeout)
|
||||
defer cancel()
|
||||
if perConnLimiter, ok := ctx2.Value("limiter").(*rate.Limiter); ok {
|
||||
if perConnLimiter, ok := ctx2.Value(perConnLimiterKey).(*rate.Limiter); ok {
|
||||
err := perConnLimiter.WaitN(ctx2, tokens)
|
||||
if err != nil {
|
||||
return fmt.Errorf("connection limited. %w", err)
|
||||
|
Loading…
Reference in New Issue
Block a user