mirror of
https://github.com/tenrok/axios.git
synced 2026-06-20 20:00:40 +03:00
Choose between follow-redirects or core
This commit is contained in:
+20
-5
@@ -3,8 +3,10 @@
|
|||||||
var utils = require('./../utils');
|
var utils = require('./../utils');
|
||||||
var buildURL = require('./../helpers/buildURL');
|
var buildURL = require('./../helpers/buildURL');
|
||||||
var transformData = require('./../helpers/transformData');
|
var transformData = require('./../helpers/transformData');
|
||||||
var http = require('follow-redirects').http;
|
var http = require('http');
|
||||||
var https = require('follow-redirects').https;
|
var https = require('https');
|
||||||
|
var httpFollow = require('follow-redirects').http;
|
||||||
|
var httpsFollow = require('follow-redirects').https;
|
||||||
var url = require('url');
|
var url = require('url');
|
||||||
var zlib = require('zlib');
|
var zlib = require('zlib');
|
||||||
var pkg = require('./../../package.json');
|
var pkg = require('./../../package.json');
|
||||||
@@ -12,7 +14,12 @@ var Buffer = require('buffer').Buffer;
|
|||||||
|
|
||||||
// Resolve or reject the Promise based on the status
|
// Resolve or reject the Promise based on the status
|
||||||
function settle(resolve, reject, response) {
|
function settle(resolve, reject, response) {
|
||||||
(response.status >= 200 && response.status < 300 ?
|
var minCode = 200;
|
||||||
|
var maxCode = 300;
|
||||||
|
if (response.config.hasOwnProperty('maxRedirects')) {
|
||||||
|
maxCode = 400;
|
||||||
|
}
|
||||||
|
(response.status >= minCode && response.status < maxCode ?
|
||||||
resolve :
|
resolve :
|
||||||
reject)(response);
|
reject)(response);
|
||||||
}
|
}
|
||||||
@@ -76,8 +83,17 @@ module.exports = function httpAdapter(resolve, reject, config) {
|
|||||||
options.path = parsed.protocol + '//' + parsed.hostname + options.path;
|
options.path = parsed.protocol + '//' + parsed.hostname + options.path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var transport;
|
||||||
|
if (config.maxRedirects === 0) {
|
||||||
|
transport = parsed.protocol === 'https:' ? https : http;
|
||||||
|
} else {
|
||||||
|
if (config.maxRedirects) {
|
||||||
|
options.maxRedirects = config.maxRedirects;
|
||||||
|
}
|
||||||
|
transport = parsed.protocol === 'https:' ? httpsFollow : httpFollow;
|
||||||
|
}
|
||||||
|
|
||||||
// Create the request
|
// Create the request
|
||||||
var transport = parsed.protocol === 'https:' ? https : http;
|
|
||||||
var req = transport.request(options, function handleResponse(res) {
|
var req = transport.request(options, function handleResponse(res) {
|
||||||
if (aborted) return;
|
if (aborted) return;
|
||||||
|
|
||||||
@@ -107,7 +123,6 @@ module.exports = function httpAdapter(resolve, reject, config) {
|
|||||||
config: config,
|
config: config,
|
||||||
request: req
|
request: req
|
||||||
};
|
};
|
||||||
|
|
||||||
if (config.responseType === 'stream') {
|
if (config.responseType === 'stream') {
|
||||||
response.data = stream;
|
response.data = stream;
|
||||||
settle(resolve, reject, response);
|
settle(resolve, reject, response);
|
||||||
|
|||||||
@@ -79,6 +79,32 @@ module.exports = {
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
|
testNoRedirect: function (test) {
|
||||||
|
var str = 'test response';
|
||||||
|
|
||||||
|
server = http.createServer(function (req, res) {
|
||||||
|
var parsed = url.parse(req.url);
|
||||||
|
|
||||||
|
if (parsed.pathname === '/one') {
|
||||||
|
res.setHeader('NoRedirect', 'true');
|
||||||
|
res.setHeader('Location', '/two');
|
||||||
|
res.statusCode = 302;
|
||||||
|
res.end();
|
||||||
|
} else {
|
||||||
|
res.end(str);
|
||||||
|
}
|
||||||
|
}).listen(4444, function () {
|
||||||
|
axios.get('http://localhost:4444/one', {
|
||||||
|
maxRedirects: 0
|
||||||
|
}).then(function (res) {
|
||||||
|
test.equal(res.status, 302);
|
||||||
|
test.equal(res.headers['noredirect'], 'true');
|
||||||
|
test.equal(res.headers['location'], '/two');
|
||||||
|
test.done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
testTransparentGunzip: function (test) {
|
testTransparentGunzip: function (test) {
|
||||||
var data = {
|
var data = {
|
||||||
firstName: 'Fred',
|
firstName: 'Fred',
|
||||||
|
|||||||
Reference in New Issue
Block a user