From f69d88ee187cd09be2ef0ec1e3d37973ba667c8c Mon Sep 17 00:00:00 2001 From: Liqun Date: Wed, 21 Aug 2024 17:38:46 +0800 Subject: [PATCH] Add custom JSON-RPC error code for rate limiting (#219) --- util/rpc/middlewares/rate_limit.go | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/util/rpc/middlewares/rate_limit.go b/util/rpc/middlewares/rate_limit.go index a7dcbe6e..1db5d5d5 100644 --- a/util/rpc/middlewares/rate_limit.go +++ b/util/rpc/middlewares/rate_limit.go @@ -10,6 +10,10 @@ import ( "github.com/pkg/errors" ) +const ( + ratelimitErrorCode = -32005 +) + func QpsRateLimit(next rpc.HandleCallMsgFunc) rpc.HandleCallMsgFunc { return func(ctx context.Context, msg *rpc.JsonRpcMessage) *rpc.JsonRpcMessage { registry, ok := ctx.Value(handlers.CtxKeyRateRegistry).(*rate.Registry) @@ -33,7 +37,10 @@ func QpsRateLimit(next rpc.HandleCallMsgFunc) rpc.HandleCallMsgFunc { } func errQpsRateLimited(err error) error { - return errors.WithMessage(err, "allowed qps exceeded") + return &rpc.JsonError{ + Code: ratelimitErrorCode, + Message: errors.WithMessage(err, "request rate exceeded").Error(), + } } func DailyMaxReqRateLimit(next rpc.HandleCallMsgFunc) rpc.HandleCallMsgFunc { @@ -53,5 +60,8 @@ func DailyMaxReqRateLimit(next rpc.HandleCallMsgFunc) rpc.HandleCallMsgFunc { } func errDailyMaxReqRateLimited(err error) error { - return errors.WithMessage(err, "daily request limit exceeded") + return &rpc.JsonError{ + Code: ratelimitErrorCode, + Message: errors.WithMessage(err, "daily request count exceeded").Error(), + } }