Defined in: async-rate-limiter.ts:55
A class that creates an async rate-limited function.
Rate limiting is a simple approach that allows a function to execute up to a limit within a time window, then blocks all subsequent calls until the window passes. This can lead to "bursty" behavior where all executions happen immediately, followed by a complete block.
For smoother execution patterns, consider using:
Rate limiting is best used for hard API limits or resource constraints. For UI updates or smoothing out frequent events, throttling or debouncing usually provide better user experience.
const rateLimiter = new AsyncRateLimiter(
async (id: string) => await api.getData(id),
{ limit: 5, window: 1000 } // 5 calls per second
);
// Will execute immediately until limit reached, then block
await rateLimiter.maybeExecute('123');
const rateLimiter = new AsyncRateLimiter(
async (id: string) => await api.getData(id),
{ limit: 5, window: 1000 } // 5 calls per second
);
// Will execute immediately until limit reached, then block
await rateLimiter.maybeExecute('123');
• TFn extends (...args) => Promise<any>
• TArgs extends Parameters<TFn>
new AsyncRateLimiter<TFn, TArgs>(fn, initialOptions): AsyncRateLimiter<TFn, TArgs>
new AsyncRateLimiter<TFn, TArgs>(fn, initialOptions): AsyncRateLimiter<TFn, TArgs>
Defined in: async-rate-limiter.ts:64
TFn
AsyncRateLimiter<TFn, TArgs>
getExecutionCount(): number
getExecutionCount(): number
Defined in: async-rate-limiter.ts:91
Returns the number of times the function has been executed
number
getRejectionCount(): number
getRejectionCount(): number
Defined in: async-rate-limiter.ts:98
Returns the number of times the function has been rejected
number
getRemainingInWindow(): number
getRemainingInWindow(): number
Defined in: async-rate-limiter.ts:105
Returns the number of remaining executions allowed in the current window
number
maybeExecute(...args): Promise<boolean>
maybeExecute(...args): Promise<boolean>
Defined in: async-rate-limiter.ts:126
Attempts to execute the rate-limited function if within the configured limits. Will reject execution if the number of calls in the current window exceeds the limit. If execution is allowed, waits for any previous execution to complete before proceeding.
...TArgs
Promise<boolean>
const rateLimiter = new AsyncRateLimiter(fn, { limit: 5, window: 1000 });
// First 5 calls will execute
await rateLimiter.maybeExecute('arg1', 'arg2');
// Additional calls within the window will be rejected
await rateLimiter.maybeExecute('arg1', 'arg2'); // Rejected
const rateLimiter = new AsyncRateLimiter(fn, { limit: 5, window: 1000 });
// First 5 calls will execute
await rateLimiter.maybeExecute('arg1', 'arg2');
// Additional calls within the window will be rejected
await rateLimiter.maybeExecute('arg1', 'arg2'); // Rejected
reset(): void
reset(): void
Defined in: async-rate-limiter.ts:186
Resets the rate limiter state
void
setOptions(newOptions): AsyncRateLimiterOptions
setOptions(newOptions): AsyncRateLimiterOptions
Defined in: async-rate-limiter.ts:78
Updates the rate limiter options Returns the new options state
Partial<AsyncRateLimiterOptions>
Your weekly dose of JavaScript news. Delivered every Monday to over 100,000 devs, for free.