| import platform from "../platform/index.js"; |
| import utils from "../utils.js"; |
| import isURLSameOrigin from "./isURLSameOrigin.js"; |
| import cookies from "./cookies.js"; |
| import buildFullPath from "../core/buildFullPath.js"; |
| import mergeConfig from "../core/mergeConfig.js"; |
| import AxiosHeaders from "../core/AxiosHeaders.js"; |
| import buildURL from "./buildURL.js"; |
|
|
| export default (config) => { |
| const newConfig = mergeConfig({}, config); |
|
|
| let {data, withXSRFToken, xsrfHeaderName, xsrfCookieName, headers, auth} = newConfig; |
|
|
| newConfig.headers = headers = AxiosHeaders.from(headers); |
|
|
| newConfig.url = buildURL(buildFullPath(newConfig.baseURL, newConfig.url), config.params, config.paramsSerializer); |
|
|
| |
| if (auth) { |
| headers.set('Authorization', 'Basic ' + |
| btoa((auth.username || '') + ':' + (auth.password ? unescape(encodeURIComponent(auth.password)) : '')) |
| ); |
| } |
|
|
| let contentType; |
|
|
| if (utils.isFormData(data)) { |
| if (platform.hasStandardBrowserEnv || platform.hasStandardBrowserWebWorkerEnv) { |
| headers.setContentType(undefined); |
| } else if ((contentType = headers.getContentType()) !== false) { |
| |
| const [type, ...tokens] = contentType ? contentType.split(';').map(token => token.trim()).filter(Boolean) : []; |
| headers.setContentType([type || 'multipart/form-data', ...tokens].join('; ')); |
| } |
| } |
|
|
| |
| |
| |
|
|
| if (platform.hasStandardBrowserEnv) { |
| withXSRFToken && utils.isFunction(withXSRFToken) && (withXSRFToken = withXSRFToken(newConfig)); |
|
|
| if (withXSRFToken || (withXSRFToken !== false && isURLSameOrigin(newConfig.url))) { |
| |
| const xsrfValue = xsrfHeaderName && xsrfCookieName && cookies.read(xsrfCookieName); |
|
|
| if (xsrfValue) { |
| headers.set(xsrfHeaderName, xsrfValue); |
| } |
| } |
| } |
|
|
| return newConfig; |
| } |
|
|
|
|