mirror of
https://github.com/tenrok/axios.git
synced 2026-06-20 20:00:40 +03:00
Moving default adapter to global defaults
This commit is contained in:
+20
-34
@@ -2,10 +2,10 @@
|
|||||||
|
|
||||||
var utils = require('./../utils');
|
var utils = require('./../utils');
|
||||||
var transformData = require('./transformData');
|
var transformData = require('./transformData');
|
||||||
|
var defaults = require('../defaults');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Dispatch a request to the server using whichever adapter
|
* Dispatch a request to the server using the configured adapter.
|
||||||
* is supported by the current environment.
|
|
||||||
*
|
*
|
||||||
* @param {object} config The config that is to be used for the request
|
* @param {object} config The config that is to be used for the request
|
||||||
* @returns {Promise} The Promise to be fulfilled
|
* @returns {Promise} The Promise to be fulfilled
|
||||||
@@ -35,41 +35,27 @@ module.exports = function dispatchRequest(config) {
|
|||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
var adapter;
|
var adapter = config.adapter || defaults.adapter;
|
||||||
|
|
||||||
if (typeof config.adapter === 'function') {
|
return adapter(config).then(function onAdapterResolution(response) {
|
||||||
// For custom adapter support
|
// Transform response data
|
||||||
adapter = config.adapter;
|
response.data = transformData(
|
||||||
} else if (typeof XMLHttpRequest !== 'undefined') {
|
response.data,
|
||||||
// For browsers use XHR adapter
|
response.headers,
|
||||||
adapter = require('../adapters/xhr');
|
config.transformResponse
|
||||||
} else if (typeof process !== 'undefined') {
|
);
|
||||||
// For node use HTTP adapter
|
|
||||||
adapter = require('../adapters/http');
|
|
||||||
}
|
|
||||||
|
|
||||||
return Promise.resolve(config)
|
return response;
|
||||||
// Wrap synchronous adapter errors and pass configuration
|
}, function onAdapterRejection(error) {
|
||||||
.then(adapter)
|
// Transform response data
|
||||||
.then(function onFulfilled(response) {
|
if (error && error.response) {
|
||||||
// Transform response data
|
error.response.data = transformData(
|
||||||
response.data = transformData(
|
error.response.data,
|
||||||
response.data,
|
error.response.headers,
|
||||||
response.headers,
|
|
||||||
config.transformResponse
|
config.transformResponse
|
||||||
);
|
);
|
||||||
|
}
|
||||||
|
|
||||||
return response;
|
return Promise.reject(error);
|
||||||
}, function onRejected(error) {
|
});
|
||||||
// Transform response data
|
|
||||||
if (error && error.response) {
|
|
||||||
error.response.data = transformData(
|
|
||||||
error.response.data,
|
|
||||||
error.response.headers,
|
|
||||||
config.transformResponse
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return Promise.reject(error);
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -14,7 +14,21 @@ function setContentTypeIfUnset(headers, value) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getDefaultAdapter() {
|
||||||
|
var adapter;
|
||||||
|
if (typeof XMLHttpRequest !== 'undefined') {
|
||||||
|
// For browsers use XHR adapter
|
||||||
|
adapter = require('./adapters/xhr');
|
||||||
|
} else if (typeof process !== 'undefined') {
|
||||||
|
// For node use HTTP adapter
|
||||||
|
adapter = require('./adapters/http');
|
||||||
|
}
|
||||||
|
return adapter;
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
|
adapter: getDefaultAdapter(),
|
||||||
|
|
||||||
transformRequest: [function transformRequest(data, headers) {
|
transformRequest: [function transformRequest(data, headers) {
|
||||||
normalizeHeaderName(headers, 'Content-Type');
|
normalizeHeaderName(headers, 'Content-Type');
|
||||||
if (utils.isFormData(data) ||
|
if (utils.isFormData(data) ||
|
||||||
|
|||||||
Reference in New Issue
Block a user