Giter VIP home page Giter VIP logo

generic-throttle's Introduction

generic-throttle

npm license npm version npm downloads

A lightweight, flexible promise based throttle class perfect for any rate or concurrency limiting need.

Written in TypeScript, targets Nodejs and the Browser

Install

# Latest Stable Release
$ npm install generic-throttle

# Latest Commit
$ npm install tflanagan/generic-throttle

# Also available via Bower
$ bower install generic-throttle

Documentation

TypeDoc Documentation

Rate Limit Example

This Throttle instance will rate limit the throttle to a maximum of 10 requests every 30 seconds. It will not throw an error if the maximum is exceeded.

'use strict';

const { Throttle } = require('generic-throttle');

const throttle = new Throttle(10, 30000, false);

function delay(){
	return new Promise((resolve) => {
		setTimeout(() => {
			resolve();
		}, 2000);
	});
}

function asyncRequest(i){
	return throttle.acquire(() => {
		console.log('%d does some async request', i);

		return delay();
	}).then(function(){
		console.log('%d finished', i);
	});
}

for(let i = 0; i < 30; ++i){
	asyncRequest(i);
}

Concurrency Limit Example

This Throttle instance will limit concurrency to 5 requests at any given moment. It will not throw an error if the maximum is exceeded.

'use strict';

const { Throttle } = require('generic-throttle');

const throttle = new Throttle(5);

function delay(){
	return new Promise((resolve) => {
		setTimeout(() => {
			resolve();
		}, 2000);
	});
}

function asyncRequest(i){
	return throttle.acquire(() => {
		console.log('%d does some async request', i);

		return delay();
	}).then(function(){
		console.log('%d finished', i);
	});
}

for(let i = 0; i < 30; ++i){
	asyncRequest(i);
}

License

Copyright 2014 Tristian Flanagan

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.