twitter_rate_limiter

Twitter rate limit module to automatically limit requests to twitter to stay within rate limits

Usage no npm install needed!

<script type="module">
  import twitterRateLimiter from 'https://cdn.skypack.dev/twitter_rate_limiter';
</script>

README

twitter-rate-limiter

Description

This module helps manage your requests to the Twitter API so you don't get rate limited. If you use the module to make requests, it will automatically queue your requests and if you are in danger of exceeding Twitter's API limits, it will store them and execute them after the time window has passed. No more worrying about rate limiting.

Instructions

  npm install twitter-rate-limiter

Setup

Create a file called config.json with your twitter credentials in the format

{
    "twitter":{
        "consumerKey": "...",
        "consumerSecret": "...",
        "token": "...",
        "tokenSecret": "..."
    }
}	

You could hardcode it into the file but that wouldn't be advisable.

Usage

In your file, import the config.json file

Import the rate_limit.js file

  var RateLimiter = require('../rate_limit.js');

Instantiate a new RateLimit object.

var getfriends = new RateLimiter(2, 5000);

The two arguments are the requests in the time window in the form(requests, time window). Usually the time window is 900000 ms for 15 minutes. The request number varies by function call

Create a function for the twitter call you want to make. This example shows the GET friends request

var callGetFriends = function(username, callback) {
    var url  = 'https://api.twitter.com/1.1/friends/ids.json?cursor=-1&screen_name='+username+'&count=5000';
    console.log(url);
    request.get({url: url, oauth: oauth, json: true}, function(error, res, body) {
        callback(body);
    })
}

The function calling this would look like

getfriends.callWithLimit(callGetFriends, ["user", function(data){
    console.log(data);
    "...insert processing here"
}]);