From 75f6f84dcd65404122e1aad743deb830937c07f6 Mon Sep 17 00:00:00 2001 From: RetricSu Date: Tue, 10 Jan 2023 18:09:20 +0800 Subject: [PATCH] fix: wrong return in the loop of wsApplyBatchRateLimitByIp --- packages/api-server/src/rate-limit.ts | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/packages/api-server/src/rate-limit.ts b/packages/api-server/src/rate-limit.ts index 14c2518a..a73e7b1c 100644 --- a/packages/api-server/src/rate-limit.ts +++ b/packages/api-server/src/rate-limit.ts @@ -12,6 +12,10 @@ export async function wsApplyBatchRateLimitByIp( ): Promise { const ip = getIp(req); const methods = Object.keys(accessGuard.rpcMethods); + if (methods.length === 0) { + return undefined; + } + for (const targetMethod of methods) { const count = calcMethodCount(objs, targetMethod); if (count > 0 && ip != null) { @@ -30,7 +34,7 @@ export async function wsApplyBatchRateLimitByIp( }; logger.debug( - `Rate Limit Exceed, ip: ${ip}, method: ${targetMethod}, ttl: ${remainSecs}s` + `WS Batch Rate Limit Exceed, ip: ${ip}, method: ${targetMethod}, ttl: ${remainSecs}s` ); return new Array(objs.length).fill(error); @@ -38,9 +42,10 @@ export async function wsApplyBatchRateLimitByIp( await accessGuard.updateCount(targetMethod, ip, count); } } - - return undefined; + // continue next loop } + + return undefined; } export async function wsApplyRateLimitByIp(