Project Name | Stars | Downloads | Repos Using This | Packages Using This | Most Recent Commit | Total Releases | Latest Release | Open Issues | License | Language |
---|---|---|---|---|---|---|---|---|---|---|
Hoppscotch | 50,489 | 1 | 4 days ago | 1 | March 22, 2022 | 107 | mit | Vue | ||
👽 Open source API development ecosystem - https://hoppscotch.io | ||||||||||
Requests | 49,236 | 152,228 | 41,166 | 2 days ago | 145 | June 29, 2022 | 273 | apache-2.0 | Python | |
A simple, yet elegant, HTTP library. | ||||||||||
Alamofire | 39,073 | 15,948 | 4 days ago | 83 | July 18, 2022 | 37 | mit | Swift | ||
Elegant HTTP Networking in Swift | ||||||||||
Request | 25,614 | 680,683 | 58,509 | 4 days ago | 126 | February 11, 2020 | 101 | apache-2.0 | JavaScript | |
🏊🏾 Simplified HTTP request client. | ||||||||||
Guzzle | 22,426 | 55,713 | 19,631 | 6 days ago | 138 | August 28, 2022 | 21 | mit | PHP | |
Guzzle, an extensible PHP HTTP client | ||||||||||
Vegeta | 20,940 | 42 | 11 days ago | 74 | October 11, 2020 | 108 | mit | Go | ||
HTTP load testing tool and library. It's over 9000! | ||||||||||
Httprouter | 15,084 | 3,927 | 1,690 | a day ago | 12 | August 14, 2020 | 80 | bsd-3-clause | Go | |
A high performance HTTP request router that scales well | ||||||||||
Chi | 13,491 | 664 | 1,850 | 13 days ago | 75 | February 14, 2022 | 43 | mit | Go | |
lightweight, idiomatic and composable router for building Go HTTP services | ||||||||||
Requests Html | 13,007 | 182 | 166 | 5 days ago | 36 | February 17, 2019 | 198 | mit | Python | |
Pythonic HTML Parsing for Humans™ | ||||||||||
Got | 12,766 | 235,715 | 6,429 | 6 days ago | 162 | September 19, 2022 | 75 | mit | TypeScript | |
🌐 Human-friendly and powerful HTTP request library for Node.js |
request-retry - HTTP(s) request retry on recoverable errors.
When the connection fails with one of ECONNRESET
, ENOTFOUND
, ESOCKETTIMEDOUT
, ETIMEDOUT
, ECONNREFUSED
, EHOSTUNREACH
, EPIPE
, EAI_AGAIN
or when an HTTP 5xx or 429 error occurrs, the request will automatically be re-attempted as these are often recoverable errors and will go away on retry.
❤️ Shameless plug
Install with npm.
npm install --save requestretry
Request-retry is a drop-in replacement for request but adds two new options maxAttempts
and retryDelay
. It also adds one property to the response (or the error object, upon a network error), attempts
. It supports callbacks or promises.
var request = require('requestretry');
request({
url: 'https://api.domain.com/v1/a/b',
json: true,
// The below parameters are specific to request-retry
maxAttempts: 5, // (default) try 5 times
retryDelay: 5000, // (default) wait for 5s before trying again
retryStrategy: request.RetryStrategies.HTTPOrNetworkError // (default) retry on 5xx or network errors
}, function(err, response, body){
// this callback will only be called when the request succeeded or after maxAttempts or on error
if (response) {
console.log('The number of request attempts: ' + response.attempts);
}
});
When you're using promises, you can pass the two following options:
fullResponse
(default true) - To resolve the promise with the full response or just the bodypromiseFactory
(default whenjs) - A function to allow the usage of a different promise implementation libraryrequest({
url: 'https://api.domain.com/v1/a/b',
json: true,
fullResponse: true // (default) To resolve the promise with the full response or just the body
})
.then(function (response) {
// response = The full response object or just the body
})
.catch(function(error) {
// error = Any occurred error
})
Using promiseFactory
option to use a different promise implementation library
// See the tests for different libraries usage examples
/**
* @param {Function} resolver The promise resolver function
* @return {Object} The promise instance
*/
function customPromiseFactory(resolver) {
// With when.js
return require('when').promise(resolver);
// With RSVP.js
var Promise = require('rsvp').Promise;
return new Promise(resolver);
}
request({
url: 'https://api.domain.com/v1/a/b',
json: true,
// Custom promise factory function
promiseFactory: customPromiseFactory
})
.then(function (response) {
// response = The full response object or just the body
})
.catch(function(error) {
// error = Any occurred error
})
A retry strategy let you specify when request-retry should retry a request
/**
* @param {Null | Object} err
* @param {Object} response
* @param {Object} body
* @param {Object} options copy
* @return {Boolean} true if the request should be retried
*/
function myRetryStrategy(err, response, body, options){
// retry the request if we had an error or if the response was a 'Bad Gateway'
return !!err || response.statusCode === 502;
}
/**
* @param {Null | Object} err
* @param {Object} response
* @param {Object} body
* @param {Object} options copy
* @return {Object} mustRetry: {Boolean} true if the request should be retried
* options: {Object} new options for request
*/
function myRetryStrategy(err, response, body, options){
options.url = 'new url'; //you can overwrite some attributes or create new object
return {
mustRetry: !!err || response.statusCode === 502,
options: options, //then it should be passed back, it will be used for new requests
}
}
/**
* With an asynchronous retry strategy
* @param {Null | Object} err
* @param {Object} response
* @param {Object} body
* @param {Object} options copy
* @return {Object} mustRetry: {Boolean} true if the request should be retried
* options: {Object} new options for request
*/
async function myRetryStrategy(err, response, body, options){
let token = await getNewApiAuthToken();
options.headers = {'Authorization': `Bearer ${token}`}
return {
mustRetry: true,
options: options, // retry with new auth token
}
}
request({
url: 'https://api.domain.com/v1/a/b'
json:true,
retryStrategy: myRetryStrategy
}, function(err, response, body){
// this callback will only be called when the request succeeded or after maxAttempts or on error
});
A delay strategy let you specify how long request-retry should wait before trying again the request
/**
* @param {Null | Object} err
* @param {Object} response
* @param {Object} body
* @return {Number} number of milliseconds to wait before trying again the request
*/
function myDelayStrategy(err, response, body){
// set delay of retry to a random number between 500 and 3500 ms
return Math.floor(Math.random() * (3500 - 500 + 1) + 500);
}
request({
url: 'https://api.domain.com/v1/a/b'
json:true,
delayStrategy: myDelayStrategy // delayStrategy is called 1 less times than the maxAttempts set
}, function(err, response, body){
// this callback will only be called when the request succeeded or after maxAttempts or on error
});
Here is how to implement an exponential backoff strategy:
/**
* @param {Number} attempts The number of times that the request has been attempted.
* @return {Number} number of milliseconds to wait before retrying again the request.
*/
function getExponentialBackoff(attempts) {
return (Math.pow(2, attempts) * 100) + Math.floor(Math.random() * 50);
}
function constructExponentialBackoffStrategy() {
let attempts = 0;
return () => {
attempts += 1;
return getExponentialBackoff(attempts);
};
}
request({
url: 'https://api.domain.com/v1/a/b'
json:true,
delayStrategy: constructExponentialBackoffStrategy() // need to invoke the function to return the closure.
}, function(err, response, body){
// this callback will only be called when the request succeeded or after maxAttempts or on error
});
You can access to the underlying request
library thanks to request.Request
:
const request = require('requestretry');
console.log(request.Request); // original request library
Thus, if needed, it's possible to monkey-patch or extend the underlying Request library:
request.Request = class extends request.Request {
constructor(url, options, f, retryConfig) {
super(url, options, f, retryConfig);
// this constructor will be called for every requestretry call,
// and give you global logging
console.log('Request', url, options, f, retryConfig);
}
}
request
optionsYou can use the defaults
method to provide default options like so:
var request = require('requestretry').defaults({ json: true, retryStrategy: myRetryStrategy });
As with request
, several helpers are provided for various HTTP methods and usage:
request(options [, callback])
.request(url [, callback])
- same as request(options [, callback])
.request(url, options [, callback])
- same as request(options [, callback])
.request.get(url [, callback])
- same as request(options [, callback])
, defaults options.method
to GET
.request.get(url, options [, callback])
- same as request(options [, callback])
, defaults options.method
to GET
.request.head(url)
- same as request(options [, callback])
, defaults options.method
to HEAD
.request.post(url)
- same as request(options [, callback])
, defaults options.method
to POST
.request.put(url)
- same as request(options [, callback])
, defaults options.method
to PUT
.request.patch(url)
- same as request(options [, callback])
, defaults options.method
to PATCH
.request.del(url)
- same as request(options [, callback])
, defaults options.method
to DELETE
.request.delete(url)
- same as request(options [, callback])
, defaults options.method
to DELETE
.I maintain this project in my free time, if it helped you, well, I would be grateful to buy a beer thanks to your paypal or Bitcoins, donation!