[
MAINHACK
]
Mail Test
BC
Config Scan
HOME
Create...
New File
New Folder
Viewing / Editing File: UPGRADE_GUIDE.md
# Upgrade Guide ### 0.15.x -> 0.16.0 #### `Promise` Type Declarations The `Promise` type declarations have been removed from the axios typings in favor of the built-in type declarations. If you use axios in a TypeScript project that targets `ES5`, please make sure to include the `es2015.promise` lib. Please see [this post](https://blog.mariusschulz.com/2016/11/25/typescript-2-0-built-in-type-declarations) for details. ### 0.13.x -> 0.14.0 #### TypeScript Definitions The axios TypeScript definitions have been updated to match the axios API and use the ES2015 module syntax. Please use the following `import` statement to import axios in TypeScript: ```typescript import axios from 'axios'; axios.get('/foo') .then(response => console.log(response)) .catch(error => console.log(error)); ``` #### `agent` Config Option The `agent` config option has been replaced with two new options: `httpAgent` and `httpsAgent`. Please use them instead. ```js { // Define a custom agent for HTTP httpAgent: new http.Agent({ keepAlive: true }), // Define a custom agent for HTTPS httpsAgent: new https.Agent({ keepAlive: true }) } ``` #### `progress` Config Option The `progress` config option has been replaced with the `onUploadProgress` and `onDownloadProgress` options. ```js { // Define a handler for upload progress events onUploadProgress: function (progressEvent) { // ... }, // Define a handler for download progress events onDownloadProgress: function (progressEvent) { // ... } } ``` ### 0.12.x -> 0.13.0 The `0.13.0` release contains several changes to custom adapters and error handling. #### Error Handling Previous to this release an error could either be a server response with bad status code or an actual `Error`. With this release Promise will always reject with an `Error`. In the case that a response was received, the `Error` will also include the response. ```js axios.get('/user/12345') .catch((error) => { console.log(error.message); console.log(error.code); // Not always specified console.log(error.config); // The config that was used to make the request console.log(error.response); // Only available if response was received from the server }); ``` #### Request Adapters This release changes a few things about how request adapters work. Please take note if you are using your own custom adapter. 1. Response transformer is now called outside of adapter. 2. Request adapter returns a `Promise`. This means that you no longer need to invoke `transformData` on response data. You will also no longer receive `resolve` and `reject` as arguments in your adapter. Previous code: ```js function myAdapter(resolve, reject, config) { var response = { data: transformData( responseData, responseHeaders, config.transformResponse ), status: request.status, statusText: request.statusText, headers: responseHeaders }; settle(resolve, reject, response); } ``` New code: ```js function myAdapter(config) { return new Promise(function (resolve, reject) { var response = { data: responseData, status: request.status, statusText: request.statusText, headers: responseHeaders }; settle(resolve, reject, response); }); } ``` See the related commits for more details: - [Response transformers](https://github.com/axios/axios/commit/10eb23865101f9347570552c04e9d6211376e25e) - [Request adapter Promise](https://github.com/axios/axios/commit/157efd5615890301824e3121cc6c9d2f9b21f94a) ### 0.5.x -> 0.6.0 The `0.6.0` release contains mostly bug fixes, but there are a couple things to be aware of when upgrading. #### ES6 Promise Polyfill Up until the `0.6.0` release ES6 `Promise` was being polyfilled using [es6-promise](https://github.com/jakearchibald/es6-promise). With this release, the polyfill has been removed, and you will need to supply it yourself if your environment needs it. ```js require('es6-promise').polyfill(); var axios = require('axios'); ``` This will polyfill the global environment, and only needs to be done once. #### `axios.success`/`axios.error` The `success`, and `error` aliases were deprecated in [0.4.0](https://github.com/axios/axios/blob/master/CHANGELOG.md#040-oct-03-2014). As of this release they have been removed entirely. Instead please use `axios.then`, and `axios.catch` respectively. ```js axios.get('some/url') .then(function (res) { /* ... */ }) .catch(function (err) { /* ... */ }); ``` #### UMD Previous versions of axios shipped with an AMD, CommonJS, and Global build. This has all been rolled into a single UMD build. ```js // AMD require(['bower_components/axios/dist/axios'], function (axios) { /* ... */ }); // CommonJS var axios = require('axios/dist/axios'); ```
Save Changes
Cancel / Back
Close ×
Server Info
Hostname: server1.winmanyltd.com
Server IP: 203.161.60.52
PHP Version: 8.3.27
Server Software: Apache
System: Linux server1.winmanyltd.com 4.18.0-553.22.1.el8_10.x86_64 #1 SMP Tue Sep 24 05:16:59 EDT 2024 x86_64
HDD Total: 117.98 GB
HDD Free: 59.73 GB
Domains on IP: N/A (Requires external lookup)
System Features
Safe Mode:
Off
disable_functions:
None
allow_url_fopen:
On
allow_url_include:
Off
magic_quotes_gpc:
Off
register_globals:
Off
open_basedir:
None
cURL:
Enabled
ZipArchive:
Enabled
MySQLi:
Enabled
PDO:
Enabled
wget:
Yes
curl (cmd):
Yes
perl:
Yes
python:
Yes (py3)
gcc:
Yes
pkexec:
Yes
git:
Yes
User Info
Username: eliosofonline
User ID (UID): 1002
Group ID (GID): 1003
Script Owner UID: 1002
Current Dir Owner: 1002