update gitignore
This commit is contained in:
parent
1d84f1ca7d
commit
6fa0589e53
10
.env
10
.env
|
|
@ -1,10 +0,0 @@
|
||||||
EBAY_CLIENT_ID=apactech-Apactech-PRD-d1c822b2d-f59301fc
|
|
||||||
EBAY_CLIENT_SECRET=PRD-1c822b2dbaf0-c206-430b-b54d-ca4a
|
|
||||||
WORKER_API_KEY=4AqyhVRX7AbUpfQ0gZp5eNMX
|
|
||||||
|
|
||||||
# Telegram Configuration (optional)
|
|
||||||
TELEGRAM_BOT_TOKEN="6478549274:AAEHldiMwOjKm1RnOEuKt4L2vhRHbMk-gvw"
|
|
||||||
TELEGRAM_CHAT_ID="-5239090008"
|
|
||||||
|
|
||||||
# Server Port
|
|
||||||
PORT=3000
|
|
||||||
|
|
@ -1,8 +1,10 @@
|
||||||
node_modules
|
node_modules/
|
||||||
chrome-profile
|
.env
|
||||||
ebay_items.db
|
.env.*
|
||||||
*/.env
|
dist/
|
||||||
*.db
|
build/
|
||||||
*.sqlite
|
coverage/
|
||||||
*.sqlite3
|
npm-debug.log*
|
||||||
.env
|
yarn-debug.log*
|
||||||
|
yarn-error.log*
|
||||||
|
.DS_Store
|
||||||
|
|
@ -1,16 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*)
|
|
||||||
if command -v cygpath > /dev/null 2>&1; then
|
|
||||||
basedir=`cygpath -w "$basedir"`
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
exec "$basedir/node" "$basedir/../mime/cli.js" "$@"
|
|
||||||
else
|
|
||||||
exec node "$basedir/../mime/cli.js" "$@"
|
|
||||||
fi
|
|
||||||
|
|
@ -1,17 +0,0 @@
|
||||||
@ECHO off
|
|
||||||
GOTO start
|
|
||||||
:find_dp0
|
|
||||||
SET dp0=%~dp0
|
|
||||||
EXIT /b
|
|
||||||
:start
|
|
||||||
SETLOCAL
|
|
||||||
CALL :find_dp0
|
|
||||||
|
|
||||||
IF EXIST "%dp0%\node.exe" (
|
|
||||||
SET "_prog=%dp0%\node.exe"
|
|
||||||
) ELSE (
|
|
||||||
SET "_prog=node"
|
|
||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
|
||||||
)
|
|
||||||
|
|
||||||
endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\mime\cli.js" %*
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
#!/usr/bin/env pwsh
|
|
||||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
|
||||||
|
|
||||||
$exe=""
|
|
||||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|
||||||
# Fix case when both the Windows and Linux builds of Node
|
|
||||||
# are installed in the same directory
|
|
||||||
$exe=".exe"
|
|
||||||
}
|
|
||||||
$ret=0
|
|
||||||
if (Test-Path "$basedir/node$exe") {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "$basedir/node$exe" "$basedir/../mime/cli.js" $args
|
|
||||||
} else {
|
|
||||||
& "$basedir/node$exe" "$basedir/../mime/cli.js" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
} else {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "node$exe" "$basedir/../mime/cli.js" $args
|
|
||||||
} else {
|
|
||||||
& "node$exe" "$basedir/../mime/cli.js" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
}
|
|
||||||
exit $ret
|
|
||||||
|
|
@ -1,16 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*)
|
|
||||||
if command -v cygpath > /dev/null 2>&1; then
|
|
||||||
basedir=`cygpath -w "$basedir"`
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
exec "$basedir/node" "$basedir/../nodemon/bin/nodemon.js" "$@"
|
|
||||||
else
|
|
||||||
exec node "$basedir/../nodemon/bin/nodemon.js" "$@"
|
|
||||||
fi
|
|
||||||
|
|
@ -1,17 +0,0 @@
|
||||||
@ECHO off
|
|
||||||
GOTO start
|
|
||||||
:find_dp0
|
|
||||||
SET dp0=%~dp0
|
|
||||||
EXIT /b
|
|
||||||
:start
|
|
||||||
SETLOCAL
|
|
||||||
CALL :find_dp0
|
|
||||||
|
|
||||||
IF EXIST "%dp0%\node.exe" (
|
|
||||||
SET "_prog=%dp0%\node.exe"
|
|
||||||
) ELSE (
|
|
||||||
SET "_prog=node"
|
|
||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
|
||||||
)
|
|
||||||
|
|
||||||
endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\nodemon\bin\nodemon.js" %*
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
#!/usr/bin/env pwsh
|
|
||||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
|
||||||
|
|
||||||
$exe=""
|
|
||||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|
||||||
# Fix case when both the Windows and Linux builds of Node
|
|
||||||
# are installed in the same directory
|
|
||||||
$exe=".exe"
|
|
||||||
}
|
|
||||||
$ret=0
|
|
||||||
if (Test-Path "$basedir/node$exe") {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "$basedir/node$exe" "$basedir/../nodemon/bin/nodemon.js" $args
|
|
||||||
} else {
|
|
||||||
& "$basedir/node$exe" "$basedir/../nodemon/bin/nodemon.js" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
} else {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "node$exe" "$basedir/../nodemon/bin/nodemon.js" $args
|
|
||||||
} else {
|
|
||||||
& "node$exe" "$basedir/../nodemon/bin/nodemon.js" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
}
|
|
||||||
exit $ret
|
|
||||||
|
|
@ -1,16 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*)
|
|
||||||
if command -v cygpath > /dev/null 2>&1; then
|
|
||||||
basedir=`cygpath -w "$basedir"`
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
exec "$basedir/node" "$basedir/../touch/bin/nodetouch.js" "$@"
|
|
||||||
else
|
|
||||||
exec node "$basedir/../touch/bin/nodetouch.js" "$@"
|
|
||||||
fi
|
|
||||||
|
|
@ -1,17 +0,0 @@
|
||||||
@ECHO off
|
|
||||||
GOTO start
|
|
||||||
:find_dp0
|
|
||||||
SET dp0=%~dp0
|
|
||||||
EXIT /b
|
|
||||||
:start
|
|
||||||
SETLOCAL
|
|
||||||
CALL :find_dp0
|
|
||||||
|
|
||||||
IF EXIST "%dp0%\node.exe" (
|
|
||||||
SET "_prog=%dp0%\node.exe"
|
|
||||||
) ELSE (
|
|
||||||
SET "_prog=node"
|
|
||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
|
||||||
)
|
|
||||||
|
|
||||||
endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\touch\bin\nodetouch.js" %*
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
#!/usr/bin/env pwsh
|
|
||||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
|
||||||
|
|
||||||
$exe=""
|
|
||||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|
||||||
# Fix case when both the Windows and Linux builds of Node
|
|
||||||
# are installed in the same directory
|
|
||||||
$exe=".exe"
|
|
||||||
}
|
|
||||||
$ret=0
|
|
||||||
if (Test-Path "$basedir/node$exe") {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "$basedir/node$exe" "$basedir/../touch/bin/nodetouch.js" $args
|
|
||||||
} else {
|
|
||||||
& "$basedir/node$exe" "$basedir/../touch/bin/nodetouch.js" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
} else {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "node$exe" "$basedir/../touch/bin/nodetouch.js" $args
|
|
||||||
} else {
|
|
||||||
& "node$exe" "$basedir/../touch/bin/nodetouch.js" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
}
|
|
||||||
exit $ret
|
|
||||||
|
|
@ -1,16 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*)
|
|
||||||
if command -v cygpath > /dev/null 2>&1; then
|
|
||||||
basedir=`cygpath -w "$basedir"`
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
exec "$basedir/node" "$basedir/../semver/bin/semver.js" "$@"
|
|
||||||
else
|
|
||||||
exec node "$basedir/../semver/bin/semver.js" "$@"
|
|
||||||
fi
|
|
||||||
|
|
@ -1,17 +0,0 @@
|
||||||
@ECHO off
|
|
||||||
GOTO start
|
|
||||||
:find_dp0
|
|
||||||
SET dp0=%~dp0
|
|
||||||
EXIT /b
|
|
||||||
:start
|
|
||||||
SETLOCAL
|
|
||||||
CALL :find_dp0
|
|
||||||
|
|
||||||
IF EXIST "%dp0%\node.exe" (
|
|
||||||
SET "_prog=%dp0%\node.exe"
|
|
||||||
) ELSE (
|
|
||||||
SET "_prog=node"
|
|
||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
|
||||||
)
|
|
||||||
|
|
||||||
endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\semver\bin\semver.js" %*
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
#!/usr/bin/env pwsh
|
|
||||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
|
||||||
|
|
||||||
$exe=""
|
|
||||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|
||||||
# Fix case when both the Windows and Linux builds of Node
|
|
||||||
# are installed in the same directory
|
|
||||||
$exe=".exe"
|
|
||||||
}
|
|
||||||
$ret=0
|
|
||||||
if (Test-Path "$basedir/node$exe") {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "$basedir/node$exe" "$basedir/../semver/bin/semver.js" $args
|
|
||||||
} else {
|
|
||||||
& "$basedir/node$exe" "$basedir/../semver/bin/semver.js" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
} else {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "node$exe" "$basedir/../semver/bin/semver.js" $args
|
|
||||||
} else {
|
|
||||||
& "node$exe" "$basedir/../semver/bin/semver.js" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
}
|
|
||||||
exit $ret
|
|
||||||
|
|
@ -1,16 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*)
|
|
||||||
if command -v cygpath > /dev/null 2>&1; then
|
|
||||||
basedir=`cygpath -w "$basedir"`
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
exec "$basedir/node" "$basedir/../uuid/dist/bin/uuid" "$@"
|
|
||||||
else
|
|
||||||
exec node "$basedir/../uuid/dist/bin/uuid" "$@"
|
|
||||||
fi
|
|
||||||
|
|
@ -1,17 +0,0 @@
|
||||||
@ECHO off
|
|
||||||
GOTO start
|
|
||||||
:find_dp0
|
|
||||||
SET dp0=%~dp0
|
|
||||||
EXIT /b
|
|
||||||
:start
|
|
||||||
SETLOCAL
|
|
||||||
CALL :find_dp0
|
|
||||||
|
|
||||||
IF EXIST "%dp0%\node.exe" (
|
|
||||||
SET "_prog=%dp0%\node.exe"
|
|
||||||
) ELSE (
|
|
||||||
SET "_prog=node"
|
|
||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
|
||||||
)
|
|
||||||
|
|
||||||
endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\..\uuid\dist\bin\uuid" %*
|
|
||||||
|
|
@ -1,28 +0,0 @@
|
||||||
#!/usr/bin/env pwsh
|
|
||||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
|
||||||
|
|
||||||
$exe=""
|
|
||||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|
||||||
# Fix case when both the Windows and Linux builds of Node
|
|
||||||
# are installed in the same directory
|
|
||||||
$exe=".exe"
|
|
||||||
}
|
|
||||||
$ret=0
|
|
||||||
if (Test-Path "$basedir/node$exe") {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "$basedir/node$exe" "$basedir/../uuid/dist/bin/uuid" $args
|
|
||||||
} else {
|
|
||||||
& "$basedir/node$exe" "$basedir/../uuid/dist/bin/uuid" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
} else {
|
|
||||||
# Support pipeline input
|
|
||||||
if ($MyInvocation.ExpectingInput) {
|
|
||||||
$input | & "node$exe" "$basedir/../uuid/dist/bin/uuid" $args
|
|
||||||
} else {
|
|
||||||
& "node$exe" "$basedir/../uuid/dist/bin/uuid" $args
|
|
||||||
}
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
}
|
|
||||||
exit $ret
|
|
||||||
File diff suppressed because it is too large
Load Diff
|
|
@ -1,243 +0,0 @@
|
||||||
1.3.8 / 2022-02-02
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.34
|
|
||||||
- deps: mime-db@~1.51.0
|
|
||||||
* deps: negotiator@0.6.3
|
|
||||||
|
|
||||||
1.3.7 / 2019-04-29
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: negotiator@0.6.2
|
|
||||||
- Fix sorting charset, encoding, and language with extra parameters
|
|
||||||
|
|
||||||
1.3.6 / 2019-04-28
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.24
|
|
||||||
- deps: mime-db@~1.40.0
|
|
||||||
|
|
||||||
1.3.5 / 2018-02-28
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.18
|
|
||||||
- deps: mime-db@~1.33.0
|
|
||||||
|
|
||||||
1.3.4 / 2017-08-22
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.16
|
|
||||||
- deps: mime-db@~1.29.0
|
|
||||||
|
|
||||||
1.3.3 / 2016-05-02
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.11
|
|
||||||
- deps: mime-db@~1.23.0
|
|
||||||
* deps: negotiator@0.6.1
|
|
||||||
- perf: improve `Accept` parsing speed
|
|
||||||
- perf: improve `Accept-Charset` parsing speed
|
|
||||||
- perf: improve `Accept-Encoding` parsing speed
|
|
||||||
- perf: improve `Accept-Language` parsing speed
|
|
||||||
|
|
||||||
1.3.2 / 2016-03-08
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.10
|
|
||||||
- Fix extension of `application/dash+xml`
|
|
||||||
- Update primary extension for `audio/mp4`
|
|
||||||
- deps: mime-db@~1.22.0
|
|
||||||
|
|
||||||
1.3.1 / 2016-01-19
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.9
|
|
||||||
- deps: mime-db@~1.21.0
|
|
||||||
|
|
||||||
1.3.0 / 2015-09-29
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.7
|
|
||||||
- deps: mime-db@~1.19.0
|
|
||||||
* deps: negotiator@0.6.0
|
|
||||||
- Fix including type extensions in parameters in `Accept` parsing
|
|
||||||
- Fix parsing `Accept` parameters with quoted equals
|
|
||||||
- Fix parsing `Accept` parameters with quoted semicolons
|
|
||||||
- Lazy-load modules from main entry point
|
|
||||||
- perf: delay type concatenation until needed
|
|
||||||
- perf: enable strict mode
|
|
||||||
- perf: hoist regular expressions
|
|
||||||
- perf: remove closures getting spec properties
|
|
||||||
- perf: remove a closure from media type parsing
|
|
||||||
- perf: remove property delete from media type parsing
|
|
||||||
|
|
||||||
1.2.13 / 2015-09-06
|
|
||||||
===================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.6
|
|
||||||
- deps: mime-db@~1.18.0
|
|
||||||
|
|
||||||
1.2.12 / 2015-07-30
|
|
||||||
===================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.4
|
|
||||||
- deps: mime-db@~1.16.0
|
|
||||||
|
|
||||||
1.2.11 / 2015-07-16
|
|
||||||
===================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.3
|
|
||||||
- deps: mime-db@~1.15.0
|
|
||||||
|
|
||||||
1.2.10 / 2015-07-01
|
|
||||||
===================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.2
|
|
||||||
- deps: mime-db@~1.14.0
|
|
||||||
|
|
||||||
1.2.9 / 2015-06-08
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.1
|
|
||||||
- perf: fix deopt during mapping
|
|
||||||
|
|
||||||
1.2.8 / 2015-06-07
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.1.0
|
|
||||||
- deps: mime-db@~1.13.0
|
|
||||||
* perf: avoid argument reassignment & argument slice
|
|
||||||
* perf: avoid negotiator recursive construction
|
|
||||||
* perf: enable strict mode
|
|
||||||
* perf: remove unnecessary bitwise operator
|
|
||||||
|
|
||||||
1.2.7 / 2015-05-10
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: negotiator@0.5.3
|
|
||||||
- Fix media type parameter matching to be case-insensitive
|
|
||||||
|
|
||||||
1.2.6 / 2015-05-07
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.0.11
|
|
||||||
- deps: mime-db@~1.9.1
|
|
||||||
* deps: negotiator@0.5.2
|
|
||||||
- Fix comparing media types with quoted values
|
|
||||||
- Fix splitting media types with quoted commas
|
|
||||||
|
|
||||||
1.2.5 / 2015-03-13
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.0.10
|
|
||||||
- deps: mime-db@~1.8.0
|
|
||||||
|
|
||||||
1.2.4 / 2015-02-14
|
|
||||||
==================
|
|
||||||
|
|
||||||
* Support Node.js 0.6
|
|
||||||
* deps: mime-types@~2.0.9
|
|
||||||
- deps: mime-db@~1.7.0
|
|
||||||
* deps: negotiator@0.5.1
|
|
||||||
- Fix preference sorting to be stable for long acceptable lists
|
|
||||||
|
|
||||||
1.2.3 / 2015-01-31
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.0.8
|
|
||||||
- deps: mime-db@~1.6.0
|
|
||||||
|
|
||||||
1.2.2 / 2014-12-30
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.0.7
|
|
||||||
- deps: mime-db@~1.5.0
|
|
||||||
|
|
||||||
1.2.1 / 2014-12-30
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.0.5
|
|
||||||
- deps: mime-db@~1.3.1
|
|
||||||
|
|
||||||
1.2.0 / 2014-12-19
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: negotiator@0.5.0
|
|
||||||
- Fix list return order when large accepted list
|
|
||||||
- Fix missing identity encoding when q=0 exists
|
|
||||||
- Remove dynamic building of Negotiator class
|
|
||||||
|
|
||||||
1.1.4 / 2014-12-10
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.0.4
|
|
||||||
- deps: mime-db@~1.3.0
|
|
||||||
|
|
||||||
1.1.3 / 2014-11-09
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.0.3
|
|
||||||
- deps: mime-db@~1.2.0
|
|
||||||
|
|
||||||
1.1.2 / 2014-10-14
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: negotiator@0.4.9
|
|
||||||
- Fix error when media type has invalid parameter
|
|
||||||
|
|
||||||
1.1.1 / 2014-09-28
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: mime-types@~2.0.2
|
|
||||||
- deps: mime-db@~1.1.0
|
|
||||||
* deps: negotiator@0.4.8
|
|
||||||
- Fix all negotiations to be case-insensitive
|
|
||||||
- Stable sort preferences of same quality according to client order
|
|
||||||
|
|
||||||
1.1.0 / 2014-09-02
|
|
||||||
==================
|
|
||||||
|
|
||||||
* update `mime-types`
|
|
||||||
|
|
||||||
1.0.7 / 2014-07-04
|
|
||||||
==================
|
|
||||||
|
|
||||||
* Fix wrong type returned from `type` when match after unknown extension
|
|
||||||
|
|
||||||
1.0.6 / 2014-06-24
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: negotiator@0.4.7
|
|
||||||
|
|
||||||
1.0.5 / 2014-06-20
|
|
||||||
==================
|
|
||||||
|
|
||||||
* fix crash when unknown extension given
|
|
||||||
|
|
||||||
1.0.4 / 2014-06-19
|
|
||||||
==================
|
|
||||||
|
|
||||||
* use `mime-types`
|
|
||||||
|
|
||||||
1.0.3 / 2014-06-11
|
|
||||||
==================
|
|
||||||
|
|
||||||
* deps: negotiator@0.4.6
|
|
||||||
- Order by specificity when quality is the same
|
|
||||||
|
|
||||||
1.0.2 / 2014-05-29
|
|
||||||
==================
|
|
||||||
|
|
||||||
* Fix interpretation when header not in request
|
|
||||||
* deps: pin negotiator@0.4.5
|
|
||||||
|
|
||||||
1.0.1 / 2014-01-18
|
|
||||||
==================
|
|
||||||
|
|
||||||
* Identity encoding isn't always acceptable
|
|
||||||
* deps: negotiator@~0.4.0
|
|
||||||
|
|
||||||
1.0.0 / 2013-12-27
|
|
||||||
==================
|
|
||||||
|
|
||||||
* Genesis
|
|
||||||
|
|
@ -1,23 +0,0 @@
|
||||||
(The MIT License)
|
|
||||||
|
|
||||||
Copyright (c) 2014 Jonathan Ong <me@jongleberry.com>
|
|
||||||
Copyright (c) 2015 Douglas Christopher Wilson <doug@somethingdoug.com>
|
|
||||||
|
|
||||||
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.
|
|
||||||
|
|
@ -1,140 +0,0 @@
|
||||||
# accepts
|
|
||||||
|
|
||||||
[![NPM Version][npm-version-image]][npm-url]
|
|
||||||
[![NPM Downloads][npm-downloads-image]][npm-url]
|
|
||||||
[![Node.js Version][node-version-image]][node-version-url]
|
|
||||||
[![Build Status][github-actions-ci-image]][github-actions-ci-url]
|
|
||||||
[![Test Coverage][coveralls-image]][coveralls-url]
|
|
||||||
|
|
||||||
Higher level content negotiation based on [negotiator](https://www.npmjs.com/package/negotiator).
|
|
||||||
Extracted from [koa](https://www.npmjs.com/package/koa) for general use.
|
|
||||||
|
|
||||||
In addition to negotiator, it allows:
|
|
||||||
|
|
||||||
- Allows types as an array or arguments list, ie `(['text/html', 'application/json'])`
|
|
||||||
as well as `('text/html', 'application/json')`.
|
|
||||||
- Allows type shorthands such as `json`.
|
|
||||||
- Returns `false` when no types match
|
|
||||||
- Treats non-existent headers as `*`
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
This is a [Node.js](https://nodejs.org/en/) module available through the
|
|
||||||
[npm registry](https://www.npmjs.com/). Installation is done using the
|
|
||||||
[`npm install` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally):
|
|
||||||
|
|
||||||
```sh
|
|
||||||
$ npm install accepts
|
|
||||||
```
|
|
||||||
|
|
||||||
## API
|
|
||||||
|
|
||||||
```js
|
|
||||||
var accepts = require('accepts')
|
|
||||||
```
|
|
||||||
|
|
||||||
### accepts(req)
|
|
||||||
|
|
||||||
Create a new `Accepts` object for the given `req`.
|
|
||||||
|
|
||||||
#### .charset(charsets)
|
|
||||||
|
|
||||||
Return the first accepted charset. If nothing in `charsets` is accepted,
|
|
||||||
then `false` is returned.
|
|
||||||
|
|
||||||
#### .charsets()
|
|
||||||
|
|
||||||
Return the charsets that the request accepts, in the order of the client's
|
|
||||||
preference (most preferred first).
|
|
||||||
|
|
||||||
#### .encoding(encodings)
|
|
||||||
|
|
||||||
Return the first accepted encoding. If nothing in `encodings` is accepted,
|
|
||||||
then `false` is returned.
|
|
||||||
|
|
||||||
#### .encodings()
|
|
||||||
|
|
||||||
Return the encodings that the request accepts, in the order of the client's
|
|
||||||
preference (most preferred first).
|
|
||||||
|
|
||||||
#### .language(languages)
|
|
||||||
|
|
||||||
Return the first accepted language. If nothing in `languages` is accepted,
|
|
||||||
then `false` is returned.
|
|
||||||
|
|
||||||
#### .languages()
|
|
||||||
|
|
||||||
Return the languages that the request accepts, in the order of the client's
|
|
||||||
preference (most preferred first).
|
|
||||||
|
|
||||||
#### .type(types)
|
|
||||||
|
|
||||||
Return the first accepted type (and it is returned as the same text as what
|
|
||||||
appears in the `types` array). If nothing in `types` is accepted, then `false`
|
|
||||||
is returned.
|
|
||||||
|
|
||||||
The `types` array can contain full MIME types or file extensions. Any value
|
|
||||||
that is not a full MIME types is passed to `require('mime-types').lookup`.
|
|
||||||
|
|
||||||
#### .types()
|
|
||||||
|
|
||||||
Return the types that the request accepts, in the order of the client's
|
|
||||||
preference (most preferred first).
|
|
||||||
|
|
||||||
## Examples
|
|
||||||
|
|
||||||
### Simple type negotiation
|
|
||||||
|
|
||||||
This simple example shows how to use `accepts` to return a different typed
|
|
||||||
respond body based on what the client wants to accept. The server lists it's
|
|
||||||
preferences in order and will get back the best match between the client and
|
|
||||||
server.
|
|
||||||
|
|
||||||
```js
|
|
||||||
var accepts = require('accepts')
|
|
||||||
var http = require('http')
|
|
||||||
|
|
||||||
function app (req, res) {
|
|
||||||
var accept = accepts(req)
|
|
||||||
|
|
||||||
// the order of this list is significant; should be server preferred order
|
|
||||||
switch (accept.type(['json', 'html'])) {
|
|
||||||
case 'json':
|
|
||||||
res.setHeader('Content-Type', 'application/json')
|
|
||||||
res.write('{"hello":"world!"}')
|
|
||||||
break
|
|
||||||
case 'html':
|
|
||||||
res.setHeader('Content-Type', 'text/html')
|
|
||||||
res.write('<b>hello, world!</b>')
|
|
||||||
break
|
|
||||||
default:
|
|
||||||
// the fallback is text/plain, so no need to specify it above
|
|
||||||
res.setHeader('Content-Type', 'text/plain')
|
|
||||||
res.write('hello, world!')
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
res.end()
|
|
||||||
}
|
|
||||||
|
|
||||||
http.createServer(app).listen(3000)
|
|
||||||
```
|
|
||||||
|
|
||||||
You can test this out with the cURL program:
|
|
||||||
```sh
|
|
||||||
curl -I -H'Accept: text/html' http://localhost:3000/
|
|
||||||
```
|
|
||||||
|
|
||||||
## License
|
|
||||||
|
|
||||||
[MIT](LICENSE)
|
|
||||||
|
|
||||||
[coveralls-image]: https://badgen.net/coveralls/c/github/jshttp/accepts/master
|
|
||||||
[coveralls-url]: https://coveralls.io/r/jshttp/accepts?branch=master
|
|
||||||
[github-actions-ci-image]: https://badgen.net/github/checks/jshttp/accepts/master?label=ci
|
|
||||||
[github-actions-ci-url]: https://github.com/jshttp/accepts/actions/workflows/ci.yml
|
|
||||||
[node-version-image]: https://badgen.net/npm/node/accepts
|
|
||||||
[node-version-url]: https://nodejs.org/en/download
|
|
||||||
[npm-downloads-image]: https://badgen.net/npm/dm/accepts
|
|
||||||
[npm-url]: https://npmjs.org/package/accepts
|
|
||||||
[npm-version-image]: https://badgen.net/npm/v/accepts
|
|
||||||
|
|
@ -1,238 +0,0 @@
|
||||||
/*!
|
|
||||||
* accepts
|
|
||||||
* Copyright(c) 2014 Jonathan Ong
|
|
||||||
* Copyright(c) 2015 Douglas Christopher Wilson
|
|
||||||
* MIT Licensed
|
|
||||||
*/
|
|
||||||
|
|
||||||
'use strict'
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Module dependencies.
|
|
||||||
* @private
|
|
||||||
*/
|
|
||||||
|
|
||||||
var Negotiator = require('negotiator')
|
|
||||||
var mime = require('mime-types')
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Module exports.
|
|
||||||
* @public
|
|
||||||
*/
|
|
||||||
|
|
||||||
module.exports = Accepts
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create a new Accepts object for the given req.
|
|
||||||
*
|
|
||||||
* @param {object} req
|
|
||||||
* @public
|
|
||||||
*/
|
|
||||||
|
|
||||||
function Accepts (req) {
|
|
||||||
if (!(this instanceof Accepts)) {
|
|
||||||
return new Accepts(req)
|
|
||||||
}
|
|
||||||
|
|
||||||
this.headers = req.headers
|
|
||||||
this.negotiator = new Negotiator(req)
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if the given `type(s)` is acceptable, returning
|
|
||||||
* the best match when true, otherwise `undefined`, in which
|
|
||||||
* case you should respond with 406 "Not Acceptable".
|
|
||||||
*
|
|
||||||
* The `type` value may be a single mime type string
|
|
||||||
* such as "application/json", the extension name
|
|
||||||
* such as "json" or an array `["json", "html", "text/plain"]`. When a list
|
|
||||||
* or array is given the _best_ match, if any is returned.
|
|
||||||
*
|
|
||||||
* Examples:
|
|
||||||
*
|
|
||||||
* // Accept: text/html
|
|
||||||
* this.types('html');
|
|
||||||
* // => "html"
|
|
||||||
*
|
|
||||||
* // Accept: text/*, application/json
|
|
||||||
* this.types('html');
|
|
||||||
* // => "html"
|
|
||||||
* this.types('text/html');
|
|
||||||
* // => "text/html"
|
|
||||||
* this.types('json', 'text');
|
|
||||||
* // => "json"
|
|
||||||
* this.types('application/json');
|
|
||||||
* // => "application/json"
|
|
||||||
*
|
|
||||||
* // Accept: text/*, application/json
|
|
||||||
* this.types('image/png');
|
|
||||||
* this.types('png');
|
|
||||||
* // => undefined
|
|
||||||
*
|
|
||||||
* // Accept: text/*;q=.5, application/json
|
|
||||||
* this.types(['html', 'json']);
|
|
||||||
* this.types('html', 'json');
|
|
||||||
* // => "json"
|
|
||||||
*
|
|
||||||
* @param {String|Array} types...
|
|
||||||
* @return {String|Array|Boolean}
|
|
||||||
* @public
|
|
||||||
*/
|
|
||||||
|
|
||||||
Accepts.prototype.type =
|
|
||||||
Accepts.prototype.types = function (types_) {
|
|
||||||
var types = types_
|
|
||||||
|
|
||||||
// support flattened arguments
|
|
||||||
if (types && !Array.isArray(types)) {
|
|
||||||
types = new Array(arguments.length)
|
|
||||||
for (var i = 0; i < types.length; i++) {
|
|
||||||
types[i] = arguments[i]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// no types, return all requested types
|
|
||||||
if (!types || types.length === 0) {
|
|
||||||
return this.negotiator.mediaTypes()
|
|
||||||
}
|
|
||||||
|
|
||||||
// no accept header, return first given type
|
|
||||||
if (!this.headers.accept) {
|
|
||||||
return types[0]
|
|
||||||
}
|
|
||||||
|
|
||||||
var mimes = types.map(extToMime)
|
|
||||||
var accepts = this.negotiator.mediaTypes(mimes.filter(validMime))
|
|
||||||
var first = accepts[0]
|
|
||||||
|
|
||||||
return first
|
|
||||||
? types[mimes.indexOf(first)]
|
|
||||||
: false
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return accepted encodings or best fit based on `encodings`.
|
|
||||||
*
|
|
||||||
* Given `Accept-Encoding: gzip, deflate`
|
|
||||||
* an array sorted by quality is returned:
|
|
||||||
*
|
|
||||||
* ['gzip', 'deflate']
|
|
||||||
*
|
|
||||||
* @param {String|Array} encodings...
|
|
||||||
* @return {String|Array}
|
|
||||||
* @public
|
|
||||||
*/
|
|
||||||
|
|
||||||
Accepts.prototype.encoding =
|
|
||||||
Accepts.prototype.encodings = function (encodings_) {
|
|
||||||
var encodings = encodings_
|
|
||||||
|
|
||||||
// support flattened arguments
|
|
||||||
if (encodings && !Array.isArray(encodings)) {
|
|
||||||
encodings = new Array(arguments.length)
|
|
||||||
for (var i = 0; i < encodings.length; i++) {
|
|
||||||
encodings[i] = arguments[i]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// no encodings, return all requested encodings
|
|
||||||
if (!encodings || encodings.length === 0) {
|
|
||||||
return this.negotiator.encodings()
|
|
||||||
}
|
|
||||||
|
|
||||||
return this.negotiator.encodings(encodings)[0] || false
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return accepted charsets or best fit based on `charsets`.
|
|
||||||
*
|
|
||||||
* Given `Accept-Charset: utf-8, iso-8859-1;q=0.2, utf-7;q=0.5`
|
|
||||||
* an array sorted by quality is returned:
|
|
||||||
*
|
|
||||||
* ['utf-8', 'utf-7', 'iso-8859-1']
|
|
||||||
*
|
|
||||||
* @param {String|Array} charsets...
|
|
||||||
* @return {String|Array}
|
|
||||||
* @public
|
|
||||||
*/
|
|
||||||
|
|
||||||
Accepts.prototype.charset =
|
|
||||||
Accepts.prototype.charsets = function (charsets_) {
|
|
||||||
var charsets = charsets_
|
|
||||||
|
|
||||||
// support flattened arguments
|
|
||||||
if (charsets && !Array.isArray(charsets)) {
|
|
||||||
charsets = new Array(arguments.length)
|
|
||||||
for (var i = 0; i < charsets.length; i++) {
|
|
||||||
charsets[i] = arguments[i]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// no charsets, return all requested charsets
|
|
||||||
if (!charsets || charsets.length === 0) {
|
|
||||||
return this.negotiator.charsets()
|
|
||||||
}
|
|
||||||
|
|
||||||
return this.negotiator.charsets(charsets)[0] || false
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Return accepted languages or best fit based on `langs`.
|
|
||||||
*
|
|
||||||
* Given `Accept-Language: en;q=0.8, es, pt`
|
|
||||||
* an array sorted by quality is returned:
|
|
||||||
*
|
|
||||||
* ['es', 'pt', 'en']
|
|
||||||
*
|
|
||||||
* @param {String|Array} langs...
|
|
||||||
* @return {Array|String}
|
|
||||||
* @public
|
|
||||||
*/
|
|
||||||
|
|
||||||
Accepts.prototype.lang =
|
|
||||||
Accepts.prototype.langs =
|
|
||||||
Accepts.prototype.language =
|
|
||||||
Accepts.prototype.languages = function (languages_) {
|
|
||||||
var languages = languages_
|
|
||||||
|
|
||||||
// support flattened arguments
|
|
||||||
if (languages && !Array.isArray(languages)) {
|
|
||||||
languages = new Array(arguments.length)
|
|
||||||
for (var i = 0; i < languages.length; i++) {
|
|
||||||
languages[i] = arguments[i]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// no languages, return all requested languages
|
|
||||||
if (!languages || languages.length === 0) {
|
|
||||||
return this.negotiator.languages()
|
|
||||||
}
|
|
||||||
|
|
||||||
return this.negotiator.languages(languages)[0] || false
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert extnames to mime.
|
|
||||||
*
|
|
||||||
* @param {String} type
|
|
||||||
* @return {String}
|
|
||||||
* @private
|
|
||||||
*/
|
|
||||||
|
|
||||||
function extToMime (type) {
|
|
||||||
return type.indexOf('/') === -1
|
|
||||||
? mime.lookup(type)
|
|
||||||
: type
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Check if mime is valid.
|
|
||||||
*
|
|
||||||
* @param {String} type
|
|
||||||
* @return {String}
|
|
||||||
* @private
|
|
||||||
*/
|
|
||||||
|
|
||||||
function validMime (type) {
|
|
||||||
return typeof type === 'string'
|
|
||||||
}
|
|
||||||
|
|
@ -1,47 +0,0 @@
|
||||||
{
|
|
||||||
"name": "accepts",
|
|
||||||
"description": "Higher-level content negotiation",
|
|
||||||
"version": "1.3.8",
|
|
||||||
"contributors": [
|
|
||||||
"Douglas Christopher Wilson <doug@somethingdoug.com>",
|
|
||||||
"Jonathan Ong <me@jongleberry.com> (http://jongleberry.com)"
|
|
||||||
],
|
|
||||||
"license": "MIT",
|
|
||||||
"repository": "jshttp/accepts",
|
|
||||||
"dependencies": {
|
|
||||||
"mime-types": "~2.1.34",
|
|
||||||
"negotiator": "0.6.3"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"deep-equal": "1.0.1",
|
|
||||||
"eslint": "7.32.0",
|
|
||||||
"eslint-config-standard": "14.1.1",
|
|
||||||
"eslint-plugin-import": "2.25.4",
|
|
||||||
"eslint-plugin-markdown": "2.2.1",
|
|
||||||
"eslint-plugin-node": "11.1.0",
|
|
||||||
"eslint-plugin-promise": "4.3.1",
|
|
||||||
"eslint-plugin-standard": "4.1.0",
|
|
||||||
"mocha": "9.2.0",
|
|
||||||
"nyc": "15.1.0"
|
|
||||||
},
|
|
||||||
"files": [
|
|
||||||
"LICENSE",
|
|
||||||
"HISTORY.md",
|
|
||||||
"index.js"
|
|
||||||
],
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 0.6"
|
|
||||||
},
|
|
||||||
"scripts": {
|
|
||||||
"lint": "eslint .",
|
|
||||||
"test": "mocha --reporter spec --check-leaks --bail test/",
|
|
||||||
"test-ci": "nyc --reporter=lcov --reporter=text npm test",
|
|
||||||
"test-cov": "nyc --reporter=html --reporter=text npm test"
|
|
||||||
},
|
|
||||||
"keywords": [
|
|
||||||
"content",
|
|
||||||
"negotiation",
|
|
||||||
"accept",
|
|
||||||
"accepts"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
|
|
@ -1,15 +0,0 @@
|
||||||
The ISC License
|
|
||||||
|
|
||||||
Copyright (c) 2019 Elan Shanker, Paul Miller (https://paulmillr.com)
|
|
||||||
|
|
||||||
Permission to use, copy, modify, and/or distribute this software for any
|
|
||||||
purpose with or without fee is hereby granted, provided that the above
|
|
||||||
copyright notice and this permission notice appear in all copies.
|
|
||||||
|
|
||||||
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
||||||
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
||||||
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
||||||
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
||||||
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
||||||
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
|
|
||||||
IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
||||||
|
|
@ -1,87 +0,0 @@
|
||||||
anymatch [](https://travis-ci.org/micromatch/anymatch) [](https://coveralls.io/r/micromatch/anymatch?branch=master)
|
|
||||||
======
|
|
||||||
Javascript module to match a string against a regular expression, glob, string,
|
|
||||||
or function that takes the string as an argument and returns a truthy or falsy
|
|
||||||
value. The matcher can also be an array of any or all of these. Useful for
|
|
||||||
allowing a very flexible user-defined config to define things like file paths.
|
|
||||||
|
|
||||||
__Note: This module has Bash-parity, please be aware that Windows-style backslashes are not supported as separators. See https://github.com/micromatch/micromatch#backslashes for more information.__
|
|
||||||
|
|
||||||
|
|
||||||
Usage
|
|
||||||
-----
|
|
||||||
```sh
|
|
||||||
npm install anymatch
|
|
||||||
```
|
|
||||||
|
|
||||||
#### anymatch(matchers, testString, [returnIndex], [options])
|
|
||||||
* __matchers__: (_Array|String|RegExp|Function_)
|
|
||||||
String to be directly matched, string with glob patterns, regular expression
|
|
||||||
test, function that takes the testString as an argument and returns a truthy
|
|
||||||
value if it should be matched, or an array of any number and mix of these types.
|
|
||||||
* __testString__: (_String|Array_) The string to test against the matchers. If
|
|
||||||
passed as an array, the first element of the array will be used as the
|
|
||||||
`testString` for non-function matchers, while the entire array will be applied
|
|
||||||
as the arguments for function matchers.
|
|
||||||
* __options__: (_Object_ [optional]_) Any of the [picomatch](https://github.com/micromatch/picomatch#options) options.
|
|
||||||
* __returnIndex__: (_Boolean [optional]_) If true, return the array index of
|
|
||||||
the first matcher that that testString matched, or -1 if no match, instead of a
|
|
||||||
boolean result.
|
|
||||||
|
|
||||||
```js
|
|
||||||
const anymatch = require('anymatch');
|
|
||||||
|
|
||||||
const matchers = [ 'path/to/file.js', 'path/anyjs/**/*.js', /foo.js$/, string => string.includes('bar') && string.length > 10 ] ;
|
|
||||||
|
|
||||||
anymatch(matchers, 'path/to/file.js'); // true
|
|
||||||
anymatch(matchers, 'path/anyjs/baz.js'); // true
|
|
||||||
anymatch(matchers, 'path/to/foo.js'); // true
|
|
||||||
anymatch(matchers, 'path/to/bar.js'); // true
|
|
||||||
anymatch(matchers, 'bar.js'); // false
|
|
||||||
|
|
||||||
// returnIndex = true
|
|
||||||
anymatch(matchers, 'foo.js', {returnIndex: true}); // 2
|
|
||||||
anymatch(matchers, 'path/anyjs/foo.js', {returnIndex: true}); // 1
|
|
||||||
|
|
||||||
// any picomatc
|
|
||||||
|
|
||||||
// using globs to match directories and their children
|
|
||||||
anymatch('node_modules', 'node_modules'); // true
|
|
||||||
anymatch('node_modules', 'node_modules/somelib/index.js'); // false
|
|
||||||
anymatch('node_modules/**', 'node_modules/somelib/index.js'); // true
|
|
||||||
anymatch('node_modules/**', '/absolute/path/to/node_modules/somelib/index.js'); // false
|
|
||||||
anymatch('**/node_modules/**', '/absolute/path/to/node_modules/somelib/index.js'); // true
|
|
||||||
|
|
||||||
const matcher = anymatch(matchers);
|
|
||||||
['foo.js', 'bar.js'].filter(matcher); // [ 'foo.js' ]
|
|
||||||
anymatch master* ❯
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
#### anymatch(matchers)
|
|
||||||
You can also pass in only your matcher(s) to get a curried function that has
|
|
||||||
already been bound to the provided matching criteria. This can be used as an
|
|
||||||
`Array#filter` callback.
|
|
||||||
|
|
||||||
```js
|
|
||||||
var matcher = anymatch(matchers);
|
|
||||||
|
|
||||||
matcher('path/to/file.js'); // true
|
|
||||||
matcher('path/anyjs/baz.js', true); // 1
|
|
||||||
|
|
||||||
['foo.js', 'bar.js'].filter(matcher); // ['foo.js']
|
|
||||||
```
|
|
||||||
|
|
||||||
Changelog
|
|
||||||
----------
|
|
||||||
[See release notes page on GitHub](https://github.com/micromatch/anymatch/releases)
|
|
||||||
|
|
||||||
- **v3.0:** Removed `startIndex` and `endIndex` arguments. Node 8.x-only.
|
|
||||||
- **v2.0:** [micromatch](https://github.com/jonschlinkert/micromatch) moves away from minimatch-parity and inline with Bash. This includes handling backslashes differently (see https://github.com/micromatch/micromatch#backslashes for more information).
|
|
||||||
- **v1.2:** anymatch uses [micromatch](https://github.com/jonschlinkert/micromatch)
|
|
||||||
for glob pattern matching. Issues with glob pattern matching should be
|
|
||||||
reported directly to the [micromatch issue tracker](https://github.com/jonschlinkert/micromatch/issues).
|
|
||||||
|
|
||||||
License
|
|
||||||
-------
|
|
||||||
[ISC](https://raw.github.com/micromatch/anymatch/master/LICENSE)
|
|
||||||
|
|
@ -1,20 +0,0 @@
|
||||||
type AnymatchFn = (testString: string) => boolean;
|
|
||||||
type AnymatchPattern = string|RegExp|AnymatchFn;
|
|
||||||
type AnymatchMatcher = AnymatchPattern|AnymatchPattern[]
|
|
||||||
type AnymatchTester = {
|
|
||||||
(testString: string|any[], returnIndex: true): number;
|
|
||||||
(testString: string|any[]): boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
type PicomatchOptions = {dot: boolean};
|
|
||||||
|
|
||||||
declare const anymatch: {
|
|
||||||
(matchers: AnymatchMatcher): AnymatchTester;
|
|
||||||
(matchers: AnymatchMatcher, testString: null, returnIndex: true | PicomatchOptions): AnymatchTester;
|
|
||||||
(matchers: AnymatchMatcher, testString: string|any[], returnIndex: true | PicomatchOptions): number;
|
|
||||||
(matchers: AnymatchMatcher, testString: string|any[]): boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
export {AnymatchMatcher as Matcher}
|
|
||||||
export {AnymatchTester as Tester}
|
|
||||||
export default anymatch
|
|
||||||
|
|
@ -1,104 +0,0 @@
|
||||||
'use strict';
|
|
||||||
|
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
|
||||||
|
|
||||||
const picomatch = require('picomatch');
|
|
||||||
const normalizePath = require('normalize-path');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @typedef {(testString: string) => boolean} AnymatchFn
|
|
||||||
* @typedef {string|RegExp|AnymatchFn} AnymatchPattern
|
|
||||||
* @typedef {AnymatchPattern|AnymatchPattern[]} AnymatchMatcher
|
|
||||||
*/
|
|
||||||
const BANG = '!';
|
|
||||||
const DEFAULT_OPTIONS = {returnIndex: false};
|
|
||||||
const arrify = (item) => Array.isArray(item) ? item : [item];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {AnymatchPattern} matcher
|
|
||||||
* @param {object} options
|
|
||||||
* @returns {AnymatchFn}
|
|
||||||
*/
|
|
||||||
const createPattern = (matcher, options) => {
|
|
||||||
if (typeof matcher === 'function') {
|
|
||||||
return matcher;
|
|
||||||
}
|
|
||||||
if (typeof matcher === 'string') {
|
|
||||||
const glob = picomatch(matcher, options);
|
|
||||||
return (string) => matcher === string || glob(string);
|
|
||||||
}
|
|
||||||
if (matcher instanceof RegExp) {
|
|
||||||
return (string) => matcher.test(string);
|
|
||||||
}
|
|
||||||
return (string) => false;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {Array<Function>} patterns
|
|
||||||
* @param {Array<Function>} negPatterns
|
|
||||||
* @param {String|Array} args
|
|
||||||
* @param {Boolean} returnIndex
|
|
||||||
* @returns {boolean|number}
|
|
||||||
*/
|
|
||||||
const matchPatterns = (patterns, negPatterns, args, returnIndex) => {
|
|
||||||
const isList = Array.isArray(args);
|
|
||||||
const _path = isList ? args[0] : args;
|
|
||||||
if (!isList && typeof _path !== 'string') {
|
|
||||||
throw new TypeError('anymatch: second argument must be a string: got ' +
|
|
||||||
Object.prototype.toString.call(_path))
|
|
||||||
}
|
|
||||||
const path = normalizePath(_path, false);
|
|
||||||
|
|
||||||
for (let index = 0; index < negPatterns.length; index++) {
|
|
||||||
const nglob = negPatterns[index];
|
|
||||||
if (nglob(path)) {
|
|
||||||
return returnIndex ? -1 : false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const applied = isList && [path].concat(args.slice(1));
|
|
||||||
for (let index = 0; index < patterns.length; index++) {
|
|
||||||
const pattern = patterns[index];
|
|
||||||
if (isList ? pattern(...applied) : pattern(path)) {
|
|
||||||
return returnIndex ? index : true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return returnIndex ? -1 : false;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param {AnymatchMatcher} matchers
|
|
||||||
* @param {Array|string} testString
|
|
||||||
* @param {object} options
|
|
||||||
* @returns {boolean|number|Function}
|
|
||||||
*/
|
|
||||||
const anymatch = (matchers, testString, options = DEFAULT_OPTIONS) => {
|
|
||||||
if (matchers == null) {
|
|
||||||
throw new TypeError('anymatch: specify first argument');
|
|
||||||
}
|
|
||||||
const opts = typeof options === 'boolean' ? {returnIndex: options} : options;
|
|
||||||
const returnIndex = opts.returnIndex || false;
|
|
||||||
|
|
||||||
// Early cache for matchers.
|
|
||||||
const mtchers = arrify(matchers);
|
|
||||||
const negatedGlobs = mtchers
|
|
||||||
.filter(item => typeof item === 'string' && item.charAt(0) === BANG)
|
|
||||||
.map(item => item.slice(1))
|
|
||||||
.map(item => picomatch(item, opts));
|
|
||||||
const patterns = mtchers
|
|
||||||
.filter(item => typeof item !== 'string' || (typeof item === 'string' && item.charAt(0) !== BANG))
|
|
||||||
.map(matcher => createPattern(matcher, opts));
|
|
||||||
|
|
||||||
if (testString == null) {
|
|
||||||
return (testString, ri = false) => {
|
|
||||||
const returnIndex = typeof ri === 'boolean' ? ri : false;
|
|
||||||
return matchPatterns(patterns, negatedGlobs, testString, returnIndex);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return matchPatterns(patterns, negatedGlobs, testString, returnIndex);
|
|
||||||
};
|
|
||||||
|
|
||||||
anymatch.default = anymatch;
|
|
||||||
module.exports = anymatch;
|
|
||||||
|
|
@ -1,48 +0,0 @@
|
||||||
{
|
|
||||||
"name": "anymatch",
|
|
||||||
"version": "3.1.3",
|
|
||||||
"description": "Matches strings against configurable strings, globs, regular expressions, and/or functions",
|
|
||||||
"files": [
|
|
||||||
"index.js",
|
|
||||||
"index.d.ts"
|
|
||||||
],
|
|
||||||
"dependencies": {
|
|
||||||
"normalize-path": "^3.0.0",
|
|
||||||
"picomatch": "^2.0.4"
|
|
||||||
},
|
|
||||||
"author": {
|
|
||||||
"name": "Elan Shanker",
|
|
||||||
"url": "https://github.com/es128"
|
|
||||||
},
|
|
||||||
"license": "ISC",
|
|
||||||
"homepage": "https://github.com/micromatch/anymatch",
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "https://github.com/micromatch/anymatch"
|
|
||||||
},
|
|
||||||
"keywords": [
|
|
||||||
"match",
|
|
||||||
"any",
|
|
||||||
"string",
|
|
||||||
"file",
|
|
||||||
"fs",
|
|
||||||
"list",
|
|
||||||
"glob",
|
|
||||||
"regex",
|
|
||||||
"regexp",
|
|
||||||
"regular",
|
|
||||||
"expression",
|
|
||||||
"function"
|
|
||||||
],
|
|
||||||
"scripts": {
|
|
||||||
"test": "nyc mocha",
|
|
||||||
"mocha": "mocha"
|
|
||||||
},
|
|
||||||
"devDependencies": {
|
|
||||||
"mocha": "^6.1.3",
|
|
||||||
"nyc": "^14.0.0"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">= 8"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -1,21 +0,0 @@
|
||||||
The MIT License (MIT)
|
|
||||||
|
|
||||||
Copyright (c) 2014 Blake Embrey (hello@blakeembrey.com)
|
|
||||||
|
|
||||||
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.
|
|
||||||
|
|
@ -1,43 +0,0 @@
|
||||||
# Array Flatten
|
|
||||||
|
|
||||||
[![NPM version][npm-image]][npm-url]
|
|
||||||
[![NPM downloads][downloads-image]][downloads-url]
|
|
||||||
[![Build status][travis-image]][travis-url]
|
|
||||||
[![Test coverage][coveralls-image]][coveralls-url]
|
|
||||||
|
|
||||||
> Flatten an array of nested arrays into a single flat array. Accepts an optional depth.
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
```
|
|
||||||
npm install array-flatten --save
|
|
||||||
```
|
|
||||||
|
|
||||||
## Usage
|
|
||||||
|
|
||||||
```javascript
|
|
||||||
var flatten = require('array-flatten')
|
|
||||||
|
|
||||||
flatten([1, [2, [3, [4, [5], 6], 7], 8], 9])
|
|
||||||
//=> [1, 2, 3, 4, 5, 6, 7, 8, 9]
|
|
||||||
|
|
||||||
flatten([1, [2, [3, [4, [5], 6], 7], 8], 9], 2)
|
|
||||||
//=> [1, 2, 3, [4, [5], 6], 7, 8, 9]
|
|
||||||
|
|
||||||
(function () {
|
|
||||||
flatten(arguments) //=> [1, 2, 3]
|
|
||||||
})(1, [2, 3])
|
|
||||||
```
|
|
||||||
|
|
||||||
## License
|
|
||||||
|
|
||||||
MIT
|
|
||||||
|
|
||||||
[npm-image]: https://img.shields.io/npm/v/array-flatten.svg?style=flat
|
|
||||||
[npm-url]: https://npmjs.org/package/array-flatten
|
|
||||||
[downloads-image]: https://img.shields.io/npm/dm/array-flatten.svg?style=flat
|
|
||||||
[downloads-url]: https://npmjs.org/package/array-flatten
|
|
||||||
[travis-image]: https://img.shields.io/travis/blakeembrey/array-flatten.svg?style=flat
|
|
||||||
[travis-url]: https://travis-ci.org/blakeembrey/array-flatten
|
|
||||||
[coveralls-image]: https://img.shields.io/coveralls/blakeembrey/array-flatten.svg?style=flat
|
|
||||||
[coveralls-url]: https://coveralls.io/r/blakeembrey/array-flatten?branch=master
|
|
||||||
|
|
@ -1,64 +0,0 @@
|
||||||
'use strict'
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Expose `arrayFlatten`.
|
|
||||||
*/
|
|
||||||
module.exports = arrayFlatten
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Recursive flatten function with depth.
|
|
||||||
*
|
|
||||||
* @param {Array} array
|
|
||||||
* @param {Array} result
|
|
||||||
* @param {Number} depth
|
|
||||||
* @return {Array}
|
|
||||||
*/
|
|
||||||
function flattenWithDepth (array, result, depth) {
|
|
||||||
for (var i = 0; i < array.length; i++) {
|
|
||||||
var value = array[i]
|
|
||||||
|
|
||||||
if (depth > 0 && Array.isArray(value)) {
|
|
||||||
flattenWithDepth(value, result, depth - 1)
|
|
||||||
} else {
|
|
||||||
result.push(value)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return result
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Recursive flatten function. Omitting depth is slightly faster.
|
|
||||||
*
|
|
||||||
* @param {Array} array
|
|
||||||
* @param {Array} result
|
|
||||||
* @return {Array}
|
|
||||||
*/
|
|
||||||
function flattenForever (array, result) {
|
|
||||||
for (var i = 0; i < array.length; i++) {
|
|
||||||
var value = array[i]
|
|
||||||
|
|
||||||
if (Array.isArray(value)) {
|
|
||||||
flattenForever(value, result)
|
|
||||||
} else {
|
|
||||||
result.push(value)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return result
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Flatten an array, with the ability to define a depth.
|
|
||||||
*
|
|
||||||
* @param {Array} array
|
|
||||||
* @param {Number} depth
|
|
||||||
* @return {Array}
|
|
||||||
*/
|
|
||||||
function arrayFlatten (array, depth) {
|
|
||||||
if (depth == null) {
|
|
||||||
return flattenForever(array, [])
|
|
||||||
}
|
|
||||||
|
|
||||||
return flattenWithDepth(array, [], depth)
|
|
||||||
}
|
|
||||||
|
|
@ -1,39 +0,0 @@
|
||||||
{
|
|
||||||
"name": "array-flatten",
|
|
||||||
"version": "1.1.1",
|
|
||||||
"description": "Flatten an array of nested arrays into a single flat array",
|
|
||||||
"main": "array-flatten.js",
|
|
||||||
"files": [
|
|
||||||
"array-flatten.js",
|
|
||||||
"LICENSE"
|
|
||||||
],
|
|
||||||
"scripts": {
|
|
||||||
"test": "istanbul cover _mocha -- -R spec"
|
|
||||||
},
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "git://github.com/blakeembrey/array-flatten.git"
|
|
||||||
},
|
|
||||||
"keywords": [
|
|
||||||
"array",
|
|
||||||
"flatten",
|
|
||||||
"arguments",
|
|
||||||
"depth"
|
|
||||||
],
|
|
||||||
"author": {
|
|
||||||
"name": "Blake Embrey",
|
|
||||||
"email": "hello@blakeembrey.com",
|
|
||||||
"url": "http://blakeembrey.me"
|
|
||||||
},
|
|
||||||
"license": "MIT",
|
|
||||||
"bugs": {
|
|
||||||
"url": "https://github.com/blakeembrey/array-flatten/issues"
|
|
||||||
},
|
|
||||||
"homepage": "https://github.com/blakeembrey/array-flatten",
|
|
||||||
"devDependencies": {
|
|
||||||
"istanbul": "^0.3.13",
|
|
||||||
"mocha": "^2.2.4",
|
|
||||||
"pre-commit": "^1.0.7",
|
|
||||||
"standard": "^3.7.3"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -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.
|
|
||||||
|
|
@ -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.
|
|
||||||
|
|
@ -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 });
|
|
||||||
|
|
@ -1,6 +0,0 @@
|
||||||
module.exports =
|
|
||||||
{
|
|
||||||
parallel : require('./parallel.js'),
|
|
||||||
serial : require('./serial.js'),
|
|
||||||
serialOrdered : require('./serialOrdered.js')
|
|
||||||
};
|
|
||||||
|
|
@ -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]();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
@ -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()
|
|
||||||
{
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
@ -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": {}
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
File diff suppressed because it is too large
Load Diff
|
|
@ -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.
|
|
||||||
|
|
@ -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.*
|
|
||||||
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
|
|
@ -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;
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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,
|
|
||||||
};
|
|
||||||
|
|
@ -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
|
|
||||||
});
|
|
||||||
};
|
|
||||||
```
|
|
||||||
|
|
@ -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,
|
|
||||||
};
|
|
||||||
|
|
@ -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;
|
|
||||||
File diff suppressed because it is too large
Load Diff
|
|
@ -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);
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
'use strict';
|
|
||||||
|
|
||||||
export default function isCancel(value) {
|
|
||||||
return !!(value && value.__CANCEL__);
|
|
||||||
}
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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
|
|
||||||
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
@ -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);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
@ -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
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -1,8 +0,0 @@
|
||||||
'use strict';
|
|
||||||
|
|
||||||
export default {
|
|
||||||
silentJSONParsing: true,
|
|
||||||
forcedJSONParsing: true,
|
|
||||||
clarifyTimeoutError: false,
|
|
||||||
legacyInterceptorReqResOrdering: true,
|
|
||||||
};
|
|
||||||
|
|
@ -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.
|
|
||||||
|
|
@ -1,2 +0,0 @@
|
||||||
import _FormData from 'form-data';
|
|
||||||
export default typeof FormData !== 'undefined' ? FormData : _FormData;
|
|
||||||
|
|
@ -1 +0,0 @@
|
||||||
export const VERSION = "1.15.2";
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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;
|
|
||||||
|
|
@ -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
|
|
||||||
|
|
@ -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;
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue