edit
This commit is contained in:
323
node_modules/.package-lock.json
generated
vendored
323
node_modules/.package-lock.json
generated
vendored
@@ -1,323 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "twitch-eventsub",
|
|
||||||
"version": "1.0.0",
|
|
||||||
"lockfileVersion": 3,
|
|
||||||
"requires": true,
|
|
||||||
"packages": {
|
|
||||||
"node_modules/asynckit": {
|
|
||||||
"version": "0.4.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz",
|
|
||||||
"integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==",
|
|
||||||
"license": "MIT"
|
|
||||||
},
|
|
||||||
"node_modules/axios": {
|
|
||||||
"version": "1.15.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/axios/-/axios-1.15.2.tgz",
|
|
||||||
"integrity": "sha512-wLrXxPtcrPTsNlJmKjkPnNPK2Ihe0hn0wGSaTEiHRPxwjvJwT3hKmXF4dpqxmPO9SoNb2FsYXj/xEo0gHN+D5A==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"follow-redirects": "^1.15.11",
|
|
||||||
"form-data": "^4.0.5",
|
|
||||||
"proxy-from-env": "^2.1.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/call-bind-apply-helpers": {
|
|
||||||
"version": "1.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.2.tgz",
|
|
||||||
"integrity": "sha512-Sp1ablJ0ivDkSzjcaJdxEunN5/XvksFJ2sMBFfq6x0ryhQV/2b/KwFe21cMpmHtPOSij8K99/wSfoEuTObmuMQ==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"es-errors": "^1.3.0",
|
|
||||||
"function-bind": "^1.1.2"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/combined-stream": {
|
|
||||||
"version": "1.0.8",
|
|
||||||
"resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz",
|
|
||||||
"integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"delayed-stream": "~1.0.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.8"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/delayed-stream": {
|
|
||||||
"version": "1.0.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz",
|
|
||||||
"integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=0.4.0"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/dotenv": {
|
|
||||||
"version": "17.4.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/dotenv/-/dotenv-17.4.2.tgz",
|
|
||||||
"integrity": "sha512-nI4U3TottKAcAD9LLud4Cb7b2QztQMUEfHbvhTH09bqXTxnSie8WnjPALV/WMCrJZ6UV/qHJ6L03OqO3LcdYZw==",
|
|
||||||
"license": "BSD-2-Clause",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=12"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"url": "https://dotenvx.com"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/dunder-proto": {
|
|
||||||
"version": "1.0.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/dunder-proto/-/dunder-proto-1.0.1.tgz",
|
|
||||||
"integrity": "sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"call-bind-apply-helpers": "^1.0.1",
|
|
||||||
"es-errors": "^1.3.0",
|
|
||||||
"gopd": "^1.2.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/es-define-property": {
|
|
||||||
"version": "1.0.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.1.tgz",
|
|
||||||
"integrity": "sha512-e3nRfgfUZ4rNGL232gUgX06QNyyez04KdjFrF+LTRoOXmrOgFKDg4BCdsjW8EnT69eqdYGmRpJwiPVYNrCaW3g==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/es-errors": {
|
|
||||||
"version": "1.3.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz",
|
|
||||||
"integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/es-object-atoms": {
|
|
||||||
"version": "1.1.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.1.1.tgz",
|
|
||||||
"integrity": "sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"es-errors": "^1.3.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/es-set-tostringtag": {
|
|
||||||
"version": "2.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.1.0.tgz",
|
|
||||||
"integrity": "sha512-j6vWzfrGVfyXxge+O0x5sh6cvxAog0a/4Rdd2K36zCMV5eJ+/+tOAngRO8cODMNWbVRdVlmGZQL2YS3yR8bIUA==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"es-errors": "^1.3.0",
|
|
||||||
"get-intrinsic": "^1.2.6",
|
|
||||||
"has-tostringtag": "^1.0.2",
|
|
||||||
"hasown": "^2.0.2"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/follow-redirects": {
|
|
||||||
"version": "1.16.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.16.0.tgz",
|
|
||||||
"integrity": "sha512-y5rN/uOsadFT/JfYwhxRS5R7Qce+g3zG97+JrtFZlC9klX/W5hD7iiLzScI4nZqUS7DNUdhPgw4xI8W2LuXlUw==",
|
|
||||||
"funding": [
|
|
||||||
{
|
|
||||||
"type": "individual",
|
|
||||||
"url": "https://github.com/sponsors/RubenVerborgh"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=4.0"
|
|
||||||
},
|
|
||||||
"peerDependenciesMeta": {
|
|
||||||
"debug": {
|
|
||||||
"optional": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/form-data": {
|
|
||||||
"version": "4.0.5",
|
|
||||||
"resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.5.tgz",
|
|
||||||
"integrity": "sha512-8RipRLol37bNs2bhoV67fiTEvdTrbMUYcFTiy3+wuuOnUog2QBHCZWXDRijWQfAkhBj2Uf5UnVaiWwA5vdd82w==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"asynckit": "^0.4.0",
|
|
||||||
"combined-stream": "^1.0.8",
|
|
||||||
"es-set-tostringtag": "^2.1.0",
|
|
||||||
"hasown": "^2.0.2",
|
|
||||||
"mime-types": "^2.1.12"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/function-bind": {
|
|
||||||
"version": "1.1.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz",
|
|
||||||
"integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==",
|
|
||||||
"license": "MIT",
|
|
||||||
"funding": {
|
|
||||||
"url": "https://github.com/sponsors/ljharb"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/get-intrinsic": {
|
|
||||||
"version": "1.3.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.3.0.tgz",
|
|
||||||
"integrity": "sha512-9fSjSaos/fRIVIp+xSJlE6lfwhES7LNtKaCBIamHsjr2na1BiABJPo0mOjjz8GJDURarmCPGqaiVg5mfjb98CQ==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"call-bind-apply-helpers": "^1.0.2",
|
|
||||||
"es-define-property": "^1.0.1",
|
|
||||||
"es-errors": "^1.3.0",
|
|
||||||
"es-object-atoms": "^1.1.1",
|
|
||||||
"function-bind": "^1.1.2",
|
|
||||||
"get-proto": "^1.0.1",
|
|
||||||
"gopd": "^1.2.0",
|
|
||||||
"has-symbols": "^1.1.0",
|
|
||||||
"hasown": "^2.0.2",
|
|
||||||
"math-intrinsics": "^1.1.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"url": "https://github.com/sponsors/ljharb"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/get-proto": {
|
|
||||||
"version": "1.0.1",
|
|
||||||
"resolved": "https://registry.npmjs.org/get-proto/-/get-proto-1.0.1.tgz",
|
|
||||||
"integrity": "sha512-sTSfBjoXBp89JvIKIefqw7U2CCebsc74kiY6awiGogKtoSGbgjYE/G/+l9sF3MWFPNc9IcoOC4ODfKHfxFmp0g==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"dunder-proto": "^1.0.1",
|
|
||||||
"es-object-atoms": "^1.0.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/gopd": {
|
|
||||||
"version": "1.2.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/gopd/-/gopd-1.2.0.tgz",
|
|
||||||
"integrity": "sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"url": "https://github.com/sponsors/ljharb"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/has-symbols": {
|
|
||||||
"version": "1.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.1.0.tgz",
|
|
||||||
"integrity": "sha512-1cDNdwJ2Jaohmb3sg4OmKaMBwuC48sYni5HUw2DvsC8LjGTLK9h+eb1X6RyuOHe4hT0ULCW68iomhjUoKUqlPQ==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"url": "https://github.com/sponsors/ljharb"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/has-tostringtag": {
|
|
||||||
"version": "1.0.2",
|
|
||||||
"resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz",
|
|
||||||
"integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"has-symbols": "^1.0.3"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"url": "https://github.com/sponsors/ljharb"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/hasown": {
|
|
||||||
"version": "2.0.3",
|
|
||||||
"resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.3.tgz",
|
|
||||||
"integrity": "sha512-ej4AhfhfL2Q2zpMmLo7U1Uv9+PyhIZpgQLGT1F9miIGmiCJIoCgSmczFdrc97mWT4kVY72KA+WnnhJ5pghSvSg==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"function-bind": "^1.1.2"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/math-intrinsics": {
|
|
||||||
"version": "1.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/math-intrinsics/-/math-intrinsics-1.1.0.tgz",
|
|
||||||
"integrity": "sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.4"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/mime-db": {
|
|
||||||
"version": "1.52.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz",
|
|
||||||
"integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/mime-types": {
|
|
||||||
"version": "2.1.35",
|
|
||||||
"resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz",
|
|
||||||
"integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==",
|
|
||||||
"license": "MIT",
|
|
||||||
"dependencies": {
|
|
||||||
"mime-db": "1.52.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.6"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/proxy-from-env": {
|
|
||||||
"version": "2.1.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-2.1.0.tgz",
|
|
||||||
"integrity": "sha512-cJ+oHTW1VAEa8cJslgmUZrc+sjRKgAKl3Zyse6+PV38hZe/V6Z14TbCuXcan9F9ghlz4QrFr2c92TNF82UkYHA==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=10"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
"node_modules/ws": {
|
|
||||||
"version": "8.20.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/ws/-/ws-8.20.0.tgz",
|
|
||||||
"integrity": "sha512-sAt8BhgNbzCtgGbt2OxmpuryO63ZoDk/sqaB/znQm94T4fCEsy/yV+7CdC1kJhOU9lboAEU7R3kquuycDoibVA==",
|
|
||||||
"license": "MIT",
|
|
||||||
"engines": {
|
|
||||||
"node": ">=10.0.0"
|
|
||||||
},
|
|
||||||
"peerDependencies": {
|
|
||||||
"bufferutil": "^4.0.1",
|
|
||||||
"utf-8-validate": ">=5.0.2"
|
|
||||||
},
|
|
||||||
"peerDependenciesMeta": {
|
|
||||||
"bufferutil": {
|
|
||||||
"optional": true
|
|
||||||
},
|
|
||||||
"utf-8-validate": {
|
|
||||||
"optional": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
21
node_modules/asynckit/LICENSE
generated
vendored
21
node_modules/asynckit/LICENSE
generated
vendored
@@ -1,21 +0,0 @@
|
|||||||
The MIT License (MIT)
|
|
||||||
|
|
||||||
Copyright (c) 2016 Alex Indigo
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
|
||||||
in the Software without restriction, including without limitation the rights
|
|
||||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
||||||
copies of the Software, and to permit persons to whom the Software is
|
|
||||||
furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all
|
|
||||||
copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
||||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
||||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
||||||
SOFTWARE.
|
|
||||||
233
node_modules/asynckit/README.md
generated
vendored
233
node_modules/asynckit/README.md
generated
vendored
@@ -1,233 +0,0 @@
|
|||||||
# asynckit [](https://www.npmjs.com/package/asynckit)
|
|
||||||
|
|
||||||
Minimal async jobs utility library, with streams support.
|
|
||||||
|
|
||||||
[](https://travis-ci.org/alexindigo/asynckit)
|
|
||||||
[](https://travis-ci.org/alexindigo/asynckit)
|
|
||||||
[](https://ci.appveyor.com/project/alexindigo/asynckit)
|
|
||||||
|
|
||||||
[](https://coveralls.io/github/alexindigo/asynckit?branch=master)
|
|
||||||
[](https://david-dm.org/alexindigo/asynckit)
|
|
||||||
[](https://www.bithound.io/github/alexindigo/asynckit)
|
|
||||||
|
|
||||||
<!-- [](https://www.npmjs.com/package/reamde) -->
|
|
||||||
|
|
||||||
AsyncKit provides harness for `parallel` and `serial` iterators over list of items represented by arrays or objects.
|
|
||||||
Optionally it accepts abort function (should be synchronously return by iterator for each item), and terminates left over jobs upon an error event. For specific iteration order built-in (`ascending` and `descending`) and custom sort helpers also supported, via `asynckit.serialOrdered` method.
|
|
||||||
|
|
||||||
It ensures async operations to keep behavior more stable and prevent `Maximum call stack size exceeded` errors, from sync iterators.
|
|
||||||
|
|
||||||
| compression | size |
|
|
||||||
| :----------------- | -------: |
|
|
||||||
| asynckit.js | 12.34 kB |
|
|
||||||
| asynckit.min.js | 4.11 kB |
|
|
||||||
| asynckit.min.js.gz | 1.47 kB |
|
|
||||||
|
|
||||||
|
|
||||||
## Install
|
|
||||||
|
|
||||||
```sh
|
|
||||||
$ npm install --save asynckit
|
|
||||||
```
|
|
||||||
|
|
||||||
## Examples
|
|
||||||
|
|
||||||
### Parallel Jobs
|
|
||||||
|
|
||||||
Runs iterator over provided array in parallel. Stores output in the `result` array,
|
|
||||||
on the matching positions. In unlikely event of an error from one of the jobs,
|
|
||||||
will terminate rest of the active jobs (if abort function is provided)
|
|
||||||
and return error along with salvaged data to the main callback function.
|
|
||||||
|
|
||||||
#### Input Array
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
var parallel = require('asynckit').parallel
|
|
||||||
, assert = require('assert')
|
|
||||||
;
|
|
||||||
|
|
||||||
var source = [ 1, 1, 4, 16, 64, 32, 8, 2 ]
|
|
||||||
, expectedResult = [ 2, 2, 8, 32, 128, 64, 16, 4 ]
|
|
||||||
, expectedTarget = [ 1, 1, 2, 4, 8, 16, 32, 64 ]
|
|
||||||
, target = []
|
|
||||||
;
|
|
||||||
|
|
||||||
parallel(source, asyncJob, function(err, result)
|
|
||||||
{
|
|
||||||
assert.deepEqual(result, expectedResult);
|
|
||||||
assert.deepEqual(target, expectedTarget);
|
|
||||||
});
|
|
||||||
|
|
||||||
// async job accepts one element from the array
|
|
||||||
// and a callback function
|
|
||||||
function asyncJob(item, cb)
|
|
||||||
{
|
|
||||||
// different delays (in ms) per item
|
|
||||||
var delay = item * 25;
|
|
||||||
|
|
||||||
// pretend different jobs take different time to finish
|
|
||||||
// and not in consequential order
|
|
||||||
var timeoutId = setTimeout(function() {
|
|
||||||
target.push(item);
|
|
||||||
cb(null, item * 2);
|
|
||||||
}, delay);
|
|
||||||
|
|
||||||
// allow to cancel "leftover" jobs upon error
|
|
||||||
// return function, invoking of which will abort this job
|
|
||||||
return clearTimeout.bind(null, timeoutId);
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
More examples could be found in [test/test-parallel-array.js](test/test-parallel-array.js).
|
|
||||||
|
|
||||||
#### Input Object
|
|
||||||
|
|
||||||
Also it supports named jobs, listed via object.
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
var parallel = require('asynckit/parallel')
|
|
||||||
, assert = require('assert')
|
|
||||||
;
|
|
||||||
|
|
||||||
var source = { first: 1, one: 1, four: 4, sixteen: 16, sixtyFour: 64, thirtyTwo: 32, eight: 8, two: 2 }
|
|
||||||
, expectedResult = { first: 2, one: 2, four: 8, sixteen: 32, sixtyFour: 128, thirtyTwo: 64, eight: 16, two: 4 }
|
|
||||||
, expectedTarget = [ 1, 1, 2, 4, 8, 16, 32, 64 ]
|
|
||||||
, expectedKeys = [ 'first', 'one', 'two', 'four', 'eight', 'sixteen', 'thirtyTwo', 'sixtyFour' ]
|
|
||||||
, target = []
|
|
||||||
, keys = []
|
|
||||||
;
|
|
||||||
|
|
||||||
parallel(source, asyncJob, function(err, result)
|
|
||||||
{
|
|
||||||
assert.deepEqual(result, expectedResult);
|
|
||||||
assert.deepEqual(target, expectedTarget);
|
|
||||||
assert.deepEqual(keys, expectedKeys);
|
|
||||||
});
|
|
||||||
|
|
||||||
// supports full value, key, callback (shortcut) interface
|
|
||||||
function asyncJob(item, key, cb)
|
|
||||||
{
|
|
||||||
// different delays (in ms) per item
|
|
||||||
var delay = item * 25;
|
|
||||||
|
|
||||||
// pretend different jobs take different time to finish
|
|
||||||
// and not in consequential order
|
|
||||||
var timeoutId = setTimeout(function() {
|
|
||||||
keys.push(key);
|
|
||||||
target.push(item);
|
|
||||||
cb(null, item * 2);
|
|
||||||
}, delay);
|
|
||||||
|
|
||||||
// allow to cancel "leftover" jobs upon error
|
|
||||||
// return function, invoking of which will abort this job
|
|
||||||
return clearTimeout.bind(null, timeoutId);
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
More examples could be found in [test/test-parallel-object.js](test/test-parallel-object.js).
|
|
||||||
|
|
||||||
### Serial Jobs
|
|
||||||
|
|
||||||
Runs iterator over provided array sequentially. Stores output in the `result` array,
|
|
||||||
on the matching positions. In unlikely event of an error from one of the jobs,
|
|
||||||
will not proceed to the rest of the items in the list
|
|
||||||
and return error along with salvaged data to the main callback function.
|
|
||||||
|
|
||||||
#### Input Array
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
var serial = require('asynckit/serial')
|
|
||||||
, assert = require('assert')
|
|
||||||
;
|
|
||||||
|
|
||||||
var source = [ 1, 1, 4, 16, 64, 32, 8, 2 ]
|
|
||||||
, expectedResult = [ 2, 2, 8, 32, 128, 64, 16, 4 ]
|
|
||||||
, expectedTarget = [ 0, 1, 2, 3, 4, 5, 6, 7 ]
|
|
||||||
, target = []
|
|
||||||
;
|
|
||||||
|
|
||||||
serial(source, asyncJob, function(err, result)
|
|
||||||
{
|
|
||||||
assert.deepEqual(result, expectedResult);
|
|
||||||
assert.deepEqual(target, expectedTarget);
|
|
||||||
});
|
|
||||||
|
|
||||||
// extended interface (item, key, callback)
|
|
||||||
// also supported for arrays
|
|
||||||
function asyncJob(item, key, cb)
|
|
||||||
{
|
|
||||||
target.push(key);
|
|
||||||
|
|
||||||
// it will be automatically made async
|
|
||||||
// even it iterator "returns" in the same event loop
|
|
||||||
cb(null, item * 2);
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
More examples could be found in [test/test-serial-array.js](test/test-serial-array.js).
|
|
||||||
|
|
||||||
#### Input Object
|
|
||||||
|
|
||||||
Also it supports named jobs, listed via object.
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
var serial = require('asynckit').serial
|
|
||||||
, assert = require('assert')
|
|
||||||
;
|
|
||||||
|
|
||||||
var source = [ 1, 1, 4, 16, 64, 32, 8, 2 ]
|
|
||||||
, expectedResult = [ 2, 2, 8, 32, 128, 64, 16, 4 ]
|
|
||||||
, expectedTarget = [ 0, 1, 2, 3, 4, 5, 6, 7 ]
|
|
||||||
, target = []
|
|
||||||
;
|
|
||||||
|
|
||||||
var source = { first: 1, one: 1, four: 4, sixteen: 16, sixtyFour: 64, thirtyTwo: 32, eight: 8, two: 2 }
|
|
||||||
, expectedResult = { first: 2, one: 2, four: 8, sixteen: 32, sixtyFour: 128, thirtyTwo: 64, eight: 16, two: 4 }
|
|
||||||
, expectedTarget = [ 1, 1, 4, 16, 64, 32, 8, 2 ]
|
|
||||||
, target = []
|
|
||||||
;
|
|
||||||
|
|
||||||
|
|
||||||
serial(source, asyncJob, function(err, result)
|
|
||||||
{
|
|
||||||
assert.deepEqual(result, expectedResult);
|
|
||||||
assert.deepEqual(target, expectedTarget);
|
|
||||||
});
|
|
||||||
|
|
||||||
// shortcut interface (item, callback)
|
|
||||||
// works for object as well as for the arrays
|
|
||||||
function asyncJob(item, cb)
|
|
||||||
{
|
|
||||||
target.push(item);
|
|
||||||
|
|
||||||
// it will be automatically made async
|
|
||||||
// even it iterator "returns" in the same event loop
|
|
||||||
cb(null, item * 2);
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
More examples could be found in [test/test-serial-object.js](test/test-serial-object.js).
|
|
||||||
|
|
||||||
_Note: Since _object_ is an _unordered_ collection of properties,
|
|
||||||
it may produce unexpected results with sequential iterations.
|
|
||||||
Whenever order of the jobs' execution is important please use `serialOrdered` method._
|
|
||||||
|
|
||||||
### Ordered Serial Iterations
|
|
||||||
|
|
||||||
TBD
|
|
||||||
|
|
||||||
For example [compare-property](compare-property) package.
|
|
||||||
|
|
||||||
### Streaming interface
|
|
||||||
|
|
||||||
TBD
|
|
||||||
|
|
||||||
## Want to Know More?
|
|
||||||
|
|
||||||
More examples can be found in [test folder](test/).
|
|
||||||
|
|
||||||
Or open an [issue](https://github.com/alexindigo/asynckit/issues) with questions and/or suggestions.
|
|
||||||
|
|
||||||
## License
|
|
||||||
|
|
||||||
AsyncKit is licensed under the MIT license.
|
|
||||||
76
node_modules/asynckit/bench.js
generated
vendored
76
node_modules/asynckit/bench.js
generated
vendored
@@ -1,76 +0,0 @@
|
|||||||
/* eslint no-console: "off" */
|
|
||||||
|
|
||||||
var asynckit = require('./')
|
|
||||||
, async = require('async')
|
|
||||||
, assert = require('assert')
|
|
||||||
, expected = 0
|
|
||||||
;
|
|
||||||
|
|
||||||
var Benchmark = require('benchmark');
|
|
||||||
var suite = new Benchmark.Suite;
|
|
||||||
|
|
||||||
var source = [];
|
|
||||||
for (var z = 1; z < 100; z++)
|
|
||||||
{
|
|
||||||
source.push(z);
|
|
||||||
expected += z;
|
|
||||||
}
|
|
||||||
|
|
||||||
suite
|
|
||||||
// add tests
|
|
||||||
|
|
||||||
.add('async.map', function(deferred)
|
|
||||||
{
|
|
||||||
var total = 0;
|
|
||||||
|
|
||||||
async.map(source,
|
|
||||||
function(i, cb)
|
|
||||||
{
|
|
||||||
setImmediate(function()
|
|
||||||
{
|
|
||||||
total += i;
|
|
||||||
cb(null, total);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
function(err, result)
|
|
||||||
{
|
|
||||||
assert.ifError(err);
|
|
||||||
assert.equal(result[result.length - 1], expected);
|
|
||||||
deferred.resolve();
|
|
||||||
});
|
|
||||||
}, {'defer': true})
|
|
||||||
|
|
||||||
|
|
||||||
.add('asynckit.parallel', function(deferred)
|
|
||||||
{
|
|
||||||
var total = 0;
|
|
||||||
|
|
||||||
asynckit.parallel(source,
|
|
||||||
function(i, cb)
|
|
||||||
{
|
|
||||||
setImmediate(function()
|
|
||||||
{
|
|
||||||
total += i;
|
|
||||||
cb(null, total);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
function(err, result)
|
|
||||||
{
|
|
||||||
assert.ifError(err);
|
|
||||||
assert.equal(result[result.length - 1], expected);
|
|
||||||
deferred.resolve();
|
|
||||||
});
|
|
||||||
}, {'defer': true})
|
|
||||||
|
|
||||||
|
|
||||||
// add listeners
|
|
||||||
.on('cycle', function(ev)
|
|
||||||
{
|
|
||||||
console.log(String(ev.target));
|
|
||||||
})
|
|
||||||
.on('complete', function()
|
|
||||||
{
|
|
||||||
console.log('Fastest is ' + this.filter('fastest').map('name'));
|
|
||||||
})
|
|
||||||
// run async
|
|
||||||
.run({ 'async': true });
|
|
||||||
6
node_modules/asynckit/index.js
generated
vendored
6
node_modules/asynckit/index.js
generated
vendored
@@ -1,6 +0,0 @@
|
|||||||
module.exports =
|
|
||||||
{
|
|
||||||
parallel : require('./parallel.js'),
|
|
||||||
serial : require('./serial.js'),
|
|
||||||
serialOrdered : require('./serialOrdered.js')
|
|
||||||
};
|
|
||||||
29
node_modules/asynckit/lib/abort.js
generated
vendored
29
node_modules/asynckit/lib/abort.js
generated
vendored
@@ -1,29 +0,0 @@
|
|||||||
// API
|
|
||||||
module.exports = abort;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Aborts leftover active jobs
|
|
||||||
*
|
|
||||||
* @param {object} state - current state object
|
|
||||||
*/
|
|
||||||
function abort(state)
|
|
||||||
{
|
|
||||||
Object.keys(state.jobs).forEach(clean.bind(state));
|
|
||||||
|
|
||||||
// reset leftover jobs
|
|
||||||
state.jobs = {};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Cleans up leftover job by invoking abort function for the provided job id
|
|
||||||
*
|
|
||||||
* @this state
|
|
||||||
* @param {string|number} key - job id to abort
|
|
||||||
*/
|
|
||||||
function clean(key)
|
|
||||||
{
|
|
||||||
if (typeof this.jobs[key] == 'function')
|
|
||||||
{
|
|
||||||
this.jobs[key]();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
34
node_modules/asynckit/lib/async.js
generated
vendored
34
node_modules/asynckit/lib/async.js
generated
vendored
@@ -1,34 +0,0 @@
|
|||||||
var defer = require('./defer.js');
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports = async;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Runs provided callback asynchronously
|
|
||||||
* even if callback itself is not
|
|
||||||
*
|
|
||||||
* @param {function} callback - callback to invoke
|
|
||||||
* @returns {function} - augmented callback
|
|
||||||
*/
|
|
||||||
function async(callback)
|
|
||||||
{
|
|
||||||
var isAsync = false;
|
|
||||||
|
|
||||||
// check if async happened
|
|
||||||
defer(function() { isAsync = true; });
|
|
||||||
|
|
||||||
return function async_callback(err, result)
|
|
||||||
{
|
|
||||||
if (isAsync)
|
|
||||||
{
|
|
||||||
callback(err, result);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
defer(function nextTick_callback()
|
|
||||||
{
|
|
||||||
callback(err, result);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
26
node_modules/asynckit/lib/defer.js
generated
vendored
26
node_modules/asynckit/lib/defer.js
generated
vendored
@@ -1,26 +0,0 @@
|
|||||||
module.exports = defer;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Runs provided function on next iteration of the event loop
|
|
||||||
*
|
|
||||||
* @param {function} fn - function to run
|
|
||||||
*/
|
|
||||||
function defer(fn)
|
|
||||||
{
|
|
||||||
var nextTick = typeof setImmediate == 'function'
|
|
||||||
? setImmediate
|
|
||||||
: (
|
|
||||||
typeof process == 'object' && typeof process.nextTick == 'function'
|
|
||||||
? process.nextTick
|
|
||||||
: null
|
|
||||||
);
|
|
||||||
|
|
||||||
if (nextTick)
|
|
||||||
{
|
|
||||||
nextTick(fn);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
setTimeout(fn, 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
75
node_modules/asynckit/lib/iterate.js
generated
vendored
75
node_modules/asynckit/lib/iterate.js
generated
vendored
@@ -1,75 +0,0 @@
|
|||||||
var async = require('./async.js')
|
|
||||||
, abort = require('./abort.js')
|
|
||||||
;
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports = iterate;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Iterates over each job object
|
|
||||||
*
|
|
||||||
* @param {array|object} list - array or object (named list) to iterate over
|
|
||||||
* @param {function} iterator - iterator to run
|
|
||||||
* @param {object} state - current job status
|
|
||||||
* @param {function} callback - invoked when all elements processed
|
|
||||||
*/
|
|
||||||
function iterate(list, iterator, state, callback)
|
|
||||||
{
|
|
||||||
// store current index
|
|
||||||
var key = state['keyedList'] ? state['keyedList'][state.index] : state.index;
|
|
||||||
|
|
||||||
state.jobs[key] = runJob(iterator, key, list[key], function(error, output)
|
|
||||||
{
|
|
||||||
// don't repeat yourself
|
|
||||||
// skip secondary callbacks
|
|
||||||
if (!(key in state.jobs))
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// clean up jobs
|
|
||||||
delete state.jobs[key];
|
|
||||||
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
// don't process rest of the results
|
|
||||||
// stop still active jobs
|
|
||||||
// and reset the list
|
|
||||||
abort(state);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
state.results[key] = output;
|
|
||||||
}
|
|
||||||
|
|
||||||
// return salvaged results
|
|
||||||
callback(error, state.results);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Runs iterator over provided job element
|
|
||||||
*
|
|
||||||
* @param {function} iterator - iterator to invoke
|
|
||||||
* @param {string|number} key - key/index of the element in the list of jobs
|
|
||||||
* @param {mixed} item - job description
|
|
||||||
* @param {function} callback - invoked after iterator is done with the job
|
|
||||||
* @returns {function|mixed} - job abort function or something else
|
|
||||||
*/
|
|
||||||
function runJob(iterator, key, item, callback)
|
|
||||||
{
|
|
||||||
var aborter;
|
|
||||||
|
|
||||||
// allow shortcut if iterator expects only two arguments
|
|
||||||
if (iterator.length == 2)
|
|
||||||
{
|
|
||||||
aborter = iterator(item, async(callback));
|
|
||||||
}
|
|
||||||
// otherwise go with full three arguments
|
|
||||||
else
|
|
||||||
{
|
|
||||||
aborter = iterator(item, key, async(callback));
|
|
||||||
}
|
|
||||||
|
|
||||||
return aborter;
|
|
||||||
}
|
|
||||||
91
node_modules/asynckit/lib/readable_asynckit.js
generated
vendored
91
node_modules/asynckit/lib/readable_asynckit.js
generated
vendored
@@ -1,91 +0,0 @@
|
|||||||
var streamify = require('./streamify.js')
|
|
||||||
, defer = require('./defer.js')
|
|
||||||
;
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports = ReadableAsyncKit;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Base constructor for all streams
|
|
||||||
* used to hold properties/methods
|
|
||||||
*/
|
|
||||||
function ReadableAsyncKit()
|
|
||||||
{
|
|
||||||
ReadableAsyncKit.super_.apply(this, arguments);
|
|
||||||
|
|
||||||
// list of active jobs
|
|
||||||
this.jobs = {};
|
|
||||||
|
|
||||||
// add stream methods
|
|
||||||
this.destroy = destroy;
|
|
||||||
this._start = _start;
|
|
||||||
this._read = _read;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Destroys readable stream,
|
|
||||||
* by aborting outstanding jobs
|
|
||||||
*
|
|
||||||
* @returns {void}
|
|
||||||
*/
|
|
||||||
function destroy()
|
|
||||||
{
|
|
||||||
if (this.destroyed)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.destroyed = true;
|
|
||||||
|
|
||||||
if (typeof this.terminator == 'function')
|
|
||||||
{
|
|
||||||
this.terminator();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Starts provided jobs in async manner
|
|
||||||
*
|
|
||||||
* @private
|
|
||||||
*/
|
|
||||||
function _start()
|
|
||||||
{
|
|
||||||
// first argument – runner function
|
|
||||||
var runner = arguments[0]
|
|
||||||
// take away first argument
|
|
||||||
, args = Array.prototype.slice.call(arguments, 1)
|
|
||||||
// second argument - input data
|
|
||||||
, input = args[0]
|
|
||||||
// last argument - result callback
|
|
||||||
, endCb = streamify.callback.call(this, args[args.length - 1])
|
|
||||||
;
|
|
||||||
|
|
||||||
args[args.length - 1] = endCb;
|
|
||||||
// third argument - iterator
|
|
||||||
args[1] = streamify.iterator.call(this, args[1]);
|
|
||||||
|
|
||||||
// allow time for proper setup
|
|
||||||
defer(function()
|
|
||||||
{
|
|
||||||
if (!this.destroyed)
|
|
||||||
{
|
|
||||||
this.terminator = runner.apply(null, args);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
endCb(null, Array.isArray(input) ? [] : {});
|
|
||||||
}
|
|
||||||
}.bind(this));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Implement _read to comply with Readable streams
|
|
||||||
* Doesn't really make sense for flowing object mode
|
|
||||||
*
|
|
||||||
* @private
|
|
||||||
*/
|
|
||||||
function _read()
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
25
node_modules/asynckit/lib/readable_parallel.js
generated
vendored
25
node_modules/asynckit/lib/readable_parallel.js
generated
vendored
@@ -1,25 +0,0 @@
|
|||||||
var parallel = require('../parallel.js');
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports = ReadableParallel;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Streaming wrapper to `asynckit.parallel`
|
|
||||||
*
|
|
||||||
* @param {array|object} list - array or object (named list) to iterate over
|
|
||||||
* @param {function} iterator - iterator to run
|
|
||||||
* @param {function} callback - invoked when all elements processed
|
|
||||||
* @returns {stream.Readable#}
|
|
||||||
*/
|
|
||||||
function ReadableParallel(list, iterator, callback)
|
|
||||||
{
|
|
||||||
if (!(this instanceof ReadableParallel))
|
|
||||||
{
|
|
||||||
return new ReadableParallel(list, iterator, callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
// turn on object mode
|
|
||||||
ReadableParallel.super_.call(this, {objectMode: true});
|
|
||||||
|
|
||||||
this._start(parallel, list, iterator, callback);
|
|
||||||
}
|
|
||||||
25
node_modules/asynckit/lib/readable_serial.js
generated
vendored
25
node_modules/asynckit/lib/readable_serial.js
generated
vendored
@@ -1,25 +0,0 @@
|
|||||||
var serial = require('../serial.js');
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports = ReadableSerial;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Streaming wrapper to `asynckit.serial`
|
|
||||||
*
|
|
||||||
* @param {array|object} list - array or object (named list) to iterate over
|
|
||||||
* @param {function} iterator - iterator to run
|
|
||||||
* @param {function} callback - invoked when all elements processed
|
|
||||||
* @returns {stream.Readable#}
|
|
||||||
*/
|
|
||||||
function ReadableSerial(list, iterator, callback)
|
|
||||||
{
|
|
||||||
if (!(this instanceof ReadableSerial))
|
|
||||||
{
|
|
||||||
return new ReadableSerial(list, iterator, callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
// turn on object mode
|
|
||||||
ReadableSerial.super_.call(this, {objectMode: true});
|
|
||||||
|
|
||||||
this._start(serial, list, iterator, callback);
|
|
||||||
}
|
|
||||||
29
node_modules/asynckit/lib/readable_serial_ordered.js
generated
vendored
29
node_modules/asynckit/lib/readable_serial_ordered.js
generated
vendored
@@ -1,29 +0,0 @@
|
|||||||
var serialOrdered = require('../serialOrdered.js');
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports = ReadableSerialOrdered;
|
|
||||||
// expose sort helpers
|
|
||||||
module.exports.ascending = serialOrdered.ascending;
|
|
||||||
module.exports.descending = serialOrdered.descending;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Streaming wrapper to `asynckit.serialOrdered`
|
|
||||||
*
|
|
||||||
* @param {array|object} list - array or object (named list) to iterate over
|
|
||||||
* @param {function} iterator - iterator to run
|
|
||||||
* @param {function} sortMethod - custom sort function
|
|
||||||
* @param {function} callback - invoked when all elements processed
|
|
||||||
* @returns {stream.Readable#}
|
|
||||||
*/
|
|
||||||
function ReadableSerialOrdered(list, iterator, sortMethod, callback)
|
|
||||||
{
|
|
||||||
if (!(this instanceof ReadableSerialOrdered))
|
|
||||||
{
|
|
||||||
return new ReadableSerialOrdered(list, iterator, sortMethod, callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
// turn on object mode
|
|
||||||
ReadableSerialOrdered.super_.call(this, {objectMode: true});
|
|
||||||
|
|
||||||
this._start(serialOrdered, list, iterator, sortMethod, callback);
|
|
||||||
}
|
|
||||||
37
node_modules/asynckit/lib/state.js
generated
vendored
37
node_modules/asynckit/lib/state.js
generated
vendored
@@ -1,37 +0,0 @@
|
|||||||
// API
|
|
||||||
module.exports = state;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates initial state object
|
|
||||||
* for iteration over list
|
|
||||||
*
|
|
||||||
* @param {array|object} list - list to iterate over
|
|
||||||
* @param {function|null} sortMethod - function to use for keys sort,
|
|
||||||
* or `null` to keep them as is
|
|
||||||
* @returns {object} - initial state object
|
|
||||||
*/
|
|
||||||
function state(list, sortMethod)
|
|
||||||
{
|
|
||||||
var isNamedList = !Array.isArray(list)
|
|
||||||
, initState =
|
|
||||||
{
|
|
||||||
index : 0,
|
|
||||||
keyedList: isNamedList || sortMethod ? Object.keys(list) : null,
|
|
||||||
jobs : {},
|
|
||||||
results : isNamedList ? {} : [],
|
|
||||||
size : isNamedList ? Object.keys(list).length : list.length
|
|
||||||
}
|
|
||||||
;
|
|
||||||
|
|
||||||
if (sortMethod)
|
|
||||||
{
|
|
||||||
// sort array keys based on it's values
|
|
||||||
// sort object's keys just on own merit
|
|
||||||
initState.keyedList.sort(isNamedList ? sortMethod : function(a, b)
|
|
||||||
{
|
|
||||||
return sortMethod(list[a], list[b]);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return initState;
|
|
||||||
}
|
|
||||||
141
node_modules/asynckit/lib/streamify.js
generated
vendored
141
node_modules/asynckit/lib/streamify.js
generated
vendored
@@ -1,141 +0,0 @@
|
|||||||
var async = require('./async.js');
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports = {
|
|
||||||
iterator: wrapIterator,
|
|
||||||
callback: wrapCallback
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Wraps iterators with long signature
|
|
||||||
*
|
|
||||||
* @this ReadableAsyncKit#
|
|
||||||
* @param {function} iterator - function to wrap
|
|
||||||
* @returns {function} - wrapped function
|
|
||||||
*/
|
|
||||||
function wrapIterator(iterator)
|
|
||||||
{
|
|
||||||
var stream = this;
|
|
||||||
|
|
||||||
return function(item, key, cb)
|
|
||||||
{
|
|
||||||
var aborter
|
|
||||||
, wrappedCb = async(wrapIteratorCallback.call(stream, cb, key))
|
|
||||||
;
|
|
||||||
|
|
||||||
stream.jobs[key] = wrappedCb;
|
|
||||||
|
|
||||||
// it's either shortcut (item, cb)
|
|
||||||
if (iterator.length == 2)
|
|
||||||
{
|
|
||||||
aborter = iterator(item, wrappedCb);
|
|
||||||
}
|
|
||||||
// or long format (item, key, cb)
|
|
||||||
else
|
|
||||||
{
|
|
||||||
aborter = iterator(item, key, wrappedCb);
|
|
||||||
}
|
|
||||||
|
|
||||||
return aborter;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Wraps provided callback function
|
|
||||||
* allowing to execute snitch function before
|
|
||||||
* real callback
|
|
||||||
*
|
|
||||||
* @this ReadableAsyncKit#
|
|
||||||
* @param {function} callback - function to wrap
|
|
||||||
* @returns {function} - wrapped function
|
|
||||||
*/
|
|
||||||
function wrapCallback(callback)
|
|
||||||
{
|
|
||||||
var stream = this;
|
|
||||||
|
|
||||||
var wrapped = function(error, result)
|
|
||||||
{
|
|
||||||
return finisher.call(stream, error, result, callback);
|
|
||||||
};
|
|
||||||
|
|
||||||
return wrapped;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Wraps provided iterator callback function
|
|
||||||
* makes sure snitch only called once,
|
|
||||||
* but passes secondary calls to the original callback
|
|
||||||
*
|
|
||||||
* @this ReadableAsyncKit#
|
|
||||||
* @param {function} callback - callback to wrap
|
|
||||||
* @param {number|string} key - iteration key
|
|
||||||
* @returns {function} wrapped callback
|
|
||||||
*/
|
|
||||||
function wrapIteratorCallback(callback, key)
|
|
||||||
{
|
|
||||||
var stream = this;
|
|
||||||
|
|
||||||
return function(error, output)
|
|
||||||
{
|
|
||||||
// don't repeat yourself
|
|
||||||
if (!(key in stream.jobs))
|
|
||||||
{
|
|
||||||
callback(error, output);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// clean up jobs
|
|
||||||
delete stream.jobs[key];
|
|
||||||
|
|
||||||
return streamer.call(stream, error, {key: key, value: output}, callback);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Stream wrapper for iterator callback
|
|
||||||
*
|
|
||||||
* @this ReadableAsyncKit#
|
|
||||||
* @param {mixed} error - error response
|
|
||||||
* @param {mixed} output - iterator output
|
|
||||||
* @param {function} callback - callback that expects iterator results
|
|
||||||
*/
|
|
||||||
function streamer(error, output, callback)
|
|
||||||
{
|
|
||||||
if (error && !this.error)
|
|
||||||
{
|
|
||||||
this.error = error;
|
|
||||||
this.pause();
|
|
||||||
this.emit('error', error);
|
|
||||||
// send back value only, as expected
|
|
||||||
callback(error, output && output.value);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// stream stuff
|
|
||||||
this.push(output);
|
|
||||||
|
|
||||||
// back to original track
|
|
||||||
// send back value only, as expected
|
|
||||||
callback(error, output && output.value);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Stream wrapper for finishing callback
|
|
||||||
*
|
|
||||||
* @this ReadableAsyncKit#
|
|
||||||
* @param {mixed} error - error response
|
|
||||||
* @param {mixed} output - iterator output
|
|
||||||
* @param {function} callback - callback that expects final results
|
|
||||||
*/
|
|
||||||
function finisher(error, output, callback)
|
|
||||||
{
|
|
||||||
// signal end of the stream
|
|
||||||
// only for successfully finished streams
|
|
||||||
if (!error)
|
|
||||||
{
|
|
||||||
this.push(null);
|
|
||||||
}
|
|
||||||
|
|
||||||
// back to original track
|
|
||||||
callback(error, output);
|
|
||||||
}
|
|
||||||
29
node_modules/asynckit/lib/terminator.js
generated
vendored
29
node_modules/asynckit/lib/terminator.js
generated
vendored
@@ -1,29 +0,0 @@
|
|||||||
var abort = require('./abort.js')
|
|
||||||
, async = require('./async.js')
|
|
||||||
;
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports = terminator;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Terminates jobs in the attached state context
|
|
||||||
*
|
|
||||||
* @this AsyncKitState#
|
|
||||||
* @param {function} callback - final callback to invoke after termination
|
|
||||||
*/
|
|
||||||
function terminator(callback)
|
|
||||||
{
|
|
||||||
if (!Object.keys(this.jobs).length)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// fast forward iteration index
|
|
||||||
this.index = this.size;
|
|
||||||
|
|
||||||
// abort jobs
|
|
||||||
abort(this);
|
|
||||||
|
|
||||||
// send back results we have so far
|
|
||||||
async(callback)(null, this.results);
|
|
||||||
}
|
|
||||||
63
node_modules/asynckit/package.json
generated
vendored
63
node_modules/asynckit/package.json
generated
vendored
@@ -1,63 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "asynckit",
|
|
||||||
"version": "0.4.0",
|
|
||||||
"description": "Minimal async jobs utility library, with streams support",
|
|
||||||
"main": "index.js",
|
|
||||||
"scripts": {
|
|
||||||
"clean": "rimraf coverage",
|
|
||||||
"lint": "eslint *.js lib/*.js test/*.js",
|
|
||||||
"test": "istanbul cover --reporter=json tape -- 'test/test-*.js' | tap-spec",
|
|
||||||
"win-test": "tape test/test-*.js",
|
|
||||||
"browser": "browserify -t browserify-istanbul test/lib/browserify_adjustment.js test/test-*.js | obake --coverage | tap-spec",
|
|
||||||
"report": "istanbul report",
|
|
||||||
"size": "browserify index.js | size-table asynckit",
|
|
||||||
"debug": "tape test/test-*.js"
|
|
||||||
},
|
|
||||||
"pre-commit": [
|
|
||||||
"clean",
|
|
||||||
"lint",
|
|
||||||
"test",
|
|
||||||
"browser",
|
|
||||||
"report",
|
|
||||||
"size"
|
|
||||||
],
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "git+https://github.com/alexindigo/asynckit.git"
|
|
||||||
},
|
|
||||||
"keywords": [
|
|
||||||
"async",
|
|
||||||
"jobs",
|
|
||||||
"parallel",
|
|
||||||
"serial",
|
|
||||||
"iterator",
|
|
||||||
"array",
|
|
||||||
"object",
|
|
||||||
"stream",
|
|
||||||
"destroy",
|
|
||||||
"terminate",
|
|
||||||
"abort"
|
|
||||||
],
|
|
||||||
"author": "Alex Indigo <iam@alexindigo.com>",
|
|
||||||
"license": "MIT",
|
|
||||||
"bugs": {
|
|
||||||
"url": "https://github.com/alexindigo/asynckit/issues"
|
|
||||||
},
|
|
||||||
"homepage": "https://github.com/alexindigo/asynckit#readme",
|
|
||||||
"devDependencies": {
|
|
||||||
"browserify": "^13.0.0",
|
|
||||||
"browserify-istanbul": "^2.0.0",
|
|
||||||
"coveralls": "^2.11.9",
|
|
||||||
"eslint": "^2.9.0",
|
|
||||||
"istanbul": "^0.4.3",
|
|
||||||
"obake": "^0.1.2",
|
|
||||||
"phantomjs-prebuilt": "^2.1.7",
|
|
||||||
"pre-commit": "^1.1.3",
|
|
||||||
"reamde": "^1.1.0",
|
|
||||||
"rimraf": "^2.5.2",
|
|
||||||
"size-table": "^0.2.0",
|
|
||||||
"tap-spec": "^4.1.1",
|
|
||||||
"tape": "^4.5.1"
|
|
||||||
},
|
|
||||||
"dependencies": {}
|
|
||||||
}
|
|
||||||
43
node_modules/asynckit/parallel.js
generated
vendored
43
node_modules/asynckit/parallel.js
generated
vendored
@@ -1,43 +0,0 @@
|
|||||||
var iterate = require('./lib/iterate.js')
|
|
||||||
, initState = require('./lib/state.js')
|
|
||||||
, terminator = require('./lib/terminator.js')
|
|
||||||
;
|
|
||||||
|
|
||||||
// Public API
|
|
||||||
module.exports = parallel;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Runs iterator over provided array elements in parallel
|
|
||||||
*
|
|
||||||
* @param {array|object} list - array or object (named list) to iterate over
|
|
||||||
* @param {function} iterator - iterator to run
|
|
||||||
* @param {function} callback - invoked when all elements processed
|
|
||||||
* @returns {function} - jobs terminator
|
|
||||||
*/
|
|
||||||
function parallel(list, iterator, callback)
|
|
||||||
{
|
|
||||||
var state = initState(list);
|
|
||||||
|
|
||||||
while (state.index < (state['keyedList'] || list).length)
|
|
||||||
{
|
|
||||||
iterate(list, iterator, state, function(error, result)
|
|
||||||
{
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
callback(error, result);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// looks like it's the last one
|
|
||||||
if (Object.keys(state.jobs).length === 0)
|
|
||||||
{
|
|
||||||
callback(null, state.results);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
state.index++;
|
|
||||||
}
|
|
||||||
|
|
||||||
return terminator.bind(state, callback);
|
|
||||||
}
|
|
||||||
17
node_modules/asynckit/serial.js
generated
vendored
17
node_modules/asynckit/serial.js
generated
vendored
@@ -1,17 +0,0 @@
|
|||||||
var serialOrdered = require('./serialOrdered.js');
|
|
||||||
|
|
||||||
// Public API
|
|
||||||
module.exports = serial;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Runs iterator over provided array elements in series
|
|
||||||
*
|
|
||||||
* @param {array|object} list - array or object (named list) to iterate over
|
|
||||||
* @param {function} iterator - iterator to run
|
|
||||||
* @param {function} callback - invoked when all elements processed
|
|
||||||
* @returns {function} - jobs terminator
|
|
||||||
*/
|
|
||||||
function serial(list, iterator, callback)
|
|
||||||
{
|
|
||||||
return serialOrdered(list, iterator, null, callback);
|
|
||||||
}
|
|
||||||
75
node_modules/asynckit/serialOrdered.js
generated
vendored
75
node_modules/asynckit/serialOrdered.js
generated
vendored
@@ -1,75 +0,0 @@
|
|||||||
var iterate = require('./lib/iterate.js')
|
|
||||||
, initState = require('./lib/state.js')
|
|
||||||
, terminator = require('./lib/terminator.js')
|
|
||||||
;
|
|
||||||
|
|
||||||
// Public API
|
|
||||||
module.exports = serialOrdered;
|
|
||||||
// sorting helpers
|
|
||||||
module.exports.ascending = ascending;
|
|
||||||
module.exports.descending = descending;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Runs iterator over provided sorted array elements in series
|
|
||||||
*
|
|
||||||
* @param {array|object} list - array or object (named list) to iterate over
|
|
||||||
* @param {function} iterator - iterator to run
|
|
||||||
* @param {function} sortMethod - custom sort function
|
|
||||||
* @param {function} callback - invoked when all elements processed
|
|
||||||
* @returns {function} - jobs terminator
|
|
||||||
*/
|
|
||||||
function serialOrdered(list, iterator, sortMethod, callback)
|
|
||||||
{
|
|
||||||
var state = initState(list, sortMethod);
|
|
||||||
|
|
||||||
iterate(list, iterator, state, function iteratorHandler(error, result)
|
|
||||||
{
|
|
||||||
if (error)
|
|
||||||
{
|
|
||||||
callback(error, result);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
state.index++;
|
|
||||||
|
|
||||||
// are we there yet?
|
|
||||||
if (state.index < (state['keyedList'] || list).length)
|
|
||||||
{
|
|
||||||
iterate(list, iterator, state, iteratorHandler);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// done here
|
|
||||||
callback(null, state.results);
|
|
||||||
});
|
|
||||||
|
|
||||||
return terminator.bind(state, callback);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* -- Sort methods
|
|
||||||
*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* sort helper to sort array elements in ascending order
|
|
||||||
*
|
|
||||||
* @param {mixed} a - an item to compare
|
|
||||||
* @param {mixed} b - an item to compare
|
|
||||||
* @returns {number} - comparison result
|
|
||||||
*/
|
|
||||||
function ascending(a, b)
|
|
||||||
{
|
|
||||||
return a < b ? -1 : a > b ? 1 : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* sort helper to sort array elements in descending order
|
|
||||||
*
|
|
||||||
* @param {mixed} a - an item to compare
|
|
||||||
* @param {mixed} b - an item to compare
|
|
||||||
* @returns {number} - comparison result
|
|
||||||
*/
|
|
||||||
function descending(a, b)
|
|
||||||
{
|
|
||||||
return -1 * ascending(a, b);
|
|
||||||
}
|
|
||||||
21
node_modules/asynckit/stream.js
generated
vendored
21
node_modules/asynckit/stream.js
generated
vendored
@@ -1,21 +0,0 @@
|
|||||||
var inherits = require('util').inherits
|
|
||||||
, Readable = require('stream').Readable
|
|
||||||
, ReadableAsyncKit = require('./lib/readable_asynckit.js')
|
|
||||||
, ReadableParallel = require('./lib/readable_parallel.js')
|
|
||||||
, ReadableSerial = require('./lib/readable_serial.js')
|
|
||||||
, ReadableSerialOrdered = require('./lib/readable_serial_ordered.js')
|
|
||||||
;
|
|
||||||
|
|
||||||
// API
|
|
||||||
module.exports =
|
|
||||||
{
|
|
||||||
parallel : ReadableParallel,
|
|
||||||
serial : ReadableSerial,
|
|
||||||
serialOrdered : ReadableSerialOrdered,
|
|
||||||
};
|
|
||||||
|
|
||||||
inherits(ReadableAsyncKit, Readable);
|
|
||||||
|
|
||||||
inherits(ReadableParallel, ReadableAsyncKit);
|
|
||||||
inherits(ReadableSerial, ReadableAsyncKit);
|
|
||||||
inherits(ReadableSerialOrdered, ReadableAsyncKit);
|
|
||||||
1650
node_modules/axios/CHANGELOG.md
generated
vendored
1650
node_modules/axios/CHANGELOG.md
generated
vendored
File diff suppressed because it is too large
Load Diff
7
node_modules/axios/LICENSE
generated
vendored
7
node_modules/axios/LICENSE
generated
vendored
@@ -1,7 +0,0 @@
|
|||||||
# Copyright (c) 2014-present Matt Zabriskie & Collaborators
|
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
||||||
|
|
||||||
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
||||||
877
node_modules/axios/MIGRATION_GUIDE.md
generated
vendored
877
node_modules/axios/MIGRATION_GUIDE.md
generated
vendored
@@ -1,877 +0,0 @@
|
|||||||
# Axios Migration Guide
|
|
||||||
|
|
||||||
> **Migrating from Axios 0.x to 1.x**
|
|
||||||
>
|
|
||||||
> This guide helps developers upgrade from Axios 0.x to 1.x by documenting breaking changes, providing migration strategies, and offering solutions to common upgrade challenges.
|
|
||||||
|
|
||||||
## Table of Contents
|
|
||||||
|
|
||||||
- [Overview](#overview)
|
|
||||||
- [Breaking Changes](#breaking-changes)
|
|
||||||
- [Error Handling Migration](#error-handling-migration)
|
|
||||||
- [API Changes](#api-changes)
|
|
||||||
- [Configuration Changes](#configuration-changes)
|
|
||||||
- [Migration Strategies](#migration-strategies)
|
|
||||||
- [Common Patterns](#common-patterns)
|
|
||||||
- [Troubleshooting](#troubleshooting)
|
|
||||||
- [Resources](#resources)
|
|
||||||
|
|
||||||
## Overview
|
|
||||||
|
|
||||||
Axios 1.x introduced several breaking changes to improve consistency, security, and developer experience. While these changes provide better error handling and more predictable behavior, they require code updates when migrating from 0.x versions.
|
|
||||||
|
|
||||||
### Key Changes Summary
|
|
||||||
|
|
||||||
| Area | 0.x Behavior | 1.x Behavior | Impact |
|
|
||||||
|------|--------------|--------------|--------|
|
|
||||||
| Error Handling | Selective throwing | Consistent throwing | High |
|
|
||||||
| JSON Parsing | Lenient | Strict | Medium |
|
|
||||||
| Browser Support | IE11+ | Modern browsers | Low-Medium |
|
|
||||||
| TypeScript | Partial | Full support | Low |
|
|
||||||
|
|
||||||
### Migration Complexity
|
|
||||||
|
|
||||||
- **Simple applications**: 1-2 hours
|
|
||||||
- **Medium applications**: 1-2 days
|
|
||||||
- **Large applications with complex error handling**: 3-5 days
|
|
||||||
|
|
||||||
## Breaking Changes
|
|
||||||
|
|
||||||
### 1. Error Handling Changes
|
|
||||||
|
|
||||||
**The most significant change in Axios 1.x is how errors are handled.**
|
|
||||||
|
|
||||||
#### 0.x Behavior
|
|
||||||
```javascript
|
|
||||||
// Axios 0.x - Some HTTP error codes didn't throw
|
|
||||||
axios.get('/api/data')
|
|
||||||
.then(response => {
|
|
||||||
// Response interceptor could handle all errors
|
|
||||||
console.log('Success:', response.data);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Response interceptor handled everything
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
error => {
|
|
||||||
handleError(error);
|
|
||||||
// Error was "handled" and didn't propagate
|
|
||||||
}
|
|
||||||
);
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 1.x Behavior
|
|
||||||
```javascript
|
|
||||||
// Axios 1.x - All HTTP errors throw consistently
|
|
||||||
axios.get('/api/data')
|
|
||||||
.then(response => {
|
|
||||||
console.log('Success:', response.data);
|
|
||||||
})
|
|
||||||
.catch(error => {
|
|
||||||
// Must handle errors at call site or they propagate
|
|
||||||
console.error('Request failed:', error);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Response interceptor must re-throw or return rejected promise
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
error => {
|
|
||||||
handleError(error);
|
|
||||||
// Must explicitly handle propagation
|
|
||||||
return Promise.reject(error); // or throw error;
|
|
||||||
}
|
|
||||||
);
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Impact
|
|
||||||
- **Response interceptors** can no longer "swallow" errors silently
|
|
||||||
- **Every API call** must handle errors explicitly or they become unhandled promise rejections
|
|
||||||
- **Centralized error handling** requires new patterns
|
|
||||||
|
|
||||||
### 2. JSON Parsing Changes
|
|
||||||
|
|
||||||
#### 0.x Behavior
|
|
||||||
```javascript
|
|
||||||
// Axios 0.x - Lenient JSON parsing
|
|
||||||
// Would attempt to parse even invalid JSON
|
|
||||||
response.data; // Might contain partial data or fallbacks
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 1.x Behavior
|
|
||||||
```javascript
|
|
||||||
// Axios 1.x - Strict JSON parsing
|
|
||||||
// Throws clear errors for invalid JSON
|
|
||||||
try {
|
|
||||||
const data = response.data;
|
|
||||||
} catch (error) {
|
|
||||||
// Handle JSON parsing errors explicitly
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
### 3. Request/Response Transform Changes
|
|
||||||
|
|
||||||
#### 0.x Behavior
|
|
||||||
```javascript
|
|
||||||
// Implicit transformations with some edge cases
|
|
||||||
transformRequest: [function (data) {
|
|
||||||
// Less predictable behavior
|
|
||||||
return data;
|
|
||||||
}]
|
|
||||||
```
|
|
||||||
|
|
||||||
#### 1.x Behavior
|
|
||||||
```javascript
|
|
||||||
// More consistent transformation pipeline
|
|
||||||
transformRequest: [function (data, headers) {
|
|
||||||
// Headers parameter always available
|
|
||||||
// More predictable behavior
|
|
||||||
return data;
|
|
||||||
}]
|
|
||||||
```
|
|
||||||
|
|
||||||
### 4. Browser Support Changes
|
|
||||||
|
|
||||||
- **0.x**: Supported IE11 and older browsers
|
|
||||||
- **1.x**: Requires modern browsers with Promise support
|
|
||||||
- **Polyfills**: May be needed for older browser support
|
|
||||||
|
|
||||||
## Error Handling Migration
|
|
||||||
|
|
||||||
The error handling changes are the most complex part of migrating to Axios 1.x. Here are proven strategies:
|
|
||||||
|
|
||||||
### Strategy 1: Centralized Error Handling with Error Boundary
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// Create a centralized error handler
|
|
||||||
class ApiErrorHandler {
|
|
||||||
constructor() {
|
|
||||||
this.setupInterceptors();
|
|
||||||
}
|
|
||||||
|
|
||||||
setupInterceptors() {
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
error => {
|
|
||||||
// Centralized error processing
|
|
||||||
this.processError(error);
|
|
||||||
|
|
||||||
// Return a resolved promise with error info for handled errors
|
|
||||||
if (this.isHandledError(error)) {
|
|
||||||
return Promise.resolve({
|
|
||||||
data: null,
|
|
||||||
error: this.normalizeError(error),
|
|
||||||
handled: true
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// Re-throw unhandled errors
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
processError(error) {
|
|
||||||
// Log errors
|
|
||||||
console.error('API Error:', error);
|
|
||||||
|
|
||||||
// Show user notifications
|
|
||||||
if (error.response?.status === 401) {
|
|
||||||
this.handleAuthError();
|
|
||||||
} else if (error.response?.status >= 500) {
|
|
||||||
this.showErrorNotification('Server error occurred');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
isHandledError(error) {
|
|
||||||
// Define which errors are "handled" centrally
|
|
||||||
const handledStatuses = [401, 403, 404, 422, 500, 502, 503];
|
|
||||||
return handledStatuses.includes(error.response?.status);
|
|
||||||
}
|
|
||||||
|
|
||||||
normalizeError(error) {
|
|
||||||
return {
|
|
||||||
status: error.response?.status,
|
|
||||||
message: error.response?.data?.message || error.message,
|
|
||||||
code: error.response?.data?.code || error.code
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
handleAuthError() {
|
|
||||||
// Redirect to login, clear tokens, etc.
|
|
||||||
localStorage.removeItem('token');
|
|
||||||
window.location.href = '/login';
|
|
||||||
}
|
|
||||||
|
|
||||||
showErrorNotification(message) {
|
|
||||||
// Show user-friendly error message
|
|
||||||
console.error(message); // Replace with your notification system
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize globally
|
|
||||||
const errorHandler = new ApiErrorHandler();
|
|
||||||
|
|
||||||
// Usage in components/services
|
|
||||||
async function fetchUserData(userId) {
|
|
||||||
try {
|
|
||||||
const response = await axios.get(`/api/users/${userId}`);
|
|
||||||
|
|
||||||
// Check if error was handled centrally
|
|
||||||
if (response.handled) {
|
|
||||||
return { data: null, error: response.error };
|
|
||||||
}
|
|
||||||
|
|
||||||
return { data: response.data, error: null };
|
|
||||||
} catch (error) {
|
|
||||||
// Unhandled errors still need local handling
|
|
||||||
return { data: null, error: { message: 'Unexpected error occurred' } };
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
### Strategy 2: Wrapper Function Pattern
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// Create a wrapper that provides 0.x-like behavior
|
|
||||||
function createApiWrapper() {
|
|
||||||
const api = axios.create();
|
|
||||||
|
|
||||||
// Add response interceptor for centralized handling
|
|
||||||
api.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
error => {
|
|
||||||
// Handle common errors centrally
|
|
||||||
if (error.response?.status === 401) {
|
|
||||||
// Handle auth errors
|
|
||||||
handleAuthError();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (error.response?.status >= 500) {
|
|
||||||
// Handle server errors
|
|
||||||
showServerErrorNotification();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Always reject to maintain error propagation
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
// Wrapper function that mimics 0.x behavior
|
|
||||||
function safeRequest(requestConfig, options = {}) {
|
|
||||||
return api(requestConfig)
|
|
||||||
.then(response => response)
|
|
||||||
.catch(error => {
|
|
||||||
if (options.suppressErrors) {
|
|
||||||
// Return error info instead of throwing
|
|
||||||
return {
|
|
||||||
data: null,
|
|
||||||
error: {
|
|
||||||
status: error.response?.status,
|
|
||||||
message: error.response?.data?.message || error.message
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
throw error;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return { safeRequest, axios: api };
|
|
||||||
}
|
|
||||||
|
|
||||||
// Usage
|
|
||||||
const { safeRequest } = createApiWrapper();
|
|
||||||
|
|
||||||
// For calls where you want centralized error handling
|
|
||||||
const result = await safeRequest(
|
|
||||||
{ method: 'get', url: '/api/data' },
|
|
||||||
{ suppressErrors: true }
|
|
||||||
);
|
|
||||||
|
|
||||||
if (result.error) {
|
|
||||||
// Handle error case
|
|
||||||
console.log('Request failed:', result.error.message);
|
|
||||||
} else {
|
|
||||||
// Handle success case
|
|
||||||
console.log('Data:', result.data);
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
### Strategy 3: Global Error Handler with Custom Events
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// Set up global error handling with events
|
|
||||||
class GlobalErrorHandler extends EventTarget {
|
|
||||||
constructor() {
|
|
||||||
super();
|
|
||||||
this.setupInterceptors();
|
|
||||||
}
|
|
||||||
|
|
||||||
setupInterceptors() {
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
error => {
|
|
||||||
// Emit custom event for global handling
|
|
||||||
this.dispatchEvent(new CustomEvent('apiError', {
|
|
||||||
detail: { error, timestamp: new Date() }
|
|
||||||
}));
|
|
||||||
|
|
||||||
// Always reject to maintain proper error flow
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const globalErrorHandler = new GlobalErrorHandler();
|
|
||||||
|
|
||||||
// Set up global listeners
|
|
||||||
globalErrorHandler.addEventListener('apiError', (event) => {
|
|
||||||
const { error } = event.detail;
|
|
||||||
|
|
||||||
// Centralized error logic
|
|
||||||
if (error.response?.status === 401) {
|
|
||||||
handleAuthError();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (error.response?.status >= 500) {
|
|
||||||
showErrorNotification('Server error occurred');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// Usage remains clean
|
|
||||||
async function apiCall() {
|
|
||||||
try {
|
|
||||||
const response = await axios.get('/api/data');
|
|
||||||
return response.data;
|
|
||||||
} catch (error) {
|
|
||||||
// Error was already handled globally
|
|
||||||
// Just handle component-specific logic
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## API Changes
|
|
||||||
|
|
||||||
### Request Configuration
|
|
||||||
|
|
||||||
#### 0.x to 1.x Changes
|
|
||||||
```javascript
|
|
||||||
// 0.x - Some properties had different defaults
|
|
||||||
const config = {
|
|
||||||
timeout: 0, // No timeout by default
|
|
||||||
maxContentLength: -1, // No limit
|
|
||||||
};
|
|
||||||
|
|
||||||
// 1.x - More secure defaults
|
|
||||||
const config = {
|
|
||||||
timeout: 0, // Still no timeout, but easier to configure
|
|
||||||
maxContentLength: 2000, // Default limit for security
|
|
||||||
maxBodyLength: 2000, // New property
|
|
||||||
};
|
|
||||||
```
|
|
||||||
|
|
||||||
### Response Object
|
|
||||||
|
|
||||||
The response object structure remains largely the same, but error responses are more consistent:
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// Both 0.x and 1.x
|
|
||||||
response = {
|
|
||||||
data: {}, // Response body
|
|
||||||
status: 200, // HTTP status
|
|
||||||
statusText: 'OK', // HTTP status message
|
|
||||||
headers: {}, // Response headers
|
|
||||||
config: {}, // Request config
|
|
||||||
request: {} // Request object
|
|
||||||
};
|
|
||||||
|
|
||||||
// Error responses are more consistent in 1.x
|
|
||||||
error.response = {
|
|
||||||
data: {}, // Error response body
|
|
||||||
status: 404, // HTTP error status
|
|
||||||
statusText: 'Not Found',
|
|
||||||
headers: {},
|
|
||||||
config: {},
|
|
||||||
request: {}
|
|
||||||
};
|
|
||||||
```
|
|
||||||
|
|
||||||
## Configuration Changes
|
|
||||||
|
|
||||||
### Default Configuration Updates
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// 0.x defaults
|
|
||||||
axios.defaults.timeout = 0; // No timeout
|
|
||||||
axios.defaults.maxContentLength = -1; // No limit
|
|
||||||
|
|
||||||
// 1.x defaults (more secure)
|
|
||||||
axios.defaults.timeout = 0; // Still no timeout
|
|
||||||
axios.defaults.maxContentLength = 2000; // 2MB limit
|
|
||||||
axios.defaults.maxBodyLength = 2000; // 2MB limit
|
|
||||||
```
|
|
||||||
|
|
||||||
### Instance Configuration
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// 0.x - Instance creation
|
|
||||||
const api = axios.create({
|
|
||||||
baseURL: 'https://api.example.com',
|
|
||||||
timeout: 1000,
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1.x - Same API, but more options available
|
|
||||||
const api = axios.create({
|
|
||||||
baseURL: 'https://api.example.com',
|
|
||||||
timeout: 1000,
|
|
||||||
maxBodyLength: Infinity, // Override default if needed
|
|
||||||
maxContentLength: Infinity,
|
|
||||||
});
|
|
||||||
```
|
|
||||||
|
|
||||||
## Migration Strategies
|
|
||||||
|
|
||||||
### Step-by-Step Migration Process
|
|
||||||
|
|
||||||
#### Phase 1: Preparation
|
|
||||||
1. **Audit Current Error Handling**
|
|
||||||
```bash
|
|
||||||
# Find all axios usage
|
|
||||||
grep -r "axios\." src/
|
|
||||||
grep -r "\.catch" src/
|
|
||||||
grep -r "interceptors" src/
|
|
||||||
```
|
|
||||||
|
|
||||||
2. **Identify Patterns**
|
|
||||||
- Response interceptors that handle errors
|
|
||||||
- Components that rely on centralized error handling
|
|
||||||
- Authentication and retry logic
|
|
||||||
|
|
||||||
3. **Create Test Cases**
|
|
||||||
```javascript
|
|
||||||
// Test current error handling behavior
|
|
||||||
describe('Error Handling Migration', () => {
|
|
||||||
it('should handle 401 errors consistently', async () => {
|
|
||||||
// Test authentication error flows
|
|
||||||
});
|
|
||||||
|
|
||||||
it('should handle 500 errors with user feedback', async () => {
|
|
||||||
// Test server error handling
|
|
||||||
});
|
|
||||||
});
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Phase 2: Implementation
|
|
||||||
1. **Update Dependencies**
|
|
||||||
```bash
|
|
||||||
npm update axios
|
|
||||||
```
|
|
||||||
|
|
||||||
2. **Implement New Error Handling**
|
|
||||||
- Choose one of the strategies above
|
|
||||||
- Update response interceptors
|
|
||||||
- Add error handling to API calls
|
|
||||||
|
|
||||||
3. **Update Authentication Logic**
|
|
||||||
```javascript
|
|
||||||
// 0.x pattern
|
|
||||||
axios.interceptors.response.use(null, error => {
|
|
||||||
if (error.response?.status === 401) {
|
|
||||||
logout();
|
|
||||||
// Error was "handled"
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
// 1.x pattern
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
error => {
|
|
||||||
if (error.response?.status === 401) {
|
|
||||||
logout();
|
|
||||||
}
|
|
||||||
return Promise.reject(error); // Always propagate
|
|
||||||
}
|
|
||||||
);
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Phase 3: Testing and Validation
|
|
||||||
1. **Test Error Scenarios**
|
|
||||||
- Network failures
|
|
||||||
- HTTP error codes (401, 403, 404, 500, etc.)
|
|
||||||
- Timeout errors
|
|
||||||
- JSON parsing errors
|
|
||||||
|
|
||||||
2. **Validate User Experience**
|
|
||||||
- Error messages are shown appropriately
|
|
||||||
- Authentication redirects work
|
|
||||||
- Loading states are handled correctly
|
|
||||||
|
|
||||||
### Gradual Migration Approach
|
|
||||||
|
|
||||||
For large applications, consider gradual migration:
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// Create a compatibility layer
|
|
||||||
const axiosCompat = {
|
|
||||||
// Use new axios instance for new code
|
|
||||||
v1: axios.create({
|
|
||||||
// 1.x configuration
|
|
||||||
}),
|
|
||||||
|
|
||||||
// Wrapper for legacy code
|
|
||||||
legacy: createLegacyWrapper(axios.create({
|
|
||||||
// Configuration that mimics 0.x behavior
|
|
||||||
}))
|
|
||||||
};
|
|
||||||
|
|
||||||
function createLegacyWrapper(axiosInstance) {
|
|
||||||
// Add interceptors that provide 0.x-like behavior
|
|
||||||
axiosInstance.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
error => {
|
|
||||||
// Handle errors in 0.x style for legacy code
|
|
||||||
handleLegacyError(error);
|
|
||||||
// Don't propagate certain errors
|
|
||||||
if (shouldSuppressError(error)) {
|
|
||||||
return Promise.resolve({ data: null, error: true });
|
|
||||||
}
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
return axiosInstance;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Common Patterns
|
|
||||||
|
|
||||||
### Authentication Interceptors
|
|
||||||
|
|
||||||
#### Updated Authentication Pattern
|
|
||||||
```javascript
|
|
||||||
// Token refresh interceptor for 1.x
|
|
||||||
let isRefreshing = false;
|
|
||||||
let refreshSubscribers = [];
|
|
||||||
|
|
||||||
function subscribeTokenRefresh(cb) {
|
|
||||||
refreshSubscribers.push(cb);
|
|
||||||
}
|
|
||||||
|
|
||||||
function onTokenRefreshed(token) {
|
|
||||||
refreshSubscribers.forEach(cb => cb(token));
|
|
||||||
refreshSubscribers = [];
|
|
||||||
}
|
|
||||||
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
async error => {
|
|
||||||
const originalRequest = error.config;
|
|
||||||
|
|
||||||
if (error.response?.status === 401 && !originalRequest._retry) {
|
|
||||||
if (isRefreshing) {
|
|
||||||
// Wait for token refresh
|
|
||||||
return new Promise(resolve => {
|
|
||||||
subscribeTokenRefresh(token => {
|
|
||||||
originalRequest.headers.Authorization = `Bearer ${token}`;
|
|
||||||
resolve(axios(originalRequest));
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
originalRequest._retry = true;
|
|
||||||
isRefreshing = true;
|
|
||||||
|
|
||||||
try {
|
|
||||||
const newToken = await refreshToken();
|
|
||||||
onTokenRefreshed(newToken);
|
|
||||||
isRefreshing = false;
|
|
||||||
|
|
||||||
originalRequest.headers.Authorization = `Bearer ${newToken}`;
|
|
||||||
return axios(originalRequest);
|
|
||||||
} catch (refreshError) {
|
|
||||||
isRefreshing = false;
|
|
||||||
logout();
|
|
||||||
return Promise.reject(refreshError);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
```
|
|
||||||
|
|
||||||
### Retry Logic
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// Retry interceptor for 1.x
|
|
||||||
function createRetryInterceptor(maxRetries = 3, retryDelay = 1000) {
|
|
||||||
return axios.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
async error => {
|
|
||||||
const config = error.config;
|
|
||||||
|
|
||||||
if (!config || !config.retry) {
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
|
|
||||||
config.__retryCount = config.__retryCount || 0;
|
|
||||||
|
|
||||||
if (config.__retryCount >= maxRetries) {
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
|
|
||||||
config.__retryCount += 1;
|
|
||||||
|
|
||||||
// Exponential backoff
|
|
||||||
const delay = retryDelay * Math.pow(2, config.__retryCount - 1);
|
|
||||||
await new Promise(resolve => setTimeout(resolve, delay));
|
|
||||||
|
|
||||||
return axios(config);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Usage
|
|
||||||
const api = axios.create();
|
|
||||||
createRetryInterceptor(3, 1000);
|
|
||||||
|
|
||||||
// Make request with retry
|
|
||||||
api.get('/api/data', { retry: true });
|
|
||||||
```
|
|
||||||
|
|
||||||
### Loading State Management
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
// Loading interceptor for 1.x
|
|
||||||
class LoadingManager {
|
|
||||||
constructor() {
|
|
||||||
this.requests = new Set();
|
|
||||||
this.setupInterceptors();
|
|
||||||
}
|
|
||||||
|
|
||||||
setupInterceptors() {
|
|
||||||
axios.interceptors.request.use(config => {
|
|
||||||
this.requests.add(config);
|
|
||||||
this.updateLoadingState();
|
|
||||||
return config;
|
|
||||||
});
|
|
||||||
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => {
|
|
||||||
this.requests.delete(response.config);
|
|
||||||
this.updateLoadingState();
|
|
||||||
return response;
|
|
||||||
},
|
|
||||||
error => {
|
|
||||||
this.requests.delete(error.config);
|
|
||||||
this.updateLoadingState();
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
updateLoadingState() {
|
|
||||||
const isLoading = this.requests.size > 0;
|
|
||||||
// Update your loading UI
|
|
||||||
document.body.classList.toggle('loading', isLoading);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const loadingManager = new LoadingManager();
|
|
||||||
```
|
|
||||||
|
|
||||||
## Troubleshooting
|
|
||||||
|
|
||||||
### Common Migration Issues
|
|
||||||
|
|
||||||
#### Issue 1: Unhandled Promise Rejections
|
|
||||||
|
|
||||||
**Problem:**
|
|
||||||
```javascript
|
|
||||||
// This pattern worked in 0.x but causes unhandled rejections in 1.x
|
|
||||||
axios.get('/api/data'); // No .catch() handler
|
|
||||||
```
|
|
||||||
|
|
||||||
**Solution:**
|
|
||||||
```javascript
|
|
||||||
// Always handle promises
|
|
||||||
axios.get('/api/data')
|
|
||||||
.catch(error => {
|
|
||||||
// Handle error appropriately
|
|
||||||
console.error('Request failed:', error.message);
|
|
||||||
});
|
|
||||||
|
|
||||||
// Or use async/await with try/catch
|
|
||||||
async function fetchData() {
|
|
||||||
try {
|
|
||||||
const response = await axios.get('/api/data');
|
|
||||||
return response.data;
|
|
||||||
} catch (error) {
|
|
||||||
console.error('Request failed:', error.message);
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Issue 2: Response Interceptors Not "Handling" Errors
|
|
||||||
|
|
||||||
**Problem:**
|
|
||||||
```javascript
|
|
||||||
// 0.x style - interceptor "handled" errors
|
|
||||||
axios.interceptors.response.use(null, error => {
|
|
||||||
showErrorMessage(error.message);
|
|
||||||
// Error was considered "handled"
|
|
||||||
});
|
|
||||||
```
|
|
||||||
|
|
||||||
**Solution:**
|
|
||||||
```javascript
|
|
||||||
// 1.x style - explicitly control error propagation
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => response,
|
|
||||||
error => {
|
|
||||||
showErrorMessage(error.message);
|
|
||||||
|
|
||||||
// Choose whether to propagate the error
|
|
||||||
if (shouldPropagateError(error)) {
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Return success-like response for "handled" errors
|
|
||||||
return Promise.resolve({
|
|
||||||
data: null,
|
|
||||||
handled: true,
|
|
||||||
error: normalizeError(error)
|
|
||||||
});
|
|
||||||
}
|
|
||||||
);
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Issue 3: JSON Parsing Errors
|
|
||||||
|
|
||||||
**Problem:**
|
|
||||||
```javascript
|
|
||||||
// 1.x is stricter about JSON parsing
|
|
||||||
// This might throw where 0.x was lenient
|
|
||||||
const data = response.data;
|
|
||||||
```
|
|
||||||
|
|
||||||
**Solution:**
|
|
||||||
```javascript
|
|
||||||
// Add response transformer for better error handling
|
|
||||||
axios.defaults.transformResponse = [
|
|
||||||
function (data) {
|
|
||||||
if (typeof data === 'string') {
|
|
||||||
try {
|
|
||||||
return JSON.parse(data);
|
|
||||||
} catch (e) {
|
|
||||||
// Handle JSON parsing errors gracefully
|
|
||||||
console.warn('Invalid JSON response:', data);
|
|
||||||
return { error: 'Invalid JSON', rawData: data };
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
];
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Issue 4: TypeScript Errors After Upgrade
|
|
||||||
|
|
||||||
**Problem:**
|
|
||||||
```typescript
|
|
||||||
// TypeScript errors after upgrade
|
|
||||||
const response = await axios.get('/api/data');
|
|
||||||
// Property 'someProperty' does not exist on type 'any'
|
|
||||||
```
|
|
||||||
|
|
||||||
**Solution:**
|
|
||||||
```typescript
|
|
||||||
// Define proper interfaces
|
|
||||||
interface ApiResponse {
|
|
||||||
data: any;
|
|
||||||
message: string;
|
|
||||||
success: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
const response = await axios.get<ApiResponse>('/api/data');
|
|
||||||
// Now properly typed
|
|
||||||
console.log(response.data.data);
|
|
||||||
```
|
|
||||||
|
|
||||||
### Debug Migration Issues
|
|
||||||
|
|
||||||
#### Enable Debug Logging
|
|
||||||
```javascript
|
|
||||||
// Add request/response logging
|
|
||||||
axios.interceptors.request.use(config => {
|
|
||||||
console.log('Request:', config);
|
|
||||||
return config;
|
|
||||||
});
|
|
||||||
|
|
||||||
axios.interceptors.response.use(
|
|
||||||
response => {
|
|
||||||
console.log('Response:', response);
|
|
||||||
return response;
|
|
||||||
},
|
|
||||||
error => {
|
|
||||||
console.log('Error:', error);
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
```
|
|
||||||
|
|
||||||
#### Compare Behavior
|
|
||||||
```javascript
|
|
||||||
// Create side-by-side comparison during migration
|
|
||||||
const axios0x = require('axios-0x'); // Keep old version for testing
|
|
||||||
const axios1x = require('axios');
|
|
||||||
|
|
||||||
async function compareRequests(config) {
|
|
||||||
try {
|
|
||||||
const [result0x, result1x] = await Promise.allSettled([
|
|
||||||
axios0x(config),
|
|
||||||
axios1x(config)
|
|
||||||
]);
|
|
||||||
|
|
||||||
console.log('0.x result:', result0x);
|
|
||||||
console.log('1.x result:', result1x);
|
|
||||||
} catch (error) {
|
|
||||||
console.log('Comparison error:', error);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
## Resources
|
|
||||||
|
|
||||||
### Official Documentation
|
|
||||||
- [Axios 1.x Documentation](https://axios-http.com/)
|
|
||||||
- [Axios GitHub Repository](https://github.com/axios/axios)
|
|
||||||
- [Axios Changelog](https://github.com/axios/axios/blob/main/CHANGELOG.md)
|
|
||||||
|
|
||||||
### Migration Tools
|
|
||||||
- [Axios Migration Codemod](https://github.com/axios/axios-migration-codemod) *(if available)*
|
|
||||||
- [ESLint Rules for Axios 1.x](https://github.com/axios/eslint-plugin-axios) *(if available)*
|
|
||||||
|
|
||||||
### Community Resources
|
|
||||||
- [Stack Overflow - Axios Migration Questions](https://stackoverflow.com/questions/tagged/axios+migration)
|
|
||||||
- [GitHub Discussions](https://github.com/axios/axios/discussions)
|
|
||||||
- [Axios Discord Community](https://discord.gg/axios) *(if available)*
|
|
||||||
|
|
||||||
### Related Issues
|
|
||||||
- [Error Handling Changes Discussion](https://github.com/axios/axios/issues/7208)
|
|
||||||
- [Migration Guide Request](https://github.com/axios/axios/issues/xxxx) *(link to related issues)*
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
## Need Help?
|
|
||||||
|
|
||||||
If you encounter issues during migration that aren't covered in this guide:
|
|
||||||
|
|
||||||
1. **Search existing issues** in the [Axios GitHub repository](https://github.com/axios/axios/issues)
|
|
||||||
2. **Ask questions** in [GitHub Discussions](https://github.com/axios/axios/discussions)
|
|
||||||
3. **Contribute improvements** to this migration guide
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
*This migration guide is maintained by the community. If you find errors or have suggestions, please [open an issue](https://github.com/axios/axios/issues) or submit a pull request.*
|
|
||||||
2055
node_modules/axios/README.md
generated
vendored
2055
node_modules/axios/README.md
generated
vendored
File diff suppressed because it is too large
Load Diff
4546
node_modules/axios/dist/axios.js
generated
vendored
4546
node_modules/axios/dist/axios.js
generated
vendored
File diff suppressed because it is too large
Load Diff
1
node_modules/axios/dist/axios.js.map
generated
vendored
1
node_modules/axios/dist/axios.js.map
generated
vendored
File diff suppressed because one or more lines are too long
5
node_modules/axios/dist/axios.min.js
generated
vendored
5
node_modules/axios/dist/axios.min.js
generated
vendored
File diff suppressed because one or more lines are too long
1
node_modules/axios/dist/axios.min.js.map
generated
vendored
1
node_modules/axios/dist/axios.min.js.map
generated
vendored
File diff suppressed because one or more lines are too long
4338
node_modules/axios/dist/browser/axios.cjs
generated
vendored
4338
node_modules/axios/dist/browser/axios.cjs
generated
vendored
File diff suppressed because it is too large
Load Diff
1
node_modules/axios/dist/browser/axios.cjs.map
generated
vendored
1
node_modules/axios/dist/browser/axios.cjs.map
generated
vendored
File diff suppressed because one or more lines are too long
4358
node_modules/axios/dist/esm/axios.js
generated
vendored
4358
node_modules/axios/dist/esm/axios.js
generated
vendored
File diff suppressed because it is too large
Load Diff
1
node_modules/axios/dist/esm/axios.js.map
generated
vendored
1
node_modules/axios/dist/esm/axios.js.map
generated
vendored
File diff suppressed because one or more lines are too long
3
node_modules/axios/dist/esm/axios.min.js
generated
vendored
3
node_modules/axios/dist/esm/axios.min.js
generated
vendored
File diff suppressed because one or more lines are too long
1
node_modules/axios/dist/esm/axios.min.js.map
generated
vendored
1
node_modules/axios/dist/esm/axios.min.js.map
generated
vendored
File diff suppressed because one or more lines are too long
4989
node_modules/axios/dist/node/axios.cjs
generated
vendored
4989
node_modules/axios/dist/node/axios.cjs
generated
vendored
File diff suppressed because it is too large
Load Diff
1
node_modules/axios/dist/node/axios.cjs.map
generated
vendored
1
node_modules/axios/dist/node/axios.cjs.map
generated
vendored
File diff suppressed because one or more lines are too long
703
node_modules/axios/index.d.cts
generated
vendored
703
node_modules/axios/index.d.cts
generated
vendored
@@ -1,703 +0,0 @@
|
|||||||
interface RawAxiosHeaders {
|
|
||||||
[key: string]: axios.AxiosHeaderValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
type MethodsHeaders = Partial<
|
|
||||||
{
|
|
||||||
[Key in axios.Method as Lowercase<Key>]: AxiosHeaders;
|
|
||||||
} & { common: AxiosHeaders }
|
|
||||||
>;
|
|
||||||
|
|
||||||
type AxiosHeaderMatcher =
|
|
||||||
| string
|
|
||||||
| RegExp
|
|
||||||
| ((this: AxiosHeaders, value: string, name: string) => boolean);
|
|
||||||
|
|
||||||
type AxiosHeaderParser = (this: AxiosHeaders, value: axios.AxiosHeaderValue, header: string) => any;
|
|
||||||
|
|
||||||
type CommonRequestHeadersList =
|
|
||||||
| 'Accept'
|
|
||||||
| 'Content-Length'
|
|
||||||
| 'User-Agent'
|
|
||||||
| 'Content-Encoding'
|
|
||||||
| 'Authorization'
|
|
||||||
| 'Location';
|
|
||||||
|
|
||||||
type ContentType =
|
|
||||||
| axios.AxiosHeaderValue
|
|
||||||
| 'text/html'
|
|
||||||
| 'text/plain'
|
|
||||||
| 'multipart/form-data'
|
|
||||||
| 'application/json'
|
|
||||||
| 'application/x-www-form-urlencoded'
|
|
||||||
| 'application/octet-stream';
|
|
||||||
|
|
||||||
type CommonResponseHeadersList =
|
|
||||||
| 'Server'
|
|
||||||
| 'Content-Type'
|
|
||||||
| 'Content-Length'
|
|
||||||
| 'Cache-Control'
|
|
||||||
| 'Content-Encoding';
|
|
||||||
|
|
||||||
type CommonResponseHeaderKey = CommonResponseHeadersList | Lowercase<CommonResponseHeadersList>;
|
|
||||||
|
|
||||||
type BrowserProgressEvent = any;
|
|
||||||
|
|
||||||
declare class AxiosHeaders {
|
|
||||||
constructor(headers?: RawAxiosHeaders | AxiosHeaders | string);
|
|
||||||
|
|
||||||
[key: string]: any;
|
|
||||||
|
|
||||||
set(
|
|
||||||
headerName?: string,
|
|
||||||
value?: axios.AxiosHeaderValue,
|
|
||||||
rewrite?: boolean | AxiosHeaderMatcher
|
|
||||||
): AxiosHeaders;
|
|
||||||
set(headers?: RawAxiosHeaders | AxiosHeaders | string, rewrite?: boolean): AxiosHeaders;
|
|
||||||
|
|
||||||
get(headerName: string, parser: RegExp): RegExpExecArray | null;
|
|
||||||
get(headerName: string, matcher?: true | AxiosHeaderParser): axios.AxiosHeaderValue;
|
|
||||||
|
|
||||||
has(header: string, matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
delete(header: string | string[], matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
clear(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
normalize(format: boolean): AxiosHeaders;
|
|
||||||
|
|
||||||
concat(
|
|
||||||
...targets: Array<AxiosHeaders | RawAxiosHeaders | string | undefined | null>
|
|
||||||
): AxiosHeaders;
|
|
||||||
|
|
||||||
toJSON(asStrings?: boolean): RawAxiosHeaders;
|
|
||||||
|
|
||||||
static from(thing?: AxiosHeaders | RawAxiosHeaders | string): AxiosHeaders;
|
|
||||||
|
|
||||||
static accessor(header: string | string[]): AxiosHeaders;
|
|
||||||
|
|
||||||
static concat(
|
|
||||||
...targets: Array<AxiosHeaders | RawAxiosHeaders | string | undefined | null>
|
|
||||||
): AxiosHeaders;
|
|
||||||
|
|
||||||
setContentType(value: ContentType, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getContentType(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getContentType(matcher?: AxiosHeaderMatcher): axios.AxiosHeaderValue;
|
|
||||||
hasContentType(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setContentLength(
|
|
||||||
value: axios.AxiosHeaderValue,
|
|
||||||
rewrite?: boolean | AxiosHeaderMatcher
|
|
||||||
): AxiosHeaders;
|
|
||||||
getContentLength(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getContentLength(matcher?: AxiosHeaderMatcher): axios.AxiosHeaderValue;
|
|
||||||
hasContentLength(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setAccept(value: axios.AxiosHeaderValue, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getAccept(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getAccept(matcher?: AxiosHeaderMatcher): axios.AxiosHeaderValue;
|
|
||||||
hasAccept(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setUserAgent(value: axios.AxiosHeaderValue, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getUserAgent(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getUserAgent(matcher?: AxiosHeaderMatcher): axios.AxiosHeaderValue;
|
|
||||||
hasUserAgent(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setContentEncoding(
|
|
||||||
value: axios.AxiosHeaderValue,
|
|
||||||
rewrite?: boolean | AxiosHeaderMatcher
|
|
||||||
): AxiosHeaders;
|
|
||||||
getContentEncoding(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getContentEncoding(matcher?: AxiosHeaderMatcher): axios.AxiosHeaderValue;
|
|
||||||
hasContentEncoding(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setAuthorization(
|
|
||||||
value: axios.AxiosHeaderValue,
|
|
||||||
rewrite?: boolean | AxiosHeaderMatcher
|
|
||||||
): AxiosHeaders;
|
|
||||||
getAuthorization(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getAuthorization(matcher?: AxiosHeaderMatcher): axios.AxiosHeaderValue;
|
|
||||||
hasAuthorization(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
getSetCookie(): string[];
|
|
||||||
|
|
||||||
[Symbol.iterator](): IterableIterator<[string, axios.AxiosHeaderValue]>;
|
|
||||||
}
|
|
||||||
|
|
||||||
declare class AxiosError<T = unknown, D = any> extends Error {
|
|
||||||
constructor(
|
|
||||||
message?: string,
|
|
||||||
code?: string,
|
|
||||||
config?: axios.InternalAxiosRequestConfig<D>,
|
|
||||||
request?: any,
|
|
||||||
response?: axios.AxiosResponse<T, D>
|
|
||||||
);
|
|
||||||
|
|
||||||
config?: axios.InternalAxiosRequestConfig<D>;
|
|
||||||
code?: string;
|
|
||||||
request?: any;
|
|
||||||
response?: axios.AxiosResponse<T, D>;
|
|
||||||
isAxiosError: boolean;
|
|
||||||
status?: number;
|
|
||||||
toJSON: () => object;
|
|
||||||
cause?: Error;
|
|
||||||
event?: BrowserProgressEvent;
|
|
||||||
static from<T = unknown, D = any>(
|
|
||||||
error: Error | unknown,
|
|
||||||
code?: string,
|
|
||||||
config?: axios.InternalAxiosRequestConfig<D>,
|
|
||||||
request?: any,
|
|
||||||
response?: axios.AxiosResponse<T, D>,
|
|
||||||
customProps?: object
|
|
||||||
): AxiosError<T, D>;
|
|
||||||
static readonly ERR_FR_TOO_MANY_REDIRECTS = 'ERR_FR_TOO_MANY_REDIRECTS';
|
|
||||||
static readonly ERR_BAD_OPTION_VALUE = 'ERR_BAD_OPTION_VALUE';
|
|
||||||
static readonly ERR_BAD_OPTION = 'ERR_BAD_OPTION';
|
|
||||||
static readonly ERR_NETWORK = 'ERR_NETWORK';
|
|
||||||
static readonly ERR_DEPRECATED = 'ERR_DEPRECATED';
|
|
||||||
static readonly ERR_BAD_RESPONSE = 'ERR_BAD_RESPONSE';
|
|
||||||
static readonly ERR_BAD_REQUEST = 'ERR_BAD_REQUEST';
|
|
||||||
static readonly ERR_NOT_SUPPORT = 'ERR_NOT_SUPPORT';
|
|
||||||
static readonly ERR_INVALID_URL = 'ERR_INVALID_URL';
|
|
||||||
static readonly ERR_CANCELED = 'ERR_CANCELED';
|
|
||||||
static readonly ERR_FORM_DATA_DEPTH_EXCEEDED = 'ERR_FORM_DATA_DEPTH_EXCEEDED';
|
|
||||||
static readonly ECONNABORTED = 'ECONNABORTED';
|
|
||||||
static readonly ETIMEDOUT = 'ETIMEDOUT';
|
|
||||||
}
|
|
||||||
|
|
||||||
declare class CanceledError<T> extends AxiosError<T> {}
|
|
||||||
|
|
||||||
declare class Axios {
|
|
||||||
constructor(config?: axios.AxiosRequestConfig);
|
|
||||||
defaults: axios.AxiosDefaults;
|
|
||||||
interceptors: {
|
|
||||||
request: axios.AxiosInterceptorManager<axios.InternalAxiosRequestConfig>;
|
|
||||||
response: axios.AxiosInterceptorManager<axios.AxiosResponse>;
|
|
||||||
};
|
|
||||||
getUri(config?: axios.AxiosRequestConfig): string;
|
|
||||||
request<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
config: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
get<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
delete<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
head<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
options<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
post<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
put<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
patch<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
postForm<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
putForm<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
patchForm<T = any, R = axios.AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: axios.AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
}
|
|
||||||
|
|
||||||
declare enum HttpStatusCode {
|
|
||||||
Continue = 100,
|
|
||||||
SwitchingProtocols = 101,
|
|
||||||
Processing = 102,
|
|
||||||
EarlyHints = 103,
|
|
||||||
Ok = 200,
|
|
||||||
Created = 201,
|
|
||||||
Accepted = 202,
|
|
||||||
NonAuthoritativeInformation = 203,
|
|
||||||
NoContent = 204,
|
|
||||||
ResetContent = 205,
|
|
||||||
PartialContent = 206,
|
|
||||||
MultiStatus = 207,
|
|
||||||
AlreadyReported = 208,
|
|
||||||
ImUsed = 226,
|
|
||||||
MultipleChoices = 300,
|
|
||||||
MovedPermanently = 301,
|
|
||||||
Found = 302,
|
|
||||||
SeeOther = 303,
|
|
||||||
NotModified = 304,
|
|
||||||
UseProxy = 305,
|
|
||||||
Unused = 306,
|
|
||||||
TemporaryRedirect = 307,
|
|
||||||
PermanentRedirect = 308,
|
|
||||||
BadRequest = 400,
|
|
||||||
Unauthorized = 401,
|
|
||||||
PaymentRequired = 402,
|
|
||||||
Forbidden = 403,
|
|
||||||
NotFound = 404,
|
|
||||||
MethodNotAllowed = 405,
|
|
||||||
NotAcceptable = 406,
|
|
||||||
ProxyAuthenticationRequired = 407,
|
|
||||||
RequestTimeout = 408,
|
|
||||||
Conflict = 409,
|
|
||||||
Gone = 410,
|
|
||||||
LengthRequired = 411,
|
|
||||||
PreconditionFailed = 412,
|
|
||||||
PayloadTooLarge = 413,
|
|
||||||
UriTooLong = 414,
|
|
||||||
UnsupportedMediaType = 415,
|
|
||||||
RangeNotSatisfiable = 416,
|
|
||||||
ExpectationFailed = 417,
|
|
||||||
ImATeapot = 418,
|
|
||||||
MisdirectedRequest = 421,
|
|
||||||
UnprocessableEntity = 422,
|
|
||||||
Locked = 423,
|
|
||||||
FailedDependency = 424,
|
|
||||||
TooEarly = 425,
|
|
||||||
UpgradeRequired = 426,
|
|
||||||
PreconditionRequired = 428,
|
|
||||||
TooManyRequests = 429,
|
|
||||||
RequestHeaderFieldsTooLarge = 431,
|
|
||||||
UnavailableForLegalReasons = 451,
|
|
||||||
InternalServerError = 500,
|
|
||||||
NotImplemented = 501,
|
|
||||||
BadGateway = 502,
|
|
||||||
ServiceUnavailable = 503,
|
|
||||||
GatewayTimeout = 504,
|
|
||||||
HttpVersionNotSupported = 505,
|
|
||||||
VariantAlsoNegotiates = 506,
|
|
||||||
InsufficientStorage = 507,
|
|
||||||
LoopDetected = 508,
|
|
||||||
NotExtended = 510,
|
|
||||||
NetworkAuthenticationRequired = 511,
|
|
||||||
}
|
|
||||||
|
|
||||||
type InternalAxiosError<T = unknown, D = any> = AxiosError<T, D>;
|
|
||||||
|
|
||||||
declare namespace axios {
|
|
||||||
type AxiosError<T = unknown, D = any> = InternalAxiosError<T, D>;
|
|
||||||
|
|
||||||
type RawAxiosRequestHeaders = Partial<
|
|
||||||
RawAxiosHeaders & {
|
|
||||||
[Key in CommonRequestHeadersList]: AxiosHeaderValue;
|
|
||||||
} & {
|
|
||||||
'Content-Type': ContentType;
|
|
||||||
}
|
|
||||||
>;
|
|
||||||
|
|
||||||
type AxiosRequestHeaders = RawAxiosRequestHeaders & AxiosHeaders;
|
|
||||||
|
|
||||||
type AxiosHeaderValue = AxiosHeaders | string | string[] | number | boolean | null;
|
|
||||||
|
|
||||||
type RawCommonResponseHeaders = {
|
|
||||||
[Key in CommonResponseHeaderKey]: AxiosHeaderValue;
|
|
||||||
} & {
|
|
||||||
'set-cookie': string[];
|
|
||||||
};
|
|
||||||
|
|
||||||
type RawAxiosResponseHeaders = Partial<RawAxiosHeaders & RawCommonResponseHeaders>;
|
|
||||||
|
|
||||||
type AxiosResponseHeaders = RawAxiosResponseHeaders & AxiosHeaders;
|
|
||||||
|
|
||||||
interface AxiosRequestTransformer {
|
|
||||||
(this: InternalAxiosRequestConfig, data: any, headers: AxiosRequestHeaders): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosResponseTransformer {
|
|
||||||
(
|
|
||||||
this: InternalAxiosRequestConfig,
|
|
||||||
data: any,
|
|
||||||
headers: AxiosResponseHeaders,
|
|
||||||
status?: number
|
|
||||||
): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosAdapter {
|
|
||||||
(config: InternalAxiosRequestConfig): AxiosPromise;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosBasicCredentials {
|
|
||||||
username: string;
|
|
||||||
password: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosProxyConfig {
|
|
||||||
host: string;
|
|
||||||
port: number;
|
|
||||||
auth?: AxiosBasicCredentials;
|
|
||||||
protocol?: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
type UppercaseMethod =
|
|
||||||
| 'GET'
|
|
||||||
| 'DELETE'
|
|
||||||
| 'HEAD'
|
|
||||||
| 'OPTIONS'
|
|
||||||
| 'POST'
|
|
||||||
| 'PUT'
|
|
||||||
| 'PATCH'
|
|
||||||
| 'PURGE'
|
|
||||||
| 'LINK'
|
|
||||||
| 'UNLINK';
|
|
||||||
|
|
||||||
type Method = (UppercaseMethod | Lowercase<UppercaseMethod>) & {};
|
|
||||||
|
|
||||||
type ResponseType = 'arraybuffer' | 'blob' | 'document' | 'json' | 'text' | 'stream' | 'formdata';
|
|
||||||
|
|
||||||
type UppercaseResponseEncoding =
|
|
||||||
| 'ASCII'
|
|
||||||
| 'ANSI'
|
|
||||||
| 'BINARY'
|
|
||||||
| 'BASE64'
|
|
||||||
| 'BASE64URL'
|
|
||||||
| 'HEX'
|
|
||||||
| 'LATIN1'
|
|
||||||
| 'UCS-2'
|
|
||||||
| 'UCS2'
|
|
||||||
| 'UTF-8'
|
|
||||||
| 'UTF8'
|
|
||||||
| 'UTF16LE';
|
|
||||||
|
|
||||||
type responseEncoding = (UppercaseResponseEncoding | Lowercase<UppercaseResponseEncoding>) & {};
|
|
||||||
|
|
||||||
interface TransitionalOptions {
|
|
||||||
silentJSONParsing?: boolean;
|
|
||||||
forcedJSONParsing?: boolean;
|
|
||||||
clarifyTimeoutError?: boolean;
|
|
||||||
legacyInterceptorReqResOrdering?: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface GenericAbortSignal {
|
|
||||||
readonly aborted: boolean;
|
|
||||||
onabort?: ((...args: any) => any) | null;
|
|
||||||
addEventListener?: (...args: any) => any;
|
|
||||||
removeEventListener?: (...args: any) => any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface FormDataVisitorHelpers {
|
|
||||||
defaultVisitor: SerializerVisitor;
|
|
||||||
convertValue: (value: any) => any;
|
|
||||||
isVisitable: (value: any) => boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface SerializerVisitor {
|
|
||||||
(
|
|
||||||
this: GenericFormData,
|
|
||||||
value: any,
|
|
||||||
key: string | number,
|
|
||||||
path: null | Array<string | number>,
|
|
||||||
helpers: FormDataVisitorHelpers
|
|
||||||
): boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface SerializerOptions {
|
|
||||||
visitor?: SerializerVisitor;
|
|
||||||
dots?: boolean;
|
|
||||||
metaTokens?: boolean;
|
|
||||||
indexes?: boolean | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// tslint:disable-next-line
|
|
||||||
interface FormSerializerOptions extends SerializerOptions {}
|
|
||||||
|
|
||||||
interface ParamEncoder {
|
|
||||||
(value: any, defaultEncoder: (value: any) => any): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CustomParamsSerializer {
|
|
||||||
(params: Record<string, any>, options?: ParamsSerializerOptions): string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ParamsSerializerOptions extends SerializerOptions {
|
|
||||||
encode?: ParamEncoder;
|
|
||||||
serialize?: CustomParamsSerializer;
|
|
||||||
}
|
|
||||||
|
|
||||||
type MaxUploadRate = number;
|
|
||||||
|
|
||||||
type MaxDownloadRate = number;
|
|
||||||
|
|
||||||
interface AxiosProgressEvent {
|
|
||||||
loaded: number;
|
|
||||||
total?: number;
|
|
||||||
progress?: number;
|
|
||||||
bytes: number;
|
|
||||||
rate?: number;
|
|
||||||
estimated?: number;
|
|
||||||
upload?: boolean;
|
|
||||||
download?: boolean;
|
|
||||||
event?: BrowserProgressEvent;
|
|
||||||
lengthComputable: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
type Milliseconds = number;
|
|
||||||
|
|
||||||
type AxiosAdapterName = 'fetch' | 'xhr' | 'http' | (string & {});
|
|
||||||
|
|
||||||
type AxiosAdapterConfig = AxiosAdapter | AxiosAdapterName;
|
|
||||||
|
|
||||||
type AddressFamily = 4 | 6 | undefined;
|
|
||||||
|
|
||||||
interface LookupAddressEntry {
|
|
||||||
address: string;
|
|
||||||
family?: AddressFamily;
|
|
||||||
}
|
|
||||||
|
|
||||||
type LookupAddress = string | LookupAddressEntry;
|
|
||||||
|
|
||||||
interface AxiosRequestConfig<D = any> {
|
|
||||||
url?: string;
|
|
||||||
method?: Method | string;
|
|
||||||
baseURL?: string;
|
|
||||||
allowAbsoluteUrls?: boolean;
|
|
||||||
transformRequest?: AxiosRequestTransformer | AxiosRequestTransformer[];
|
|
||||||
transformResponse?: AxiosResponseTransformer | AxiosResponseTransformer[];
|
|
||||||
headers?: (RawAxiosRequestHeaders & MethodsHeaders) | AxiosHeaders;
|
|
||||||
params?: any;
|
|
||||||
paramsSerializer?: ParamsSerializerOptions | CustomParamsSerializer;
|
|
||||||
data?: D;
|
|
||||||
timeout?: Milliseconds;
|
|
||||||
timeoutErrorMessage?: string;
|
|
||||||
withCredentials?: boolean;
|
|
||||||
adapter?: AxiosAdapterConfig | AxiosAdapterConfig[];
|
|
||||||
auth?: AxiosBasicCredentials;
|
|
||||||
responseType?: ResponseType;
|
|
||||||
responseEncoding?: responseEncoding | string;
|
|
||||||
xsrfCookieName?: string;
|
|
||||||
xsrfHeaderName?: string;
|
|
||||||
onUploadProgress?: (progressEvent: AxiosProgressEvent) => void;
|
|
||||||
onDownloadProgress?: (progressEvent: AxiosProgressEvent) => void;
|
|
||||||
maxContentLength?: number;
|
|
||||||
validateStatus?: ((status: number) => boolean) | null;
|
|
||||||
maxBodyLength?: number;
|
|
||||||
maxRedirects?: number;
|
|
||||||
maxRate?: number | [MaxUploadRate, MaxDownloadRate];
|
|
||||||
beforeRedirect?: (
|
|
||||||
options: Record<string, any>,
|
|
||||||
responseDetails: { headers: Record<string, string>; statusCode: HttpStatusCode }
|
|
||||||
) => void;
|
|
||||||
socketPath?: string | null;
|
|
||||||
allowedSocketPaths?: string | string[] | null;
|
|
||||||
transport?: any;
|
|
||||||
httpAgent?: any;
|
|
||||||
httpsAgent?: any;
|
|
||||||
proxy?: AxiosProxyConfig | false;
|
|
||||||
cancelToken?: CancelToken;
|
|
||||||
decompress?: boolean;
|
|
||||||
transitional?: TransitionalOptions;
|
|
||||||
signal?: GenericAbortSignal;
|
|
||||||
insecureHTTPParser?: boolean;
|
|
||||||
env?: {
|
|
||||||
FormData?: new (...args: any[]) => object;
|
|
||||||
fetch?: (input: URL | Request | string, init?: RequestInit) => Promise<Response>;
|
|
||||||
Request?: new (input: URL | Request | string, init?: RequestInit) => Request;
|
|
||||||
Response?: new (
|
|
||||||
body?: ArrayBuffer | ArrayBufferView | Blob | FormData | URLSearchParams | string | null,
|
|
||||||
init?: ResponseInit
|
|
||||||
) => Response;
|
|
||||||
};
|
|
||||||
formSerializer?: FormSerializerOptions;
|
|
||||||
family?: AddressFamily;
|
|
||||||
lookup?:
|
|
||||||
| ((
|
|
||||||
hostname: string,
|
|
||||||
options: object,
|
|
||||||
cb: (
|
|
||||||
err: Error | null,
|
|
||||||
address: LookupAddress | LookupAddress[],
|
|
||||||
family?: AddressFamily
|
|
||||||
) => void
|
|
||||||
) => void)
|
|
||||||
| ((
|
|
||||||
hostname: string,
|
|
||||||
options: object
|
|
||||||
) => Promise<
|
|
||||||
| [address: LookupAddressEntry | LookupAddressEntry[], family?: AddressFamily]
|
|
||||||
| LookupAddress
|
|
||||||
>);
|
|
||||||
withXSRFToken?: boolean | ((config: InternalAxiosRequestConfig) => boolean | undefined);
|
|
||||||
fetchOptions?:
|
|
||||||
| Omit<RequestInit, 'body' | 'headers' | 'method' | 'signal'>
|
|
||||||
| Record<string, any>;
|
|
||||||
httpVersion?: 1 | 2;
|
|
||||||
http2Options?: Record<string, any> & {
|
|
||||||
sessionTimeout?: number;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// Alias
|
|
||||||
type RawAxiosRequestConfig<D = any> = AxiosRequestConfig<D>;
|
|
||||||
|
|
||||||
interface InternalAxiosRequestConfig<D = any> extends AxiosRequestConfig<D> {
|
|
||||||
headers: AxiosRequestHeaders;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface HeadersDefaults {
|
|
||||||
common: RawAxiosRequestHeaders;
|
|
||||||
delete: RawAxiosRequestHeaders;
|
|
||||||
get: RawAxiosRequestHeaders;
|
|
||||||
head: RawAxiosRequestHeaders;
|
|
||||||
post: RawAxiosRequestHeaders;
|
|
||||||
put: RawAxiosRequestHeaders;
|
|
||||||
patch: RawAxiosRequestHeaders;
|
|
||||||
options?: RawAxiosRequestHeaders;
|
|
||||||
purge?: RawAxiosRequestHeaders;
|
|
||||||
link?: RawAxiosRequestHeaders;
|
|
||||||
unlink?: RawAxiosRequestHeaders;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosDefaults<D = any> extends Omit<AxiosRequestConfig<D>, 'headers'> {
|
|
||||||
headers: HeadersDefaults;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CreateAxiosDefaults<D = any> extends Omit<AxiosRequestConfig<D>, 'headers'> {
|
|
||||||
headers?: RawAxiosRequestHeaders | AxiosHeaders | Partial<HeadersDefaults>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosResponse<T = any, D = any, H = {}> {
|
|
||||||
data: T;
|
|
||||||
status: number;
|
|
||||||
statusText: string;
|
|
||||||
headers: (H & RawAxiosResponseHeaders) | AxiosResponseHeaders;
|
|
||||||
config: InternalAxiosRequestConfig<D>;
|
|
||||||
request?: any;
|
|
||||||
}
|
|
||||||
|
|
||||||
type AxiosPromise<T = any> = Promise<AxiosResponse<T>>;
|
|
||||||
|
|
||||||
interface CancelStatic {
|
|
||||||
new (message?: string): Cancel;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface Cancel {
|
|
||||||
message: string | undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface Canceler {
|
|
||||||
(message?: string, config?: AxiosRequestConfig, request?: any): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CancelTokenStatic {
|
|
||||||
new (executor: (cancel: Canceler) => void): CancelToken;
|
|
||||||
source(): CancelTokenSource;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CancelToken {
|
|
||||||
promise: Promise<Cancel>;
|
|
||||||
reason?: Cancel;
|
|
||||||
throwIfRequested(): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CancelTokenSource {
|
|
||||||
token: CancelToken;
|
|
||||||
cancel: Canceler;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosInterceptorOptions {
|
|
||||||
synchronous?: boolean;
|
|
||||||
runWhen?: ((config: InternalAxiosRequestConfig) => boolean) | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
type AxiosInterceptorFulfilled<T> = (value: T) => T | Promise<T>;
|
|
||||||
type AxiosInterceptorRejected = (error: any) => any;
|
|
||||||
|
|
||||||
type AxiosRequestInterceptorUse<T> = (
|
|
||||||
onFulfilled?: AxiosInterceptorFulfilled<T> | null,
|
|
||||||
onRejected?: AxiosInterceptorRejected | null,
|
|
||||||
options?: AxiosInterceptorOptions
|
|
||||||
) => number;
|
|
||||||
|
|
||||||
type AxiosResponseInterceptorUse<T> = (
|
|
||||||
onFulfilled?: AxiosInterceptorFulfilled<T> | null,
|
|
||||||
onRejected?: AxiosInterceptorRejected | null
|
|
||||||
) => number;
|
|
||||||
|
|
||||||
interface AxiosInterceptorHandler<T> {
|
|
||||||
fulfilled: AxiosInterceptorFulfilled<T>;
|
|
||||||
rejected?: AxiosInterceptorRejected;
|
|
||||||
synchronous: boolean;
|
|
||||||
runWhen?: ((config: InternalAxiosRequestConfig) => boolean) | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosInterceptorManager<V> {
|
|
||||||
use: V extends AxiosResponse ? AxiosResponseInterceptorUse<V> : AxiosRequestInterceptorUse<V>;
|
|
||||||
eject(id: number): void;
|
|
||||||
clear(): void;
|
|
||||||
handlers?: Array<AxiosInterceptorHandler<V>>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosInstance extends Axios {
|
|
||||||
<T = any, R = AxiosResponse<T>, D = any>(config: AxiosRequestConfig<D>): Promise<R>;
|
|
||||||
<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
|
|
||||||
create(config?: CreateAxiosDefaults): AxiosInstance;
|
|
||||||
defaults: Omit<AxiosDefaults, 'headers'> & {
|
|
||||||
headers: HeadersDefaults & {
|
|
||||||
[key: string]: AxiosHeaderValue;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
interface GenericFormData {
|
|
||||||
append(name: string, value: any, options?: any): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface GenericHTMLFormElement {
|
|
||||||
name: string;
|
|
||||||
method: string;
|
|
||||||
submit(): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AxiosStatic extends AxiosInstance {
|
|
||||||
Cancel: CancelStatic;
|
|
||||||
CancelToken: CancelTokenStatic;
|
|
||||||
Axios: typeof Axios;
|
|
||||||
AxiosError: typeof AxiosError;
|
|
||||||
CanceledError: typeof CanceledError;
|
|
||||||
HttpStatusCode: typeof HttpStatusCode;
|
|
||||||
readonly VERSION: string;
|
|
||||||
isCancel(value: any): value is Cancel;
|
|
||||||
all<T>(values: Array<T | Promise<T>>): Promise<T[]>;
|
|
||||||
spread<T, R>(callback: (...args: T[]) => R): (array: T[]) => R;
|
|
||||||
isAxiosError<T = any, D = any>(payload: any): payload is AxiosError<T, D>;
|
|
||||||
toFormData(
|
|
||||||
sourceObj: object,
|
|
||||||
targetFormData?: GenericFormData,
|
|
||||||
options?: FormSerializerOptions
|
|
||||||
): GenericFormData;
|
|
||||||
formToJSON(form: GenericFormData | GenericHTMLFormElement): object;
|
|
||||||
getAdapter(adapters: AxiosAdapterConfig | AxiosAdapterConfig[] | undefined): AxiosAdapter;
|
|
||||||
AxiosHeaders: typeof AxiosHeaders;
|
|
||||||
mergeConfig<D = any>(
|
|
||||||
config1: AxiosRequestConfig<D>,
|
|
||||||
config2: AxiosRequestConfig<D>
|
|
||||||
): AxiosRequestConfig<D>;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare const axios: axios.AxiosStatic;
|
|
||||||
|
|
||||||
export = axios;
|
|
||||||
717
node_modules/axios/index.d.ts
generated
vendored
717
node_modules/axios/index.d.ts
generated
vendored
@@ -1,717 +0,0 @@
|
|||||||
// TypeScript Version: 4.7
|
|
||||||
type StringLiteralsOrString<Literals extends string> = Literals | (string & {});
|
|
||||||
|
|
||||||
export type AxiosHeaderValue = AxiosHeaders | string | string[] | number | boolean | null;
|
|
||||||
|
|
||||||
interface RawAxiosHeaders {
|
|
||||||
[key: string]: AxiosHeaderValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
type MethodsHeaders = Partial<
|
|
||||||
{
|
|
||||||
[Key in Method as Lowercase<Key>]: AxiosHeaders;
|
|
||||||
} & { common: AxiosHeaders }
|
|
||||||
>;
|
|
||||||
|
|
||||||
type AxiosHeaderMatcher =
|
|
||||||
| string
|
|
||||||
| RegExp
|
|
||||||
| ((this: AxiosHeaders, value: string, name: string) => boolean);
|
|
||||||
|
|
||||||
type AxiosHeaderParser = (this: AxiosHeaders, value: AxiosHeaderValue, header: string) => any;
|
|
||||||
|
|
||||||
export class AxiosHeaders {
|
|
||||||
constructor(headers?: RawAxiosHeaders | AxiosHeaders | string);
|
|
||||||
|
|
||||||
[key: string]: any;
|
|
||||||
|
|
||||||
set(
|
|
||||||
headerName?: string,
|
|
||||||
value?: AxiosHeaderValue,
|
|
||||||
rewrite?: boolean | AxiosHeaderMatcher
|
|
||||||
): AxiosHeaders;
|
|
||||||
set(headers?: RawAxiosHeaders | AxiosHeaders | string, rewrite?: boolean): AxiosHeaders;
|
|
||||||
|
|
||||||
get(headerName: string, parser: RegExp): RegExpExecArray | null;
|
|
||||||
get(headerName: string, matcher?: true | AxiosHeaderParser): AxiosHeaderValue;
|
|
||||||
|
|
||||||
has(header: string, matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
delete(header: string | string[], matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
clear(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
normalize(format: boolean): AxiosHeaders;
|
|
||||||
|
|
||||||
concat(
|
|
||||||
...targets: Array<AxiosHeaders | RawAxiosHeaders | string | undefined | null>
|
|
||||||
): AxiosHeaders;
|
|
||||||
|
|
||||||
toJSON(asStrings?: boolean): RawAxiosHeaders;
|
|
||||||
|
|
||||||
static from(thing?: AxiosHeaders | RawAxiosHeaders | string): AxiosHeaders;
|
|
||||||
|
|
||||||
static accessor(header: string | string[]): AxiosHeaders;
|
|
||||||
|
|
||||||
static concat(
|
|
||||||
...targets: Array<AxiosHeaders | RawAxiosHeaders | string | undefined | null>
|
|
||||||
): AxiosHeaders;
|
|
||||||
|
|
||||||
setContentType(value: ContentType, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getContentType(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getContentType(matcher?: AxiosHeaderMatcher): AxiosHeaderValue;
|
|
||||||
hasContentType(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setContentLength(value: AxiosHeaderValue, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getContentLength(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getContentLength(matcher?: AxiosHeaderMatcher): AxiosHeaderValue;
|
|
||||||
hasContentLength(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setAccept(value: AxiosHeaderValue, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getAccept(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getAccept(matcher?: AxiosHeaderMatcher): AxiosHeaderValue;
|
|
||||||
hasAccept(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setUserAgent(value: AxiosHeaderValue, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getUserAgent(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getUserAgent(matcher?: AxiosHeaderMatcher): AxiosHeaderValue;
|
|
||||||
hasUserAgent(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setContentEncoding(value: AxiosHeaderValue, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getContentEncoding(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getContentEncoding(matcher?: AxiosHeaderMatcher): AxiosHeaderValue;
|
|
||||||
hasContentEncoding(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
setAuthorization(value: AxiosHeaderValue, rewrite?: boolean | AxiosHeaderMatcher): AxiosHeaders;
|
|
||||||
getAuthorization(parser?: RegExp): RegExpExecArray | null;
|
|
||||||
getAuthorization(matcher?: AxiosHeaderMatcher): AxiosHeaderValue;
|
|
||||||
hasAuthorization(matcher?: AxiosHeaderMatcher): boolean;
|
|
||||||
|
|
||||||
getSetCookie(): string[];
|
|
||||||
|
|
||||||
[Symbol.iterator](): IterableIterator<[string, AxiosHeaderValue]>;
|
|
||||||
}
|
|
||||||
|
|
||||||
type CommonRequestHeadersList =
|
|
||||||
| 'Accept'
|
|
||||||
| 'Content-Length'
|
|
||||||
| 'User-Agent'
|
|
||||||
| 'Content-Encoding'
|
|
||||||
| 'Authorization'
|
|
||||||
| 'Location';
|
|
||||||
|
|
||||||
type ContentType =
|
|
||||||
| AxiosHeaderValue
|
|
||||||
| 'text/html'
|
|
||||||
| 'text/plain'
|
|
||||||
| 'multipart/form-data'
|
|
||||||
| 'application/json'
|
|
||||||
| 'application/x-www-form-urlencoded'
|
|
||||||
| 'application/octet-stream';
|
|
||||||
|
|
||||||
export type RawAxiosRequestHeaders = Partial<
|
|
||||||
RawAxiosHeaders & {
|
|
||||||
[Key in CommonRequestHeadersList]: AxiosHeaderValue;
|
|
||||||
} & {
|
|
||||||
'Content-Type': ContentType;
|
|
||||||
}
|
|
||||||
>;
|
|
||||||
|
|
||||||
export type AxiosRequestHeaders = RawAxiosRequestHeaders & AxiosHeaders;
|
|
||||||
|
|
||||||
type CommonResponseHeadersList =
|
|
||||||
| 'Server'
|
|
||||||
| 'Content-Type'
|
|
||||||
| 'Content-Length'
|
|
||||||
| 'Cache-Control'
|
|
||||||
| 'Content-Encoding';
|
|
||||||
|
|
||||||
type CommonResponseHeaderKey = CommonResponseHeadersList | Lowercase<CommonResponseHeadersList>;
|
|
||||||
|
|
||||||
type RawCommonResponseHeaders = {
|
|
||||||
[Key in CommonResponseHeaderKey]: AxiosHeaderValue;
|
|
||||||
} & {
|
|
||||||
'set-cookie': string[];
|
|
||||||
};
|
|
||||||
|
|
||||||
export type RawAxiosResponseHeaders = Partial<RawAxiosHeaders & RawCommonResponseHeaders>;
|
|
||||||
|
|
||||||
export type AxiosResponseHeaders = RawAxiosResponseHeaders & AxiosHeaders;
|
|
||||||
|
|
||||||
export interface AxiosRequestTransformer {
|
|
||||||
(this: InternalAxiosRequestConfig, data: any, headers: AxiosRequestHeaders): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosResponseTransformer {
|
|
||||||
(
|
|
||||||
this: InternalAxiosRequestConfig,
|
|
||||||
data: any,
|
|
||||||
headers: AxiosResponseHeaders,
|
|
||||||
status?: number
|
|
||||||
): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosAdapter {
|
|
||||||
(config: InternalAxiosRequestConfig): AxiosPromise;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosBasicCredentials {
|
|
||||||
username: string;
|
|
||||||
password: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosProxyConfig {
|
|
||||||
host: string;
|
|
||||||
port: number;
|
|
||||||
auth?: AxiosBasicCredentials;
|
|
||||||
protocol?: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export enum HttpStatusCode {
|
|
||||||
Continue = 100,
|
|
||||||
SwitchingProtocols = 101,
|
|
||||||
Processing = 102,
|
|
||||||
EarlyHints = 103,
|
|
||||||
Ok = 200,
|
|
||||||
Created = 201,
|
|
||||||
Accepted = 202,
|
|
||||||
NonAuthoritativeInformation = 203,
|
|
||||||
NoContent = 204,
|
|
||||||
ResetContent = 205,
|
|
||||||
PartialContent = 206,
|
|
||||||
MultiStatus = 207,
|
|
||||||
AlreadyReported = 208,
|
|
||||||
ImUsed = 226,
|
|
||||||
MultipleChoices = 300,
|
|
||||||
MovedPermanently = 301,
|
|
||||||
Found = 302,
|
|
||||||
SeeOther = 303,
|
|
||||||
NotModified = 304,
|
|
||||||
UseProxy = 305,
|
|
||||||
Unused = 306,
|
|
||||||
TemporaryRedirect = 307,
|
|
||||||
PermanentRedirect = 308,
|
|
||||||
BadRequest = 400,
|
|
||||||
Unauthorized = 401,
|
|
||||||
PaymentRequired = 402,
|
|
||||||
Forbidden = 403,
|
|
||||||
NotFound = 404,
|
|
||||||
MethodNotAllowed = 405,
|
|
||||||
NotAcceptable = 406,
|
|
||||||
ProxyAuthenticationRequired = 407,
|
|
||||||
RequestTimeout = 408,
|
|
||||||
Conflict = 409,
|
|
||||||
Gone = 410,
|
|
||||||
LengthRequired = 411,
|
|
||||||
PreconditionFailed = 412,
|
|
||||||
PayloadTooLarge = 413,
|
|
||||||
UriTooLong = 414,
|
|
||||||
UnsupportedMediaType = 415,
|
|
||||||
RangeNotSatisfiable = 416,
|
|
||||||
ExpectationFailed = 417,
|
|
||||||
ImATeapot = 418,
|
|
||||||
MisdirectedRequest = 421,
|
|
||||||
UnprocessableEntity = 422,
|
|
||||||
Locked = 423,
|
|
||||||
FailedDependency = 424,
|
|
||||||
TooEarly = 425,
|
|
||||||
UpgradeRequired = 426,
|
|
||||||
PreconditionRequired = 428,
|
|
||||||
TooManyRequests = 429,
|
|
||||||
RequestHeaderFieldsTooLarge = 431,
|
|
||||||
UnavailableForLegalReasons = 451,
|
|
||||||
InternalServerError = 500,
|
|
||||||
NotImplemented = 501,
|
|
||||||
BadGateway = 502,
|
|
||||||
ServiceUnavailable = 503,
|
|
||||||
GatewayTimeout = 504,
|
|
||||||
HttpVersionNotSupported = 505,
|
|
||||||
VariantAlsoNegotiates = 506,
|
|
||||||
InsufficientStorage = 507,
|
|
||||||
LoopDetected = 508,
|
|
||||||
NotExtended = 510,
|
|
||||||
NetworkAuthenticationRequired = 511,
|
|
||||||
}
|
|
||||||
|
|
||||||
type UppercaseMethod =
|
|
||||||
| 'GET'
|
|
||||||
| 'DELETE'
|
|
||||||
| 'HEAD'
|
|
||||||
| 'OPTIONS'
|
|
||||||
| 'POST'
|
|
||||||
| 'PUT'
|
|
||||||
| 'PATCH'
|
|
||||||
| 'PURGE'
|
|
||||||
| 'LINK'
|
|
||||||
| 'UNLINK';
|
|
||||||
|
|
||||||
export type Method = (UppercaseMethod | Lowercase<UppercaseMethod>) & {};
|
|
||||||
|
|
||||||
export type ResponseType =
|
|
||||||
| 'arraybuffer'
|
|
||||||
| 'blob'
|
|
||||||
| 'document'
|
|
||||||
| 'json'
|
|
||||||
| 'text'
|
|
||||||
| 'stream'
|
|
||||||
| 'formdata';
|
|
||||||
|
|
||||||
type UppercaseResponseEncoding =
|
|
||||||
| 'ASCII'
|
|
||||||
| 'ANSI'
|
|
||||||
| 'BINARY'
|
|
||||||
| 'BASE64'
|
|
||||||
| 'BASE64URL'
|
|
||||||
| 'HEX'
|
|
||||||
| 'LATIN1'
|
|
||||||
| 'UCS-2'
|
|
||||||
| 'UCS2'
|
|
||||||
| 'UTF-8'
|
|
||||||
| 'UTF8'
|
|
||||||
| 'UTF16LE';
|
|
||||||
|
|
||||||
export type responseEncoding = (
|
|
||||||
| UppercaseResponseEncoding
|
|
||||||
| Lowercase<UppercaseResponseEncoding>
|
|
||||||
) & {};
|
|
||||||
|
|
||||||
export interface TransitionalOptions {
|
|
||||||
silentJSONParsing?: boolean;
|
|
||||||
forcedJSONParsing?: boolean;
|
|
||||||
clarifyTimeoutError?: boolean;
|
|
||||||
legacyInterceptorReqResOrdering?: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface GenericAbortSignal {
|
|
||||||
readonly aborted: boolean;
|
|
||||||
onabort?: ((...args: any) => any) | null;
|
|
||||||
addEventListener?: (...args: any) => any;
|
|
||||||
removeEventListener?: (...args: any) => any;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface FormDataVisitorHelpers {
|
|
||||||
defaultVisitor: SerializerVisitor;
|
|
||||||
convertValue: (value: any) => any;
|
|
||||||
isVisitable: (value: any) => boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface SerializerVisitor {
|
|
||||||
(
|
|
||||||
this: GenericFormData,
|
|
||||||
value: any,
|
|
||||||
key: string | number,
|
|
||||||
path: null | Array<string | number>,
|
|
||||||
helpers: FormDataVisitorHelpers
|
|
||||||
): boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface SerializerOptions {
|
|
||||||
visitor?: SerializerVisitor;
|
|
||||||
dots?: boolean;
|
|
||||||
metaTokens?: boolean;
|
|
||||||
indexes?: boolean | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
// tslint:disable-next-line
|
|
||||||
export interface FormSerializerOptions extends SerializerOptions {}
|
|
||||||
|
|
||||||
export interface ParamEncoder {
|
|
||||||
(value: any, defaultEncoder: (value: any) => any): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface CustomParamsSerializer {
|
|
||||||
(params: Record<string, any>, options?: ParamsSerializerOptions): string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface ParamsSerializerOptions extends SerializerOptions {
|
|
||||||
encode?: ParamEncoder;
|
|
||||||
serialize?: CustomParamsSerializer;
|
|
||||||
}
|
|
||||||
|
|
||||||
type MaxUploadRate = number;
|
|
||||||
|
|
||||||
type MaxDownloadRate = number;
|
|
||||||
|
|
||||||
type BrowserProgressEvent = any;
|
|
||||||
|
|
||||||
export interface AxiosProgressEvent {
|
|
||||||
loaded: number;
|
|
||||||
total?: number;
|
|
||||||
progress?: number;
|
|
||||||
bytes: number;
|
|
||||||
rate?: number;
|
|
||||||
estimated?: number;
|
|
||||||
upload?: boolean;
|
|
||||||
download?: boolean;
|
|
||||||
event?: BrowserProgressEvent;
|
|
||||||
lengthComputable: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
type Milliseconds = number;
|
|
||||||
|
|
||||||
type AxiosAdapterName = StringLiteralsOrString<'xhr' | 'http' | 'fetch'>;
|
|
||||||
|
|
||||||
type AxiosAdapterConfig = AxiosAdapter | AxiosAdapterName;
|
|
||||||
|
|
||||||
export type AddressFamily = 4 | 6 | undefined;
|
|
||||||
|
|
||||||
export interface LookupAddressEntry {
|
|
||||||
address: string;
|
|
||||||
family?: AddressFamily;
|
|
||||||
}
|
|
||||||
|
|
||||||
export type LookupAddress = string | LookupAddressEntry;
|
|
||||||
|
|
||||||
export interface AxiosRequestConfig<D = any> {
|
|
||||||
url?: string;
|
|
||||||
method?: StringLiteralsOrString<Method>;
|
|
||||||
baseURL?: string;
|
|
||||||
allowAbsoluteUrls?: boolean;
|
|
||||||
transformRequest?: AxiosRequestTransformer | AxiosRequestTransformer[];
|
|
||||||
transformResponse?: AxiosResponseTransformer | AxiosResponseTransformer[];
|
|
||||||
headers?: (RawAxiosRequestHeaders & MethodsHeaders) | AxiosHeaders;
|
|
||||||
params?: any;
|
|
||||||
paramsSerializer?: ParamsSerializerOptions | CustomParamsSerializer;
|
|
||||||
data?: D;
|
|
||||||
timeout?: Milliseconds;
|
|
||||||
timeoutErrorMessage?: string;
|
|
||||||
withCredentials?: boolean;
|
|
||||||
adapter?: AxiosAdapterConfig | AxiosAdapterConfig[];
|
|
||||||
auth?: AxiosBasicCredentials;
|
|
||||||
responseType?: ResponseType;
|
|
||||||
responseEncoding?: StringLiteralsOrString<responseEncoding>;
|
|
||||||
xsrfCookieName?: string;
|
|
||||||
xsrfHeaderName?: string;
|
|
||||||
onUploadProgress?: (progressEvent: AxiosProgressEvent) => void;
|
|
||||||
onDownloadProgress?: (progressEvent: AxiosProgressEvent) => void;
|
|
||||||
maxContentLength?: number;
|
|
||||||
validateStatus?: ((status: number) => boolean) | null;
|
|
||||||
maxBodyLength?: number;
|
|
||||||
maxRedirects?: number;
|
|
||||||
maxRate?: number | [MaxUploadRate, MaxDownloadRate];
|
|
||||||
beforeRedirect?: (
|
|
||||||
options: Record<string, any>,
|
|
||||||
responseDetails: {
|
|
||||||
headers: Record<string, string>;
|
|
||||||
statusCode: HttpStatusCode;
|
|
||||||
}
|
|
||||||
) => void;
|
|
||||||
socketPath?: string | null;
|
|
||||||
allowedSocketPaths?: string | string[] | null;
|
|
||||||
transport?: any;
|
|
||||||
httpAgent?: any;
|
|
||||||
httpsAgent?: any;
|
|
||||||
proxy?: AxiosProxyConfig | false;
|
|
||||||
cancelToken?: CancelToken | undefined;
|
|
||||||
decompress?: boolean;
|
|
||||||
transitional?: TransitionalOptions;
|
|
||||||
signal?: GenericAbortSignal;
|
|
||||||
insecureHTTPParser?: boolean;
|
|
||||||
env?: {
|
|
||||||
FormData?: new (...args: any[]) => object;
|
|
||||||
fetch?: (input: URL | Request | string, init?: RequestInit) => Promise<Response>;
|
|
||||||
Request?: new (input: URL | Request | string, init?: RequestInit) => Request;
|
|
||||||
Response?: new (
|
|
||||||
body?: ArrayBuffer | ArrayBufferView | Blob | FormData | URLSearchParams | string | null,
|
|
||||||
init?: ResponseInit
|
|
||||||
) => Response;
|
|
||||||
};
|
|
||||||
formSerializer?: FormSerializerOptions;
|
|
||||||
family?: AddressFamily;
|
|
||||||
lookup?:
|
|
||||||
| ((
|
|
||||||
hostname: string,
|
|
||||||
options: object,
|
|
||||||
cb: (
|
|
||||||
err: Error | null,
|
|
||||||
address: LookupAddress | LookupAddress[],
|
|
||||||
family?: AddressFamily
|
|
||||||
) => void
|
|
||||||
) => void)
|
|
||||||
| ((
|
|
||||||
hostname: string,
|
|
||||||
options: object
|
|
||||||
) => Promise<
|
|
||||||
[address: LookupAddressEntry | LookupAddressEntry[], family?: AddressFamily] | LookupAddress
|
|
||||||
>);
|
|
||||||
withXSRFToken?: boolean | ((config: InternalAxiosRequestConfig) => boolean | undefined);
|
|
||||||
parseReviver?: (this: any, key: string, value: any) => any;
|
|
||||||
fetchOptions?: Omit<RequestInit, 'body' | 'headers' | 'method' | 'signal'> | Record<string, any>;
|
|
||||||
httpVersion?: 1 | 2;
|
|
||||||
http2Options?: Record<string, any> & {
|
|
||||||
sessionTimeout?: number;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// Alias
|
|
||||||
export type RawAxiosRequestConfig<D = any> = AxiosRequestConfig<D>;
|
|
||||||
|
|
||||||
export interface InternalAxiosRequestConfig<D = any> extends AxiosRequestConfig<D> {
|
|
||||||
headers: AxiosRequestHeaders;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface HeadersDefaults {
|
|
||||||
common: RawAxiosRequestHeaders;
|
|
||||||
delete: RawAxiosRequestHeaders;
|
|
||||||
get: RawAxiosRequestHeaders;
|
|
||||||
head: RawAxiosRequestHeaders;
|
|
||||||
post: RawAxiosRequestHeaders;
|
|
||||||
put: RawAxiosRequestHeaders;
|
|
||||||
patch: RawAxiosRequestHeaders;
|
|
||||||
options?: RawAxiosRequestHeaders;
|
|
||||||
purge?: RawAxiosRequestHeaders;
|
|
||||||
link?: RawAxiosRequestHeaders;
|
|
||||||
unlink?: RawAxiosRequestHeaders;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosDefaults<D = any> extends Omit<AxiosRequestConfig<D>, 'headers'> {
|
|
||||||
headers: HeadersDefaults;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface CreateAxiosDefaults<D = any> extends Omit<AxiosRequestConfig<D>, 'headers'> {
|
|
||||||
headers?: RawAxiosRequestHeaders | AxiosHeaders | Partial<HeadersDefaults>;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosResponse<T = any, D = any, H = {}> {
|
|
||||||
data: T;
|
|
||||||
status: number;
|
|
||||||
statusText: string;
|
|
||||||
headers: (H & RawAxiosResponseHeaders) | AxiosResponseHeaders;
|
|
||||||
config: InternalAxiosRequestConfig<D>;
|
|
||||||
request?: any;
|
|
||||||
}
|
|
||||||
|
|
||||||
export class AxiosError<T = unknown, D = any> extends Error {
|
|
||||||
constructor(
|
|
||||||
message?: string,
|
|
||||||
code?: string,
|
|
||||||
config?: InternalAxiosRequestConfig<D>,
|
|
||||||
request?: any,
|
|
||||||
response?: AxiosResponse<T, D>
|
|
||||||
);
|
|
||||||
|
|
||||||
config?: InternalAxiosRequestConfig<D>;
|
|
||||||
code?: string;
|
|
||||||
request?: any;
|
|
||||||
response?: AxiosResponse<T, D>;
|
|
||||||
isAxiosError: boolean;
|
|
||||||
status?: number;
|
|
||||||
toJSON: () => object;
|
|
||||||
cause?: Error;
|
|
||||||
event?: BrowserProgressEvent;
|
|
||||||
static from<T = unknown, D = any>(
|
|
||||||
error: Error | unknown,
|
|
||||||
code?: string,
|
|
||||||
config?: InternalAxiosRequestConfig<D>,
|
|
||||||
request?: any,
|
|
||||||
response?: AxiosResponse<T, D>,
|
|
||||||
customProps?: object
|
|
||||||
): AxiosError<T, D>;
|
|
||||||
static readonly ERR_FR_TOO_MANY_REDIRECTS = 'ERR_FR_TOO_MANY_REDIRECTS';
|
|
||||||
static readonly ERR_BAD_OPTION_VALUE = 'ERR_BAD_OPTION_VALUE';
|
|
||||||
static readonly ERR_BAD_OPTION = 'ERR_BAD_OPTION';
|
|
||||||
static readonly ERR_NETWORK = 'ERR_NETWORK';
|
|
||||||
static readonly ERR_DEPRECATED = 'ERR_DEPRECATED';
|
|
||||||
static readonly ERR_BAD_RESPONSE = 'ERR_BAD_RESPONSE';
|
|
||||||
static readonly ERR_BAD_REQUEST = 'ERR_BAD_REQUEST';
|
|
||||||
static readonly ERR_NOT_SUPPORT = 'ERR_NOT_SUPPORT';
|
|
||||||
static readonly ERR_INVALID_URL = 'ERR_INVALID_URL';
|
|
||||||
static readonly ERR_CANCELED = 'ERR_CANCELED';
|
|
||||||
static readonly ERR_FORM_DATA_DEPTH_EXCEEDED = 'ERR_FORM_DATA_DEPTH_EXCEEDED';
|
|
||||||
static readonly ECONNABORTED = 'ECONNABORTED';
|
|
||||||
static readonly ETIMEDOUT = 'ETIMEDOUT';
|
|
||||||
}
|
|
||||||
|
|
||||||
export class CanceledError<T> extends AxiosError<T> {
|
|
||||||
readonly name: 'CanceledError';
|
|
||||||
}
|
|
||||||
|
|
||||||
export type AxiosPromise<T = any> = Promise<AxiosResponse<T>>;
|
|
||||||
|
|
||||||
export interface CancelStatic {
|
|
||||||
new (message?: string): Cancel;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface Cancel {
|
|
||||||
message: string | undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface Canceler {
|
|
||||||
(message?: string, config?: AxiosRequestConfig, request?: any): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface CancelTokenStatic {
|
|
||||||
new (executor: (cancel: Canceler) => void): CancelToken;
|
|
||||||
source(): CancelTokenSource;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface CancelToken {
|
|
||||||
promise: Promise<Cancel>;
|
|
||||||
reason?: Cancel;
|
|
||||||
throwIfRequested(): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface CancelTokenSource {
|
|
||||||
token: CancelToken;
|
|
||||||
cancel: Canceler;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosInterceptorOptions {
|
|
||||||
synchronous?: boolean;
|
|
||||||
runWhen?: ((config: InternalAxiosRequestConfig) => boolean) | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
type AxiosInterceptorFulfilled<T> = (value: T) => T | Promise<T>;
|
|
||||||
type AxiosInterceptorRejected = (error: any) => any;
|
|
||||||
|
|
||||||
type AxiosRequestInterceptorUse<T> = (
|
|
||||||
onFulfilled?: AxiosInterceptorFulfilled<T> | null,
|
|
||||||
onRejected?: AxiosInterceptorRejected | null,
|
|
||||||
options?: AxiosInterceptorOptions
|
|
||||||
) => number;
|
|
||||||
|
|
||||||
type AxiosResponseInterceptorUse<T> = (
|
|
||||||
onFulfilled?: AxiosInterceptorFulfilled<T> | null,
|
|
||||||
onRejected?: AxiosInterceptorRejected | null
|
|
||||||
) => number;
|
|
||||||
|
|
||||||
interface AxiosInterceptorHandler<T> {
|
|
||||||
fulfilled: AxiosInterceptorFulfilled<T>;
|
|
||||||
rejected?: AxiosInterceptorRejected;
|
|
||||||
synchronous: boolean;
|
|
||||||
runWhen?: ((config: InternalAxiosRequestConfig) => boolean) | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosInterceptorManager<V> {
|
|
||||||
use: V extends AxiosResponse ? AxiosResponseInterceptorUse<V> : AxiosRequestInterceptorUse<V>;
|
|
||||||
eject(id: number): void;
|
|
||||||
clear(): void;
|
|
||||||
handlers?: Array<AxiosInterceptorHandler<V>>;
|
|
||||||
}
|
|
||||||
|
|
||||||
export class Axios {
|
|
||||||
constructor(config?: AxiosRequestConfig);
|
|
||||||
defaults: AxiosDefaults;
|
|
||||||
interceptors: {
|
|
||||||
request: AxiosInterceptorManager<InternalAxiosRequestConfig>;
|
|
||||||
response: AxiosInterceptorManager<AxiosResponse>;
|
|
||||||
};
|
|
||||||
getUri(config?: AxiosRequestConfig): string;
|
|
||||||
request<T = any, R = AxiosResponse<T>, D = any>(config: AxiosRequestConfig<D>): Promise<R>;
|
|
||||||
get<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
delete<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
head<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
options<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
post<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
put<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
patch<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
postForm<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
putForm<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
patchForm<T = any, R = AxiosResponse<T>, D = any>(
|
|
||||||
url: string,
|
|
||||||
data?: D,
|
|
||||||
config?: AxiosRequestConfig<D>
|
|
||||||
): Promise<R>;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface AxiosInstance extends Axios {
|
|
||||||
<T = any, R = AxiosResponse<T>, D = any>(config: AxiosRequestConfig<D>): Promise<R>;
|
|
||||||
<T = any, R = AxiosResponse<T>, D = any>(url: string, config?: AxiosRequestConfig<D>): Promise<R>;
|
|
||||||
|
|
||||||
create(config?: CreateAxiosDefaults): AxiosInstance;
|
|
||||||
defaults: Omit<AxiosDefaults, 'headers'> & {
|
|
||||||
headers: HeadersDefaults & {
|
|
||||||
[key: string]: AxiosHeaderValue;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface GenericFormData {
|
|
||||||
append(name: string, value: any, options?: any): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
export interface GenericHTMLFormElement {
|
|
||||||
name: string;
|
|
||||||
method: string;
|
|
||||||
submit(): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
export function getAdapter(
|
|
||||||
adapters: AxiosAdapterConfig | AxiosAdapterConfig[] | undefined
|
|
||||||
): AxiosAdapter;
|
|
||||||
|
|
||||||
export function toFormData(
|
|
||||||
sourceObj: object,
|
|
||||||
targetFormData?: GenericFormData,
|
|
||||||
options?: FormSerializerOptions
|
|
||||||
): GenericFormData;
|
|
||||||
|
|
||||||
export function formToJSON(form: GenericFormData | GenericHTMLFormElement): object;
|
|
||||||
|
|
||||||
export function isAxiosError<T = any, D = any>(payload: any): payload is AxiosError<T, D>;
|
|
||||||
|
|
||||||
export function spread<T, R>(callback: (...args: T[]) => R): (array: T[]) => R;
|
|
||||||
|
|
||||||
export function isCancel<T = any>(value: any): value is CanceledError<T>;
|
|
||||||
|
|
||||||
export function all<T>(values: Array<T | Promise<T>>): Promise<T[]>;
|
|
||||||
|
|
||||||
export function mergeConfig<D = any>(
|
|
||||||
config1: AxiosRequestConfig<D>,
|
|
||||||
config2: AxiosRequestConfig<D>
|
|
||||||
): AxiosRequestConfig<D>;
|
|
||||||
|
|
||||||
export interface AxiosStatic extends AxiosInstance {
|
|
||||||
Cancel: CancelStatic;
|
|
||||||
CancelToken: CancelTokenStatic;
|
|
||||||
Axios: typeof Axios;
|
|
||||||
AxiosError: typeof AxiosError;
|
|
||||||
HttpStatusCode: typeof HttpStatusCode;
|
|
||||||
readonly VERSION: string;
|
|
||||||
isCancel: typeof isCancel;
|
|
||||||
all: typeof all;
|
|
||||||
spread: typeof spread;
|
|
||||||
isAxiosError: typeof isAxiosError;
|
|
||||||
toFormData: typeof toFormData;
|
|
||||||
formToJSON: typeof formToJSON;
|
|
||||||
getAdapter: typeof getAdapter;
|
|
||||||
CanceledError: typeof CanceledError;
|
|
||||||
AxiosHeaders: typeof AxiosHeaders;
|
|
||||||
mergeConfig: typeof mergeConfig;
|
|
||||||
}
|
|
||||||
|
|
||||||
declare const axios: AxiosStatic;
|
|
||||||
|
|
||||||
export default axios;
|
|
||||||
43
node_modules/axios/index.js
generated
vendored
43
node_modules/axios/index.js
generated
vendored
@@ -1,43 +0,0 @@
|
|||||||
import axios from './lib/axios.js';
|
|
||||||
|
|
||||||
// This module is intended to unwrap Axios default export as named.
|
|
||||||
// Keep top-level export same with static properties
|
|
||||||
// so that it can keep same with es module or cjs
|
|
||||||
const {
|
|
||||||
Axios,
|
|
||||||
AxiosError,
|
|
||||||
CanceledError,
|
|
||||||
isCancel,
|
|
||||||
CancelToken,
|
|
||||||
VERSION,
|
|
||||||
all,
|
|
||||||
Cancel,
|
|
||||||
isAxiosError,
|
|
||||||
spread,
|
|
||||||
toFormData,
|
|
||||||
AxiosHeaders,
|
|
||||||
HttpStatusCode,
|
|
||||||
formToJSON,
|
|
||||||
getAdapter,
|
|
||||||
mergeConfig,
|
|
||||||
} = axios;
|
|
||||||
|
|
||||||
export {
|
|
||||||
axios as default,
|
|
||||||
Axios,
|
|
||||||
AxiosError,
|
|
||||||
CanceledError,
|
|
||||||
isCancel,
|
|
||||||
CancelToken,
|
|
||||||
VERSION,
|
|
||||||
all,
|
|
||||||
Cancel,
|
|
||||||
isAxiosError,
|
|
||||||
spread,
|
|
||||||
toFormData,
|
|
||||||
AxiosHeaders,
|
|
||||||
HttpStatusCode,
|
|
||||||
formToJSON,
|
|
||||||
getAdapter,
|
|
||||||
mergeConfig,
|
|
||||||
};
|
|
||||||
36
node_modules/axios/lib/adapters/README.md
generated
vendored
36
node_modules/axios/lib/adapters/README.md
generated
vendored
@@ -1,36 +0,0 @@
|
|||||||
# axios // adapters
|
|
||||||
|
|
||||||
The modules under `adapters/` are modules that handle dispatching a request and settling a returned `Promise` once a response is received.
|
|
||||||
|
|
||||||
## Example
|
|
||||||
|
|
||||||
```js
|
|
||||||
var settle = require('../core/settle');
|
|
||||||
|
|
||||||
module.exports = function myAdapter(config) {
|
|
||||||
// At this point:
|
|
||||||
// - config has been merged with defaults
|
|
||||||
// - request transformers have already run
|
|
||||||
// - request interceptors have already run
|
|
||||||
|
|
||||||
// Make the request using config provided
|
|
||||||
// Upon response settle the Promise
|
|
||||||
|
|
||||||
return new Promise(function (resolve, reject) {
|
|
||||||
var response = {
|
|
||||||
data: responseData,
|
|
||||||
status: request.status,
|
|
||||||
statusText: request.statusText,
|
|
||||||
headers: responseHeaders,
|
|
||||||
config: config,
|
|
||||||
request: request,
|
|
||||||
};
|
|
||||||
|
|
||||||
settle(resolve, reject, response);
|
|
||||||
|
|
||||||
// From here:
|
|
||||||
// - response transformers will run
|
|
||||||
// - response interceptors will run
|
|
||||||
});
|
|
||||||
};
|
|
||||||
```
|
|
||||||
130
node_modules/axios/lib/adapters/adapters.js
generated
vendored
130
node_modules/axios/lib/adapters/adapters.js
generated
vendored
@@ -1,130 +0,0 @@
|
|||||||
import utils from '../utils.js';
|
|
||||||
import httpAdapter from './http.js';
|
|
||||||
import xhrAdapter from './xhr.js';
|
|
||||||
import * as fetchAdapter from './fetch.js';
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Known adapters mapping.
|
|
||||||
* Provides environment-specific adapters for Axios:
|
|
||||||
* - `http` for Node.js
|
|
||||||
* - `xhr` for browsers
|
|
||||||
* - `fetch` for fetch API-based requests
|
|
||||||
*
|
|
||||||
* @type {Object<string, Function|Object>}
|
|
||||||
*/
|
|
||||||
const knownAdapters = {
|
|
||||||
http: httpAdapter,
|
|
||||||
xhr: xhrAdapter,
|
|
||||||
fetch: {
|
|
||||||
get: fetchAdapter.getFetch,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
// Assign adapter names for easier debugging and identification
|
|
||||||
utils.forEach(knownAdapters, (fn, value) => {
|
|
||||||
if (fn) {
|
|
||||||
try {
|
|
||||||
Object.defineProperty(fn, 'name', { value });
|
|
||||||
} catch (e) {
|
|
||||||
// eslint-disable-next-line no-empty
|
|
||||||
}
|
|
||||||
Object.defineProperty(fn, 'adapterName', { value });
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Render a rejection reason string for unknown or unsupported adapters
|
|
||||||
*
|
|
||||||
* @param {string} reason
|
|
||||||
* @returns {string}
|
|
||||||
*/
|
|
||||||
const renderReason = (reason) => `- ${reason}`;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if the adapter is resolved (function, null, or false)
|
|
||||||
*
|
|
||||||
* @param {Function|null|false} adapter
|
|
||||||
* @returns {boolean}
|
|
||||||
*/
|
|
||||||
const isResolvedHandle = (adapter) =>
|
|
||||||
utils.isFunction(adapter) || adapter === null || adapter === false;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get the first suitable adapter from the provided list.
|
|
||||||
* Tries each adapter in order until a supported one is found.
|
|
||||||
* Throws an AxiosError if no adapter is suitable.
|
|
||||||
*
|
|
||||||
* @param {Array<string|Function>|string|Function} adapters - Adapter(s) by name or function.
|
|
||||||
* @param {Object} config - Axios request configuration
|
|
||||||
* @throws {AxiosError} If no suitable adapter is available
|
|
||||||
* @returns {Function} The resolved adapter function
|
|
||||||
*/
|
|
||||||
function getAdapter(adapters, config) {
|
|
||||||
adapters = utils.isArray(adapters) ? adapters : [adapters];
|
|
||||||
|
|
||||||
const { length } = adapters;
|
|
||||||
let nameOrAdapter;
|
|
||||||
let adapter;
|
|
||||||
|
|
||||||
const rejectedReasons = {};
|
|
||||||
|
|
||||||
for (let i = 0; i < length; i++) {
|
|
||||||
nameOrAdapter = adapters[i];
|
|
||||||
let id;
|
|
||||||
|
|
||||||
adapter = nameOrAdapter;
|
|
||||||
|
|
||||||
if (!isResolvedHandle(nameOrAdapter)) {
|
|
||||||
adapter = knownAdapters[(id = String(nameOrAdapter)).toLowerCase()];
|
|
||||||
|
|
||||||
if (adapter === undefined) {
|
|
||||||
throw new AxiosError(`Unknown adapter '${id}'`);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (adapter && (utils.isFunction(adapter) || (adapter = adapter.get(config)))) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
rejectedReasons[id || '#' + i] = adapter;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!adapter) {
|
|
||||||
const reasons = Object.entries(rejectedReasons).map(
|
|
||||||
([id, state]) =>
|
|
||||||
`adapter ${id} ` +
|
|
||||||
(state === false ? 'is not supported by the environment' : 'is not available in the build')
|
|
||||||
);
|
|
||||||
|
|
||||||
let s = length
|
|
||||||
? reasons.length > 1
|
|
||||||
? 'since :\n' + reasons.map(renderReason).join('\n')
|
|
||||||
: ' ' + renderReason(reasons[0])
|
|
||||||
: 'as no adapter specified';
|
|
||||||
|
|
||||||
throw new AxiosError(
|
|
||||||
`There is no suitable adapter to dispatch the request ` + s,
|
|
||||||
'ERR_NOT_SUPPORT'
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return adapter;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Exports Axios adapters and utility to resolve an adapter
|
|
||||||
*/
|
|
||||||
export default {
|
|
||||||
/**
|
|
||||||
* Resolve an adapter from a list of adapter names or functions.
|
|
||||||
* @type {Function}
|
|
||||||
*/
|
|
||||||
getAdapter,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Exposes all known adapters
|
|
||||||
* @type {Object<string, Function|Object>}
|
|
||||||
*/
|
|
||||||
adapters: knownAdapters,
|
|
||||||
};
|
|
||||||
353
node_modules/axios/lib/adapters/fetch.js
generated
vendored
353
node_modules/axios/lib/adapters/fetch.js
generated
vendored
@@ -1,353 +0,0 @@
|
|||||||
import platform from '../platform/index.js';
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
import composeSignals from '../helpers/composeSignals.js';
|
|
||||||
import { trackStream } from '../helpers/trackStream.js';
|
|
||||||
import AxiosHeaders from '../core/AxiosHeaders.js';
|
|
||||||
import {
|
|
||||||
progressEventReducer,
|
|
||||||
progressEventDecorator,
|
|
||||||
asyncDecorator,
|
|
||||||
} from '../helpers/progressEventReducer.js';
|
|
||||||
import resolveConfig from '../helpers/resolveConfig.js';
|
|
||||||
import settle from '../core/settle.js';
|
|
||||||
|
|
||||||
const DEFAULT_CHUNK_SIZE = 64 * 1024;
|
|
||||||
|
|
||||||
const { isFunction } = utils;
|
|
||||||
|
|
||||||
const globalFetchAPI = (({ Request, Response }) => ({
|
|
||||||
Request,
|
|
||||||
Response,
|
|
||||||
}))(utils.global);
|
|
||||||
|
|
||||||
const { ReadableStream, TextEncoder } = utils.global;
|
|
||||||
|
|
||||||
const test = (fn, ...args) => {
|
|
||||||
try {
|
|
||||||
return !!fn(...args);
|
|
||||||
} catch (e) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const factory = (env) => {
|
|
||||||
env = utils.merge.call(
|
|
||||||
{
|
|
||||||
skipUndefined: true,
|
|
||||||
},
|
|
||||||
globalFetchAPI,
|
|
||||||
env
|
|
||||||
);
|
|
||||||
|
|
||||||
const { fetch: envFetch, Request, Response } = env;
|
|
||||||
const isFetchSupported = envFetch ? isFunction(envFetch) : typeof fetch === 'function';
|
|
||||||
const isRequestSupported = isFunction(Request);
|
|
||||||
const isResponseSupported = isFunction(Response);
|
|
||||||
|
|
||||||
if (!isFetchSupported) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const isReadableStreamSupported = isFetchSupported && isFunction(ReadableStream);
|
|
||||||
|
|
||||||
const encodeText =
|
|
||||||
isFetchSupported &&
|
|
||||||
(typeof TextEncoder === 'function'
|
|
||||||
? (
|
|
||||||
(encoder) => (str) =>
|
|
||||||
encoder.encode(str)
|
|
||||||
)(new TextEncoder())
|
|
||||||
: async (str) => new Uint8Array(await new Request(str).arrayBuffer()));
|
|
||||||
|
|
||||||
const supportsRequestStream =
|
|
||||||
isRequestSupported &&
|
|
||||||
isReadableStreamSupported &&
|
|
||||||
test(() => {
|
|
||||||
let duplexAccessed = false;
|
|
||||||
|
|
||||||
const request = new Request(platform.origin, {
|
|
||||||
body: new ReadableStream(),
|
|
||||||
method: 'POST',
|
|
||||||
get duplex() {
|
|
||||||
duplexAccessed = true;
|
|
||||||
return 'half';
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const hasContentType = request.headers.has('Content-Type');
|
|
||||||
|
|
||||||
if (request.body != null) {
|
|
||||||
request.body.cancel();
|
|
||||||
}
|
|
||||||
|
|
||||||
return duplexAccessed && !hasContentType;
|
|
||||||
});
|
|
||||||
|
|
||||||
const supportsResponseStream =
|
|
||||||
isResponseSupported &&
|
|
||||||
isReadableStreamSupported &&
|
|
||||||
test(() => utils.isReadableStream(new Response('').body));
|
|
||||||
|
|
||||||
const resolvers = {
|
|
||||||
stream: supportsResponseStream && ((res) => res.body),
|
|
||||||
};
|
|
||||||
|
|
||||||
isFetchSupported &&
|
|
||||||
(() => {
|
|
||||||
['text', 'arrayBuffer', 'blob', 'formData', 'stream'].forEach((type) => {
|
|
||||||
!resolvers[type] &&
|
|
||||||
(resolvers[type] = (res, config) => {
|
|
||||||
let method = res && res[type];
|
|
||||||
|
|
||||||
if (method) {
|
|
||||||
return method.call(res);
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new AxiosError(
|
|
||||||
`Response type '${type}' is not supported`,
|
|
||||||
AxiosError.ERR_NOT_SUPPORT,
|
|
||||||
config
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
})();
|
|
||||||
|
|
||||||
const getBodyLength = async (body) => {
|
|
||||||
if (body == null) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isBlob(body)) {
|
|
||||||
return body.size;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isSpecCompliantForm(body)) {
|
|
||||||
const _request = new Request(platform.origin, {
|
|
||||||
method: 'POST',
|
|
||||||
body,
|
|
||||||
});
|
|
||||||
return (await _request.arrayBuffer()).byteLength;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isArrayBufferView(body) || utils.isArrayBuffer(body)) {
|
|
||||||
return body.byteLength;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isURLSearchParams(body)) {
|
|
||||||
body = body + '';
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isString(body)) {
|
|
||||||
return (await encodeText(body)).byteLength;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const resolveBodyLength = async (headers, body) => {
|
|
||||||
const length = utils.toFiniteNumber(headers.getContentLength());
|
|
||||||
|
|
||||||
return length == null ? getBodyLength(body) : length;
|
|
||||||
};
|
|
||||||
|
|
||||||
return async (config) => {
|
|
||||||
let {
|
|
||||||
url,
|
|
||||||
method,
|
|
||||||
data,
|
|
||||||
signal,
|
|
||||||
cancelToken,
|
|
||||||
timeout,
|
|
||||||
onDownloadProgress,
|
|
||||||
onUploadProgress,
|
|
||||||
responseType,
|
|
||||||
headers,
|
|
||||||
withCredentials = 'same-origin',
|
|
||||||
fetchOptions,
|
|
||||||
} = resolveConfig(config);
|
|
||||||
|
|
||||||
let _fetch = envFetch || fetch;
|
|
||||||
|
|
||||||
responseType = responseType ? (responseType + '').toLowerCase() : 'text';
|
|
||||||
|
|
||||||
let composedSignal = composeSignals(
|
|
||||||
[signal, cancelToken && cancelToken.toAbortSignal()],
|
|
||||||
timeout
|
|
||||||
);
|
|
||||||
|
|
||||||
let request = null;
|
|
||||||
|
|
||||||
const unsubscribe =
|
|
||||||
composedSignal &&
|
|
||||||
composedSignal.unsubscribe &&
|
|
||||||
(() => {
|
|
||||||
composedSignal.unsubscribe();
|
|
||||||
});
|
|
||||||
|
|
||||||
let requestContentLength;
|
|
||||||
|
|
||||||
try {
|
|
||||||
if (
|
|
||||||
onUploadProgress &&
|
|
||||||
supportsRequestStream &&
|
|
||||||
method !== 'get' &&
|
|
||||||
method !== 'head' &&
|
|
||||||
(requestContentLength = await resolveBodyLength(headers, data)) !== 0
|
|
||||||
) {
|
|
||||||
let _request = new Request(url, {
|
|
||||||
method: 'POST',
|
|
||||||
body: data,
|
|
||||||
duplex: 'half',
|
|
||||||
});
|
|
||||||
|
|
||||||
let contentTypeHeader;
|
|
||||||
|
|
||||||
if (utils.isFormData(data) && (contentTypeHeader = _request.headers.get('content-type'))) {
|
|
||||||
headers.setContentType(contentTypeHeader);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_request.body) {
|
|
||||||
const [onProgress, flush] = progressEventDecorator(
|
|
||||||
requestContentLength,
|
|
||||||
progressEventReducer(asyncDecorator(onUploadProgress))
|
|
||||||
);
|
|
||||||
|
|
||||||
data = trackStream(_request.body, DEFAULT_CHUNK_SIZE, onProgress, flush);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!utils.isString(withCredentials)) {
|
|
||||||
withCredentials = withCredentials ? 'include' : 'omit';
|
|
||||||
}
|
|
||||||
|
|
||||||
// Cloudflare Workers throws when credentials are defined
|
|
||||||
// see https://github.com/cloudflare/workerd/issues/902
|
|
||||||
const isCredentialsSupported = isRequestSupported && 'credentials' in Request.prototype;
|
|
||||||
|
|
||||||
// If data is FormData and Content-Type is multipart/form-data without boundary,
|
|
||||||
// delete it so fetch can set it correctly with the boundary
|
|
||||||
if (utils.isFormData(data)) {
|
|
||||||
const contentType = headers.getContentType();
|
|
||||||
if (
|
|
||||||
contentType &&
|
|
||||||
/^multipart\/form-data/i.test(contentType) &&
|
|
||||||
!/boundary=/i.test(contentType)
|
|
||||||
) {
|
|
||||||
headers.delete('content-type');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const resolvedOptions = {
|
|
||||||
...fetchOptions,
|
|
||||||
signal: composedSignal,
|
|
||||||
method: method.toUpperCase(),
|
|
||||||
headers: headers.normalize().toJSON(),
|
|
||||||
body: data,
|
|
||||||
duplex: 'half',
|
|
||||||
credentials: isCredentialsSupported ? withCredentials : undefined,
|
|
||||||
};
|
|
||||||
|
|
||||||
request = isRequestSupported && new Request(url, resolvedOptions);
|
|
||||||
|
|
||||||
let response = await (isRequestSupported
|
|
||||||
? _fetch(request, fetchOptions)
|
|
||||||
: _fetch(url, resolvedOptions));
|
|
||||||
|
|
||||||
const isStreamResponse =
|
|
||||||
supportsResponseStream && (responseType === 'stream' || responseType === 'response');
|
|
||||||
|
|
||||||
if (supportsResponseStream && (onDownloadProgress || (isStreamResponse && unsubscribe))) {
|
|
||||||
const options = {};
|
|
||||||
|
|
||||||
['status', 'statusText', 'headers'].forEach((prop) => {
|
|
||||||
options[prop] = response[prop];
|
|
||||||
});
|
|
||||||
|
|
||||||
const responseContentLength = utils.toFiniteNumber(response.headers.get('content-length'));
|
|
||||||
|
|
||||||
const [onProgress, flush] =
|
|
||||||
(onDownloadProgress &&
|
|
||||||
progressEventDecorator(
|
|
||||||
responseContentLength,
|
|
||||||
progressEventReducer(asyncDecorator(onDownloadProgress), true)
|
|
||||||
)) ||
|
|
||||||
[];
|
|
||||||
|
|
||||||
response = new Response(
|
|
||||||
trackStream(response.body, DEFAULT_CHUNK_SIZE, onProgress, () => {
|
|
||||||
flush && flush();
|
|
||||||
unsubscribe && unsubscribe();
|
|
||||||
}),
|
|
||||||
options
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
responseType = responseType || 'text';
|
|
||||||
|
|
||||||
let responseData = await resolvers[utils.findKey(resolvers, responseType) || 'text'](
|
|
||||||
response,
|
|
||||||
config
|
|
||||||
);
|
|
||||||
|
|
||||||
!isStreamResponse && unsubscribe && unsubscribe();
|
|
||||||
|
|
||||||
return await new Promise((resolve, reject) => {
|
|
||||||
settle(resolve, reject, {
|
|
||||||
data: responseData,
|
|
||||||
headers: AxiosHeaders.from(response.headers),
|
|
||||||
status: response.status,
|
|
||||||
statusText: response.statusText,
|
|
||||||
config,
|
|
||||||
request,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
} catch (err) {
|
|
||||||
unsubscribe && unsubscribe();
|
|
||||||
|
|
||||||
if (err && err.name === 'TypeError' && /Load failed|fetch/i.test(err.message)) {
|
|
||||||
throw Object.assign(
|
|
||||||
new AxiosError(
|
|
||||||
'Network Error',
|
|
||||||
AxiosError.ERR_NETWORK,
|
|
||||||
config,
|
|
||||||
request,
|
|
||||||
err && err.response
|
|
||||||
),
|
|
||||||
{
|
|
||||||
cause: err.cause || err,
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
throw AxiosError.from(err, err && err.code, config, request, err && err.response);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
const seedCache = new Map();
|
|
||||||
|
|
||||||
export const getFetch = (config) => {
|
|
||||||
let env = (config && config.env) || {};
|
|
||||||
const { fetch, Request, Response } = env;
|
|
||||||
const seeds = [Request, Response, fetch];
|
|
||||||
|
|
||||||
let len = seeds.length,
|
|
||||||
i = len,
|
|
||||||
seed,
|
|
||||||
target,
|
|
||||||
map = seedCache;
|
|
||||||
|
|
||||||
while (i--) {
|
|
||||||
seed = seeds[i];
|
|
||||||
target = map.get(seed);
|
|
||||||
|
|
||||||
target === undefined && map.set(seed, (target = i ? new Map() : factory(env)));
|
|
||||||
|
|
||||||
map = target;
|
|
||||||
}
|
|
||||||
|
|
||||||
return target;
|
|
||||||
};
|
|
||||||
|
|
||||||
const adapter = getFetch();
|
|
||||||
|
|
||||||
export default adapter;
|
|
||||||
1083
node_modules/axios/lib/adapters/http.js
generated
vendored
1083
node_modules/axios/lib/adapters/http.js
generated
vendored
File diff suppressed because it is too large
Load Diff
222
node_modules/axios/lib/adapters/xhr.js
generated
vendored
222
node_modules/axios/lib/adapters/xhr.js
generated
vendored
@@ -1,222 +0,0 @@
|
|||||||
import utils from '../utils.js';
|
|
||||||
import settle from '../core/settle.js';
|
|
||||||
import transitionalDefaults from '../defaults/transitional.js';
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
import CanceledError from '../cancel/CanceledError.js';
|
|
||||||
import parseProtocol from '../helpers/parseProtocol.js';
|
|
||||||
import platform from '../platform/index.js';
|
|
||||||
import AxiosHeaders from '../core/AxiosHeaders.js';
|
|
||||||
import { progressEventReducer } from '../helpers/progressEventReducer.js';
|
|
||||||
import resolveConfig from '../helpers/resolveConfig.js';
|
|
||||||
|
|
||||||
const isXHRAdapterSupported = typeof XMLHttpRequest !== 'undefined';
|
|
||||||
|
|
||||||
export default isXHRAdapterSupported &&
|
|
||||||
function (config) {
|
|
||||||
return new Promise(function dispatchXhrRequest(resolve, reject) {
|
|
||||||
const _config = resolveConfig(config);
|
|
||||||
let requestData = _config.data;
|
|
||||||
const requestHeaders = AxiosHeaders.from(_config.headers).normalize();
|
|
||||||
let { responseType, onUploadProgress, onDownloadProgress } = _config;
|
|
||||||
let onCanceled;
|
|
||||||
let uploadThrottled, downloadThrottled;
|
|
||||||
let flushUpload, flushDownload;
|
|
||||||
|
|
||||||
function done() {
|
|
||||||
flushUpload && flushUpload(); // flush events
|
|
||||||
flushDownload && flushDownload(); // flush events
|
|
||||||
|
|
||||||
_config.cancelToken && _config.cancelToken.unsubscribe(onCanceled);
|
|
||||||
|
|
||||||
_config.signal && _config.signal.removeEventListener('abort', onCanceled);
|
|
||||||
}
|
|
||||||
|
|
||||||
let request = new XMLHttpRequest();
|
|
||||||
|
|
||||||
request.open(_config.method.toUpperCase(), _config.url, true);
|
|
||||||
|
|
||||||
// Set the request timeout in MS
|
|
||||||
request.timeout = _config.timeout;
|
|
||||||
|
|
||||||
function onloadend() {
|
|
||||||
if (!request) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// Prepare the response
|
|
||||||
const responseHeaders = AxiosHeaders.from(
|
|
||||||
'getAllResponseHeaders' in request && request.getAllResponseHeaders()
|
|
||||||
);
|
|
||||||
const responseData =
|
|
||||||
!responseType || responseType === 'text' || responseType === 'json'
|
|
||||||
? request.responseText
|
|
||||||
: request.response;
|
|
||||||
const response = {
|
|
||||||
data: responseData,
|
|
||||||
status: request.status,
|
|
||||||
statusText: request.statusText,
|
|
||||||
headers: responseHeaders,
|
|
||||||
config,
|
|
||||||
request,
|
|
||||||
};
|
|
||||||
|
|
||||||
settle(
|
|
||||||
function _resolve(value) {
|
|
||||||
resolve(value);
|
|
||||||
done();
|
|
||||||
},
|
|
||||||
function _reject(err) {
|
|
||||||
reject(err);
|
|
||||||
done();
|
|
||||||
},
|
|
||||||
response
|
|
||||||
);
|
|
||||||
|
|
||||||
// Clean up request
|
|
||||||
request = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ('onloadend' in request) {
|
|
||||||
// Use onloadend if available
|
|
||||||
request.onloadend = onloadend;
|
|
||||||
} else {
|
|
||||||
// Listen for ready state to emulate onloadend
|
|
||||||
request.onreadystatechange = function handleLoad() {
|
|
||||||
if (!request || request.readyState !== 4) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// The request errored out and we didn't get a response, this will be
|
|
||||||
// handled by onerror instead
|
|
||||||
// With one exception: request that using file: protocol, most browsers
|
|
||||||
// will return status as 0 even though it's a successful request
|
|
||||||
if (
|
|
||||||
request.status === 0 &&
|
|
||||||
!(request.responseURL && request.responseURL.indexOf('file:') === 0)
|
|
||||||
) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// readystate handler is calling before onerror or ontimeout handlers,
|
|
||||||
// so we should call onloadend on the next 'tick'
|
|
||||||
setTimeout(onloadend);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle browser request cancellation (as opposed to a manual cancellation)
|
|
||||||
request.onabort = function handleAbort() {
|
|
||||||
if (!request) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
reject(new AxiosError('Request aborted', AxiosError.ECONNABORTED, config, request));
|
|
||||||
|
|
||||||
// Clean up request
|
|
||||||
request = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Handle low level network errors
|
|
||||||
request.onerror = function handleError(event) {
|
|
||||||
// Browsers deliver a ProgressEvent in XHR onerror
|
|
||||||
// (message may be empty; when present, surface it)
|
|
||||||
// See https://developer.mozilla.org/docs/Web/API/XMLHttpRequest/error_event
|
|
||||||
const msg = event && event.message ? event.message : 'Network Error';
|
|
||||||
const err = new AxiosError(msg, AxiosError.ERR_NETWORK, config, request);
|
|
||||||
// attach the underlying event for consumers who want details
|
|
||||||
err.event = event || null;
|
|
||||||
reject(err);
|
|
||||||
request = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Handle timeout
|
|
||||||
request.ontimeout = function handleTimeout() {
|
|
||||||
let timeoutErrorMessage = _config.timeout
|
|
||||||
? 'timeout of ' + _config.timeout + 'ms exceeded'
|
|
||||||
: 'timeout exceeded';
|
|
||||||
const transitional = _config.transitional || transitionalDefaults;
|
|
||||||
if (_config.timeoutErrorMessage) {
|
|
||||||
timeoutErrorMessage = _config.timeoutErrorMessage;
|
|
||||||
}
|
|
||||||
reject(
|
|
||||||
new AxiosError(
|
|
||||||
timeoutErrorMessage,
|
|
||||||
transitional.clarifyTimeoutError ? AxiosError.ETIMEDOUT : AxiosError.ECONNABORTED,
|
|
||||||
config,
|
|
||||||
request
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
// Clean up request
|
|
||||||
request = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Remove Content-Type if data is undefined
|
|
||||||
requestData === undefined && requestHeaders.setContentType(null);
|
|
||||||
|
|
||||||
// Add headers to the request
|
|
||||||
if ('setRequestHeader' in request) {
|
|
||||||
utils.forEach(requestHeaders.toJSON(), function setRequestHeader(val, key) {
|
|
||||||
request.setRequestHeader(key, val);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add withCredentials to request if needed
|
|
||||||
if (!utils.isUndefined(_config.withCredentials)) {
|
|
||||||
request.withCredentials = !!_config.withCredentials;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add responseType to request if needed
|
|
||||||
if (responseType && responseType !== 'json') {
|
|
||||||
request.responseType = _config.responseType;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Handle progress if needed
|
|
||||||
if (onDownloadProgress) {
|
|
||||||
[downloadThrottled, flushDownload] = progressEventReducer(onDownloadProgress, true);
|
|
||||||
request.addEventListener('progress', downloadThrottled);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Not all browsers support upload events
|
|
||||||
if (onUploadProgress && request.upload) {
|
|
||||||
[uploadThrottled, flushUpload] = progressEventReducer(onUploadProgress);
|
|
||||||
|
|
||||||
request.upload.addEventListener('progress', uploadThrottled);
|
|
||||||
|
|
||||||
request.upload.addEventListener('loadend', flushUpload);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_config.cancelToken || _config.signal) {
|
|
||||||
// Handle cancellation
|
|
||||||
// eslint-disable-next-line func-names
|
|
||||||
onCanceled = (cancel) => {
|
|
||||||
if (!request) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
reject(!cancel || cancel.type ? new CanceledError(null, config, request) : cancel);
|
|
||||||
request.abort();
|
|
||||||
request = null;
|
|
||||||
};
|
|
||||||
|
|
||||||
_config.cancelToken && _config.cancelToken.subscribe(onCanceled);
|
|
||||||
if (_config.signal) {
|
|
||||||
_config.signal.aborted
|
|
||||||
? onCanceled()
|
|
||||||
: _config.signal.addEventListener('abort', onCanceled);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const protocol = parseProtocol(_config.url);
|
|
||||||
|
|
||||||
if (protocol && platform.protocols.indexOf(protocol) === -1) {
|
|
||||||
reject(
|
|
||||||
new AxiosError(
|
|
||||||
'Unsupported protocol ' + protocol + ':',
|
|
||||||
AxiosError.ERR_BAD_REQUEST,
|
|
||||||
config
|
|
||||||
)
|
|
||||||
);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Send the request
|
|
||||||
request.send(requestData || null);
|
|
||||||
});
|
|
||||||
};
|
|
||||||
89
node_modules/axios/lib/axios.js
generated
vendored
89
node_modules/axios/lib/axios.js
generated
vendored
@@ -1,89 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from './utils.js';
|
|
||||||
import bind from './helpers/bind.js';
|
|
||||||
import Axios from './core/Axios.js';
|
|
||||||
import mergeConfig from './core/mergeConfig.js';
|
|
||||||
import defaults from './defaults/index.js';
|
|
||||||
import formDataToJSON from './helpers/formDataToJSON.js';
|
|
||||||
import CanceledError from './cancel/CanceledError.js';
|
|
||||||
import CancelToken from './cancel/CancelToken.js';
|
|
||||||
import isCancel from './cancel/isCancel.js';
|
|
||||||
import { VERSION } from './env/data.js';
|
|
||||||
import toFormData from './helpers/toFormData.js';
|
|
||||||
import AxiosError from './core/AxiosError.js';
|
|
||||||
import spread from './helpers/spread.js';
|
|
||||||
import isAxiosError from './helpers/isAxiosError.js';
|
|
||||||
import AxiosHeaders from './core/AxiosHeaders.js';
|
|
||||||
import adapters from './adapters/adapters.js';
|
|
||||||
import HttpStatusCode from './helpers/HttpStatusCode.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an instance of Axios
|
|
||||||
*
|
|
||||||
* @param {Object} defaultConfig The default config for the instance
|
|
||||||
*
|
|
||||||
* @returns {Axios} A new instance of Axios
|
|
||||||
*/
|
|
||||||
function createInstance(defaultConfig) {
|
|
||||||
const context = new Axios(defaultConfig);
|
|
||||||
const instance = bind(Axios.prototype.request, context);
|
|
||||||
|
|
||||||
// Copy axios.prototype to instance
|
|
||||||
utils.extend(instance, Axios.prototype, context, { allOwnKeys: true });
|
|
||||||
|
|
||||||
// Copy context to instance
|
|
||||||
utils.extend(instance, context, null, { allOwnKeys: true });
|
|
||||||
|
|
||||||
// Factory for creating new instances
|
|
||||||
instance.create = function create(instanceConfig) {
|
|
||||||
return createInstance(mergeConfig(defaultConfig, instanceConfig));
|
|
||||||
};
|
|
||||||
|
|
||||||
return instance;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Create the default instance to be exported
|
|
||||||
const axios = createInstance(defaults);
|
|
||||||
|
|
||||||
// Expose Axios class to allow class inheritance
|
|
||||||
axios.Axios = Axios;
|
|
||||||
|
|
||||||
// Expose Cancel & CancelToken
|
|
||||||
axios.CanceledError = CanceledError;
|
|
||||||
axios.CancelToken = CancelToken;
|
|
||||||
axios.isCancel = isCancel;
|
|
||||||
axios.VERSION = VERSION;
|
|
||||||
axios.toFormData = toFormData;
|
|
||||||
|
|
||||||
// Expose AxiosError class
|
|
||||||
axios.AxiosError = AxiosError;
|
|
||||||
|
|
||||||
// alias for CanceledError for backward compatibility
|
|
||||||
axios.Cancel = axios.CanceledError;
|
|
||||||
|
|
||||||
// Expose all/spread
|
|
||||||
axios.all = function all(promises) {
|
|
||||||
return Promise.all(promises);
|
|
||||||
};
|
|
||||||
|
|
||||||
axios.spread = spread;
|
|
||||||
|
|
||||||
// Expose isAxiosError
|
|
||||||
axios.isAxiosError = isAxiosError;
|
|
||||||
|
|
||||||
// Expose mergeConfig
|
|
||||||
axios.mergeConfig = mergeConfig;
|
|
||||||
|
|
||||||
axios.AxiosHeaders = AxiosHeaders;
|
|
||||||
|
|
||||||
axios.formToJSON = (thing) => formDataToJSON(utils.isHTMLForm(thing) ? new FormData(thing) : thing);
|
|
||||||
|
|
||||||
axios.getAdapter = adapters.getAdapter;
|
|
||||||
|
|
||||||
axios.HttpStatusCode = HttpStatusCode;
|
|
||||||
|
|
||||||
axios.default = axios;
|
|
||||||
|
|
||||||
// this module should only have a default export
|
|
||||||
export default axios;
|
|
||||||
135
node_modules/axios/lib/cancel/CancelToken.js
generated
vendored
135
node_modules/axios/lib/cancel/CancelToken.js
generated
vendored
@@ -1,135 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import CanceledError from './CanceledError.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A `CancelToken` is an object that can be used to request cancellation of an operation.
|
|
||||||
*
|
|
||||||
* @param {Function} executor The executor function.
|
|
||||||
*
|
|
||||||
* @returns {CancelToken}
|
|
||||||
*/
|
|
||||||
class CancelToken {
|
|
||||||
constructor(executor) {
|
|
||||||
if (typeof executor !== 'function') {
|
|
||||||
throw new TypeError('executor must be a function.');
|
|
||||||
}
|
|
||||||
|
|
||||||
let resolvePromise;
|
|
||||||
|
|
||||||
this.promise = new Promise(function promiseExecutor(resolve) {
|
|
||||||
resolvePromise = resolve;
|
|
||||||
});
|
|
||||||
|
|
||||||
const token = this;
|
|
||||||
|
|
||||||
// eslint-disable-next-line func-names
|
|
||||||
this.promise.then((cancel) => {
|
|
||||||
if (!token._listeners) return;
|
|
||||||
|
|
||||||
let i = token._listeners.length;
|
|
||||||
|
|
||||||
while (i-- > 0) {
|
|
||||||
token._listeners[i](cancel);
|
|
||||||
}
|
|
||||||
token._listeners = null;
|
|
||||||
});
|
|
||||||
|
|
||||||
// eslint-disable-next-line func-names
|
|
||||||
this.promise.then = (onfulfilled) => {
|
|
||||||
let _resolve;
|
|
||||||
// eslint-disable-next-line func-names
|
|
||||||
const promise = new Promise((resolve) => {
|
|
||||||
token.subscribe(resolve);
|
|
||||||
_resolve = resolve;
|
|
||||||
}).then(onfulfilled);
|
|
||||||
|
|
||||||
promise.cancel = function reject() {
|
|
||||||
token.unsubscribe(_resolve);
|
|
||||||
};
|
|
||||||
|
|
||||||
return promise;
|
|
||||||
};
|
|
||||||
|
|
||||||
executor(function cancel(message, config, request) {
|
|
||||||
if (token.reason) {
|
|
||||||
// Cancellation has already been requested
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
token.reason = new CanceledError(message, config, request);
|
|
||||||
resolvePromise(token.reason);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Throws a `CanceledError` if cancellation has been requested.
|
|
||||||
*/
|
|
||||||
throwIfRequested() {
|
|
||||||
if (this.reason) {
|
|
||||||
throw this.reason;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Subscribe to the cancel signal
|
|
||||||
*/
|
|
||||||
|
|
||||||
subscribe(listener) {
|
|
||||||
if (this.reason) {
|
|
||||||
listener(this.reason);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._listeners) {
|
|
||||||
this._listeners.push(listener);
|
|
||||||
} else {
|
|
||||||
this._listeners = [listener];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Unsubscribe from the cancel signal
|
|
||||||
*/
|
|
||||||
|
|
||||||
unsubscribe(listener) {
|
|
||||||
if (!this._listeners) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
const index = this._listeners.indexOf(listener);
|
|
||||||
if (index !== -1) {
|
|
||||||
this._listeners.splice(index, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
toAbortSignal() {
|
|
||||||
const controller = new AbortController();
|
|
||||||
|
|
||||||
const abort = (err) => {
|
|
||||||
controller.abort(err);
|
|
||||||
};
|
|
||||||
|
|
||||||
this.subscribe(abort);
|
|
||||||
|
|
||||||
controller.signal.unsubscribe = () => this.unsubscribe(abort);
|
|
||||||
|
|
||||||
return controller.signal;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns an object that contains a new `CancelToken` and a function that, when called,
|
|
||||||
* cancels the `CancelToken`.
|
|
||||||
*/
|
|
||||||
static source() {
|
|
||||||
let cancel;
|
|
||||||
const token = new CancelToken(function executor(c) {
|
|
||||||
cancel = c;
|
|
||||||
});
|
|
||||||
return {
|
|
||||||
token,
|
|
||||||
cancel,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default CancelToken;
|
|
||||||
22
node_modules/axios/lib/cancel/CanceledError.js
generated
vendored
22
node_modules/axios/lib/cancel/CanceledError.js
generated
vendored
@@ -1,22 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
|
|
||||||
class CanceledError extends AxiosError {
|
|
||||||
/**
|
|
||||||
* A `CanceledError` is an object that is thrown when an operation is canceled.
|
|
||||||
*
|
|
||||||
* @param {string=} message The message.
|
|
||||||
* @param {Object=} config The config.
|
|
||||||
* @param {Object=} request The request.
|
|
||||||
*
|
|
||||||
* @returns {CanceledError} The created error.
|
|
||||||
*/
|
|
||||||
constructor(message, config, request) {
|
|
||||||
super(message == null ? 'canceled' : message, AxiosError.ERR_CANCELED, config, request);
|
|
||||||
this.name = 'CanceledError';
|
|
||||||
this.__CANCEL__ = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default CanceledError;
|
|
||||||
5
node_modules/axios/lib/cancel/isCancel.js
generated
vendored
5
node_modules/axios/lib/cancel/isCancel.js
generated
vendored
@@ -1,5 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
export default function isCancel(value) {
|
|
||||||
return !!(value && value.__CANCEL__);
|
|
||||||
}
|
|
||||||
277
node_modules/axios/lib/core/Axios.js
generated
vendored
277
node_modules/axios/lib/core/Axios.js
generated
vendored
@@ -1,277 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import buildURL from '../helpers/buildURL.js';
|
|
||||||
import InterceptorManager from './InterceptorManager.js';
|
|
||||||
import dispatchRequest from './dispatchRequest.js';
|
|
||||||
import mergeConfig from './mergeConfig.js';
|
|
||||||
import buildFullPath from './buildFullPath.js';
|
|
||||||
import validator from '../helpers/validator.js';
|
|
||||||
import AxiosHeaders from './AxiosHeaders.js';
|
|
||||||
import transitionalDefaults from '../defaults/transitional.js';
|
|
||||||
|
|
||||||
const validators = validator.validators;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a new instance of Axios
|
|
||||||
*
|
|
||||||
* @param {Object} instanceConfig The default config for the instance
|
|
||||||
*
|
|
||||||
* @return {Axios} A new instance of Axios
|
|
||||||
*/
|
|
||||||
class Axios {
|
|
||||||
constructor(instanceConfig) {
|
|
||||||
this.defaults = instanceConfig || {};
|
|
||||||
this.interceptors = {
|
|
||||||
request: new InterceptorManager(),
|
|
||||||
response: new InterceptorManager(),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Dispatch a request
|
|
||||||
*
|
|
||||||
* @param {String|Object} configOrUrl The config specific for this request (merged with this.defaults)
|
|
||||||
* @param {?Object} config
|
|
||||||
*
|
|
||||||
* @returns {Promise} The Promise to be fulfilled
|
|
||||||
*/
|
|
||||||
async request(configOrUrl, config) {
|
|
||||||
try {
|
|
||||||
return await this._request(configOrUrl, config);
|
|
||||||
} catch (err) {
|
|
||||||
if (err instanceof Error) {
|
|
||||||
let dummy = {};
|
|
||||||
|
|
||||||
Error.captureStackTrace ? Error.captureStackTrace(dummy) : (dummy = new Error());
|
|
||||||
|
|
||||||
// slice off the Error: ... line
|
|
||||||
const stack = (() => {
|
|
||||||
if (!dummy.stack) {
|
|
||||||
return '';
|
|
||||||
}
|
|
||||||
|
|
||||||
const firstNewlineIndex = dummy.stack.indexOf('\n');
|
|
||||||
|
|
||||||
return firstNewlineIndex === -1 ? '' : dummy.stack.slice(firstNewlineIndex + 1);
|
|
||||||
})();
|
|
||||||
try {
|
|
||||||
if (!err.stack) {
|
|
||||||
err.stack = stack;
|
|
||||||
// match without the 2 top stack lines
|
|
||||||
} else if (stack) {
|
|
||||||
const firstNewlineIndex = stack.indexOf('\n');
|
|
||||||
const secondNewlineIndex =
|
|
||||||
firstNewlineIndex === -1 ? -1 : stack.indexOf('\n', firstNewlineIndex + 1);
|
|
||||||
const stackWithoutTwoTopLines =
|
|
||||||
secondNewlineIndex === -1 ? '' : stack.slice(secondNewlineIndex + 1);
|
|
||||||
|
|
||||||
if (!String(err.stack).endsWith(stackWithoutTwoTopLines)) {
|
|
||||||
err.stack += '\n' + stack;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
// ignore the case where "stack" is an un-writable property
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
_request(configOrUrl, config) {
|
|
||||||
/*eslint no-param-reassign:0*/
|
|
||||||
// Allow for axios('example/url'[, config]) a la fetch API
|
|
||||||
if (typeof configOrUrl === 'string') {
|
|
||||||
config = config || {};
|
|
||||||
config.url = configOrUrl;
|
|
||||||
} else {
|
|
||||||
config = configOrUrl || {};
|
|
||||||
}
|
|
||||||
|
|
||||||
config = mergeConfig(this.defaults, config);
|
|
||||||
|
|
||||||
const { transitional, paramsSerializer, headers } = config;
|
|
||||||
|
|
||||||
if (transitional !== undefined) {
|
|
||||||
validator.assertOptions(
|
|
||||||
transitional,
|
|
||||||
{
|
|
||||||
silentJSONParsing: validators.transitional(validators.boolean),
|
|
||||||
forcedJSONParsing: validators.transitional(validators.boolean),
|
|
||||||
clarifyTimeoutError: validators.transitional(validators.boolean),
|
|
||||||
legacyInterceptorReqResOrdering: validators.transitional(validators.boolean),
|
|
||||||
},
|
|
||||||
false
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (paramsSerializer != null) {
|
|
||||||
if (utils.isFunction(paramsSerializer)) {
|
|
||||||
config.paramsSerializer = {
|
|
||||||
serialize: paramsSerializer,
|
|
||||||
};
|
|
||||||
} else {
|
|
||||||
validator.assertOptions(
|
|
||||||
paramsSerializer,
|
|
||||||
{
|
|
||||||
encode: validators.function,
|
|
||||||
serialize: validators.function,
|
|
||||||
},
|
|
||||||
true
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Set config.allowAbsoluteUrls
|
|
||||||
if (config.allowAbsoluteUrls !== undefined) {
|
|
||||||
// do nothing
|
|
||||||
} else if (this.defaults.allowAbsoluteUrls !== undefined) {
|
|
||||||
config.allowAbsoluteUrls = this.defaults.allowAbsoluteUrls;
|
|
||||||
} else {
|
|
||||||
config.allowAbsoluteUrls = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
validator.assertOptions(
|
|
||||||
config,
|
|
||||||
{
|
|
||||||
baseUrl: validators.spelling('baseURL'),
|
|
||||||
withXsrfToken: validators.spelling('withXSRFToken'),
|
|
||||||
},
|
|
||||||
true
|
|
||||||
);
|
|
||||||
|
|
||||||
// Set config.method
|
|
||||||
config.method = (config.method || this.defaults.method || 'get').toLowerCase();
|
|
||||||
|
|
||||||
// Flatten headers
|
|
||||||
let contextHeaders = headers && utils.merge(headers.common, headers[config.method]);
|
|
||||||
|
|
||||||
headers &&
|
|
||||||
utils.forEach(['delete', 'get', 'head', 'post', 'put', 'patch', 'common'], (method) => {
|
|
||||||
delete headers[method];
|
|
||||||
});
|
|
||||||
|
|
||||||
config.headers = AxiosHeaders.concat(contextHeaders, headers);
|
|
||||||
|
|
||||||
// filter out skipped interceptors
|
|
||||||
const requestInterceptorChain = [];
|
|
||||||
let synchronousRequestInterceptors = true;
|
|
||||||
this.interceptors.request.forEach(function unshiftRequestInterceptors(interceptor) {
|
|
||||||
if (typeof interceptor.runWhen === 'function' && interceptor.runWhen(config) === false) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
synchronousRequestInterceptors = synchronousRequestInterceptors && interceptor.synchronous;
|
|
||||||
|
|
||||||
const transitional = config.transitional || transitionalDefaults;
|
|
||||||
const legacyInterceptorReqResOrdering =
|
|
||||||
transitional && transitional.legacyInterceptorReqResOrdering;
|
|
||||||
|
|
||||||
if (legacyInterceptorReqResOrdering) {
|
|
||||||
requestInterceptorChain.unshift(interceptor.fulfilled, interceptor.rejected);
|
|
||||||
} else {
|
|
||||||
requestInterceptorChain.push(interceptor.fulfilled, interceptor.rejected);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
const responseInterceptorChain = [];
|
|
||||||
this.interceptors.response.forEach(function pushResponseInterceptors(interceptor) {
|
|
||||||
responseInterceptorChain.push(interceptor.fulfilled, interceptor.rejected);
|
|
||||||
});
|
|
||||||
|
|
||||||
let promise;
|
|
||||||
let i = 0;
|
|
||||||
let len;
|
|
||||||
|
|
||||||
if (!synchronousRequestInterceptors) {
|
|
||||||
const chain = [dispatchRequest.bind(this), undefined];
|
|
||||||
chain.unshift(...requestInterceptorChain);
|
|
||||||
chain.push(...responseInterceptorChain);
|
|
||||||
len = chain.length;
|
|
||||||
|
|
||||||
promise = Promise.resolve(config);
|
|
||||||
|
|
||||||
while (i < len) {
|
|
||||||
promise = promise.then(chain[i++], chain[i++]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return promise;
|
|
||||||
}
|
|
||||||
|
|
||||||
len = requestInterceptorChain.length;
|
|
||||||
|
|
||||||
let newConfig = config;
|
|
||||||
|
|
||||||
while (i < len) {
|
|
||||||
const onFulfilled = requestInterceptorChain[i++];
|
|
||||||
const onRejected = requestInterceptorChain[i++];
|
|
||||||
try {
|
|
||||||
newConfig = onFulfilled(newConfig);
|
|
||||||
} catch (error) {
|
|
||||||
onRejected.call(this, error);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
promise = dispatchRequest.call(this, newConfig);
|
|
||||||
} catch (error) {
|
|
||||||
return Promise.reject(error);
|
|
||||||
}
|
|
||||||
|
|
||||||
i = 0;
|
|
||||||
len = responseInterceptorChain.length;
|
|
||||||
|
|
||||||
while (i < len) {
|
|
||||||
promise = promise.then(responseInterceptorChain[i++], responseInterceptorChain[i++]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return promise;
|
|
||||||
}
|
|
||||||
|
|
||||||
getUri(config) {
|
|
||||||
config = mergeConfig(this.defaults, config);
|
|
||||||
const fullPath = buildFullPath(config.baseURL, config.url, config.allowAbsoluteUrls);
|
|
||||||
return buildURL(fullPath, config.params, config.paramsSerializer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Provide aliases for supported request methods
|
|
||||||
utils.forEach(['delete', 'get', 'head', 'options'], function forEachMethodNoData(method) {
|
|
||||||
/*eslint func-names:0*/
|
|
||||||
Axios.prototype[method] = function (url, config) {
|
|
||||||
return this.request(
|
|
||||||
mergeConfig(config || {}, {
|
|
||||||
method,
|
|
||||||
url,
|
|
||||||
data: (config || {}).data,
|
|
||||||
})
|
|
||||||
);
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
utils.forEach(['post', 'put', 'patch'], function forEachMethodWithData(method) {
|
|
||||||
function generateHTTPMethod(isForm) {
|
|
||||||
return function httpMethod(url, data, config) {
|
|
||||||
return this.request(
|
|
||||||
mergeConfig(config || {}, {
|
|
||||||
method,
|
|
||||||
headers: isForm
|
|
||||||
? {
|
|
||||||
'Content-Type': 'multipart/form-data',
|
|
||||||
}
|
|
||||||
: {},
|
|
||||||
url,
|
|
||||||
data,
|
|
||||||
})
|
|
||||||
);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
Axios.prototype[method] = generateHTTPMethod();
|
|
||||||
|
|
||||||
Axios.prototype[method + 'Form'] = generateHTTPMethod(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
export default Axios;
|
|
||||||
91
node_modules/axios/lib/core/AxiosError.js
generated
vendored
91
node_modules/axios/lib/core/AxiosError.js
generated
vendored
@@ -1,91 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
class AxiosError extends Error {
|
|
||||||
static from(error, code, config, request, response, customProps) {
|
|
||||||
const axiosError = new AxiosError(error.message, code || error.code, config, request, response);
|
|
||||||
axiosError.cause = error;
|
|
||||||
axiosError.name = error.name;
|
|
||||||
|
|
||||||
// Preserve status from the original error if not already set from response
|
|
||||||
if (error.status != null && axiosError.status == null) {
|
|
||||||
axiosError.status = error.status;
|
|
||||||
}
|
|
||||||
|
|
||||||
customProps && Object.assign(axiosError, customProps);
|
|
||||||
return axiosError;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create an Error with the specified message, config, error code, request and response.
|
|
||||||
*
|
|
||||||
* @param {string} message The error message.
|
|
||||||
* @param {string} [code] The error code (for example, 'ECONNABORTED').
|
|
||||||
* @param {Object} [config] The config.
|
|
||||||
* @param {Object} [request] The request.
|
|
||||||
* @param {Object} [response] The response.
|
|
||||||
*
|
|
||||||
* @returns {Error} The created error.
|
|
||||||
*/
|
|
||||||
constructor(message, code, config, request, response) {
|
|
||||||
super(message);
|
|
||||||
|
|
||||||
// Make message enumerable to maintain backward compatibility
|
|
||||||
// The native Error constructor sets message as non-enumerable,
|
|
||||||
// but axios < v1.13.3 had it as enumerable
|
|
||||||
Object.defineProperty(this, 'message', {
|
|
||||||
value: message,
|
|
||||||
enumerable: true,
|
|
||||||
writable: true,
|
|
||||||
configurable: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
this.name = 'AxiosError';
|
|
||||||
this.isAxiosError = true;
|
|
||||||
code && (this.code = code);
|
|
||||||
config && (this.config = config);
|
|
||||||
request && (this.request = request);
|
|
||||||
if (response) {
|
|
||||||
this.response = response;
|
|
||||||
this.status = response.status;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
toJSON() {
|
|
||||||
return {
|
|
||||||
// Standard
|
|
||||||
message: this.message,
|
|
||||||
name: this.name,
|
|
||||||
// Microsoft
|
|
||||||
description: this.description,
|
|
||||||
number: this.number,
|
|
||||||
// Mozilla
|
|
||||||
fileName: this.fileName,
|
|
||||||
lineNumber: this.lineNumber,
|
|
||||||
columnNumber: this.columnNumber,
|
|
||||||
stack: this.stack,
|
|
||||||
// Axios
|
|
||||||
config: utils.toJSONObject(this.config),
|
|
||||||
code: this.code,
|
|
||||||
status: this.status,
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// This can be changed to static properties as soon as the parser options in .eslint.cjs are updated.
|
|
||||||
AxiosError.ERR_BAD_OPTION_VALUE = 'ERR_BAD_OPTION_VALUE';
|
|
||||||
AxiosError.ERR_BAD_OPTION = 'ERR_BAD_OPTION';
|
|
||||||
AxiosError.ECONNABORTED = 'ECONNABORTED';
|
|
||||||
AxiosError.ETIMEDOUT = 'ETIMEDOUT';
|
|
||||||
AxiosError.ERR_NETWORK = 'ERR_NETWORK';
|
|
||||||
AxiosError.ERR_FR_TOO_MANY_REDIRECTS = 'ERR_FR_TOO_MANY_REDIRECTS';
|
|
||||||
AxiosError.ERR_DEPRECATED = 'ERR_DEPRECATED';
|
|
||||||
AxiosError.ERR_BAD_RESPONSE = 'ERR_BAD_RESPONSE';
|
|
||||||
AxiosError.ERR_BAD_REQUEST = 'ERR_BAD_REQUEST';
|
|
||||||
AxiosError.ERR_CANCELED = 'ERR_CANCELED';
|
|
||||||
AxiosError.ERR_NOT_SUPPORT = 'ERR_NOT_SUPPORT';
|
|
||||||
AxiosError.ERR_INVALID_URL = 'ERR_INVALID_URL';
|
|
||||||
AxiosError.ERR_FORM_DATA_DEPTH_EXCEEDED = 'ERR_FORM_DATA_DEPTH_EXCEEDED';
|
|
||||||
|
|
||||||
export default AxiosError;
|
|
||||||
377
node_modules/axios/lib/core/AxiosHeaders.js
generated
vendored
377
node_modules/axios/lib/core/AxiosHeaders.js
generated
vendored
@@ -1,377 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import parseHeaders from '../helpers/parseHeaders.js';
|
|
||||||
|
|
||||||
const $internals = Symbol('internals');
|
|
||||||
|
|
||||||
const INVALID_HEADER_VALUE_CHARS_RE = /[^\x09\x20-\x7E\x80-\xFF]/g;
|
|
||||||
|
|
||||||
function trimSPorHTAB(str) {
|
|
||||||
let start = 0;
|
|
||||||
let end = str.length;
|
|
||||||
|
|
||||||
while (start < end) {
|
|
||||||
const code = str.charCodeAt(start);
|
|
||||||
|
|
||||||
if (code !== 0x09 && code !== 0x20) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
start += 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
while (end > start) {
|
|
||||||
const code = str.charCodeAt(end - 1);
|
|
||||||
|
|
||||||
if (code !== 0x09 && code !== 0x20) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
end -= 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return start === 0 && end === str.length ? str : str.slice(start, end);
|
|
||||||
}
|
|
||||||
|
|
||||||
function normalizeHeader(header) {
|
|
||||||
return header && String(header).trim().toLowerCase();
|
|
||||||
}
|
|
||||||
|
|
||||||
function sanitizeHeaderValue(str) {
|
|
||||||
return trimSPorHTAB(str.replace(INVALID_HEADER_VALUE_CHARS_RE, ''));
|
|
||||||
}
|
|
||||||
|
|
||||||
function normalizeValue(value) {
|
|
||||||
if (value === false || value == null) {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
return utils.isArray(value) ? value.map(normalizeValue) : sanitizeHeaderValue(String(value));
|
|
||||||
}
|
|
||||||
|
|
||||||
function parseTokens(str) {
|
|
||||||
const tokens = Object.create(null);
|
|
||||||
const tokensRE = /([^\s,;=]+)\s*(?:=\s*([^,;]+))?/g;
|
|
||||||
let match;
|
|
||||||
|
|
||||||
while ((match = tokensRE.exec(str))) {
|
|
||||||
tokens[match[1]] = match[2];
|
|
||||||
}
|
|
||||||
|
|
||||||
return tokens;
|
|
||||||
}
|
|
||||||
|
|
||||||
const isValidHeaderName = (str) => /^[-_a-zA-Z0-9^`|~,!#$%&'*+.]+$/.test(str.trim());
|
|
||||||
|
|
||||||
function matchHeaderValue(context, value, header, filter, isHeaderNameFilter) {
|
|
||||||
if (utils.isFunction(filter)) {
|
|
||||||
return filter.call(this, value, header);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isHeaderNameFilter) {
|
|
||||||
value = header;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!utils.isString(value)) return;
|
|
||||||
|
|
||||||
if (utils.isString(filter)) {
|
|
||||||
return value.indexOf(filter) !== -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isRegExp(filter)) {
|
|
||||||
return filter.test(value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function formatHeader(header) {
|
|
||||||
return header
|
|
||||||
.trim()
|
|
||||||
.toLowerCase()
|
|
||||||
.replace(/([a-z\d])(\w*)/g, (w, char, str) => {
|
|
||||||
return char.toUpperCase() + str;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function buildAccessors(obj, header) {
|
|
||||||
const accessorName = utils.toCamelCase(' ' + header);
|
|
||||||
|
|
||||||
['get', 'set', 'has'].forEach((methodName) => {
|
|
||||||
Object.defineProperty(obj, methodName + accessorName, {
|
|
||||||
value: function (arg1, arg2, arg3) {
|
|
||||||
return this[methodName].call(this, header, arg1, arg2, arg3);
|
|
||||||
},
|
|
||||||
configurable: true,
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
class AxiosHeaders {
|
|
||||||
constructor(headers) {
|
|
||||||
headers && this.set(headers);
|
|
||||||
}
|
|
||||||
|
|
||||||
set(header, valueOrRewrite, rewrite) {
|
|
||||||
const self = this;
|
|
||||||
|
|
||||||
function setHeader(_value, _header, _rewrite) {
|
|
||||||
const lHeader = normalizeHeader(_header);
|
|
||||||
|
|
||||||
if (!lHeader) {
|
|
||||||
throw new Error('header name must be a non-empty string');
|
|
||||||
}
|
|
||||||
|
|
||||||
const key = utils.findKey(self, lHeader);
|
|
||||||
|
|
||||||
if (
|
|
||||||
!key ||
|
|
||||||
self[key] === undefined ||
|
|
||||||
_rewrite === true ||
|
|
||||||
(_rewrite === undefined && self[key] !== false)
|
|
||||||
) {
|
|
||||||
self[key || _header] = normalizeValue(_value);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const setHeaders = (headers, _rewrite) =>
|
|
||||||
utils.forEach(headers, (_value, _header) => setHeader(_value, _header, _rewrite));
|
|
||||||
|
|
||||||
if (utils.isPlainObject(header) || header instanceof this.constructor) {
|
|
||||||
setHeaders(header, valueOrRewrite);
|
|
||||||
} else if (utils.isString(header) && (header = header.trim()) && !isValidHeaderName(header)) {
|
|
||||||
setHeaders(parseHeaders(header), valueOrRewrite);
|
|
||||||
} else if (utils.isObject(header) && utils.isIterable(header)) {
|
|
||||||
let obj = {},
|
|
||||||
dest,
|
|
||||||
key;
|
|
||||||
for (const entry of header) {
|
|
||||||
if (!utils.isArray(entry)) {
|
|
||||||
throw TypeError('Object iterator must return a key-value pair');
|
|
||||||
}
|
|
||||||
|
|
||||||
obj[(key = entry[0])] = (dest = obj[key])
|
|
||||||
? utils.isArray(dest)
|
|
||||||
? [...dest, entry[1]]
|
|
||||||
: [dest, entry[1]]
|
|
||||||
: entry[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
setHeaders(obj, valueOrRewrite);
|
|
||||||
} else {
|
|
||||||
header != null && setHeader(valueOrRewrite, header, rewrite);
|
|
||||||
}
|
|
||||||
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
get(header, parser) {
|
|
||||||
header = normalizeHeader(header);
|
|
||||||
|
|
||||||
if (header) {
|
|
||||||
const key = utils.findKey(this, header);
|
|
||||||
|
|
||||||
if (key) {
|
|
||||||
const value = this[key];
|
|
||||||
|
|
||||||
if (!parser) {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (parser === true) {
|
|
||||||
return parseTokens(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isFunction(parser)) {
|
|
||||||
return parser.call(this, value, key);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isRegExp(parser)) {
|
|
||||||
return parser.exec(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new TypeError('parser must be boolean|regexp|function');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
has(header, matcher) {
|
|
||||||
header = normalizeHeader(header);
|
|
||||||
|
|
||||||
if (header) {
|
|
||||||
const key = utils.findKey(this, header);
|
|
||||||
|
|
||||||
return !!(
|
|
||||||
key &&
|
|
||||||
this[key] !== undefined &&
|
|
||||||
(!matcher || matchHeaderValue(this, this[key], key, matcher))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
delete(header, matcher) {
|
|
||||||
const self = this;
|
|
||||||
let deleted = false;
|
|
||||||
|
|
||||||
function deleteHeader(_header) {
|
|
||||||
_header = normalizeHeader(_header);
|
|
||||||
|
|
||||||
if (_header) {
|
|
||||||
const key = utils.findKey(self, _header);
|
|
||||||
|
|
||||||
if (key && (!matcher || matchHeaderValue(self, self[key], key, matcher))) {
|
|
||||||
delete self[key];
|
|
||||||
|
|
||||||
deleted = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isArray(header)) {
|
|
||||||
header.forEach(deleteHeader);
|
|
||||||
} else {
|
|
||||||
deleteHeader(header);
|
|
||||||
}
|
|
||||||
|
|
||||||
return deleted;
|
|
||||||
}
|
|
||||||
|
|
||||||
clear(matcher) {
|
|
||||||
const keys = Object.keys(this);
|
|
||||||
let i = keys.length;
|
|
||||||
let deleted = false;
|
|
||||||
|
|
||||||
while (i--) {
|
|
||||||
const key = keys[i];
|
|
||||||
if (!matcher || matchHeaderValue(this, this[key], key, matcher, true)) {
|
|
||||||
delete this[key];
|
|
||||||
deleted = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return deleted;
|
|
||||||
}
|
|
||||||
|
|
||||||
normalize(format) {
|
|
||||||
const self = this;
|
|
||||||
const headers = {};
|
|
||||||
|
|
||||||
utils.forEach(this, (value, header) => {
|
|
||||||
const key = utils.findKey(headers, header);
|
|
||||||
|
|
||||||
if (key) {
|
|
||||||
self[key] = normalizeValue(value);
|
|
||||||
delete self[header];
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const normalized = format ? formatHeader(header) : String(header).trim();
|
|
||||||
|
|
||||||
if (normalized !== header) {
|
|
||||||
delete self[header];
|
|
||||||
}
|
|
||||||
|
|
||||||
self[normalized] = normalizeValue(value);
|
|
||||||
|
|
||||||
headers[normalized] = true;
|
|
||||||
});
|
|
||||||
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
concat(...targets) {
|
|
||||||
return this.constructor.concat(this, ...targets);
|
|
||||||
}
|
|
||||||
|
|
||||||
toJSON(asStrings) {
|
|
||||||
const obj = Object.create(null);
|
|
||||||
|
|
||||||
utils.forEach(this, (value, header) => {
|
|
||||||
value != null &&
|
|
||||||
value !== false &&
|
|
||||||
(obj[header] = asStrings && utils.isArray(value) ? value.join(', ') : value);
|
|
||||||
});
|
|
||||||
|
|
||||||
return obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
[Symbol.iterator]() {
|
|
||||||
return Object.entries(this.toJSON())[Symbol.iterator]();
|
|
||||||
}
|
|
||||||
|
|
||||||
toString() {
|
|
||||||
return Object.entries(this.toJSON())
|
|
||||||
.map(([header, value]) => header + ': ' + value)
|
|
||||||
.join('\n');
|
|
||||||
}
|
|
||||||
|
|
||||||
getSetCookie() {
|
|
||||||
return this.get('set-cookie') || [];
|
|
||||||
}
|
|
||||||
|
|
||||||
get [Symbol.toStringTag]() {
|
|
||||||
return 'AxiosHeaders';
|
|
||||||
}
|
|
||||||
|
|
||||||
static from(thing) {
|
|
||||||
return thing instanceof this ? thing : new this(thing);
|
|
||||||
}
|
|
||||||
|
|
||||||
static concat(first, ...targets) {
|
|
||||||
const computed = new this(first);
|
|
||||||
|
|
||||||
targets.forEach((target) => computed.set(target));
|
|
||||||
|
|
||||||
return computed;
|
|
||||||
}
|
|
||||||
|
|
||||||
static accessor(header) {
|
|
||||||
const internals =
|
|
||||||
(this[$internals] =
|
|
||||||
this[$internals] =
|
|
||||||
{
|
|
||||||
accessors: {},
|
|
||||||
});
|
|
||||||
|
|
||||||
const accessors = internals.accessors;
|
|
||||||
const prototype = this.prototype;
|
|
||||||
|
|
||||||
function defineAccessor(_header) {
|
|
||||||
const lHeader = normalizeHeader(_header);
|
|
||||||
|
|
||||||
if (!accessors[lHeader]) {
|
|
||||||
buildAccessors(prototype, _header);
|
|
||||||
accessors[lHeader] = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
utils.isArray(header) ? header.forEach(defineAccessor) : defineAccessor(header);
|
|
||||||
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
AxiosHeaders.accessor([
|
|
||||||
'Content-Type',
|
|
||||||
'Content-Length',
|
|
||||||
'Accept',
|
|
||||||
'Accept-Encoding',
|
|
||||||
'User-Agent',
|
|
||||||
'Authorization',
|
|
||||||
]);
|
|
||||||
|
|
||||||
// reserved names hotfix
|
|
||||||
utils.reduceDescriptors(AxiosHeaders.prototype, ({ value }, key) => {
|
|
||||||
let mapped = key[0].toUpperCase() + key.slice(1); // map `set` => `Set`
|
|
||||||
return {
|
|
||||||
get: () => value,
|
|
||||||
set(headerValue) {
|
|
||||||
this[mapped] = headerValue;
|
|
||||||
},
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
utils.freezeMethods(AxiosHeaders);
|
|
||||||
|
|
||||||
export default AxiosHeaders;
|
|
||||||
72
node_modules/axios/lib/core/InterceptorManager.js
generated
vendored
72
node_modules/axios/lib/core/InterceptorManager.js
generated
vendored
@@ -1,72 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
class InterceptorManager {
|
|
||||||
constructor() {
|
|
||||||
this.handlers = [];
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add a new interceptor to the stack
|
|
||||||
*
|
|
||||||
* @param {Function} fulfilled The function to handle `then` for a `Promise`
|
|
||||||
* @param {Function} rejected The function to handle `reject` for a `Promise`
|
|
||||||
* @param {Object} options The options for the interceptor, synchronous and runWhen
|
|
||||||
*
|
|
||||||
* @return {Number} An ID used to remove interceptor later
|
|
||||||
*/
|
|
||||||
use(fulfilled, rejected, options) {
|
|
||||||
this.handlers.push({
|
|
||||||
fulfilled,
|
|
||||||
rejected,
|
|
||||||
synchronous: options ? options.synchronous : false,
|
|
||||||
runWhen: options ? options.runWhen : null,
|
|
||||||
});
|
|
||||||
return this.handlers.length - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove an interceptor from the stack
|
|
||||||
*
|
|
||||||
* @param {Number} id The ID that was returned by `use`
|
|
||||||
*
|
|
||||||
* @returns {void}
|
|
||||||
*/
|
|
||||||
eject(id) {
|
|
||||||
if (this.handlers[id]) {
|
|
||||||
this.handlers[id] = null;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Clear all interceptors from the stack
|
|
||||||
*
|
|
||||||
* @returns {void}
|
|
||||||
*/
|
|
||||||
clear() {
|
|
||||||
if (this.handlers) {
|
|
||||||
this.handlers = [];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Iterate over all the registered interceptors
|
|
||||||
*
|
|
||||||
* This method is particularly useful for skipping over any
|
|
||||||
* interceptors that may have become `null` calling `eject`.
|
|
||||||
*
|
|
||||||
* @param {Function} fn The function to call for each interceptor
|
|
||||||
*
|
|
||||||
* @returns {void}
|
|
||||||
*/
|
|
||||||
forEach(fn) {
|
|
||||||
utils.forEach(this.handlers, function forEachHandler(h) {
|
|
||||||
if (h !== null) {
|
|
||||||
fn(h);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default InterceptorManager;
|
|
||||||
8
node_modules/axios/lib/core/README.md
generated
vendored
8
node_modules/axios/lib/core/README.md
generated
vendored
@@ -1,8 +0,0 @@
|
|||||||
# axios // core
|
|
||||||
|
|
||||||
The modules found in `core/` should be modules that are specific to the domain logic of axios. These modules would most likely not make sense to be consumed outside of the axios module, as their logic is too specific. Some examples of core modules are:
|
|
||||||
|
|
||||||
- Dispatching requests
|
|
||||||
- Requests sent via `adapters/` (see lib/adapters/README.md)
|
|
||||||
- Managing interceptors
|
|
||||||
- Handling config
|
|
||||||
22
node_modules/axios/lib/core/buildFullPath.js
generated
vendored
22
node_modules/axios/lib/core/buildFullPath.js
generated
vendored
@@ -1,22 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import isAbsoluteURL from '../helpers/isAbsoluteURL.js';
|
|
||||||
import combineURLs from '../helpers/combineURLs.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates a new URL by combining the baseURL with the requestedURL,
|
|
||||||
* only when the requestedURL is not already an absolute URL.
|
|
||||||
* If the requestURL is absolute, this function returns the requestedURL untouched.
|
|
||||||
*
|
|
||||||
* @param {string} baseURL The base URL
|
|
||||||
* @param {string} requestedURL Absolute or relative URL to combine
|
|
||||||
*
|
|
||||||
* @returns {string} The combined full path
|
|
||||||
*/
|
|
||||||
export default function buildFullPath(baseURL, requestedURL, allowAbsoluteUrls) {
|
|
||||||
let isRelativeUrl = !isAbsoluteURL(requestedURL);
|
|
||||||
if (baseURL && (isRelativeUrl || allowAbsoluteUrls === false)) {
|
|
||||||
return combineURLs(baseURL, requestedURL);
|
|
||||||
}
|
|
||||||
return requestedURL;
|
|
||||||
}
|
|
||||||
77
node_modules/axios/lib/core/dispatchRequest.js
generated
vendored
77
node_modules/axios/lib/core/dispatchRequest.js
generated
vendored
@@ -1,77 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import transformData from './transformData.js';
|
|
||||||
import isCancel from '../cancel/isCancel.js';
|
|
||||||
import defaults from '../defaults/index.js';
|
|
||||||
import CanceledError from '../cancel/CanceledError.js';
|
|
||||||
import AxiosHeaders from '../core/AxiosHeaders.js';
|
|
||||||
import adapters from '../adapters/adapters.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Throws a `CanceledError` if cancellation has been requested.
|
|
||||||
*
|
|
||||||
* @param {Object} config The config that is to be used for the request
|
|
||||||
*
|
|
||||||
* @returns {void}
|
|
||||||
*/
|
|
||||||
function throwIfCancellationRequested(config) {
|
|
||||||
if (config.cancelToken) {
|
|
||||||
config.cancelToken.throwIfRequested();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (config.signal && config.signal.aborted) {
|
|
||||||
throw new CanceledError(null, config);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Dispatch a request to the server using the configured adapter.
|
|
||||||
*
|
|
||||||
* @param {object} config The config that is to be used for the request
|
|
||||||
*
|
|
||||||
* @returns {Promise} The Promise to be fulfilled
|
|
||||||
*/
|
|
||||||
export default function dispatchRequest(config) {
|
|
||||||
throwIfCancellationRequested(config);
|
|
||||||
|
|
||||||
config.headers = AxiosHeaders.from(config.headers);
|
|
||||||
|
|
||||||
// Transform request data
|
|
||||||
config.data = transformData.call(config, config.transformRequest);
|
|
||||||
|
|
||||||
if (['post', 'put', 'patch'].indexOf(config.method) !== -1) {
|
|
||||||
config.headers.setContentType('application/x-www-form-urlencoded', false);
|
|
||||||
}
|
|
||||||
|
|
||||||
const adapter = adapters.getAdapter(config.adapter || defaults.adapter, config);
|
|
||||||
|
|
||||||
return adapter(config).then(
|
|
||||||
function onAdapterResolution(response) {
|
|
||||||
throwIfCancellationRequested(config);
|
|
||||||
|
|
||||||
// Transform response data
|
|
||||||
response.data = transformData.call(config, config.transformResponse, response);
|
|
||||||
|
|
||||||
response.headers = AxiosHeaders.from(response.headers);
|
|
||||||
|
|
||||||
return response;
|
|
||||||
},
|
|
||||||
function onAdapterRejection(reason) {
|
|
||||||
if (!isCancel(reason)) {
|
|
||||||
throwIfCancellationRequested(config);
|
|
||||||
|
|
||||||
// Transform response data
|
|
||||||
if (reason && reason.response) {
|
|
||||||
reason.response.data = transformData.call(
|
|
||||||
config,
|
|
||||||
config.transformResponse,
|
|
||||||
reason.response
|
|
||||||
);
|
|
||||||
reason.response.headers = AxiosHeaders.from(reason.response.headers);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return Promise.reject(reason);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
121
node_modules/axios/lib/core/mergeConfig.js
generated
vendored
121
node_modules/axios/lib/core/mergeConfig.js
generated
vendored
@@ -1,121 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import AxiosHeaders from './AxiosHeaders.js';
|
|
||||||
|
|
||||||
const headersToObject = (thing) => (thing instanceof AxiosHeaders ? { ...thing } : thing);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Config-specific merge-function which creates a new config-object
|
|
||||||
* by merging two configuration objects together.
|
|
||||||
*
|
|
||||||
* @param {Object} config1
|
|
||||||
* @param {Object} config2
|
|
||||||
*
|
|
||||||
* @returns {Object} New object resulting from merging config2 to config1
|
|
||||||
*/
|
|
||||||
export default function mergeConfig(config1, config2) {
|
|
||||||
// eslint-disable-next-line no-param-reassign
|
|
||||||
config2 = config2 || {};
|
|
||||||
|
|
||||||
// Use a null-prototype object so that downstream reads such as `config.auth`
|
|
||||||
// or `config.baseURL` cannot inherit polluted values from Object.prototype
|
|
||||||
// (see GHSA-q8qp-cvcw-x6jj). `hasOwnProperty` is restored as a non-enumerable
|
|
||||||
// own slot to preserve ergonomics for user code that relies on it.
|
|
||||||
const config = Object.create(null);
|
|
||||||
Object.defineProperty(config, 'hasOwnProperty', {
|
|
||||||
value: Object.prototype.hasOwnProperty,
|
|
||||||
enumerable: false,
|
|
||||||
writable: true,
|
|
||||||
configurable: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
function getMergedValue(target, source, prop, caseless) {
|
|
||||||
if (utils.isPlainObject(target) && utils.isPlainObject(source)) {
|
|
||||||
return utils.merge.call({ caseless }, target, source);
|
|
||||||
} else if (utils.isPlainObject(source)) {
|
|
||||||
return utils.merge({}, source);
|
|
||||||
} else if (utils.isArray(source)) {
|
|
||||||
return source.slice();
|
|
||||||
}
|
|
||||||
return source;
|
|
||||||
}
|
|
||||||
|
|
||||||
function mergeDeepProperties(a, b, prop, caseless) {
|
|
||||||
if (!utils.isUndefined(b)) {
|
|
||||||
return getMergedValue(a, b, prop, caseless);
|
|
||||||
} else if (!utils.isUndefined(a)) {
|
|
||||||
return getMergedValue(undefined, a, prop, caseless);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// eslint-disable-next-line consistent-return
|
|
||||||
function valueFromConfig2(a, b) {
|
|
||||||
if (!utils.isUndefined(b)) {
|
|
||||||
return getMergedValue(undefined, b);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// eslint-disable-next-line consistent-return
|
|
||||||
function defaultToConfig2(a, b) {
|
|
||||||
if (!utils.isUndefined(b)) {
|
|
||||||
return getMergedValue(undefined, b);
|
|
||||||
} else if (!utils.isUndefined(a)) {
|
|
||||||
return getMergedValue(undefined, a);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// eslint-disable-next-line consistent-return
|
|
||||||
function mergeDirectKeys(a, b, prop) {
|
|
||||||
if (utils.hasOwnProp(config2, prop)) {
|
|
||||||
return getMergedValue(a, b);
|
|
||||||
} else if (utils.hasOwnProp(config1, prop)) {
|
|
||||||
return getMergedValue(undefined, a);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const mergeMap = {
|
|
||||||
url: valueFromConfig2,
|
|
||||||
method: valueFromConfig2,
|
|
||||||
data: valueFromConfig2,
|
|
||||||
baseURL: defaultToConfig2,
|
|
||||||
transformRequest: defaultToConfig2,
|
|
||||||
transformResponse: defaultToConfig2,
|
|
||||||
paramsSerializer: defaultToConfig2,
|
|
||||||
timeout: defaultToConfig2,
|
|
||||||
timeoutMessage: defaultToConfig2,
|
|
||||||
withCredentials: defaultToConfig2,
|
|
||||||
withXSRFToken: defaultToConfig2,
|
|
||||||
adapter: defaultToConfig2,
|
|
||||||
responseType: defaultToConfig2,
|
|
||||||
xsrfCookieName: defaultToConfig2,
|
|
||||||
xsrfHeaderName: defaultToConfig2,
|
|
||||||
onUploadProgress: defaultToConfig2,
|
|
||||||
onDownloadProgress: defaultToConfig2,
|
|
||||||
decompress: defaultToConfig2,
|
|
||||||
maxContentLength: defaultToConfig2,
|
|
||||||
maxBodyLength: defaultToConfig2,
|
|
||||||
beforeRedirect: defaultToConfig2,
|
|
||||||
transport: defaultToConfig2,
|
|
||||||
httpAgent: defaultToConfig2,
|
|
||||||
httpsAgent: defaultToConfig2,
|
|
||||||
cancelToken: defaultToConfig2,
|
|
||||||
socketPath: defaultToConfig2,
|
|
||||||
allowedSocketPaths: defaultToConfig2,
|
|
||||||
responseEncoding: defaultToConfig2,
|
|
||||||
validateStatus: mergeDirectKeys,
|
|
||||||
headers: (a, b, prop) =>
|
|
||||||
mergeDeepProperties(headersToObject(a), headersToObject(b), prop, true),
|
|
||||||
};
|
|
||||||
|
|
||||||
utils.forEach(Object.keys({ ...config1, ...config2 }), function computeConfigValue(prop) {
|
|
||||||
if (prop === '__proto__' || prop === 'constructor' || prop === 'prototype') return;
|
|
||||||
const merge = utils.hasOwnProp(mergeMap, prop) ? mergeMap[prop] : mergeDeepProperties;
|
|
||||||
const a = utils.hasOwnProp(config1, prop) ? config1[prop] : undefined;
|
|
||||||
const b = utils.hasOwnProp(config2, prop) ? config2[prop] : undefined;
|
|
||||||
const configValue = merge(a, b, prop);
|
|
||||||
(utils.isUndefined(configValue) && merge !== mergeDirectKeys) || (config[prop] = configValue);
|
|
||||||
});
|
|
||||||
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
31
node_modules/axios/lib/core/settle.js
generated
vendored
31
node_modules/axios/lib/core/settle.js
generated
vendored
@@ -1,31 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import AxiosError from './AxiosError.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resolve or reject a Promise based on response status.
|
|
||||||
*
|
|
||||||
* @param {Function} resolve A function that resolves the promise.
|
|
||||||
* @param {Function} reject A function that rejects the promise.
|
|
||||||
* @param {object} response The response.
|
|
||||||
*
|
|
||||||
* @returns {object} The response.
|
|
||||||
*/
|
|
||||||
export default function settle(resolve, reject, response) {
|
|
||||||
const validateStatus = response.config.validateStatus;
|
|
||||||
if (!response.status || !validateStatus || validateStatus(response.status)) {
|
|
||||||
resolve(response);
|
|
||||||
} else {
|
|
||||||
reject(
|
|
||||||
new AxiosError(
|
|
||||||
'Request failed with status code ' + response.status,
|
|
||||||
[AxiosError.ERR_BAD_REQUEST, AxiosError.ERR_BAD_RESPONSE][
|
|
||||||
Math.floor(response.status / 100) - 4
|
|
||||||
],
|
|
||||||
response.config,
|
|
||||||
response.request,
|
|
||||||
response
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
28
node_modules/axios/lib/core/transformData.js
generated
vendored
28
node_modules/axios/lib/core/transformData.js
generated
vendored
@@ -1,28 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import defaults from '../defaults/index.js';
|
|
||||||
import AxiosHeaders from '../core/AxiosHeaders.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Transform the data for a request or a response
|
|
||||||
*
|
|
||||||
* @param {Array|Function} fns A single function or Array of functions
|
|
||||||
* @param {?Object} response The response object
|
|
||||||
*
|
|
||||||
* @returns {*} The resulting transformed data
|
|
||||||
*/
|
|
||||||
export default function transformData(fns, response) {
|
|
||||||
const config = this || defaults;
|
|
||||||
const context = response || config;
|
|
||||||
const headers = AxiosHeaders.from(context.headers);
|
|
||||||
let data = context.data;
|
|
||||||
|
|
||||||
utils.forEach(fns, function transform(fn) {
|
|
||||||
data = fn.call(config, data, headers.normalize(), response ? response.status : undefined);
|
|
||||||
});
|
|
||||||
|
|
||||||
headers.normalize();
|
|
||||||
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
177
node_modules/axios/lib/defaults/index.js
generated
vendored
177
node_modules/axios/lib/defaults/index.js
generated
vendored
@@ -1,177 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
import transitionalDefaults from './transitional.js';
|
|
||||||
import toFormData from '../helpers/toFormData.js';
|
|
||||||
import toURLEncodedForm from '../helpers/toURLEncodedForm.js';
|
|
||||||
import platform from '../platform/index.js';
|
|
||||||
import formDataToJSON from '../helpers/formDataToJSON.js';
|
|
||||||
|
|
||||||
const own = (obj, key) => (obj != null && utils.hasOwnProp(obj, key) ? obj[key] : undefined);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It takes a string, tries to parse it, and if it fails, it returns the stringified version
|
|
||||||
* of the input
|
|
||||||
*
|
|
||||||
* @param {any} rawValue - The value to be stringified.
|
|
||||||
* @param {Function} parser - A function that parses a string into a JavaScript object.
|
|
||||||
* @param {Function} encoder - A function that takes a value and returns a string.
|
|
||||||
*
|
|
||||||
* @returns {string} A stringified version of the rawValue.
|
|
||||||
*/
|
|
||||||
function stringifySafely(rawValue, parser, encoder) {
|
|
||||||
if (utils.isString(rawValue)) {
|
|
||||||
try {
|
|
||||||
(parser || JSON.parse)(rawValue);
|
|
||||||
return utils.trim(rawValue);
|
|
||||||
} catch (e) {
|
|
||||||
if (e.name !== 'SyntaxError') {
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return (encoder || JSON.stringify)(rawValue);
|
|
||||||
}
|
|
||||||
|
|
||||||
const defaults = {
|
|
||||||
transitional: transitionalDefaults,
|
|
||||||
|
|
||||||
adapter: ['xhr', 'http', 'fetch'],
|
|
||||||
|
|
||||||
transformRequest: [
|
|
||||||
function transformRequest(data, headers) {
|
|
||||||
const contentType = headers.getContentType() || '';
|
|
||||||
const hasJSONContentType = contentType.indexOf('application/json') > -1;
|
|
||||||
const isObjectPayload = utils.isObject(data);
|
|
||||||
|
|
||||||
if (isObjectPayload && utils.isHTMLForm(data)) {
|
|
||||||
data = new FormData(data);
|
|
||||||
}
|
|
||||||
|
|
||||||
const isFormData = utils.isFormData(data);
|
|
||||||
|
|
||||||
if (isFormData) {
|
|
||||||
return hasJSONContentType ? JSON.stringify(formDataToJSON(data)) : data;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (
|
|
||||||
utils.isArrayBuffer(data) ||
|
|
||||||
utils.isBuffer(data) ||
|
|
||||||
utils.isStream(data) ||
|
|
||||||
utils.isFile(data) ||
|
|
||||||
utils.isBlob(data) ||
|
|
||||||
utils.isReadableStream(data)
|
|
||||||
) {
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
if (utils.isArrayBufferView(data)) {
|
|
||||||
return data.buffer;
|
|
||||||
}
|
|
||||||
if (utils.isURLSearchParams(data)) {
|
|
||||||
headers.setContentType('application/x-www-form-urlencoded;charset=utf-8', false);
|
|
||||||
return data.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
let isFileList;
|
|
||||||
|
|
||||||
if (isObjectPayload) {
|
|
||||||
const formSerializer = own(this, 'formSerializer');
|
|
||||||
if (contentType.indexOf('application/x-www-form-urlencoded') > -1) {
|
|
||||||
return toURLEncodedForm(data, formSerializer).toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (
|
|
||||||
(isFileList = utils.isFileList(data)) ||
|
|
||||||
contentType.indexOf('multipart/form-data') > -1
|
|
||||||
) {
|
|
||||||
const env = own(this, 'env');
|
|
||||||
const _FormData = env && env.FormData;
|
|
||||||
|
|
||||||
return toFormData(
|
|
||||||
isFileList ? { 'files[]': data } : data,
|
|
||||||
_FormData && new _FormData(),
|
|
||||||
formSerializer
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isObjectPayload || hasJSONContentType) {
|
|
||||||
headers.setContentType('application/json', false);
|
|
||||||
return stringifySafely(data);
|
|
||||||
}
|
|
||||||
|
|
||||||
return data;
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
transformResponse: [
|
|
||||||
function transformResponse(data) {
|
|
||||||
const transitional = own(this, 'transitional') || defaults.transitional;
|
|
||||||
const forcedJSONParsing = transitional && transitional.forcedJSONParsing;
|
|
||||||
const responseType = own(this, 'responseType');
|
|
||||||
const JSONRequested = responseType === 'json';
|
|
||||||
|
|
||||||
if (utils.isResponse(data) || utils.isReadableStream(data)) {
|
|
||||||
return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (
|
|
||||||
data &&
|
|
||||||
utils.isString(data) &&
|
|
||||||
((forcedJSONParsing && !responseType) || JSONRequested)
|
|
||||||
) {
|
|
||||||
const silentJSONParsing = transitional && transitional.silentJSONParsing;
|
|
||||||
const strictJSONParsing = !silentJSONParsing && JSONRequested;
|
|
||||||
|
|
||||||
try {
|
|
||||||
return JSON.parse(data, own(this, 'parseReviver'));
|
|
||||||
} catch (e) {
|
|
||||||
if (strictJSONParsing) {
|
|
||||||
if (e.name === 'SyntaxError') {
|
|
||||||
throw AxiosError.from(e, AxiosError.ERR_BAD_RESPONSE, this, null, own(this, 'response'));
|
|
||||||
}
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return data;
|
|
||||||
},
|
|
||||||
],
|
|
||||||
|
|
||||||
/**
|
|
||||||
* A timeout in milliseconds to abort a request. If set to 0 (default) a
|
|
||||||
* timeout is not created.
|
|
||||||
*/
|
|
||||||
timeout: 0,
|
|
||||||
|
|
||||||
xsrfCookieName: 'XSRF-TOKEN',
|
|
||||||
xsrfHeaderName: 'X-XSRF-TOKEN',
|
|
||||||
|
|
||||||
maxContentLength: -1,
|
|
||||||
maxBodyLength: -1,
|
|
||||||
|
|
||||||
env: {
|
|
||||||
FormData: platform.classes.FormData,
|
|
||||||
Blob: platform.classes.Blob,
|
|
||||||
},
|
|
||||||
|
|
||||||
validateStatus: function validateStatus(status) {
|
|
||||||
return status >= 200 && status < 300;
|
|
||||||
},
|
|
||||||
|
|
||||||
headers: {
|
|
||||||
common: {
|
|
||||||
Accept: 'application/json, text/plain, */*',
|
|
||||||
'Content-Type': undefined,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
utils.forEach(['delete', 'get', 'head', 'post', 'put', 'patch'], (method) => {
|
|
||||||
defaults.headers[method] = {};
|
|
||||||
});
|
|
||||||
|
|
||||||
export default defaults;
|
|
||||||
8
node_modules/axios/lib/defaults/transitional.js
generated
vendored
8
node_modules/axios/lib/defaults/transitional.js
generated
vendored
@@ -1,8 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
export default {
|
|
||||||
silentJSONParsing: true,
|
|
||||||
forcedJSONParsing: true,
|
|
||||||
clarifyTimeoutError: false,
|
|
||||||
legacyInterceptorReqResOrdering: true,
|
|
||||||
};
|
|
||||||
3
node_modules/axios/lib/env/README.md
generated
vendored
3
node_modules/axios/lib/env/README.md
generated
vendored
@@ -1,3 +0,0 @@
|
|||||||
# axios // env
|
|
||||||
|
|
||||||
The `data.js` file is updated automatically when the package version is upgrading. Please do not edit it manually.
|
|
||||||
2
node_modules/axios/lib/env/classes/FormData.js
generated
vendored
2
node_modules/axios/lib/env/classes/FormData.js
generated
vendored
@@ -1,2 +0,0 @@
|
|||||||
import _FormData from 'form-data';
|
|
||||||
export default typeof FormData !== 'undefined' ? FormData : _FormData;
|
|
||||||
1
node_modules/axios/lib/env/data.js
generated
vendored
1
node_modules/axios/lib/env/data.js
generated
vendored
@@ -1 +0,0 @@
|
|||||||
export const VERSION = "1.15.2";
|
|
||||||
156
node_modules/axios/lib/helpers/AxiosTransformStream.js
generated
vendored
156
node_modules/axios/lib/helpers/AxiosTransformStream.js
generated
vendored
@@ -1,156 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import stream from 'stream';
|
|
||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
const kInternals = Symbol('internals');
|
|
||||||
|
|
||||||
class AxiosTransformStream extends stream.Transform {
|
|
||||||
constructor(options) {
|
|
||||||
options = utils.toFlatObject(
|
|
||||||
options,
|
|
||||||
{
|
|
||||||
maxRate: 0,
|
|
||||||
chunkSize: 64 * 1024,
|
|
||||||
minChunkSize: 100,
|
|
||||||
timeWindow: 500,
|
|
||||||
ticksRate: 2,
|
|
||||||
samplesCount: 15,
|
|
||||||
},
|
|
||||||
null,
|
|
||||||
(prop, source) => {
|
|
||||||
return !utils.isUndefined(source[prop]);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
super({
|
|
||||||
readableHighWaterMark: options.chunkSize,
|
|
||||||
});
|
|
||||||
|
|
||||||
const internals = (this[kInternals] = {
|
|
||||||
timeWindow: options.timeWindow,
|
|
||||||
chunkSize: options.chunkSize,
|
|
||||||
maxRate: options.maxRate,
|
|
||||||
minChunkSize: options.minChunkSize,
|
|
||||||
bytesSeen: 0,
|
|
||||||
isCaptured: false,
|
|
||||||
notifiedBytesLoaded: 0,
|
|
||||||
ts: Date.now(),
|
|
||||||
bytes: 0,
|
|
||||||
onReadCallback: null,
|
|
||||||
});
|
|
||||||
|
|
||||||
this.on('newListener', (event) => {
|
|
||||||
if (event === 'progress') {
|
|
||||||
if (!internals.isCaptured) {
|
|
||||||
internals.isCaptured = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
_read(size) {
|
|
||||||
const internals = this[kInternals];
|
|
||||||
|
|
||||||
if (internals.onReadCallback) {
|
|
||||||
internals.onReadCallback();
|
|
||||||
}
|
|
||||||
|
|
||||||
return super._read(size);
|
|
||||||
}
|
|
||||||
|
|
||||||
_transform(chunk, encoding, callback) {
|
|
||||||
const internals = this[kInternals];
|
|
||||||
const maxRate = internals.maxRate;
|
|
||||||
|
|
||||||
const readableHighWaterMark = this.readableHighWaterMark;
|
|
||||||
|
|
||||||
const timeWindow = internals.timeWindow;
|
|
||||||
|
|
||||||
const divider = 1000 / timeWindow;
|
|
||||||
const bytesThreshold = maxRate / divider;
|
|
||||||
const minChunkSize =
|
|
||||||
internals.minChunkSize !== false
|
|
||||||
? Math.max(internals.minChunkSize, bytesThreshold * 0.01)
|
|
||||||
: 0;
|
|
||||||
|
|
||||||
const pushChunk = (_chunk, _callback) => {
|
|
||||||
const bytes = Buffer.byteLength(_chunk);
|
|
||||||
internals.bytesSeen += bytes;
|
|
||||||
internals.bytes += bytes;
|
|
||||||
|
|
||||||
internals.isCaptured && this.emit('progress', internals.bytesSeen);
|
|
||||||
|
|
||||||
if (this.push(_chunk)) {
|
|
||||||
process.nextTick(_callback);
|
|
||||||
} else {
|
|
||||||
internals.onReadCallback = () => {
|
|
||||||
internals.onReadCallback = null;
|
|
||||||
process.nextTick(_callback);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const transformChunk = (_chunk, _callback) => {
|
|
||||||
const chunkSize = Buffer.byteLength(_chunk);
|
|
||||||
let chunkRemainder = null;
|
|
||||||
let maxChunkSize = readableHighWaterMark;
|
|
||||||
let bytesLeft;
|
|
||||||
let passed = 0;
|
|
||||||
|
|
||||||
if (maxRate) {
|
|
||||||
const now = Date.now();
|
|
||||||
|
|
||||||
if (!internals.ts || (passed = now - internals.ts) >= timeWindow) {
|
|
||||||
internals.ts = now;
|
|
||||||
bytesLeft = bytesThreshold - internals.bytes;
|
|
||||||
internals.bytes = bytesLeft < 0 ? -bytesLeft : 0;
|
|
||||||
passed = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
bytesLeft = bytesThreshold - internals.bytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (maxRate) {
|
|
||||||
if (bytesLeft <= 0) {
|
|
||||||
// next time window
|
|
||||||
return setTimeout(() => {
|
|
||||||
_callback(null, _chunk);
|
|
||||||
}, timeWindow - passed);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bytesLeft < maxChunkSize) {
|
|
||||||
maxChunkSize = bytesLeft;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (maxChunkSize && chunkSize > maxChunkSize && chunkSize - maxChunkSize > minChunkSize) {
|
|
||||||
chunkRemainder = _chunk.subarray(maxChunkSize);
|
|
||||||
_chunk = _chunk.subarray(0, maxChunkSize);
|
|
||||||
}
|
|
||||||
|
|
||||||
pushChunk(
|
|
||||||
_chunk,
|
|
||||||
chunkRemainder
|
|
||||||
? () => {
|
|
||||||
process.nextTick(_callback, null, chunkRemainder);
|
|
||||||
}
|
|
||||||
: _callback
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
transformChunk(chunk, function transformNextChunk(err, _chunk) {
|
|
||||||
if (err) {
|
|
||||||
return callback(err);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_chunk) {
|
|
||||||
transformChunk(_chunk, transformNextChunk);
|
|
||||||
} else {
|
|
||||||
callback(null);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default AxiosTransformStream;
|
|
||||||
61
node_modules/axios/lib/helpers/AxiosURLSearchParams.js
generated
vendored
61
node_modules/axios/lib/helpers/AxiosURLSearchParams.js
generated
vendored
@@ -1,61 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import toFormData from './toFormData.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It encodes a string by replacing all characters that are not in the unreserved set with
|
|
||||||
* their percent-encoded equivalents
|
|
||||||
*
|
|
||||||
* @param {string} str - The string to encode.
|
|
||||||
*
|
|
||||||
* @returns {string} The encoded string.
|
|
||||||
*/
|
|
||||||
function encode(str) {
|
|
||||||
const charMap = {
|
|
||||||
'!': '%21',
|
|
||||||
"'": '%27',
|
|
||||||
'(': '%28',
|
|
||||||
')': '%29',
|
|
||||||
'~': '%7E',
|
|
||||||
'%20': '+',
|
|
||||||
};
|
|
||||||
return encodeURIComponent(str).replace(/[!'()~]|%20/g, function replacer(match) {
|
|
||||||
return charMap[match];
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It takes a params object and converts it to a FormData object
|
|
||||||
*
|
|
||||||
* @param {Object<string, any>} params - The parameters to be converted to a FormData object.
|
|
||||||
* @param {Object<string, any>} options - The options object passed to the Axios constructor.
|
|
||||||
*
|
|
||||||
* @returns {void}
|
|
||||||
*/
|
|
||||||
function AxiosURLSearchParams(params, options) {
|
|
||||||
this._pairs = [];
|
|
||||||
|
|
||||||
params && toFormData(params, this, options);
|
|
||||||
}
|
|
||||||
|
|
||||||
const prototype = AxiosURLSearchParams.prototype;
|
|
||||||
|
|
||||||
prototype.append = function append(name, value) {
|
|
||||||
this._pairs.push([name, value]);
|
|
||||||
};
|
|
||||||
|
|
||||||
prototype.toString = function toString(encoder) {
|
|
||||||
const _encode = encoder
|
|
||||||
? function (value) {
|
|
||||||
return encoder.call(this, value, encode);
|
|
||||||
}
|
|
||||||
: encode;
|
|
||||||
|
|
||||||
return this._pairs
|
|
||||||
.map(function each(pair) {
|
|
||||||
return _encode(pair[0]) + '=' + _encode(pair[1]);
|
|
||||||
}, '')
|
|
||||||
.join('&');
|
|
||||||
};
|
|
||||||
|
|
||||||
export default AxiosURLSearchParams;
|
|
||||||
77
node_modules/axios/lib/helpers/HttpStatusCode.js
generated
vendored
77
node_modules/axios/lib/helpers/HttpStatusCode.js
generated
vendored
@@ -1,77 +0,0 @@
|
|||||||
const HttpStatusCode = {
|
|
||||||
Continue: 100,
|
|
||||||
SwitchingProtocols: 101,
|
|
||||||
Processing: 102,
|
|
||||||
EarlyHints: 103,
|
|
||||||
Ok: 200,
|
|
||||||
Created: 201,
|
|
||||||
Accepted: 202,
|
|
||||||
NonAuthoritativeInformation: 203,
|
|
||||||
NoContent: 204,
|
|
||||||
ResetContent: 205,
|
|
||||||
PartialContent: 206,
|
|
||||||
MultiStatus: 207,
|
|
||||||
AlreadyReported: 208,
|
|
||||||
ImUsed: 226,
|
|
||||||
MultipleChoices: 300,
|
|
||||||
MovedPermanently: 301,
|
|
||||||
Found: 302,
|
|
||||||
SeeOther: 303,
|
|
||||||
NotModified: 304,
|
|
||||||
UseProxy: 305,
|
|
||||||
Unused: 306,
|
|
||||||
TemporaryRedirect: 307,
|
|
||||||
PermanentRedirect: 308,
|
|
||||||
BadRequest: 400,
|
|
||||||
Unauthorized: 401,
|
|
||||||
PaymentRequired: 402,
|
|
||||||
Forbidden: 403,
|
|
||||||
NotFound: 404,
|
|
||||||
MethodNotAllowed: 405,
|
|
||||||
NotAcceptable: 406,
|
|
||||||
ProxyAuthenticationRequired: 407,
|
|
||||||
RequestTimeout: 408,
|
|
||||||
Conflict: 409,
|
|
||||||
Gone: 410,
|
|
||||||
LengthRequired: 411,
|
|
||||||
PreconditionFailed: 412,
|
|
||||||
PayloadTooLarge: 413,
|
|
||||||
UriTooLong: 414,
|
|
||||||
UnsupportedMediaType: 415,
|
|
||||||
RangeNotSatisfiable: 416,
|
|
||||||
ExpectationFailed: 417,
|
|
||||||
ImATeapot: 418,
|
|
||||||
MisdirectedRequest: 421,
|
|
||||||
UnprocessableEntity: 422,
|
|
||||||
Locked: 423,
|
|
||||||
FailedDependency: 424,
|
|
||||||
TooEarly: 425,
|
|
||||||
UpgradeRequired: 426,
|
|
||||||
PreconditionRequired: 428,
|
|
||||||
TooManyRequests: 429,
|
|
||||||
RequestHeaderFieldsTooLarge: 431,
|
|
||||||
UnavailableForLegalReasons: 451,
|
|
||||||
InternalServerError: 500,
|
|
||||||
NotImplemented: 501,
|
|
||||||
BadGateway: 502,
|
|
||||||
ServiceUnavailable: 503,
|
|
||||||
GatewayTimeout: 504,
|
|
||||||
HttpVersionNotSupported: 505,
|
|
||||||
VariantAlsoNegotiates: 506,
|
|
||||||
InsufficientStorage: 507,
|
|
||||||
LoopDetected: 508,
|
|
||||||
NotExtended: 510,
|
|
||||||
NetworkAuthenticationRequired: 511,
|
|
||||||
WebServerIsDown: 521,
|
|
||||||
ConnectionTimedOut: 522,
|
|
||||||
OriginIsUnreachable: 523,
|
|
||||||
TimeoutOccurred: 524,
|
|
||||||
SslHandshakeFailed: 525,
|
|
||||||
InvalidSslCertificate: 526,
|
|
||||||
};
|
|
||||||
|
|
||||||
Object.entries(HttpStatusCode).forEach(([key, value]) => {
|
|
||||||
HttpStatusCode[value] = key;
|
|
||||||
});
|
|
||||||
|
|
||||||
export default HttpStatusCode;
|
|
||||||
7
node_modules/axios/lib/helpers/README.md
generated
vendored
7
node_modules/axios/lib/helpers/README.md
generated
vendored
@@ -1,7 +0,0 @@
|
|||||||
# axios // helpers
|
|
||||||
|
|
||||||
The modules found in `helpers/` should be generic modules that are _not_ specific to the domain logic of axios. These modules could theoretically be published to npm on their own and consumed by other modules or apps. Some examples of generic modules are things like:
|
|
||||||
|
|
||||||
- Browser polyfills
|
|
||||||
- Managing cookies
|
|
||||||
- Parsing HTTP headers
|
|
||||||
29
node_modules/axios/lib/helpers/ZlibHeaderTransformStream.js
generated
vendored
29
node_modules/axios/lib/helpers/ZlibHeaderTransformStream.js
generated
vendored
@@ -1,29 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import stream from 'stream';
|
|
||||||
|
|
||||||
class ZlibHeaderTransformStream extends stream.Transform {
|
|
||||||
__transform(chunk, encoding, callback) {
|
|
||||||
this.push(chunk);
|
|
||||||
callback();
|
|
||||||
}
|
|
||||||
|
|
||||||
_transform(chunk, encoding, callback) {
|
|
||||||
if (chunk.length !== 0) {
|
|
||||||
this._transform = this.__transform;
|
|
||||||
|
|
||||||
// Add Default Compression headers if no zlib headers are present
|
|
||||||
if (chunk[0] !== 120) {
|
|
||||||
// Hex: 78
|
|
||||||
const header = Buffer.alloc(2);
|
|
||||||
header[0] = 120; // Hex: 78
|
|
||||||
header[1] = 156; // Hex: 9C
|
|
||||||
this.push(header, encoding);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.__transform(chunk, encoding, callback);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default ZlibHeaderTransformStream;
|
|
||||||
14
node_modules/axios/lib/helpers/bind.js
generated
vendored
14
node_modules/axios/lib/helpers/bind.js
generated
vendored
@@ -1,14 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a bound version of a function with a specified `this` context
|
|
||||||
*
|
|
||||||
* @param {Function} fn - The function to bind
|
|
||||||
* @param {*} thisArg - The value to be passed as the `this` parameter
|
|
||||||
* @returns {Function} A new function that will call the original function with the specified `this` context
|
|
||||||
*/
|
|
||||||
export default function bind(fn, thisArg) {
|
|
||||||
return function wrap() {
|
|
||||||
return fn.apply(thisArg, arguments);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
66
node_modules/axios/lib/helpers/buildURL.js
generated
vendored
66
node_modules/axios/lib/helpers/buildURL.js
generated
vendored
@@ -1,66 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import AxiosURLSearchParams from '../helpers/AxiosURLSearchParams.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It replaces URL-encoded forms of `:`, `$`, `,`, and spaces with
|
|
||||||
* their plain counterparts (`:`, `$`, `,`, `+`).
|
|
||||||
*
|
|
||||||
* @param {string} val The value to be encoded.
|
|
||||||
*
|
|
||||||
* @returns {string} The encoded value.
|
|
||||||
*/
|
|
||||||
function encode(val) {
|
|
||||||
return encodeURIComponent(val)
|
|
||||||
.replace(/%3A/gi, ':')
|
|
||||||
.replace(/%24/g, '$')
|
|
||||||
.replace(/%2C/gi, ',')
|
|
||||||
.replace(/%20/g, '+');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Build a URL by appending params to the end
|
|
||||||
*
|
|
||||||
* @param {string} url The base of the url (e.g., http://www.google.com)
|
|
||||||
* @param {object} [params] The params to be appended
|
|
||||||
* @param {?(object|Function)} options
|
|
||||||
*
|
|
||||||
* @returns {string} The formatted url
|
|
||||||
*/
|
|
||||||
export default function buildURL(url, params, options) {
|
|
||||||
if (!params) {
|
|
||||||
return url;
|
|
||||||
}
|
|
||||||
|
|
||||||
const _encode = (options && options.encode) || encode;
|
|
||||||
|
|
||||||
const _options = utils.isFunction(options)
|
|
||||||
? {
|
|
||||||
serialize: options,
|
|
||||||
}
|
|
||||||
: options;
|
|
||||||
|
|
||||||
const serializeFn = _options && _options.serialize;
|
|
||||||
|
|
||||||
let serializedParams;
|
|
||||||
|
|
||||||
if (serializeFn) {
|
|
||||||
serializedParams = serializeFn(params, _options);
|
|
||||||
} else {
|
|
||||||
serializedParams = utils.isURLSearchParams(params)
|
|
||||||
? params.toString()
|
|
||||||
: new AxiosURLSearchParams(params, _options).toString(_encode);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (serializedParams) {
|
|
||||||
const hashmarkIndex = url.indexOf('#');
|
|
||||||
|
|
||||||
if (hashmarkIndex !== -1) {
|
|
||||||
url = url.slice(0, hashmarkIndex);
|
|
||||||
}
|
|
||||||
url += (url.indexOf('?') === -1 ? '?' : '&') + serializedParams;
|
|
||||||
}
|
|
||||||
|
|
||||||
return url;
|
|
||||||
}
|
|
||||||
18
node_modules/axios/lib/helpers/callbackify.js
generated
vendored
18
node_modules/axios/lib/helpers/callbackify.js
generated
vendored
@@ -1,18 +0,0 @@
|
|||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
const callbackify = (fn, reducer) => {
|
|
||||||
return utils.isAsyncFn(fn)
|
|
||||||
? function (...args) {
|
|
||||||
const cb = args.pop();
|
|
||||||
fn.apply(this, args).then((value) => {
|
|
||||||
try {
|
|
||||||
reducer ? cb(null, ...reducer(value)) : cb(null, value);
|
|
||||||
} catch (err) {
|
|
||||||
cb(err);
|
|
||||||
}
|
|
||||||
}, cb);
|
|
||||||
}
|
|
||||||
: fn;
|
|
||||||
};
|
|
||||||
|
|
||||||
export default callbackify;
|
|
||||||
15
node_modules/axios/lib/helpers/combineURLs.js
generated
vendored
15
node_modules/axios/lib/helpers/combineURLs.js
generated
vendored
@@ -1,15 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates a new URL by combining the specified URLs
|
|
||||||
*
|
|
||||||
* @param {string} baseURL The base URL
|
|
||||||
* @param {string} relativeURL The relative URL
|
|
||||||
*
|
|
||||||
* @returns {string} The combined URL
|
|
||||||
*/
|
|
||||||
export default function combineURLs(baseURL, relativeURL) {
|
|
||||||
return relativeURL
|
|
||||||
? baseURL.replace(/\/?\/$/, '') + '/' + relativeURL.replace(/^\/+/, '')
|
|
||||||
: baseURL;
|
|
||||||
}
|
|
||||||
56
node_modules/axios/lib/helpers/composeSignals.js
generated
vendored
56
node_modules/axios/lib/helpers/composeSignals.js
generated
vendored
@@ -1,56 +0,0 @@
|
|||||||
import CanceledError from '../cancel/CanceledError.js';
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
const composeSignals = (signals, timeout) => {
|
|
||||||
const { length } = (signals = signals ? signals.filter(Boolean) : []);
|
|
||||||
|
|
||||||
if (timeout || length) {
|
|
||||||
let controller = new AbortController();
|
|
||||||
|
|
||||||
let aborted;
|
|
||||||
|
|
||||||
const onabort = function (reason) {
|
|
||||||
if (!aborted) {
|
|
||||||
aborted = true;
|
|
||||||
unsubscribe();
|
|
||||||
const err = reason instanceof Error ? reason : this.reason;
|
|
||||||
controller.abort(
|
|
||||||
err instanceof AxiosError
|
|
||||||
? err
|
|
||||||
: new CanceledError(err instanceof Error ? err.message : err)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
let timer =
|
|
||||||
timeout &&
|
|
||||||
setTimeout(() => {
|
|
||||||
timer = null;
|
|
||||||
onabort(new AxiosError(`timeout of ${timeout}ms exceeded`, AxiosError.ETIMEDOUT));
|
|
||||||
}, timeout);
|
|
||||||
|
|
||||||
const unsubscribe = () => {
|
|
||||||
if (signals) {
|
|
||||||
timer && clearTimeout(timer);
|
|
||||||
timer = null;
|
|
||||||
signals.forEach((signal) => {
|
|
||||||
signal.unsubscribe
|
|
||||||
? signal.unsubscribe(onabort)
|
|
||||||
: signal.removeEventListener('abort', onabort);
|
|
||||||
});
|
|
||||||
signals = null;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
signals.forEach((signal) => signal.addEventListener('abort', onabort));
|
|
||||||
|
|
||||||
const { signal } = controller;
|
|
||||||
|
|
||||||
signal.unsubscribe = () => utils.asap(unsubscribe);
|
|
||||||
|
|
||||||
return signal;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export default composeSignals;
|
|
||||||
48
node_modules/axios/lib/helpers/cookies.js
generated
vendored
48
node_modules/axios/lib/helpers/cookies.js
generated
vendored
@@ -1,48 +0,0 @@
|
|||||||
import utils from '../utils.js';
|
|
||||||
import platform from '../platform/index.js';
|
|
||||||
|
|
||||||
export default platform.hasStandardBrowserEnv
|
|
||||||
? // Standard browser envs support document.cookie
|
|
||||||
{
|
|
||||||
write(name, value, expires, path, domain, secure, sameSite) {
|
|
||||||
if (typeof document === 'undefined') return;
|
|
||||||
|
|
||||||
const cookie = [`${name}=${encodeURIComponent(value)}`];
|
|
||||||
|
|
||||||
if (utils.isNumber(expires)) {
|
|
||||||
cookie.push(`expires=${new Date(expires).toUTCString()}`);
|
|
||||||
}
|
|
||||||
if (utils.isString(path)) {
|
|
||||||
cookie.push(`path=${path}`);
|
|
||||||
}
|
|
||||||
if (utils.isString(domain)) {
|
|
||||||
cookie.push(`domain=${domain}`);
|
|
||||||
}
|
|
||||||
if (secure === true) {
|
|
||||||
cookie.push('secure');
|
|
||||||
}
|
|
||||||
if (utils.isString(sameSite)) {
|
|
||||||
cookie.push(`SameSite=${sameSite}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
document.cookie = cookie.join('; ');
|
|
||||||
},
|
|
||||||
|
|
||||||
read(name) {
|
|
||||||
if (typeof document === 'undefined') return null;
|
|
||||||
const match = document.cookie.match(new RegExp('(?:^|; )' + name + '=([^;]*)'));
|
|
||||||
return match ? decodeURIComponent(match[1]) : null;
|
|
||||||
},
|
|
||||||
|
|
||||||
remove(name) {
|
|
||||||
this.write(name, '', Date.now() - 86400000, '/');
|
|
||||||
},
|
|
||||||
}
|
|
||||||
: // Non-standard browser env (web workers, react-native) lack needed support.
|
|
||||||
{
|
|
||||||
write() {},
|
|
||||||
read() {
|
|
||||||
return null;
|
|
||||||
},
|
|
||||||
remove() {},
|
|
||||||
};
|
|
||||||
31
node_modules/axios/lib/helpers/deprecatedMethod.js
generated
vendored
31
node_modules/axios/lib/helpers/deprecatedMethod.js
generated
vendored
@@ -1,31 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
/*eslint no-console:0*/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Supply a warning to the developer that a method they are using
|
|
||||||
* has been deprecated.
|
|
||||||
*
|
|
||||||
* @param {string} method The name of the deprecated method
|
|
||||||
* @param {string} [instead] The alternate method to use if applicable
|
|
||||||
* @param {string} [docs] The documentation URL to get further details
|
|
||||||
*
|
|
||||||
* @returns {void}
|
|
||||||
*/
|
|
||||||
export default function deprecatedMethod(method, instead, docs) {
|
|
||||||
try {
|
|
||||||
console.warn(
|
|
||||||
'DEPRECATED method `' +
|
|
||||||
method +
|
|
||||||
'`.' +
|
|
||||||
(instead ? ' Use `' + instead + '` instead.' : '') +
|
|
||||||
' This method will be removed in a future release.'
|
|
||||||
);
|
|
||||||
|
|
||||||
if (docs) {
|
|
||||||
console.warn('For more information about usage see ' + docs);
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
/* Ignore */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
73
node_modules/axios/lib/helpers/estimateDataURLDecodedBytes.js
generated
vendored
73
node_modules/axios/lib/helpers/estimateDataURLDecodedBytes.js
generated
vendored
@@ -1,73 +0,0 @@
|
|||||||
/**
|
|
||||||
* Estimate decoded byte length of a data:// URL *without* allocating large buffers.
|
|
||||||
* - For base64: compute exact decoded size using length and padding;
|
|
||||||
* handle %XX at the character-count level (no string allocation).
|
|
||||||
* - For non-base64: use UTF-8 byteLength of the encoded body as a safe upper bound.
|
|
||||||
*
|
|
||||||
* @param {string} url
|
|
||||||
* @returns {number}
|
|
||||||
*/
|
|
||||||
export default function estimateDataURLDecodedBytes(url) {
|
|
||||||
if (!url || typeof url !== 'string') return 0;
|
|
||||||
if (!url.startsWith('data:')) return 0;
|
|
||||||
|
|
||||||
const comma = url.indexOf(',');
|
|
||||||
if (comma < 0) return 0;
|
|
||||||
|
|
||||||
const meta = url.slice(5, comma);
|
|
||||||
const body = url.slice(comma + 1);
|
|
||||||
const isBase64 = /;base64/i.test(meta);
|
|
||||||
|
|
||||||
if (isBase64) {
|
|
||||||
let effectiveLen = body.length;
|
|
||||||
const len = body.length; // cache length
|
|
||||||
|
|
||||||
for (let i = 0; i < len; i++) {
|
|
||||||
if (body.charCodeAt(i) === 37 /* '%' */ && i + 2 < len) {
|
|
||||||
const a = body.charCodeAt(i + 1);
|
|
||||||
const b = body.charCodeAt(i + 2);
|
|
||||||
const isHex =
|
|
||||||
((a >= 48 && a <= 57) || (a >= 65 && a <= 70) || (a >= 97 && a <= 102)) &&
|
|
||||||
((b >= 48 && b <= 57) || (b >= 65 && b <= 70) || (b >= 97 && b <= 102));
|
|
||||||
|
|
||||||
if (isHex) {
|
|
||||||
effectiveLen -= 2;
|
|
||||||
i += 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let pad = 0;
|
|
||||||
let idx = len - 1;
|
|
||||||
|
|
||||||
const tailIsPct3D = (j) =>
|
|
||||||
j >= 2 &&
|
|
||||||
body.charCodeAt(j - 2) === 37 && // '%'
|
|
||||||
body.charCodeAt(j - 1) === 51 && // '3'
|
|
||||||
(body.charCodeAt(j) === 68 || body.charCodeAt(j) === 100); // 'D' or 'd'
|
|
||||||
|
|
||||||
if (idx >= 0) {
|
|
||||||
if (body.charCodeAt(idx) === 61 /* '=' */) {
|
|
||||||
pad++;
|
|
||||||
idx--;
|
|
||||||
} else if (tailIsPct3D(idx)) {
|
|
||||||
pad++;
|
|
||||||
idx -= 3;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pad === 1 && idx >= 0) {
|
|
||||||
if (body.charCodeAt(idx) === 61 /* '=' */) {
|
|
||||||
pad++;
|
|
||||||
} else if (tailIsPct3D(idx)) {
|
|
||||||
pad++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const groups = Math.floor(effectiveLen / 4);
|
|
||||||
const bytes = groups * 3 - (pad || 0);
|
|
||||||
return bytes > 0 ? bytes : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return Buffer.byteLength(body, 'utf8');
|
|
||||||
}
|
|
||||||
97
node_modules/axios/lib/helpers/formDataToJSON.js
generated
vendored
97
node_modules/axios/lib/helpers/formDataToJSON.js
generated
vendored
@@ -1,97 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It takes a string like `foo[x][y][z]` and returns an array like `['foo', 'x', 'y', 'z']
|
|
||||||
*
|
|
||||||
* @param {string} name - The name of the property to get.
|
|
||||||
*
|
|
||||||
* @returns An array of strings.
|
|
||||||
*/
|
|
||||||
function parsePropPath(name) {
|
|
||||||
// foo[x][y][z]
|
|
||||||
// foo.x.y.z
|
|
||||||
// foo-x-y-z
|
|
||||||
// foo x y z
|
|
||||||
return utils.matchAll(/\w+|\[(\w*)]/g, name).map((match) => {
|
|
||||||
return match[0] === '[]' ? '' : match[1] || match[0];
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert an array to an object.
|
|
||||||
*
|
|
||||||
* @param {Array<any>} arr - The array to convert to an object.
|
|
||||||
*
|
|
||||||
* @returns An object with the same keys and values as the array.
|
|
||||||
*/
|
|
||||||
function arrayToObject(arr) {
|
|
||||||
const obj = {};
|
|
||||||
const keys = Object.keys(arr);
|
|
||||||
let i;
|
|
||||||
const len = keys.length;
|
|
||||||
let key;
|
|
||||||
for (i = 0; i < len; i++) {
|
|
||||||
key = keys[i];
|
|
||||||
obj[key] = arr[key];
|
|
||||||
}
|
|
||||||
return obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It takes a FormData object and returns a JavaScript object
|
|
||||||
*
|
|
||||||
* @param {string} formData The FormData object to convert to JSON.
|
|
||||||
*
|
|
||||||
* @returns {Object<string, any> | null} The converted object.
|
|
||||||
*/
|
|
||||||
function formDataToJSON(formData) {
|
|
||||||
function buildPath(path, value, target, index) {
|
|
||||||
let name = path[index++];
|
|
||||||
|
|
||||||
if (name === '__proto__') return true;
|
|
||||||
|
|
||||||
const isNumericKey = Number.isFinite(+name);
|
|
||||||
const isLast = index >= path.length;
|
|
||||||
name = !name && utils.isArray(target) ? target.length : name;
|
|
||||||
|
|
||||||
if (isLast) {
|
|
||||||
if (utils.hasOwnProp(target, name)) {
|
|
||||||
target[name] = utils.isArray(target[name])
|
|
||||||
? target[name].concat(value)
|
|
||||||
: [target[name], value];
|
|
||||||
} else {
|
|
||||||
target[name] = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
return !isNumericKey;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!target[name] || !utils.isObject(target[name])) {
|
|
||||||
target[name] = [];
|
|
||||||
}
|
|
||||||
|
|
||||||
const result = buildPath(path, value, target[name], index);
|
|
||||||
|
|
||||||
if (result && utils.isArray(target[name])) {
|
|
||||||
target[name] = arrayToObject(target[name]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return !isNumericKey;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isFormData(formData) && utils.isFunction(formData.entries)) {
|
|
||||||
const obj = {};
|
|
||||||
|
|
||||||
utils.forEachEntry(formData, (name, value) => {
|
|
||||||
buildPath(parsePropPath(name), value, obj, 0);
|
|
||||||
});
|
|
||||||
|
|
||||||
return obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
export default formDataToJSON;
|
|
||||||
119
node_modules/axios/lib/helpers/formDataToStream.js
generated
vendored
119
node_modules/axios/lib/helpers/formDataToStream.js
generated
vendored
@@ -1,119 +0,0 @@
|
|||||||
import util from 'util';
|
|
||||||
import { Readable } from 'stream';
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import readBlob from './readBlob.js';
|
|
||||||
import platform from '../platform/index.js';
|
|
||||||
|
|
||||||
const BOUNDARY_ALPHABET = platform.ALPHABET.ALPHA_DIGIT + '-_';
|
|
||||||
|
|
||||||
const textEncoder = typeof TextEncoder === 'function' ? new TextEncoder() : new util.TextEncoder();
|
|
||||||
|
|
||||||
const CRLF = '\r\n';
|
|
||||||
const CRLF_BYTES = textEncoder.encode(CRLF);
|
|
||||||
const CRLF_BYTES_COUNT = 2;
|
|
||||||
|
|
||||||
class FormDataPart {
|
|
||||||
constructor(name, value) {
|
|
||||||
const { escapeName } = this.constructor;
|
|
||||||
const isStringValue = utils.isString(value);
|
|
||||||
|
|
||||||
let headers = `Content-Disposition: form-data; name="${escapeName(name)}"${
|
|
||||||
!isStringValue && value.name ? `; filename="${escapeName(value.name)}"` : ''
|
|
||||||
}${CRLF}`;
|
|
||||||
|
|
||||||
if (isStringValue) {
|
|
||||||
value = textEncoder.encode(String(value).replace(/\r?\n|\r\n?/g, CRLF));
|
|
||||||
} else {
|
|
||||||
const safeType = String(value.type || 'application/octet-stream').replace(/[\r\n]/g, '');
|
|
||||||
headers += `Content-Type: ${safeType}${CRLF}`;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.headers = textEncoder.encode(headers + CRLF);
|
|
||||||
|
|
||||||
this.contentLength = isStringValue ? value.byteLength : value.size;
|
|
||||||
|
|
||||||
this.size = this.headers.byteLength + this.contentLength + CRLF_BYTES_COUNT;
|
|
||||||
|
|
||||||
this.name = name;
|
|
||||||
this.value = value;
|
|
||||||
}
|
|
||||||
|
|
||||||
async *encode() {
|
|
||||||
yield this.headers;
|
|
||||||
|
|
||||||
const { value } = this;
|
|
||||||
|
|
||||||
if (utils.isTypedArray(value)) {
|
|
||||||
yield value;
|
|
||||||
} else {
|
|
||||||
yield* readBlob(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
yield CRLF_BYTES;
|
|
||||||
}
|
|
||||||
|
|
||||||
static escapeName(name) {
|
|
||||||
return String(name).replace(
|
|
||||||
/[\r\n"]/g,
|
|
||||||
(match) =>
|
|
||||||
({
|
|
||||||
'\r': '%0D',
|
|
||||||
'\n': '%0A',
|
|
||||||
'"': '%22',
|
|
||||||
})[match]
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const formDataToStream = (form, headersHandler, options) => {
|
|
||||||
const {
|
|
||||||
tag = 'form-data-boundary',
|
|
||||||
size = 25,
|
|
||||||
boundary = tag + '-' + platform.generateString(size, BOUNDARY_ALPHABET),
|
|
||||||
} = options || {};
|
|
||||||
|
|
||||||
if (!utils.isFormData(form)) {
|
|
||||||
throw TypeError('FormData instance required');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (boundary.length < 1 || boundary.length > 70) {
|
|
||||||
throw Error('boundary must be 10-70 characters long');
|
|
||||||
}
|
|
||||||
|
|
||||||
const boundaryBytes = textEncoder.encode('--' + boundary + CRLF);
|
|
||||||
const footerBytes = textEncoder.encode('--' + boundary + '--' + CRLF);
|
|
||||||
let contentLength = footerBytes.byteLength;
|
|
||||||
|
|
||||||
const parts = Array.from(form.entries()).map(([name, value]) => {
|
|
||||||
const part = new FormDataPart(name, value);
|
|
||||||
contentLength += part.size;
|
|
||||||
return part;
|
|
||||||
});
|
|
||||||
|
|
||||||
contentLength += boundaryBytes.byteLength * parts.length;
|
|
||||||
|
|
||||||
contentLength = utils.toFiniteNumber(contentLength);
|
|
||||||
|
|
||||||
const computedHeaders = {
|
|
||||||
'Content-Type': `multipart/form-data; boundary=${boundary}`,
|
|
||||||
};
|
|
||||||
|
|
||||||
if (Number.isFinite(contentLength)) {
|
|
||||||
computedHeaders['Content-Length'] = contentLength;
|
|
||||||
}
|
|
||||||
|
|
||||||
headersHandler && headersHandler(computedHeaders);
|
|
||||||
|
|
||||||
return Readable.from(
|
|
||||||
(async function* () {
|
|
||||||
for (const part of parts) {
|
|
||||||
yield boundaryBytes;
|
|
||||||
yield* part.encode();
|
|
||||||
}
|
|
||||||
|
|
||||||
yield footerBytes;
|
|
||||||
})()
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
export default formDataToStream;
|
|
||||||
53
node_modules/axios/lib/helpers/fromDataURI.js
generated
vendored
53
node_modules/axios/lib/helpers/fromDataURI.js
generated
vendored
@@ -1,53 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
import parseProtocol from './parseProtocol.js';
|
|
||||||
import platform from '../platform/index.js';
|
|
||||||
|
|
||||||
const DATA_URL_PATTERN = /^(?:([^;]+);)?(?:[^;]+;)?(base64|),([\s\S]*)$/;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parse data uri to a Buffer or Blob
|
|
||||||
*
|
|
||||||
* @param {String} uri
|
|
||||||
* @param {?Boolean} asBlob
|
|
||||||
* @param {?Object} options
|
|
||||||
* @param {?Function} options.Blob
|
|
||||||
*
|
|
||||||
* @returns {Buffer|Blob}
|
|
||||||
*/
|
|
||||||
export default function fromDataURI(uri, asBlob, options) {
|
|
||||||
const _Blob = (options && options.Blob) || platform.classes.Blob;
|
|
||||||
const protocol = parseProtocol(uri);
|
|
||||||
|
|
||||||
if (asBlob === undefined && _Blob) {
|
|
||||||
asBlob = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (protocol === 'data') {
|
|
||||||
uri = protocol.length ? uri.slice(protocol.length + 1) : uri;
|
|
||||||
|
|
||||||
const match = DATA_URL_PATTERN.exec(uri);
|
|
||||||
|
|
||||||
if (!match) {
|
|
||||||
throw new AxiosError('Invalid URL', AxiosError.ERR_INVALID_URL);
|
|
||||||
}
|
|
||||||
|
|
||||||
const mime = match[1];
|
|
||||||
const isBase64 = match[2];
|
|
||||||
const body = match[3];
|
|
||||||
const buffer = Buffer.from(decodeURIComponent(body), isBase64 ? 'base64' : 'utf8');
|
|
||||||
|
|
||||||
if (asBlob) {
|
|
||||||
if (!_Blob) {
|
|
||||||
throw new AxiosError('Blob is not supported', AxiosError.ERR_NOT_SUPPORT);
|
|
||||||
}
|
|
||||||
|
|
||||||
return new _Blob([buffer], { type: mime });
|
|
||||||
}
|
|
||||||
|
|
||||||
return buffer;
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new AxiosError('Unsupported protocol ' + protocol, AxiosError.ERR_NOT_SUPPORT);
|
|
||||||
}
|
|
||||||
19
node_modules/axios/lib/helpers/isAbsoluteURL.js
generated
vendored
19
node_modules/axios/lib/helpers/isAbsoluteURL.js
generated
vendored
@@ -1,19 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Determines whether the specified URL is absolute
|
|
||||||
*
|
|
||||||
* @param {string} url The URL to test
|
|
||||||
*
|
|
||||||
* @returns {boolean} True if the specified URL is absolute, otherwise false
|
|
||||||
*/
|
|
||||||
export default function isAbsoluteURL(url) {
|
|
||||||
// A URL is considered absolute if it begins with "<scheme>://" or "//" (protocol-relative URL).
|
|
||||||
// RFC 3986 defines scheme name as a sequence of characters beginning with a letter and followed
|
|
||||||
// by any combination of letters, digits, plus, period, or hyphen.
|
|
||||||
if (typeof url !== 'string') {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return /^([a-z][a-z\d+\-.]*:)?\/\//i.test(url);
|
|
||||||
}
|
|
||||||
14
node_modules/axios/lib/helpers/isAxiosError.js
generated
vendored
14
node_modules/axios/lib/helpers/isAxiosError.js
generated
vendored
@@ -1,14 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Determines whether the payload is an error thrown by Axios
|
|
||||||
*
|
|
||||||
* @param {*} payload The value to test
|
|
||||||
*
|
|
||||||
* @returns {boolean} True if the payload is an error thrown by Axios, otherwise false
|
|
||||||
*/
|
|
||||||
export default function isAxiosError(payload) {
|
|
||||||
return utils.isObject(payload) && payload.isAxiosError === true;
|
|
||||||
}
|
|
||||||
16
node_modules/axios/lib/helpers/isURLSameOrigin.js
generated
vendored
16
node_modules/axios/lib/helpers/isURLSameOrigin.js
generated
vendored
@@ -1,16 +0,0 @@
|
|||||||
import platform from '../platform/index.js';
|
|
||||||
|
|
||||||
export default platform.hasStandardBrowserEnv
|
|
||||||
? ((origin, isMSIE) => (url) => {
|
|
||||||
url = new URL(url, platform.origin);
|
|
||||||
|
|
||||||
return (
|
|
||||||
origin.protocol === url.protocol &&
|
|
||||||
origin.host === url.host &&
|
|
||||||
(isMSIE || origin.port === url.port)
|
|
||||||
);
|
|
||||||
})(
|
|
||||||
new URL(platform.origin),
|
|
||||||
platform.navigator && /(msie|trident)/i.test(platform.navigator.userAgent)
|
|
||||||
)
|
|
||||||
: () => true;
|
|
||||||
2
node_modules/axios/lib/helpers/null.js
generated
vendored
2
node_modules/axios/lib/helpers/null.js
generated
vendored
@@ -1,2 +0,0 @@
|
|||||||
// eslint-disable-next-line strict
|
|
||||||
export default null;
|
|
||||||
69
node_modules/axios/lib/helpers/parseHeaders.js
generated
vendored
69
node_modules/axios/lib/helpers/parseHeaders.js
generated
vendored
@@ -1,69 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
// RawAxiosHeaders whose duplicates are ignored by node
|
|
||||||
// c.f. https://nodejs.org/api/http.html#http_message_headers
|
|
||||||
const ignoreDuplicateOf = utils.toObjectSet([
|
|
||||||
'age',
|
|
||||||
'authorization',
|
|
||||||
'content-length',
|
|
||||||
'content-type',
|
|
||||||
'etag',
|
|
||||||
'expires',
|
|
||||||
'from',
|
|
||||||
'host',
|
|
||||||
'if-modified-since',
|
|
||||||
'if-unmodified-since',
|
|
||||||
'last-modified',
|
|
||||||
'location',
|
|
||||||
'max-forwards',
|
|
||||||
'proxy-authorization',
|
|
||||||
'referer',
|
|
||||||
'retry-after',
|
|
||||||
'user-agent',
|
|
||||||
]);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Parse headers into an object
|
|
||||||
*
|
|
||||||
* ```
|
|
||||||
* Date: Wed, 27 Aug 2014 08:58:49 GMT
|
|
||||||
* Content-Type: application/json
|
|
||||||
* Connection: keep-alive
|
|
||||||
* Transfer-Encoding: chunked
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* @param {String} rawHeaders Headers needing to be parsed
|
|
||||||
*
|
|
||||||
* @returns {Object} Headers parsed into an object
|
|
||||||
*/
|
|
||||||
export default (rawHeaders) => {
|
|
||||||
const parsed = {};
|
|
||||||
let key;
|
|
||||||
let val;
|
|
||||||
let i;
|
|
||||||
|
|
||||||
rawHeaders &&
|
|
||||||
rawHeaders.split('\n').forEach(function parser(line) {
|
|
||||||
i = line.indexOf(':');
|
|
||||||
key = line.substring(0, i).trim().toLowerCase();
|
|
||||||
val = line.substring(i + 1).trim();
|
|
||||||
|
|
||||||
if (!key || (parsed[key] && ignoreDuplicateOf[key])) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (key === 'set-cookie') {
|
|
||||||
if (parsed[key]) {
|
|
||||||
parsed[key].push(val);
|
|
||||||
} else {
|
|
||||||
parsed[key] = [val];
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
parsed[key] = parsed[key] ? parsed[key] + ', ' + val : val;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return parsed;
|
|
||||||
};
|
|
||||||
6
node_modules/axios/lib/helpers/parseProtocol.js
generated
vendored
6
node_modules/axios/lib/helpers/parseProtocol.js
generated
vendored
@@ -1,6 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
export default function parseProtocol(url) {
|
|
||||||
const match = /^([-+\w]{1,25})(:?\/\/|:)/.exec(url);
|
|
||||||
return (match && match[1]) || '';
|
|
||||||
}
|
|
||||||
51
node_modules/axios/lib/helpers/progressEventReducer.js
generated
vendored
51
node_modules/axios/lib/helpers/progressEventReducer.js
generated
vendored
@@ -1,51 +0,0 @@
|
|||||||
import speedometer from './speedometer.js';
|
|
||||||
import throttle from './throttle.js';
|
|
||||||
import utils from '../utils.js';
|
|
||||||
|
|
||||||
export const progressEventReducer = (listener, isDownloadStream, freq = 3) => {
|
|
||||||
let bytesNotified = 0;
|
|
||||||
const _speedometer = speedometer(50, 250);
|
|
||||||
|
|
||||||
return throttle((e) => {
|
|
||||||
const rawLoaded = e.loaded;
|
|
||||||
const total = e.lengthComputable ? e.total : undefined;
|
|
||||||
const loaded = total != null ? Math.min(rawLoaded, total) : rawLoaded;
|
|
||||||
const progressBytes = Math.max(0, loaded - bytesNotified);
|
|
||||||
const rate = _speedometer(progressBytes);
|
|
||||||
|
|
||||||
bytesNotified = Math.max(bytesNotified, loaded);
|
|
||||||
|
|
||||||
const data = {
|
|
||||||
loaded,
|
|
||||||
total,
|
|
||||||
progress: total ? loaded / total : undefined,
|
|
||||||
bytes: progressBytes,
|
|
||||||
rate: rate ? rate : undefined,
|
|
||||||
estimated: rate && total ? (total - loaded) / rate : undefined,
|
|
||||||
event: e,
|
|
||||||
lengthComputable: total != null,
|
|
||||||
[isDownloadStream ? 'download' : 'upload']: true,
|
|
||||||
};
|
|
||||||
|
|
||||||
listener(data);
|
|
||||||
}, freq);
|
|
||||||
};
|
|
||||||
|
|
||||||
export const progressEventDecorator = (total, throttled) => {
|
|
||||||
const lengthComputable = total != null;
|
|
||||||
|
|
||||||
return [
|
|
||||||
(loaded) =>
|
|
||||||
throttled[0]({
|
|
||||||
lengthComputable,
|
|
||||||
total,
|
|
||||||
loaded,
|
|
||||||
}),
|
|
||||||
throttled[1],
|
|
||||||
];
|
|
||||||
};
|
|
||||||
|
|
||||||
export const asyncDecorator =
|
|
||||||
(fn) =>
|
|
||||||
(...args) =>
|
|
||||||
utils.asap(() => fn(...args));
|
|
||||||
15
node_modules/axios/lib/helpers/readBlob.js
generated
vendored
15
node_modules/axios/lib/helpers/readBlob.js
generated
vendored
@@ -1,15 +0,0 @@
|
|||||||
const { asyncIterator } = Symbol;
|
|
||||||
|
|
||||||
const readBlob = async function* (blob) {
|
|
||||||
if (blob.stream) {
|
|
||||||
yield* blob.stream();
|
|
||||||
} else if (blob.arrayBuffer) {
|
|
||||||
yield await blob.arrayBuffer();
|
|
||||||
} else if (blob[asyncIterator]) {
|
|
||||||
yield* blob[asyncIterator]();
|
|
||||||
} else {
|
|
||||||
yield blob;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export default readBlob;
|
|
||||||
90
node_modules/axios/lib/helpers/resolveConfig.js
generated
vendored
90
node_modules/axios/lib/helpers/resolveConfig.js
generated
vendored
@@ -1,90 +0,0 @@
|
|||||||
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);
|
|
||||||
|
|
||||||
// Read only own properties to prevent prototype pollution gadgets
|
|
||||||
// (e.g. Object.prototype.baseURL = 'https://evil.com'). See GHSA-q8qp-cvcw-x6jj.
|
|
||||||
const own = (key) => (utils.hasOwnProp(newConfig, key) ? newConfig[key] : undefined);
|
|
||||||
|
|
||||||
const data = own('data');
|
|
||||||
let withXSRFToken = own('withXSRFToken');
|
|
||||||
const xsrfHeaderName = own('xsrfHeaderName');
|
|
||||||
const xsrfCookieName = own('xsrfCookieName');
|
|
||||||
let headers = own('headers');
|
|
||||||
const auth = own('auth');
|
|
||||||
const baseURL = own('baseURL');
|
|
||||||
const allowAbsoluteUrls = own('allowAbsoluteUrls');
|
|
||||||
const url = own('url');
|
|
||||||
|
|
||||||
newConfig.headers = headers = AxiosHeaders.from(headers);
|
|
||||||
|
|
||||||
newConfig.url = buildURL(
|
|
||||||
buildFullPath(baseURL, url, allowAbsoluteUrls),
|
|
||||||
config.params,
|
|
||||||
config.paramsSerializer
|
|
||||||
);
|
|
||||||
|
|
||||||
// HTTP basic authentication
|
|
||||||
if (auth) {
|
|
||||||
headers.set(
|
|
||||||
'Authorization',
|
|
||||||
'Basic ' +
|
|
||||||
btoa(
|
|
||||||
(auth.username || '') +
|
|
||||||
':' +
|
|
||||||
(auth.password ? unescape(encodeURIComponent(auth.password)) : '')
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isFormData(data)) {
|
|
||||||
if (platform.hasStandardBrowserEnv || platform.hasStandardBrowserWebWorkerEnv) {
|
|
||||||
headers.setContentType(undefined); // browser handles it
|
|
||||||
} else if (utils.isFunction(data.getHeaders)) {
|
|
||||||
// Node.js FormData (like form-data package)
|
|
||||||
const formHeaders = data.getHeaders();
|
|
||||||
// Only set safe headers to avoid overwriting security headers
|
|
||||||
const allowedHeaders = ['content-type', 'content-length'];
|
|
||||||
Object.entries(formHeaders).forEach(([key, val]) => {
|
|
||||||
if (allowedHeaders.includes(key.toLowerCase())) {
|
|
||||||
headers.set(key, val);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add xsrf header
|
|
||||||
// This is only done if running in a standard browser environment.
|
|
||||||
// Specifically not if we're in a web worker, or react-native.
|
|
||||||
|
|
||||||
if (platform.hasStandardBrowserEnv) {
|
|
||||||
if (utils.isFunction(withXSRFToken)) {
|
|
||||||
withXSRFToken = withXSRFToken(newConfig);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Strict boolean check — prevents proto-pollution gadgets (e.g. Object.prototype.withXSRFToken = 1)
|
|
||||||
// and misconfigurations (e.g. "false") from short-circuiting the same-origin check and leaking
|
|
||||||
// the XSRF token cross-origin. See GHSA-xx6v-rp6x-q39c.
|
|
||||||
const shouldSendXSRF =
|
|
||||||
withXSRFToken === true ||
|
|
||||||
(withXSRFToken == null && isURLSameOrigin(newConfig.url));
|
|
||||||
|
|
||||||
if (shouldSendXSRF) {
|
|
||||||
const xsrfValue = xsrfHeaderName && xsrfCookieName && cookies.read(xsrfCookieName);
|
|
||||||
|
|
||||||
if (xsrfValue) {
|
|
||||||
headers.set(xsrfHeaderName, xsrfValue);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return newConfig;
|
|
||||||
};
|
|
||||||
153
node_modules/axios/lib/helpers/shouldBypassProxy.js
generated
vendored
153
node_modules/axios/lib/helpers/shouldBypassProxy.js
generated
vendored
@@ -1,153 +0,0 @@
|
|||||||
const LOOPBACK_HOSTNAMES = new Set(['localhost']);
|
|
||||||
|
|
||||||
const isIPv4Loopback = (host) => {
|
|
||||||
const parts = host.split('.');
|
|
||||||
if (parts.length !== 4) return false;
|
|
||||||
if (parts[0] !== '127') return false;
|
|
||||||
return parts.every((p) => /^\d+$/.test(p) && Number(p) >= 0 && Number(p) <= 255);
|
|
||||||
};
|
|
||||||
|
|
||||||
const isIPv6Loopback = (host) => {
|
|
||||||
// Collapse all-zero groups: any form of ::1 / 0:0:...:0:1
|
|
||||||
// First, strip any leading "::" by normalising with Set lookup of common forms,
|
|
||||||
// then fall back to structural check.
|
|
||||||
if (host === '::1') return true;
|
|
||||||
|
|
||||||
// Check IPv4-mapped IPv6 loopback: ::ffff:<v4-loopback> or ::ffff:<hex-v4-loopback>
|
|
||||||
// Node's URL parser normalises ::ffff:127.0.0.1 → ::ffff:7f00:1
|
|
||||||
const v4MappedDotted = host.match(/^::ffff:(\d+\.\d+\.\d+\.\d+)$/i);
|
|
||||||
if (v4MappedDotted) return isIPv4Loopback(v4MappedDotted[1]);
|
|
||||||
|
|
||||||
const v4MappedHex = host.match(/^::ffff:([0-9a-f]{1,4}):([0-9a-f]{1,4})$/i);
|
|
||||||
if (v4MappedHex) {
|
|
||||||
const high = parseInt(v4MappedHex[1], 16);
|
|
||||||
// High 16 bits must start with 127 (0x7f) — i.e. 0x7f00..0x7fff
|
|
||||||
return high >= 0x7f00 && high <= 0x7fff;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Full-form ::1 variants: any number of zero groups followed by trailing 1
|
|
||||||
// e.g. 0:0:0:0:0:0:0:1, 0000:...:0001
|
|
||||||
const groups = host.split(':');
|
|
||||||
if (groups.length === 8) {
|
|
||||||
for (let i = 0; i < 7; i++) {
|
|
||||||
if (!/^0+$/.test(groups[i])) return false;
|
|
||||||
}
|
|
||||||
return /^0*1$/.test(groups[7]);
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
};
|
|
||||||
|
|
||||||
const isLoopback = (host) => {
|
|
||||||
if (!host) return false;
|
|
||||||
if (LOOPBACK_HOSTNAMES.has(host)) return true;
|
|
||||||
if (isIPv4Loopback(host)) return true;
|
|
||||||
return isIPv6Loopback(host);
|
|
||||||
};
|
|
||||||
|
|
||||||
const DEFAULT_PORTS = {
|
|
||||||
http: 80,
|
|
||||||
https: 443,
|
|
||||||
ws: 80,
|
|
||||||
wss: 443,
|
|
||||||
ftp: 21,
|
|
||||||
};
|
|
||||||
|
|
||||||
const parseNoProxyEntry = (entry) => {
|
|
||||||
let entryHost = entry;
|
|
||||||
let entryPort = 0;
|
|
||||||
|
|
||||||
if (entryHost.charAt(0) === '[') {
|
|
||||||
const bracketIndex = entryHost.indexOf(']');
|
|
||||||
|
|
||||||
if (bracketIndex !== -1) {
|
|
||||||
const host = entryHost.slice(1, bracketIndex);
|
|
||||||
const rest = entryHost.slice(bracketIndex + 1);
|
|
||||||
|
|
||||||
if (rest.charAt(0) === ':' && /^\d+$/.test(rest.slice(1))) {
|
|
||||||
entryPort = Number.parseInt(rest.slice(1), 10);
|
|
||||||
}
|
|
||||||
|
|
||||||
return [host, entryPort];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const firstColon = entryHost.indexOf(':');
|
|
||||||
const lastColon = entryHost.lastIndexOf(':');
|
|
||||||
|
|
||||||
if (
|
|
||||||
firstColon !== -1 &&
|
|
||||||
firstColon === lastColon &&
|
|
||||||
/^\d+$/.test(entryHost.slice(lastColon + 1))
|
|
||||||
) {
|
|
||||||
entryPort = Number.parseInt(entryHost.slice(lastColon + 1), 10);
|
|
||||||
entryHost = entryHost.slice(0, lastColon);
|
|
||||||
}
|
|
||||||
|
|
||||||
return [entryHost, entryPort];
|
|
||||||
};
|
|
||||||
|
|
||||||
const normalizeNoProxyHost = (hostname) => {
|
|
||||||
if (!hostname) {
|
|
||||||
return hostname;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (hostname.charAt(0) === '[' && hostname.charAt(hostname.length - 1) === ']') {
|
|
||||||
hostname = hostname.slice(1, -1);
|
|
||||||
}
|
|
||||||
|
|
||||||
return hostname.replace(/\.+$/, '');
|
|
||||||
};
|
|
||||||
|
|
||||||
export default function shouldBypassProxy(location) {
|
|
||||||
let parsed;
|
|
||||||
|
|
||||||
try {
|
|
||||||
parsed = new URL(location);
|
|
||||||
} catch (_err) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const noProxy = (process.env.no_proxy || process.env.NO_PROXY || '').toLowerCase();
|
|
||||||
|
|
||||||
if (!noProxy) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (noProxy === '*') {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
const port =
|
|
||||||
Number.parseInt(parsed.port, 10) || DEFAULT_PORTS[parsed.protocol.split(':', 1)[0]] || 0;
|
|
||||||
|
|
||||||
const hostname = normalizeNoProxyHost(parsed.hostname.toLowerCase());
|
|
||||||
|
|
||||||
return noProxy.split(/[\s,]+/).some((entry) => {
|
|
||||||
if (!entry) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
let [entryHost, entryPort] = parseNoProxyEntry(entry);
|
|
||||||
|
|
||||||
entryHost = normalizeNoProxyHost(entryHost);
|
|
||||||
|
|
||||||
if (!entryHost) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (entryPort && entryPort !== port) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (entryHost.charAt(0) === '*') {
|
|
||||||
entryHost = entryHost.slice(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (entryHost.charAt(0) === '.') {
|
|
||||||
return hostname.endsWith(entryHost);
|
|
||||||
}
|
|
||||||
|
|
||||||
return hostname === entryHost || (isLoopback(hostname) && isLoopback(entryHost));
|
|
||||||
});
|
|
||||||
}
|
|
||||||
55
node_modules/axios/lib/helpers/speedometer.js
generated
vendored
55
node_modules/axios/lib/helpers/speedometer.js
generated
vendored
@@ -1,55 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Calculate data maxRate
|
|
||||||
* @param {Number} [samplesCount= 10]
|
|
||||||
* @param {Number} [min= 1000]
|
|
||||||
* @returns {Function}
|
|
||||||
*/
|
|
||||||
function speedometer(samplesCount, min) {
|
|
||||||
samplesCount = samplesCount || 10;
|
|
||||||
const bytes = new Array(samplesCount);
|
|
||||||
const timestamps = new Array(samplesCount);
|
|
||||||
let head = 0;
|
|
||||||
let tail = 0;
|
|
||||||
let firstSampleTS;
|
|
||||||
|
|
||||||
min = min !== undefined ? min : 1000;
|
|
||||||
|
|
||||||
return function push(chunkLength) {
|
|
||||||
const now = Date.now();
|
|
||||||
|
|
||||||
const startedAt = timestamps[tail];
|
|
||||||
|
|
||||||
if (!firstSampleTS) {
|
|
||||||
firstSampleTS = now;
|
|
||||||
}
|
|
||||||
|
|
||||||
bytes[head] = chunkLength;
|
|
||||||
timestamps[head] = now;
|
|
||||||
|
|
||||||
let i = tail;
|
|
||||||
let bytesCount = 0;
|
|
||||||
|
|
||||||
while (i !== head) {
|
|
||||||
bytesCount += bytes[i++];
|
|
||||||
i = i % samplesCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
head = (head + 1) % samplesCount;
|
|
||||||
|
|
||||||
if (head === tail) {
|
|
||||||
tail = (tail + 1) % samplesCount;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (now - firstSampleTS < min) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const passed = startedAt && now - startedAt;
|
|
||||||
|
|
||||||
return passed ? Math.round((bytesCount * 1000) / passed) : undefined;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
export default speedometer;
|
|
||||||
28
node_modules/axios/lib/helpers/spread.js
generated
vendored
28
node_modules/axios/lib/helpers/spread.js
generated
vendored
@@ -1,28 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Syntactic sugar for invoking a function and expanding an array for arguments.
|
|
||||||
*
|
|
||||||
* Common use case would be to use `Function.prototype.apply`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* function f(x, y, z) {}
|
|
||||||
* const args = [1, 2, 3];
|
|
||||||
* f.apply(null, args);
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* With `spread` this example can be re-written.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* spread(function(x, y, z) {})([1, 2, 3]);
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* @param {Function} callback
|
|
||||||
*
|
|
||||||
* @returns {Function}
|
|
||||||
*/
|
|
||||||
export default function spread(callback) {
|
|
||||||
return function wrap(arr) {
|
|
||||||
return callback.apply(null, arr);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
44
node_modules/axios/lib/helpers/throttle.js
generated
vendored
44
node_modules/axios/lib/helpers/throttle.js
generated
vendored
@@ -1,44 +0,0 @@
|
|||||||
/**
|
|
||||||
* Throttle decorator
|
|
||||||
* @param {Function} fn
|
|
||||||
* @param {Number} freq
|
|
||||||
* @return {Function}
|
|
||||||
*/
|
|
||||||
function throttle(fn, freq) {
|
|
||||||
let timestamp = 0;
|
|
||||||
let threshold = 1000 / freq;
|
|
||||||
let lastArgs;
|
|
||||||
let timer;
|
|
||||||
|
|
||||||
const invoke = (args, now = Date.now()) => {
|
|
||||||
timestamp = now;
|
|
||||||
lastArgs = null;
|
|
||||||
if (timer) {
|
|
||||||
clearTimeout(timer);
|
|
||||||
timer = null;
|
|
||||||
}
|
|
||||||
fn(...args);
|
|
||||||
};
|
|
||||||
|
|
||||||
const throttled = (...args) => {
|
|
||||||
const now = Date.now();
|
|
||||||
const passed = now - timestamp;
|
|
||||||
if (passed >= threshold) {
|
|
||||||
invoke(args, now);
|
|
||||||
} else {
|
|
||||||
lastArgs = args;
|
|
||||||
if (!timer) {
|
|
||||||
timer = setTimeout(() => {
|
|
||||||
timer = null;
|
|
||||||
invoke(lastArgs);
|
|
||||||
}, threshold - passed);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const flush = () => lastArgs && invoke(lastArgs);
|
|
||||||
|
|
||||||
return [throttled, flush];
|
|
||||||
}
|
|
||||||
|
|
||||||
export default throttle;
|
|
||||||
249
node_modules/axios/lib/helpers/toFormData.js
generated
vendored
249
node_modules/axios/lib/helpers/toFormData.js
generated
vendored
@@ -1,249 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
// temporary hotfix to avoid circular references until AxiosURLSearchParams is refactored
|
|
||||||
import PlatformFormData from '../platform/node/classes/FormData.js';
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Determines if the given thing is a array or js object.
|
|
||||||
*
|
|
||||||
* @param {string} thing - The object or array to be visited.
|
|
||||||
*
|
|
||||||
* @returns {boolean}
|
|
||||||
*/
|
|
||||||
function isVisitable(thing) {
|
|
||||||
return utils.isPlainObject(thing) || utils.isArray(thing);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It removes the brackets from the end of a string
|
|
||||||
*
|
|
||||||
* @param {string} key - The key of the parameter.
|
|
||||||
*
|
|
||||||
* @returns {string} the key without the brackets.
|
|
||||||
*/
|
|
||||||
function removeBrackets(key) {
|
|
||||||
return utils.endsWith(key, '[]') ? key.slice(0, -2) : key;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It takes a path, a key, and a boolean, and returns a string
|
|
||||||
*
|
|
||||||
* @param {string} path - The path to the current key.
|
|
||||||
* @param {string} key - The key of the current object being iterated over.
|
|
||||||
* @param {string} dots - If true, the key will be rendered with dots instead of brackets.
|
|
||||||
*
|
|
||||||
* @returns {string} The path to the current key.
|
|
||||||
*/
|
|
||||||
function renderKey(path, key, dots) {
|
|
||||||
if (!path) return key;
|
|
||||||
return path
|
|
||||||
.concat(key)
|
|
||||||
.map(function each(token, i) {
|
|
||||||
// eslint-disable-next-line no-param-reassign
|
|
||||||
token = removeBrackets(token);
|
|
||||||
return !dots && i ? '[' + token + ']' : token;
|
|
||||||
})
|
|
||||||
.join(dots ? '.' : '');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* If the array is an array and none of its elements are visitable, then it's a flat array.
|
|
||||||
*
|
|
||||||
* @param {Array<any>} arr - The array to check
|
|
||||||
*
|
|
||||||
* @returns {boolean}
|
|
||||||
*/
|
|
||||||
function isFlatArray(arr) {
|
|
||||||
return utils.isArray(arr) && !arr.some(isVisitable);
|
|
||||||
}
|
|
||||||
|
|
||||||
const predicates = utils.toFlatObject(utils, {}, null, function filter(prop) {
|
|
||||||
return /^is[A-Z]/.test(prop);
|
|
||||||
});
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert a data object to FormData
|
|
||||||
*
|
|
||||||
* @param {Object} obj
|
|
||||||
* @param {?Object} [formData]
|
|
||||||
* @param {?Object} [options]
|
|
||||||
* @param {Function} [options.visitor]
|
|
||||||
* @param {Boolean} [options.metaTokens = true]
|
|
||||||
* @param {Boolean} [options.dots = false]
|
|
||||||
* @param {?Boolean} [options.indexes = false]
|
|
||||||
*
|
|
||||||
* @returns {Object}
|
|
||||||
**/
|
|
||||||
|
|
||||||
/**
|
|
||||||
* It converts an object into a FormData object
|
|
||||||
*
|
|
||||||
* @param {Object<any, any>} obj - The object to convert to form data.
|
|
||||||
* @param {string} formData - The FormData object to append to.
|
|
||||||
* @param {Object<string, any>} options
|
|
||||||
*
|
|
||||||
* @returns
|
|
||||||
*/
|
|
||||||
function toFormData(obj, formData, options) {
|
|
||||||
if (!utils.isObject(obj)) {
|
|
||||||
throw new TypeError('target must be an object');
|
|
||||||
}
|
|
||||||
|
|
||||||
// eslint-disable-next-line no-param-reassign
|
|
||||||
formData = formData || new (PlatformFormData || FormData)();
|
|
||||||
|
|
||||||
// eslint-disable-next-line no-param-reassign
|
|
||||||
options = utils.toFlatObject(
|
|
||||||
options,
|
|
||||||
{
|
|
||||||
metaTokens: true,
|
|
||||||
dots: false,
|
|
||||||
indexes: false,
|
|
||||||
},
|
|
||||||
false,
|
|
||||||
function defined(option, source) {
|
|
||||||
// eslint-disable-next-line no-eq-null,eqeqeq
|
|
||||||
return !utils.isUndefined(source[option]);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
const metaTokens = options.metaTokens;
|
|
||||||
// eslint-disable-next-line no-use-before-define
|
|
||||||
const visitor = options.visitor || defaultVisitor;
|
|
||||||
const dots = options.dots;
|
|
||||||
const indexes = options.indexes;
|
|
||||||
const _Blob = options.Blob || (typeof Blob !== 'undefined' && Blob);
|
|
||||||
const maxDepth = options.maxDepth === undefined ? 100 : options.maxDepth;
|
|
||||||
const useBlob = _Blob && utils.isSpecCompliantForm(formData);
|
|
||||||
|
|
||||||
if (!utils.isFunction(visitor)) {
|
|
||||||
throw new TypeError('visitor must be a function');
|
|
||||||
}
|
|
||||||
|
|
||||||
function convertValue(value) {
|
|
||||||
if (value === null) return '';
|
|
||||||
|
|
||||||
if (utils.isDate(value)) {
|
|
||||||
return value.toISOString();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isBoolean(value)) {
|
|
||||||
return value.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!useBlob && utils.isBlob(value)) {
|
|
||||||
throw new AxiosError('Blob is not supported. Use a Buffer instead.');
|
|
||||||
}
|
|
||||||
|
|
||||||
if (utils.isArrayBuffer(value) || utils.isTypedArray(value)) {
|
|
||||||
return useBlob && typeof Blob === 'function' ? new Blob([value]) : Buffer.from(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Default visitor.
|
|
||||||
*
|
|
||||||
* @param {*} value
|
|
||||||
* @param {String|Number} key
|
|
||||||
* @param {Array<String|Number>} path
|
|
||||||
* @this {FormData}
|
|
||||||
*
|
|
||||||
* @returns {boolean} return true to visit the each prop of the value recursively
|
|
||||||
*/
|
|
||||||
function defaultVisitor(value, key, path) {
|
|
||||||
let arr = value;
|
|
||||||
|
|
||||||
if (utils.isReactNative(formData) && utils.isReactNativeBlob(value)) {
|
|
||||||
formData.append(renderKey(path, key, dots), convertValue(value));
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (value && !path && typeof value === 'object') {
|
|
||||||
if (utils.endsWith(key, '{}')) {
|
|
||||||
// eslint-disable-next-line no-param-reassign
|
|
||||||
key = metaTokens ? key : key.slice(0, -2);
|
|
||||||
// eslint-disable-next-line no-param-reassign
|
|
||||||
value = JSON.stringify(value);
|
|
||||||
} else if (
|
|
||||||
(utils.isArray(value) && isFlatArray(value)) ||
|
|
||||||
((utils.isFileList(value) || utils.endsWith(key, '[]')) && (arr = utils.toArray(value)))
|
|
||||||
) {
|
|
||||||
// eslint-disable-next-line no-param-reassign
|
|
||||||
key = removeBrackets(key);
|
|
||||||
|
|
||||||
arr.forEach(function each(el, index) {
|
|
||||||
!(utils.isUndefined(el) || el === null) &&
|
|
||||||
formData.append(
|
|
||||||
// eslint-disable-next-line no-nested-ternary
|
|
||||||
indexes === true
|
|
||||||
? renderKey([key], index, dots)
|
|
||||||
: indexes === null
|
|
||||||
? key
|
|
||||||
: key + '[]',
|
|
||||||
convertValue(el)
|
|
||||||
);
|
|
||||||
});
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (isVisitable(value)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
formData.append(renderKey(path, key, dots), convertValue(value));
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const stack = [];
|
|
||||||
|
|
||||||
const exposedHelpers = Object.assign(predicates, {
|
|
||||||
defaultVisitor,
|
|
||||||
convertValue,
|
|
||||||
isVisitable,
|
|
||||||
});
|
|
||||||
|
|
||||||
function build(value, path, depth = 0) {
|
|
||||||
if (utils.isUndefined(value)) return;
|
|
||||||
|
|
||||||
if (depth > maxDepth) {
|
|
||||||
throw new AxiosError(
|
|
||||||
'Object is too deeply nested (' + depth + ' levels). Max depth: ' + maxDepth,
|
|
||||||
AxiosError.ERR_FORM_DATA_DEPTH_EXCEEDED
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (stack.indexOf(value) !== -1) {
|
|
||||||
throw Error('Circular reference detected in ' + path.join('.'));
|
|
||||||
}
|
|
||||||
|
|
||||||
stack.push(value);
|
|
||||||
|
|
||||||
utils.forEach(value, function each(el, key) {
|
|
||||||
const result =
|
|
||||||
!(utils.isUndefined(el) || el === null) &&
|
|
||||||
visitor.call(formData, el, utils.isString(key) ? key.trim() : key, path, exposedHelpers);
|
|
||||||
|
|
||||||
if (result === true) {
|
|
||||||
build(el, path ? path.concat(key) : [key], depth + 1);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
stack.pop();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!utils.isObject(obj)) {
|
|
||||||
throw new TypeError('data must be an object');
|
|
||||||
}
|
|
||||||
|
|
||||||
build(obj);
|
|
||||||
|
|
||||||
return formData;
|
|
||||||
}
|
|
||||||
|
|
||||||
export default toFormData;
|
|
||||||
19
node_modules/axios/lib/helpers/toURLEncodedForm.js
generated
vendored
19
node_modules/axios/lib/helpers/toURLEncodedForm.js
generated
vendored
@@ -1,19 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import utils from '../utils.js';
|
|
||||||
import toFormData from './toFormData.js';
|
|
||||||
import platform from '../platform/index.js';
|
|
||||||
|
|
||||||
export default function toURLEncodedForm(data, options) {
|
|
||||||
return toFormData(data, new platform.classes.URLSearchParams(), {
|
|
||||||
visitor: function (value, key, path, helpers) {
|
|
||||||
if (platform.isNode && utils.isBuffer(value)) {
|
|
||||||
this.append(key, value.toString('base64'));
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
return helpers.defaultVisitor.apply(this, arguments);
|
|
||||||
},
|
|
||||||
...options,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
89
node_modules/axios/lib/helpers/trackStream.js
generated
vendored
89
node_modules/axios/lib/helpers/trackStream.js
generated
vendored
@@ -1,89 +0,0 @@
|
|||||||
export const streamChunk = function* (chunk, chunkSize) {
|
|
||||||
let len = chunk.byteLength;
|
|
||||||
|
|
||||||
if (!chunkSize || len < chunkSize) {
|
|
||||||
yield chunk;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let pos = 0;
|
|
||||||
let end;
|
|
||||||
|
|
||||||
while (pos < len) {
|
|
||||||
end = pos + chunkSize;
|
|
||||||
yield chunk.slice(pos, end);
|
|
||||||
pos = end;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export const readBytes = async function* (iterable, chunkSize) {
|
|
||||||
for await (const chunk of readStream(iterable)) {
|
|
||||||
yield* streamChunk(chunk, chunkSize);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const readStream = async function* (stream) {
|
|
||||||
if (stream[Symbol.asyncIterator]) {
|
|
||||||
yield* stream;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const reader = stream.getReader();
|
|
||||||
try {
|
|
||||||
for (;;) {
|
|
||||||
const { done, value } = await reader.read();
|
|
||||||
if (done) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
yield value;
|
|
||||||
}
|
|
||||||
} finally {
|
|
||||||
await reader.cancel();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export const trackStream = (stream, chunkSize, onProgress, onFinish) => {
|
|
||||||
const iterator = readBytes(stream, chunkSize);
|
|
||||||
|
|
||||||
let bytes = 0;
|
|
||||||
let done;
|
|
||||||
let _onFinish = (e) => {
|
|
||||||
if (!done) {
|
|
||||||
done = true;
|
|
||||||
onFinish && onFinish(e);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
return new ReadableStream(
|
|
||||||
{
|
|
||||||
async pull(controller) {
|
|
||||||
try {
|
|
||||||
const { done, value } = await iterator.next();
|
|
||||||
|
|
||||||
if (done) {
|
|
||||||
_onFinish();
|
|
||||||
controller.close();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
let len = value.byteLength;
|
|
||||||
if (onProgress) {
|
|
||||||
let loadedBytes = (bytes += len);
|
|
||||||
onProgress(loadedBytes);
|
|
||||||
}
|
|
||||||
controller.enqueue(new Uint8Array(value));
|
|
||||||
} catch (err) {
|
|
||||||
_onFinish(err);
|
|
||||||
throw err;
|
|
||||||
}
|
|
||||||
},
|
|
||||||
cancel(reason) {
|
|
||||||
_onFinish(reason);
|
|
||||||
return iterator.return();
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
highWaterMark: 2,
|
|
||||||
}
|
|
||||||
);
|
|
||||||
};
|
|
||||||
112
node_modules/axios/lib/helpers/validator.js
generated
vendored
112
node_modules/axios/lib/helpers/validator.js
generated
vendored
@@ -1,112 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import { VERSION } from '../env/data.js';
|
|
||||||
import AxiosError from '../core/AxiosError.js';
|
|
||||||
|
|
||||||
const validators = {};
|
|
||||||
|
|
||||||
// eslint-disable-next-line func-names
|
|
||||||
['object', 'boolean', 'number', 'function', 'string', 'symbol'].forEach((type, i) => {
|
|
||||||
validators[type] = function validator(thing) {
|
|
||||||
return typeof thing === type || 'a' + (i < 1 ? 'n ' : ' ') + type;
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
const deprecatedWarnings = {};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Transitional option validator
|
|
||||||
*
|
|
||||||
* @param {function|boolean?} validator - set to false if the transitional option has been removed
|
|
||||||
* @param {string?} version - deprecated version / removed since version
|
|
||||||
* @param {string?} message - some message with additional info
|
|
||||||
*
|
|
||||||
* @returns {function}
|
|
||||||
*/
|
|
||||||
validators.transitional = function transitional(validator, version, message) {
|
|
||||||
function formatMessage(opt, desc) {
|
|
||||||
return (
|
|
||||||
'[Axios v' +
|
|
||||||
VERSION +
|
|
||||||
"] Transitional option '" +
|
|
||||||
opt +
|
|
||||||
"'" +
|
|
||||||
desc +
|
|
||||||
(message ? '. ' + message : '')
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
// eslint-disable-next-line func-names
|
|
||||||
return (value, opt, opts) => {
|
|
||||||
if (validator === false) {
|
|
||||||
throw new AxiosError(
|
|
||||||
formatMessage(opt, ' has been removed' + (version ? ' in ' + version : '')),
|
|
||||||
AxiosError.ERR_DEPRECATED
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (version && !deprecatedWarnings[opt]) {
|
|
||||||
deprecatedWarnings[opt] = true;
|
|
||||||
// eslint-disable-next-line no-console
|
|
||||||
console.warn(
|
|
||||||
formatMessage(
|
|
||||||
opt,
|
|
||||||
' has been deprecated since v' + version + ' and will be removed in the near future'
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return validator ? validator(value, opt, opts) : true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
validators.spelling = function spelling(correctSpelling) {
|
|
||||||
return (value, opt) => {
|
|
||||||
// eslint-disable-next-line no-console
|
|
||||||
console.warn(`${opt} is likely a misspelling of ${correctSpelling}`);
|
|
||||||
return true;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Assert object's properties type
|
|
||||||
*
|
|
||||||
* @param {object} options
|
|
||||||
* @param {object} schema
|
|
||||||
* @param {boolean?} allowUnknown
|
|
||||||
*
|
|
||||||
* @returns {object}
|
|
||||||
*/
|
|
||||||
|
|
||||||
function assertOptions(options, schema, allowUnknown) {
|
|
||||||
if (typeof options !== 'object') {
|
|
||||||
throw new AxiosError('options must be an object', AxiosError.ERR_BAD_OPTION_VALUE);
|
|
||||||
}
|
|
||||||
const keys = Object.keys(options);
|
|
||||||
let i = keys.length;
|
|
||||||
while (i-- > 0) {
|
|
||||||
const opt = keys[i];
|
|
||||||
// Use hasOwnProperty so a polluted Object.prototype.<opt> cannot supply
|
|
||||||
// a non-function validator and cause a TypeError. See GHSA-q8qp-cvcw-x6jj.
|
|
||||||
const validator = Object.prototype.hasOwnProperty.call(schema, opt) ? schema[opt] : undefined;
|
|
||||||
if (validator) {
|
|
||||||
const value = options[opt];
|
|
||||||
const result = value === undefined || validator(value, opt, options);
|
|
||||||
if (result !== true) {
|
|
||||||
throw new AxiosError(
|
|
||||||
'option ' + opt + ' must be ' + result,
|
|
||||||
AxiosError.ERR_BAD_OPTION_VALUE
|
|
||||||
);
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (allowUnknown !== true) {
|
|
||||||
throw new AxiosError('Unknown option ' + opt, AxiosError.ERR_BAD_OPTION);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default {
|
|
||||||
assertOptions,
|
|
||||||
validators,
|
|
||||||
};
|
|
||||||
3
node_modules/axios/lib/platform/browser/classes/Blob.js
generated
vendored
3
node_modules/axios/lib/platform/browser/classes/Blob.js
generated
vendored
@@ -1,3 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
export default typeof Blob !== 'undefined' ? Blob : null;
|
|
||||||
3
node_modules/axios/lib/platform/browser/classes/FormData.js
generated
vendored
3
node_modules/axios/lib/platform/browser/classes/FormData.js
generated
vendored
@@ -1,3 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
export default typeof FormData !== 'undefined' ? FormData : null;
|
|
||||||
4
node_modules/axios/lib/platform/browser/classes/URLSearchParams.js
generated
vendored
4
node_modules/axios/lib/platform/browser/classes/URLSearchParams.js
generated
vendored
@@ -1,4 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
import AxiosURLSearchParams from '../../../helpers/AxiosURLSearchParams.js';
|
|
||||||
export default typeof URLSearchParams !== 'undefined' ? URLSearchParams : AxiosURLSearchParams;
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user