@corellium/corellium-cli 1.4.0 → 1.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +12 -16
- package/.gitlab-ci.yml +13 -13
- package/.nvmrc +1 -1
- package/.nycrc +14 -14
- package/.prettierrc.js +8 -7
- package/README.md +13 -6
- package/docs/OVERVIEW.md +57 -27
- package/index.js +8 -8
- package/lint-staged.config.js +3 -6
- package/node_modules/@babel/cli/README.md +1 -1
- package/node_modules/@babel/cli/bin/babel-external-helpers.mjs +3 -0
- package/node_modules/@babel/cli/bin/babel.mjs +3 -0
- package/node_modules/@babel/cli/lib/babel/dir.js +23 -73
- package/node_modules/@babel/cli/lib/babel/dir.js.map +1 -0
- package/node_modules/@babel/cli/lib/babel/file.js +27 -72
- package/node_modules/@babel/cli/lib/babel/file.js.map +1 -0
- package/node_modules/@babel/cli/lib/babel/index.js +6 -8
- package/node_modules/@babel/cli/lib/babel/index.js.map +1 -0
- package/node_modules/@babel/cli/lib/babel/options.js +70 -143
- package/node_modules/@babel/cli/lib/babel/options.js.map +1 -0
- package/node_modules/@babel/cli/lib/babel/util.js +39 -59
- package/node_modules/@babel/cli/lib/babel/util.js.map +1 -0
- package/node_modules/@babel/cli/lib/babel/watcher.js +19 -52
- package/node_modules/@babel/cli/lib/babel/watcher.js.map +1 -0
- package/node_modules/@babel/cli/lib/babel-external-helpers.js +14 -21
- package/node_modules/@babel/cli/lib/babel-external-helpers.js.map +1 -0
- package/node_modules/@babel/cli/package.json +11 -9
- package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.mjs +19 -29
- package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.mjs.map +1 -1
- package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.umd.js +19 -29
- package/node_modules/@jridgewell/resolve-uri/dist/resolve-uri.umd.js.map +1 -1
- package/node_modules/@jridgewell/resolve-uri/package.json +2 -2
- package/node_modules/@jridgewell/sourcemap-codec/README.md +147 -83
- package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs +351 -91
- package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.mjs.map +1 -1
- package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.umd.js +354 -90
- package/node_modules/@jridgewell/sourcemap-codec/dist/sourcemap-codec.umd.js.map +1 -1
- package/node_modules/@jridgewell/sourcemap-codec/dist/types/scopes.d.ts +49 -0
- package/node_modules/@jridgewell/sourcemap-codec/dist/types/sourcemap-codec.d.ts +2 -0
- package/node_modules/@jridgewell/sourcemap-codec/dist/types/strings.d.ts +15 -0
- package/node_modules/@jridgewell/sourcemap-codec/dist/types/vlq.d.ts +6 -0
- package/node_modules/@jridgewell/sourcemap-codec/package.json +7 -7
- package/node_modules/@jridgewell/trace-mapping/README.md +5 -0
- package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.mjs +202 -174
- package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.mjs.map +1 -1
- package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.umd.js +216 -182
- package/node_modules/@jridgewell/trace-mapping/dist/trace-mapping.umd.js.map +1 -1
- package/node_modules/@jridgewell/trace-mapping/dist/types/any-map.d.ts +1 -1
- package/node_modules/@jridgewell/trace-mapping/dist/types/binary-search.d.ts +1 -1
- package/node_modules/@jridgewell/trace-mapping/dist/types/by-source.d.ts +1 -1
- package/node_modules/@jridgewell/trace-mapping/dist/types/sourcemap-segment.d.ts +8 -8
- package/node_modules/@jridgewell/trace-mapping/dist/types/trace-mapping.d.ts +33 -28
- package/node_modules/@jridgewell/trace-mapping/dist/types/types.d.ts +23 -16
- package/node_modules/@jridgewell/trace-mapping/package.json +20 -18
- package/node_modules/anymatch/index.d.ts +1 -0
- package/node_modules/anymatch/index.js +1 -1
- package/node_modules/anymatch/package.json +1 -1
- package/node_modules/{form-data/README.md.bak → axios/node_modules/form-data/Readme.md} +4 -4
- package/node_modules/{superagent → axios}/node_modules/form-data/lib/form_data.js +31 -26
- package/node_modules/{superagent → axios}/node_modules/form-data/package.json +25 -19
- package/node_modules/binary-extensions/binary-extensions.json +3 -0
- package/node_modules/binary-extensions/license +2 -1
- package/node_modules/binary-extensions/package.json +4 -2
- package/node_modules/binary-extensions/readme.md +2 -18
- package/node_modules/braces/LICENSE +1 -1
- package/node_modules/braces/README.md +91 -98
- package/node_modules/braces/index.js +3 -3
- package/node_modules/braces/lib/compile.js +14 -11
- package/node_modules/braces/lib/constants.js +1 -1
- package/node_modules/braces/lib/expand.js +9 -9
- package/node_modules/braces/lib/parse.js +14 -16
- package/node_modules/braces/lib/stringify.js +4 -4
- package/node_modules/braces/lib/utils.js +13 -3
- package/node_modules/braces/package.json +2 -2
- package/node_modules/{call-bind → call-bind-apply-helpers}/.eslintrc +1 -1
- package/node_modules/call-bind-apply-helpers/.github/FUNDING.yml +12 -0
- package/node_modules/call-bind-apply-helpers/.nycrc +9 -0
- package/node_modules/call-bind-apply-helpers/CHANGELOG.md +30 -0
- package/node_modules/{call-bind → call-bind-apply-helpers}/LICENSE +1 -1
- package/node_modules/call-bind-apply-helpers/README.md +62 -0
- package/node_modules/call-bind-apply-helpers/actualApply.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/actualApply.js +10 -0
- package/node_modules/call-bind-apply-helpers/applyBind.d.ts +19 -0
- package/node_modules/call-bind-apply-helpers/applyBind.js +10 -0
- package/node_modules/call-bind-apply-helpers/functionApply.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/functionApply.js +4 -0
- package/node_modules/call-bind-apply-helpers/functionCall.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/functionCall.js +4 -0
- package/node_modules/call-bind-apply-helpers/index.d.ts +64 -0
- package/node_modules/call-bind-apply-helpers/index.js +15 -0
- package/node_modules/call-bind-apply-helpers/package.json +85 -0
- package/node_modules/call-bind-apply-helpers/reflectApply.d.ts +3 -0
- package/node_modules/call-bind-apply-helpers/reflectApply.js +4 -0
- package/node_modules/call-bind-apply-helpers/test/index.js +63 -0
- package/node_modules/call-bind-apply-helpers/tsconfig.json +9 -0
- package/node_modules/call-bound/.eslintrc +13 -0
- package/node_modules/call-bound/.github/FUNDING.yml +12 -0
- package/node_modules/call-bound/.nycrc +9 -0
- package/node_modules/call-bound/CHANGELOG.md +34 -0
- package/node_modules/call-bound/LICENSE +21 -0
- package/node_modules/call-bound/README.md +53 -0
- package/node_modules/call-bound/index.d.ts +13 -0
- package/node_modules/call-bound/index.js +18 -0
- package/node_modules/call-bound/package.json +99 -0
- package/node_modules/{call-bind/test/callBound.js → call-bound/test/index.js} +1 -2
- package/node_modules/call-bound/tsconfig.json +9 -0
- package/node_modules/chokidar/README.md +1 -1
- package/node_modules/chokidar/index.js +1 -1
- package/node_modules/chokidar/lib/constants.js +1 -0
- package/node_modules/chokidar/lib/fsevents-handler.js +2 -0
- package/node_modules/chokidar/package.json +5 -20
- package/node_modules/chokidar/types/index.d.ts +4 -0
- package/node_modules/cliui/CHANGELOG.md +18 -0
- package/node_modules/cliui/build/index.d.cts +43 -0
- package/node_modules/cliui/package.json +6 -6
- package/node_modules/commander/CHANGELOG.md +361 -0
- package/node_modules/{@babel/cli/node_modules/commander → commander}/Readme.md +243 -165
- package/node_modules/commander/index.js +1881 -0
- package/node_modules/{@babel/cli/node_modules/commander → commander}/package.json +19 -9
- package/node_modules/commander/typings/index.d.ts +410 -0
- package/node_modules/component-emitter/LICENSE +24 -24
- package/node_modules/component-emitter/Readme.md +74 -74
- package/node_modules/component-emitter/index.js +175 -175
- package/node_modules/component-emitter/package.json +3 -2
- package/node_modules/convert-source-map/README.md +97 -11
- package/node_modules/convert-source-map/index.js +127 -30
- package/node_modules/convert-source-map/package.json +3 -9
- package/node_modules/cookiejar/cookiejar.js +5 -0
- package/node_modules/cookiejar/package.json +1 -1
- package/node_modules/debug/README.md +1 -1
- package/node_modules/debug/package.json +10 -4
- package/node_modules/debug/src/browser.js +4 -1
- package/node_modules/debug/src/common.js +57 -39
- package/node_modules/debug/src/node.js +2 -2
- package/node_modules/dotenv/CHANGELOG.md +133 -1
- package/node_modules/dotenv/README-es.md +448 -0
- package/node_modules/dotenv/README.md +309 -66
- package/node_modules/dotenv/lib/cli-options.js +1 -1
- package/node_modules/dotenv/lib/env-options.js +4 -0
- package/node_modules/dotenv/lib/main.d.ts +85 -5
- package/node_modules/dotenv/lib/main.js +287 -35
- package/node_modules/dotenv/package.json +19 -14
- package/node_modules/dunder-proto/.eslintrc +5 -0
- package/node_modules/dunder-proto/.github/FUNDING.yml +12 -0
- package/node_modules/dunder-proto/CHANGELOG.md +24 -0
- package/node_modules/dunder-proto/LICENSE +21 -0
- package/node_modules/dunder-proto/README.md +54 -0
- package/node_modules/dunder-proto/get.d.ts +5 -0
- package/node_modules/dunder-proto/get.js +30 -0
- package/node_modules/dunder-proto/package.json +76 -0
- package/node_modules/dunder-proto/set.d.ts +5 -0
- package/node_modules/dunder-proto/set.js +35 -0
- package/node_modules/dunder-proto/test/get.js +34 -0
- package/node_modules/dunder-proto/test/index.js +4 -0
- package/node_modules/dunder-proto/test/set.js +50 -0
- package/node_modules/dunder-proto/tsconfig.json +9 -0
- package/node_modules/es-define-property/.eslintrc +13 -0
- package/node_modules/es-define-property/.github/FUNDING.yml +12 -0
- package/node_modules/es-define-property/.nycrc +9 -0
- package/node_modules/es-define-property/CHANGELOG.md +29 -0
- package/node_modules/es-define-property/LICENSE +21 -0
- package/node_modules/es-define-property/README.md +49 -0
- package/node_modules/es-define-property/index.d.ts +3 -0
- package/node_modules/es-define-property/index.js +14 -0
- package/node_modules/es-define-property/package.json +81 -0
- package/node_modules/es-define-property/test/index.js +56 -0
- package/node_modules/es-define-property/tsconfig.json +10 -0
- package/node_modules/es-errors/.eslintrc +5 -0
- package/node_modules/es-errors/.github/FUNDING.yml +12 -0
- package/node_modules/es-errors/CHANGELOG.md +40 -0
- package/node_modules/es-errors/LICENSE +21 -0
- package/node_modules/es-errors/README.md +55 -0
- package/node_modules/es-errors/eval.d.ts +3 -0
- package/node_modules/es-errors/eval.js +4 -0
- package/node_modules/es-errors/index.d.ts +3 -0
- package/node_modules/es-errors/index.js +4 -0
- package/node_modules/es-errors/package.json +80 -0
- package/node_modules/es-errors/range.d.ts +3 -0
- package/node_modules/es-errors/range.js +4 -0
- package/node_modules/es-errors/ref.d.ts +3 -0
- package/node_modules/es-errors/ref.js +4 -0
- package/node_modules/es-errors/syntax.d.ts +3 -0
- package/node_modules/es-errors/syntax.js +4 -0
- package/node_modules/es-errors/test/index.js +19 -0
- package/node_modules/es-errors/tsconfig.json +49 -0
- package/node_modules/es-errors/type.d.ts +3 -0
- package/node_modules/es-errors/type.js +4 -0
- package/node_modules/es-errors/uri.d.ts +3 -0
- package/node_modules/es-errors/uri.js +4 -0
- package/node_modules/es-object-atoms/.eslintrc +16 -0
- package/node_modules/es-object-atoms/.github/FUNDING.yml +12 -0
- package/node_modules/es-object-atoms/CHANGELOG.md +37 -0
- package/node_modules/es-object-atoms/LICENSE +21 -0
- package/node_modules/es-object-atoms/README.md +63 -0
- package/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +3 -0
- package/node_modules/es-object-atoms/RequireObjectCoercible.js +11 -0
- package/node_modules/es-object-atoms/ToObject.d.ts +7 -0
- package/node_modules/es-object-atoms/ToObject.js +10 -0
- package/node_modules/es-object-atoms/index.d.ts +3 -0
- package/node_modules/es-object-atoms/index.js +4 -0
- package/node_modules/es-object-atoms/isObject.d.ts +3 -0
- package/node_modules/es-object-atoms/isObject.js +6 -0
- package/node_modules/es-object-atoms/package.json +80 -0
- package/node_modules/es-object-atoms/test/index.js +38 -0
- package/node_modules/es-object-atoms/tsconfig.json +6 -0
- package/node_modules/es-set-tostringtag/.eslintrc +13 -0
- package/node_modules/es-set-tostringtag/.nycrc +9 -0
- package/node_modules/es-set-tostringtag/CHANGELOG.md +67 -0
- package/node_modules/es-set-tostringtag/LICENSE +21 -0
- package/node_modules/es-set-tostringtag/README.md +53 -0
- package/node_modules/es-set-tostringtag/index.d.ts +10 -0
- package/node_modules/es-set-tostringtag/index.js +35 -0
- package/node_modules/es-set-tostringtag/package.json +78 -0
- package/node_modules/es-set-tostringtag/test/index.js +85 -0
- package/node_modules/es-set-tostringtag/tsconfig.json +9 -0
- package/node_modules/escalade/index.d.mts +11 -0
- package/node_modules/escalade/index.d.ts +14 -2
- package/node_modules/escalade/package.json +18 -5
- package/node_modules/escalade/readme.md +1 -1
- package/node_modules/escalade/sync/index.d.mts +9 -0
- package/node_modules/escalade/sync/index.d.ts +13 -2
- package/node_modules/fill-range/index.js +4 -5
- package/node_modules/fill-range/package.json +8 -3
- package/node_modules/follow-redirects/index.js +186 -98
- package/node_modules/follow-redirects/package.json +3 -4
- package/node_modules/form-data/Readme.md +5 -7
- package/node_modules/form-data/lib/form_data.js +27 -28
- package/node_modules/form-data/package.json +24 -20
- package/node_modules/function-bind/.eslintrc +11 -5
- package/node_modules/function-bind/.github/FUNDING.yml +12 -0
- package/node_modules/function-bind/.github/SECURITY.md +3 -0
- package/node_modules/function-bind/.nycrc +13 -0
- package/node_modules/function-bind/CHANGELOG.md +136 -0
- package/node_modules/function-bind/README.md +25 -27
- package/node_modules/function-bind/implementation.js +44 -12
- package/node_modules/function-bind/package.json +38 -14
- package/node_modules/get-intrinsic/.eslintrc +1 -0
- package/node_modules/get-intrinsic/CHANGELOG.md +87 -0
- package/node_modules/get-intrinsic/index.js +75 -32
- package/node_modules/get-intrinsic/package.json +31 -22
- package/node_modules/get-intrinsic/test/GetIntrinsic.js +3 -3
- package/node_modules/get-proto/.eslintrc +10 -0
- package/node_modules/{call-bind → get-proto}/.github/FUNDING.yml +1 -1
- package/node_modules/get-proto/.nycrc +9 -0
- package/node_modules/get-proto/CHANGELOG.md +21 -0
- package/node_modules/get-proto/LICENSE +21 -0
- package/node_modules/get-proto/Object.getPrototypeOf.d.ts +5 -0
- package/node_modules/get-proto/Object.getPrototypeOf.js +6 -0
- package/node_modules/get-proto/README.md +50 -0
- package/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +3 -0
- package/node_modules/get-proto/Reflect.getPrototypeOf.js +4 -0
- package/node_modules/get-proto/index.d.ts +5 -0
- package/node_modules/get-proto/index.js +27 -0
- package/node_modules/get-proto/package.json +81 -0
- package/node_modules/get-proto/test/index.js +68 -0
- package/node_modules/get-proto/tsconfig.json +9 -0
- package/node_modules/gopd/.eslintrc +16 -0
- package/node_modules/gopd/.github/FUNDING.yml +12 -0
- package/node_modules/gopd/CHANGELOG.md +45 -0
- package/node_modules/gopd/LICENSE +21 -0
- package/node_modules/gopd/README.md +40 -0
- package/node_modules/gopd/gOPD.d.ts +1 -0
- package/node_modules/gopd/gOPD.js +4 -0
- package/node_modules/gopd/index.d.ts +5 -0
- package/node_modules/gopd/index.js +15 -0
- package/node_modules/gopd/package.json +77 -0
- package/node_modules/gopd/test/index.js +36 -0
- package/node_modules/gopd/tsconfig.json +9 -0
- package/node_modules/has-symbols/CHANGELOG.md +16 -0
- package/node_modules/has-symbols/index.d.ts +3 -0
- package/node_modules/has-symbols/index.js +1 -0
- package/node_modules/has-symbols/package.json +19 -9
- package/node_modules/has-symbols/shams.d.ts +3 -0
- package/node_modules/has-symbols/shams.js +5 -2
- package/node_modules/has-symbols/test/shams/core-js.js +1 -0
- package/node_modules/has-symbols/test/shams/get-own-property-symbols.js +1 -0
- package/node_modules/has-symbols/test/tests.js +4 -2
- package/node_modules/has-symbols/tsconfig.json +10 -0
- package/node_modules/has-tostringtag/.eslintrc +5 -0
- package/node_modules/has-tostringtag/.github/FUNDING.yml +12 -0
- package/node_modules/has-tostringtag/.nycrc +13 -0
- package/node_modules/has-tostringtag/CHANGELOG.md +42 -0
- package/node_modules/has-tostringtag/LICENSE +21 -0
- package/node_modules/has-tostringtag/README.md +46 -0
- package/node_modules/has-tostringtag/index.d.ts +3 -0
- package/node_modules/has-tostringtag/index.js +8 -0
- package/node_modules/has-tostringtag/package.json +108 -0
- package/node_modules/has-tostringtag/shams.d.ts +3 -0
- package/node_modules/has-tostringtag/shams.js +8 -0
- package/node_modules/has-tostringtag/test/index.js +21 -0
- package/node_modules/has-tostringtag/test/shams/core-js.js +31 -0
- package/node_modules/has-tostringtag/test/shams/get-own-property-symbols.js +30 -0
- package/node_modules/has-tostringtag/test/tests.js +15 -0
- package/node_modules/has-tostringtag/tsconfig.json +49 -0
- package/node_modules/hasown/.eslintrc +5 -0
- package/node_modules/hasown/.github/FUNDING.yml +12 -0
- package/node_modules/hasown/.nycrc +13 -0
- package/node_modules/hasown/CHANGELOG.md +40 -0
- package/node_modules/hasown/LICENSE +21 -0
- package/node_modules/hasown/README.md +40 -0
- package/node_modules/hasown/index.d.ts +3 -0
- package/node_modules/hasown/index.js +8 -0
- package/node_modules/hasown/package.json +92 -0
- package/node_modules/hasown/tsconfig.json +6 -0
- package/node_modules/make-dir/node_modules/semver/package.json +38 -0
- package/node_modules/{@babel/cli → make-dir}/node_modules/semver/semver.js +68 -26
- package/node_modules/math-intrinsics/.eslintrc +16 -0
- package/node_modules/math-intrinsics/.github/FUNDING.yml +12 -0
- package/node_modules/math-intrinsics/CHANGELOG.md +24 -0
- package/node_modules/math-intrinsics/LICENSE +21 -0
- package/node_modules/math-intrinsics/README.md +50 -0
- package/node_modules/math-intrinsics/abs.d.ts +1 -0
- package/node_modules/math-intrinsics/abs.js +4 -0
- package/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxArrayLength.js +4 -0
- package/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxSafeInteger.js +5 -0
- package/node_modules/math-intrinsics/constants/maxValue.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxValue.js +5 -0
- package/node_modules/math-intrinsics/floor.d.ts +1 -0
- package/node_modules/math-intrinsics/floor.js +4 -0
- package/node_modules/math-intrinsics/isFinite.d.ts +3 -0
- package/node_modules/math-intrinsics/isFinite.js +12 -0
- package/node_modules/math-intrinsics/isInteger.d.ts +3 -0
- package/node_modules/math-intrinsics/isInteger.js +16 -0
- package/node_modules/math-intrinsics/isNaN.d.ts +1 -0
- package/node_modules/math-intrinsics/isNaN.js +6 -0
- package/node_modules/math-intrinsics/isNegativeZero.d.ts +3 -0
- package/node_modules/math-intrinsics/isNegativeZero.js +6 -0
- package/node_modules/math-intrinsics/max.d.ts +1 -0
- package/node_modules/math-intrinsics/max.js +4 -0
- package/node_modules/math-intrinsics/min.d.ts +1 -0
- package/node_modules/math-intrinsics/min.js +4 -0
- package/node_modules/math-intrinsics/mod.d.ts +3 -0
- package/node_modules/math-intrinsics/mod.js +9 -0
- package/node_modules/math-intrinsics/package.json +86 -0
- package/node_modules/math-intrinsics/pow.d.ts +1 -0
- package/node_modules/math-intrinsics/pow.js +4 -0
- package/node_modules/math-intrinsics/round.d.ts +1 -0
- package/node_modules/math-intrinsics/round.js +4 -0
- package/node_modules/math-intrinsics/sign.d.ts +3 -0
- package/node_modules/math-intrinsics/sign.js +11 -0
- package/node_modules/math-intrinsics/test/index.js +192 -0
- package/node_modules/math-intrinsics/tsconfig.json +3 -0
- package/node_modules/ms/index.js +1 -1
- package/node_modules/ms/license.md +1 -1
- package/node_modules/ms/package.json +5 -4
- package/node_modules/ms/readme.md +1 -2
- package/node_modules/object-inspect/CHANGELOG.md +64 -0
- package/node_modules/object-inspect/index.js +48 -16
- package/node_modules/object-inspect/package.json +25 -14
- package/node_modules/object-inspect/readme.markdown +9 -11
- package/node_modules/object-inspect/test/global.js +17 -0
- package/node_modules/object-inspect/test/quoteStyle.js +9 -0
- package/node_modules/object-inspect/test/values.js +50 -0
- package/node_modules/qs/.editorconfig +3 -0
- package/node_modules/qs/.eslintrc +3 -2
- package/node_modules/qs/CHANGELOG.md +81 -5
- package/node_modules/qs/README.md +158 -50
- package/node_modules/qs/dist/qs.js +90 -2003
- package/node_modules/qs/lib/parse.js +89 -24
- package/node_modules/qs/lib/stringify.js +61 -31
- package/node_modules/qs/lib/utils.js +54 -38
- package/node_modules/qs/package.json +29 -13
- package/node_modules/qs/test/empty-keys-cases.js +267 -0
- package/node_modules/qs/test/parse.js +468 -47
- package/node_modules/qs/test/stringify.js +454 -57
- package/node_modules/qs/test/utils.js +126 -0
- package/node_modules/side-channel/.editorconfig +9 -0
- package/node_modules/side-channel/.eslintrc +2 -1
- package/node_modules/side-channel/CHANGELOG.md +45 -0
- package/node_modules/side-channel/README.md +60 -1
- package/node_modules/side-channel/index.d.ts +14 -0
- package/node_modules/side-channel/index.js +21 -102
- package/node_modules/side-channel/package.json +40 -22
- package/node_modules/side-channel/test/index.js +78 -52
- package/node_modules/side-channel/tsconfig.json +9 -0
- package/node_modules/{function-bind → side-channel-list}/.editorconfig +3 -14
- package/node_modules/side-channel-list/.eslintrc +11 -0
- package/node_modules/side-channel-list/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-list/.nycrc +13 -0
- package/node_modules/side-channel-list/CHANGELOG.md +15 -0
- package/node_modules/side-channel-list/LICENSE +21 -0
- package/node_modules/side-channel-list/README.md +62 -0
- package/node_modules/side-channel-list/index.d.ts +13 -0
- package/node_modules/side-channel-list/index.js +113 -0
- package/node_modules/side-channel-list/list.d.ts +14 -0
- package/node_modules/side-channel-list/package.json +77 -0
- package/node_modules/side-channel-list/test/index.js +104 -0
- package/node_modules/side-channel-list/tsconfig.json +9 -0
- package/node_modules/side-channel-map/.editorconfig +9 -0
- package/node_modules/side-channel-map/.eslintrc +11 -0
- package/node_modules/side-channel-map/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-map/.nycrc +13 -0
- package/node_modules/side-channel-map/CHANGELOG.md +22 -0
- package/node_modules/side-channel-map/LICENSE +21 -0
- package/node_modules/side-channel-map/README.md +62 -0
- package/node_modules/side-channel-map/index.d.ts +15 -0
- package/node_modules/side-channel-map/index.js +68 -0
- package/node_modules/side-channel-map/package.json +80 -0
- package/node_modules/side-channel-map/test/index.js +114 -0
- package/node_modules/side-channel-map/tsconfig.json +9 -0
- package/node_modules/side-channel-weakmap/.editorconfig +9 -0
- package/node_modules/side-channel-weakmap/.eslintrc +12 -0
- package/node_modules/side-channel-weakmap/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-weakmap/.nycrc +13 -0
- package/node_modules/side-channel-weakmap/CHANGELOG.md +28 -0
- package/node_modules/side-channel-weakmap/LICENSE +21 -0
- package/node_modules/side-channel-weakmap/README.md +62 -0
- package/node_modules/side-channel-weakmap/index.d.ts +15 -0
- package/node_modules/side-channel-weakmap/index.js +84 -0
- package/node_modules/side-channel-weakmap/package.json +87 -0
- package/node_modules/side-channel-weakmap/test/index.js +114 -0
- package/node_modules/side-channel-weakmap/tsconfig.json +9 -0
- package/node_modules/superagent/node_modules/readable-stream/README.md +1 -1
- package/node_modules/superagent/node_modules/readable-stream/lib/_stream_duplex.js +12 -25
- package/node_modules/superagent/node_modules/readable-stream/lib/_stream_passthrough.js +2 -4
- package/node_modules/superagent/node_modules/readable-stream/lib/_stream_readable.js +176 -273
- package/node_modules/superagent/node_modules/readable-stream/lib/_stream_transform.js +26 -37
- package/node_modules/superagent/node_modules/readable-stream/lib/_stream_writable.js +118 -174
- package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/async_iterator.js +10 -37
- package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/buffer_list.js +20 -47
- package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/destroy.js +8 -17
- package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +1 -19
- package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/from.js +12 -24
- package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/pipeline.js +5 -16
- package/node_modules/superagent/node_modules/readable-stream/lib/internal/streams/state.js +2 -7
- package/node_modules/superagent/node_modules/readable-stream/package.json +1 -1
- package/node_modules/{semver → superagent/node_modules/semver}/README.md +132 -36
- package/node_modules/{semver → superagent/node_modules/semver}/bin/semver.js +22 -16
- package/node_modules/{semver → superagent/node_modules/semver}/classes/comparator.js +39 -34
- package/node_modules/{semver → superagent/node_modules/semver}/classes/range.js +72 -37
- package/node_modules/{semver → superagent/node_modules/semver}/classes/semver.js +50 -19
- package/node_modules/{semver → superagent/node_modules/semver}/functions/coerce.js +14 -6
- package/node_modules/superagent/node_modules/semver/functions/diff.js +58 -0
- package/node_modules/{semver → superagent/node_modules/semver}/functions/inc.js +3 -2
- package/node_modules/superagent/node_modules/semver/functions/parse.js +16 -0
- package/node_modules/superagent/node_modules/semver/index.js +89 -0
- package/node_modules/{semver → superagent/node_modules/semver}/internal/constants.js +20 -2
- package/node_modules/superagent/node_modules/semver/internal/lrucache.js +40 -0
- package/node_modules/superagent/node_modules/semver/internal/parse-options.js +15 -0
- package/node_modules/{semver → superagent/node_modules/semver}/internal/re.js +43 -6
- package/node_modules/{semver → superagent/node_modules/semver}/package.json +29 -26
- package/node_modules/{semver → superagent/node_modules/semver}/ranges/intersects.js +1 -1
- package/node_modules/{semver → superagent/node_modules/semver}/ranges/subset.js +6 -3
- package/node_modules/yargs/browser.d.ts +5 -0
- package/node_modules/yargs/build/index.cjs +1 -1
- package/node_modules/yargs/build/lib/command.js +2 -0
- package/node_modules/yargs/build/lib/completion.js +19 -12
- package/node_modules/yargs/build/lib/usage.js +9 -4
- package/node_modules/yargs/build/lib/yargs-factory.js +18 -3
- package/node_modules/yargs/locales/cs.json +51 -0
- package/node_modules/yargs/locales/en.json +4 -0
- package/node_modules/yargs/locales/fi.json +1 -1
- package/node_modules/yargs/package.json +4 -4
- package/node_modules/yargs-parser/CHANGELOG.md +21 -0
- package/node_modules/yargs-parser/build/index.cjs +6 -4
- package/node_modules/yargs-parser/build/lib/index.js +4 -2
- package/node_modules/yargs-parser/build/lib/yargs-parser.js +2 -2
- package/node_modules/yargs-parser/package.json +10 -6
- package/package.json +1 -1
- package/renovate.json +11 -58
- package/src/clients/Agent.js +40 -37
- package/src/clients/Client.js +42 -40
- package/src/clients/Instance.js +24 -24
- package/src/clients/Webplayer.js +23 -24
- package/src/commands/extensions/delete.js +26 -26
- package/src/commands/extensions/index.js +6 -11
- package/src/commands/extensions/list.js +25 -25
- package/src/commands/extensions/load.js +51 -50
- package/src/commands/extensions/validate.js +33 -38
- package/src/commands/firmware/index.js +6 -9
- package/src/commands/firmware/list.js +49 -38
- package/src/commands/firmware/load.js +45 -42
- package/src/commands/images/create.js +30 -29
- package/src/commands/images/delete.js +21 -21
- package/src/commands/images/index.js +6 -10
- package/src/commands/images/list.js +21 -20
- package/src/commands/index.js +2 -2
- package/src/commands/instances/apps/index.js +26 -23
- package/src/commands/instances/apps/install.js +14 -14
- package/src/commands/instances/apps/open.js +17 -17
- package/src/commands/instances/create.js +35 -38
- package/src/commands/instances/delete.js +24 -25
- package/src/commands/instances/file.js +36 -32
- package/src/commands/instances/get.js +23 -16
- package/src/commands/instances/index.js +8 -8
- package/src/commands/instances/input.js +16 -17
- package/src/commands/instances/list.js +38 -28
- package/src/commands/instances/netmon/disable.js +17 -15
- package/src/commands/instances/netmon/download.js +18 -16
- package/src/commands/instances/netmon/enable.js +30 -23
- package/src/commands/instances/netmon/index.js +6 -11
- package/src/commands/instances/netmon/stream.js +18 -16
- package/src/commands/instances/ready.js +30 -27
- package/src/commands/instances/restoreBackup.js +39 -36
- package/src/commands/instances/rotate.js +20 -21
- package/src/commands/instances/start.js +23 -24
- package/src/commands/instances/stop.js +20 -21
- package/src/commands/instances/unlock.js +17 -19
- package/src/commands/instances/upgrade.js +38 -34
- package/src/commands/login.js +67 -67
- package/src/commands/logout.js +10 -12
- package/src/commands/mast/constants.js +2 -2
- package/src/commands/mast/create-assessment.js +16 -16
- package/src/commands/mast/delete-assessment.js +15 -15
- package/src/commands/mast/download-report.js +18 -15
- package/src/commands/mast/get-assessment.js +14 -14
- package/src/commands/mast/get-assessments.js +13 -13
- package/src/commands/mast/index.js +7 -7
- package/src/commands/mast/start-monitor.js +15 -15
- package/src/commands/mast/stop-monitor.js +15 -15
- package/src/commands/mast/test.js +19 -16
- package/src/commands/projects/create.js +33 -32
- package/src/commands/projects/delete.js +26 -26
- package/src/commands/projects/index.js +6 -11
- package/src/commands/projects/list.js +21 -19
- package/src/commands/projects/vpnConfig.js +29 -26
- package/src/commands/webplayer/create.js +57 -50
- package/src/commands/webplayer/destroy.js +31 -28
- package/src/commands/webplayer/index.js +6 -11
- package/src/commands/webplayer/list.js +41 -42
- package/src/commands/webplayer/login.js +31 -28
- package/src/corellium-api.js +11 -11
- package/src/error.js +20 -18
- package/src/logging.js +15 -15
- package/src/profile.js +22 -22
- package/src/progress.js +6 -6
- package/src/resumable.js +606 -664
- package/src/table.js +20 -22
- package/src/upload.js +38 -38
- package/src/utils.js +63 -64
- package/test/test.js +47 -48
- package/coverage/cobertura-coverage.xml +0 -9
- package/coverage/lcov-report/base.css +0 -224
- package/coverage/lcov-report/block-navigation.js +0 -87
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +0 -101
- package/coverage/lcov-report/prettify.css +0 -1
- package/coverage/lcov-report/prettify.js +0 -2
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +0 -196
- package/coverage/lcov.info +0 -0
- package/node_modules/@babel/cli/node_modules/commander/CHANGELOG.md +0 -436
- package/node_modules/@babel/cli/node_modules/commander/index.js +0 -1649
- package/node_modules/@babel/cli/node_modules/commander/typings/index.d.ts +0 -311
- package/node_modules/@babel/cli/node_modules/semver/CHANGELOG.md +0 -39
- package/node_modules/@babel/cli/node_modules/semver/package.json +0 -28
- package/node_modules/@jridgewell/sourcemap-codec/src/sourcemap-codec.ts +0 -198
- package/node_modules/braces/CHANGELOG.md +0 -184
- package/node_modules/call-bind/.eslintignore +0 -1
- package/node_modules/call-bind/CHANGELOG.md +0 -42
- package/node_modules/call-bind/README.md +0 -2
- package/node_modules/call-bind/callBound.js +0 -15
- package/node_modules/call-bind/index.js +0 -47
- package/node_modules/call-bind/package.json +0 -80
- package/node_modules/call-bind/test/index.js +0 -66
- package/node_modules/component-emitter/History.md +0 -75
- package/node_modules/function-bind/.jscs.json +0 -176
- package/node_modules/function-bind/.npmignore +0 -22
- package/node_modules/function-bind/.travis.yml +0 -168
- package/node_modules/has/LICENSE-MIT +0 -22
- package/node_modules/has/README.md +0 -18
- package/node_modules/has/package.json +0 -48
- package/node_modules/has/src/index.js +0 -5
- package/node_modules/has/test/index.js +0 -10
- package/node_modules/lru-cache/README.md +0 -166
- package/node_modules/lru-cache/index.js +0 -334
- package/node_modules/lru-cache/package.json +0 -34
- package/node_modules/semver/LICENSE +0 -15
- package/node_modules/semver/functions/diff.js +0 -23
- package/node_modules/semver/functions/parse.js +0 -33
- package/node_modules/semver/index.js +0 -48
- package/node_modules/semver/internal/parse-options.js +0 -11
- package/node_modules/side-channel/.eslintignore +0 -1
- package/node_modules/superagent/node_modules/form-data/README.md.bak +0 -356
- package/node_modules/superagent/node_modules/form-data/Readme.md +0 -356
- package/node_modules/yallist/LICENSE +0 -15
- package/node_modules/yallist/README.md +0 -204
- package/node_modules/yallist/iterator.js +0 -8
- package/node_modules/yallist/package.json +0 -29
- package/node_modules/yallist/yallist.js +0 -426
- /package/node_modules/{superagent → axios}/node_modules/form-data/License +0 -0
- /package/node_modules/{superagent → axios}/node_modules/form-data/index.d.ts +0 -0
- /package/node_modules/{superagent → axios}/node_modules/form-data/lib/browser.js +0 -0
- /package/node_modules/{superagent → axios}/node_modules/form-data/lib/populate.js +0 -0
- /package/node_modules/{@babel/cli/node_modules/commander → commander}/LICENSE +0 -0
- /package/node_modules/{call-bind → dunder-proto}/.nycrc +0 -0
- /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/index.d.ts +0 -0
- /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/index.js +0 -0
- /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/license +0 -0
- /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/LICENSE +0 -0
- /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/README.md +0 -0
- /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/bin/semver +0 -0
- /package/node_modules/{@babel/cli → make-dir}/node_modules/semver/range.bnf +0 -0
- /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/package.json +0 -0
- /package/node_modules/{@babel/cli/node_modules/make-dir → make-dir}/readme.md +0 -0
- /package/node_modules/{@babel/cli/node_modules/pify → pify}/index.js +0 -0
- /package/node_modules/{@babel/cli/node_modules/pify → pify}/license +0 -0
- /package/node_modules/{@babel/cli/node_modules/pify → pify}/package.json +0 -0
- /package/node_modules/{@babel/cli/node_modules/pify → pify}/readme.md +0 -0
- /package/node_modules/{@babel/cli/node_modules/slash → slash}/index.js +0 -0
- /package/node_modules/{@babel/cli/node_modules/slash → slash}/license +0 -0
- /package/node_modules/{@babel/cli/node_modules/slash → slash}/package.json +0 -0
- /package/node_modules/{@babel/cli/node_modules/slash → slash}/readme.md +0 -0
- /package/node_modules/{lru-cache → superagent/node_modules/semver}/LICENSE +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/classes/index.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/clean.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/cmp.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare-build.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare-loose.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/compare.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/eq.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/gt.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/gte.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/lt.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/lte.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/major.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/minor.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/neq.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/patch.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/prerelease.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/rcompare.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/rsort.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/satisfies.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/sort.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/functions/valid.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/internal/debug.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/internal/identifiers.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/preload.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/range.bnf +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/gtr.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/ltr.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/max-satisfying.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/min-satisfying.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/min-version.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/outside.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/simplify.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/to-comparators.js +0 -0
- /package/node_modules/{semver → superagent/node_modules/semver}/ranges/valid.js +0 -0
@@ -13,9 +13,10 @@
|
|
13
13
|
"func-name-matching": 0,
|
14
14
|
"id-length": [2, { "min": 1, "max": 25, "properties": "never" }],
|
15
15
|
"indent": [2, 4],
|
16
|
+
"max-lines": 0,
|
16
17
|
"max-lines-per-function": [2, { "max": 150 }],
|
17
|
-
"max-params": [2,
|
18
|
-
"max-statements": [2,
|
18
|
+
"max-params": [2, 18],
|
19
|
+
"max-statements": [2, 100],
|
19
20
|
"multiline-comment-style": 0,
|
20
21
|
"no-continue": 1,
|
21
22
|
"no-magic-numbers": 0,
|
@@ -1,4 +1,80 @@
|
|
1
|
-
## **6.
|
1
|
+
## **6.14.0**
|
2
|
+
- [New] `parse`: add `throwOnParameterLimitExceeded` option (#517)
|
3
|
+
- [Refactor] `parse`: use `utils.combine` more
|
4
|
+
- [patch] `parse`: add explicit `throwOnLimitExceeded` default
|
5
|
+
- [actions] use shared action; re-add finishers
|
6
|
+
- [meta] Fix changelog formatting bug
|
7
|
+
- [Deps] update `side-channel`
|
8
|
+
- [Dev Deps] update `es-value-fixtures`, `has-bigints`, `has-proto`, `has-symbols`
|
9
|
+
- [Tests] increase coverage
|
10
|
+
|
11
|
+
## **6.13.1**
|
12
|
+
- [Fix] `stringify`: avoid a crash when a `filter` key is `null`
|
13
|
+
- [Fix] `utils.merge`: functions should not be stringified into keys
|
14
|
+
- [Fix] `parse`: avoid a crash with interpretNumericEntities: true, comma: true, and iso charset
|
15
|
+
- [Fix] `stringify`: ensure a non-string `filter` does not crash
|
16
|
+
- [Refactor] use `__proto__` syntax instead of `Object.create` for null objects
|
17
|
+
- [Refactor] misc cleanup
|
18
|
+
- [Tests] `utils.merge`: add some coverage
|
19
|
+
- [Tests] fix a test case
|
20
|
+
- [actions] split out node 10-20, and 20+
|
21
|
+
- [Dev Deps] update `es-value-fixtures`, `mock-property`, `object-inspect`, `tape`
|
22
|
+
|
23
|
+
## **6.13.0**
|
24
|
+
- [New] `parse`: add `strictDepth` option (#511)
|
25
|
+
- [Tests] use `npm audit` instead of `aud`
|
26
|
+
|
27
|
+
## **6.12.3**
|
28
|
+
- [Fix] `parse`: properly account for `strictNullHandling` when `allowEmptyArrays`
|
29
|
+
- [meta] fix changelog indentation
|
30
|
+
|
31
|
+
## **6.12.2**
|
32
|
+
- [Fix] `parse`: parse encoded square brackets (#506)
|
33
|
+
- [readme] add CII best practices badge
|
34
|
+
|
35
|
+
## **6.12.1**
|
36
|
+
- [Fix] `parse`: Disable `decodeDotInKeys` by default to restore previous behavior (#501)
|
37
|
+
- [Performance] `utils`: Optimize performance under large data volumes, reduce memory usage, and speed up processing (#502)
|
38
|
+
- [Refactor] `utils`: use `+=`
|
39
|
+
- [Tests] increase coverage
|
40
|
+
|
41
|
+
## **6.12.0**
|
42
|
+
|
43
|
+
- [New] `parse`/`stringify`: add `decodeDotInKeys`/`encodeDotKeys` options (#488)
|
44
|
+
- [New] `parse`: add `duplicates` option
|
45
|
+
- [New] `parse`/`stringify`: add `allowEmptyArrays` option to allow [] in object values (#487)
|
46
|
+
- [Refactor] `parse`/`stringify`: move allowDots config logic to its own variable
|
47
|
+
- [Refactor] `stringify`: move option-handling code into `normalizeStringifyOptions`
|
48
|
+
- [readme] update readme, add logos (#484)
|
49
|
+
- [readme] `stringify`: clarify default `arrayFormat` behavior
|
50
|
+
- [readme] fix line wrapping
|
51
|
+
- [readme] remove dead badges
|
52
|
+
- [Deps] update `side-channel`
|
53
|
+
- [meta] make the dist build 50% smaller
|
54
|
+
- [meta] add `sideEffects` flag
|
55
|
+
- [meta] run build in prepack, not prepublish
|
56
|
+
- [Tests] `parse`: remove useless tests; add coverage
|
57
|
+
- [Tests] `stringify`: increase coverage
|
58
|
+
- [Tests] use `mock-property`
|
59
|
+
- [Tests] `stringify`: improve coverage
|
60
|
+
- [Dev Deps] update `@ljharb/eslint-config `, `aud`, `has-override-mistake`, `has-property-descriptors`, `mock-property`, `npmignore`, `object-inspect`, `tape`
|
61
|
+
- [Dev Deps] pin `glob`, since v10.3.8+ requires a broken `jackspeak`
|
62
|
+
- [Dev Deps] pin `jackspeak` since 2.1.2+ depends on npm aliases, which kill the install process in npm < 6
|
63
|
+
|
64
|
+
## **6.11.2**
|
65
|
+
- [Fix] `parse`: Fix parsing when the global Object prototype is frozen (#473)
|
66
|
+
- [Tests] add passing test cases with empty keys (#473)
|
67
|
+
|
68
|
+
## **6.11.1**
|
69
|
+
- [Fix] `stringify`: encode comma values more consistently (#463)
|
70
|
+
- [readme] add usage of `filter` option for injecting custom serialization, i.e. of custom types (#447)
|
71
|
+
- [meta] remove extraneous code backticks (#457)
|
72
|
+
- [meta] fix changelog markdown
|
73
|
+
- [actions] update checkout action
|
74
|
+
- [actions] restrict action permissions
|
75
|
+
- [Dev Deps] update `@ljharb/eslint-config`, `aud`, `object-inspect`, `tape`
|
76
|
+
|
77
|
+
## **6.11.0**
|
2
78
|
- [New] [Fix] `stringify`: revert 0e903c0; add `commaRoundTrip` option (#442)
|
3
79
|
- [readme] fix version badge
|
4
80
|
|
@@ -238,7 +314,7 @@
|
|
238
314
|
|
239
315
|
## **6.5.3**
|
240
316
|
- [Fix] `parse`: ignore `__proto__` keys (#428)
|
241
|
-
- [Fix]
|
317
|
+
- [Fix] `utils.merge`: avoid a crash with a null target and a truthy non-array source
|
242
318
|
- [Fix] correctly parse nested arrays
|
243
319
|
- [Fix] `stringify`: fix a crash with `strictNullHandling` and a custom `filter`/`serializeDate` (#279)
|
244
320
|
- [Fix] `utils`: `merge`: fix crash when `source` is a truthy primitive & no options are provided
|
@@ -291,7 +367,7 @@
|
|
291
367
|
- [Fix] fix for an impossible situation: when the formatter is called with a non-string value
|
292
368
|
- [Fix] use `safer-buffer` instead of `Buffer` constructor
|
293
369
|
- [Fix] `utils.merge`: avoid a crash with a null target and an array source
|
294
|
-
- [Fix]
|
370
|
+
- [Fix] `utils.merge`: avoid a crash with a null target and a truthy non-array source
|
295
371
|
- [Fix] `stringify`: fix a crash with `strictNullHandling` and a custom `filter`/`serializeDate` (#279)
|
296
372
|
- [Fix] `utils`: `merge`: fix crash when `source` is a truthy primitive & no options are provided
|
297
373
|
- [Fix] when `parseArrays` is false, properly handle keys ending in `[]`
|
@@ -320,7 +396,7 @@
|
|
320
396
|
- [Fix] `parse`: ignore `__proto__` keys (#428)
|
321
397
|
- [Fix] fix for an impossible situation: when the formatter is called with a non-string value
|
322
398
|
- [Fix] `utils.merge`: avoid a crash with a null target and an array source
|
323
|
-
- [Fix]
|
399
|
+
- [Fix] `utils.merge`: avoid a crash with a null target and a truthy non-array source
|
324
400
|
- [Fix] `stringify`: fix a crash with `strictNullHandling` and a custom `filter`/`serializeDate` (#279)
|
325
401
|
- [Fix] `utils`: `merge`: fix crash when `source` is a truthy primitive & no options are provided
|
326
402
|
- [Fix] when `parseArrays` is false, properly handle keys ending in `[]`
|
@@ -407,7 +483,7 @@
|
|
407
483
|
- [New] add "encoder" and "decoder" options, for custom param encoding/decoding (#160)
|
408
484
|
- [Fix] fix compacting of nested sparse arrays (#150)
|
409
485
|
|
410
|
-
## **6.1.2
|
486
|
+
## **6.1.2**
|
411
487
|
- [Fix] follow `allowPrototypes` option during merge (#201, #200)
|
412
488
|
- [Fix] chmod a-x
|
413
489
|
- [Fix] support keys starting with brackets (#202, #200)
|
@@ -1,11 +1,14 @@
|
|
1
|
+
<p align="center">
|
2
|
+
<img alt="qs" src="./logos/banner_default.png" width="800" />
|
3
|
+
</p>
|
4
|
+
|
1
5
|
# qs <sup>[![Version Badge][npm-version-svg]][package-url]</sup>
|
2
6
|
|
3
7
|
[![github actions][actions-image]][actions-url]
|
4
8
|
[![coverage][codecov-image]][codecov-url]
|
5
|
-
[![dependency status][deps-svg]][deps-url]
|
6
|
-
[![dev dependency status][dev-deps-svg]][dev-deps-url]
|
7
9
|
[![License][license-image]][license-url]
|
8
10
|
[![Downloads][downloads-image]][downloads-url]
|
11
|
+
[](https://bestpractices.coreinfrastructure.org/projects/9058)
|
9
12
|
|
10
13
|
[![npm badge][npm-badge-png]][package-url]
|
11
14
|
|
@@ -46,14 +49,16 @@ assert.deepEqual(qs.parse('foo[bar]=baz'), {
|
|
46
49
|
});
|
47
50
|
```
|
48
51
|
|
49
|
-
When using the `plainObjects` option the parsed value is returned as a null object, created via `
|
52
|
+
When using the `plainObjects` option the parsed value is returned as a null object, created via `{ __proto__: null }` and as such you should be aware that prototype methods will not exist on it and a user may set those names to whatever value they like:
|
50
53
|
|
51
54
|
```javascript
|
52
55
|
var nullObject = qs.parse('a[hasOwnProperty]=b', { plainObjects: true });
|
53
56
|
assert.deepEqual(nullObject, { a: { hasOwnProperty: 'b' } });
|
54
57
|
```
|
55
58
|
|
56
|
-
By default parameters that would overwrite properties on the object prototype are ignored, if you wish to keep the data from those fields either use `plainObjects` as mentioned above, or set `allowPrototypes` to `true` which will allow user input to overwrite those properties.
|
59
|
+
By default parameters that would overwrite properties on the object prototype are ignored, if you wish to keep the data from those fields either use `plainObjects` as mentioned above, or set `allowPrototypes` to `true` which will allow user input to overwrite those properties.
|
60
|
+
*WARNING* It is generally a bad idea to enable this option as it can cause problems when attempting to use the properties that have been overwritten.
|
61
|
+
Always be careful with this option.
|
57
62
|
|
58
63
|
```javascript
|
59
64
|
var protoObject = qs.parse('a[hasOwnProperty]=b', { allowPrototypes: true });
|
@@ -80,8 +85,8 @@ assert.deepEqual(qs.parse('foo[bar][baz]=foobarbaz'), {
|
|
80
85
|
});
|
81
86
|
```
|
82
87
|
|
83
|
-
By default, when nesting objects **qs** will only parse up to 5 children deep.
|
84
|
-
`'a[b][c][d][e][f][g][h][i]=j'` your resulting object will be:
|
88
|
+
By default, when nesting objects **qs** will only parse up to 5 children deep.
|
89
|
+
This means if you attempt to parse a string like `'a[b][c][d][e][f][g][h][i]=j'` your resulting object will be:
|
85
90
|
|
86
91
|
```javascript
|
87
92
|
var expected = {
|
@@ -110,7 +115,18 @@ var deep = qs.parse('a[b][c][d][e][f][g][h][i]=j', { depth: 1 });
|
|
110
115
|
assert.deepEqual(deep, { a: { b: { '[c][d][e][f][g][h][i]': 'j' } } });
|
111
116
|
```
|
112
117
|
|
113
|
-
|
118
|
+
You can configure **qs** to throw an error when parsing nested input beyond this depth using the `strictDepth` option (defaulted to false):
|
119
|
+
|
120
|
+
```javascript
|
121
|
+
try {
|
122
|
+
qs.parse('a[b][c][d][e][f][g][h][i]=j', { depth: 1, strictDepth: true });
|
123
|
+
} catch (err) {
|
124
|
+
assert(err instanceof RangeError);
|
125
|
+
assert.strictEqual(err.message, 'Input depth exceeded depth option of 1 and strictDepth is true');
|
126
|
+
}
|
127
|
+
```
|
128
|
+
|
129
|
+
The depth limit helps mitigate abuse when **qs** is used to parse user input, and it is recommended to keep it a reasonably small number. The strictDepth option adds a layer of protection by throwing an error when the limit is exceeded, allowing you to catch and handle such cases.
|
114
130
|
|
115
131
|
For similar reasons, by default **qs** will only parse up to 1000 parameters. This can be overridden by passing a `parameterLimit` option:
|
116
132
|
|
@@ -119,6 +135,18 @@ var limited = qs.parse('a=b&c=d', { parameterLimit: 1 });
|
|
119
135
|
assert.deepEqual(limited, { a: 'b' });
|
120
136
|
```
|
121
137
|
|
138
|
+
If you want an error to be thrown whenever the a limit is exceeded (eg, `parameterLimit`, `arrayLimit`), set the `throwOnLimitExceeded` option to `true`. This option will generate a descriptive error if the query string exceeds a configured limit.
|
139
|
+
```javascript
|
140
|
+
try {
|
141
|
+
qs.parse('a=1&b=2&c=3&d=4', { parameterLimit: 3, throwOnLimitExceeded: true });
|
142
|
+
} catch (err) {
|
143
|
+
assert(err instanceof Error);
|
144
|
+
assert.strictEqual(err.message, 'Parameter limit exceeded. Only 3 parameters allowed.');
|
145
|
+
}
|
146
|
+
```
|
147
|
+
|
148
|
+
When `throwOnLimitExceeded` is set to `false` (default), **qs** will parse up to the specified `parameterLimit` and ignore the rest without throwing an error.
|
149
|
+
|
122
150
|
To bypass the leading question mark, use `ignoreQueryPrefix`:
|
123
151
|
|
124
152
|
```javascript
|
@@ -147,32 +175,44 @@ var withDots = qs.parse('a.b=c', { allowDots: true });
|
|
147
175
|
assert.deepEqual(withDots, { a: { b: 'c' } });
|
148
176
|
```
|
149
177
|
|
150
|
-
|
151
|
-
|
178
|
+
Option `decodeDotInKeys` can be used to decode dots in keys
|
179
|
+
Note: it implies `allowDots`, so `parse` will error if you set `decodeDotInKeys` to `true`, and `allowDots` to `false`.
|
180
|
+
|
181
|
+
```javascript
|
182
|
+
var withDots = qs.parse('name%252Eobj.first=John&name%252Eobj.last=Doe', { decodeDotInKeys: true });
|
183
|
+
assert.deepEqual(withDots, { 'name.obj': { first: 'John', last: 'Doe' }});
|
184
|
+
```
|
185
|
+
|
186
|
+
Option `allowEmptyArrays` can be used to allowing empty array values in object
|
187
|
+
```javascript
|
188
|
+
var withEmptyArrays = qs.parse('foo[]&bar=baz', { allowEmptyArrays: true });
|
189
|
+
assert.deepEqual(withEmptyArrays, { foo: [], bar: 'baz' });
|
190
|
+
```
|
191
|
+
|
192
|
+
Option `duplicates` can be used to change the behavior when duplicate keys are encountered
|
193
|
+
```javascript
|
194
|
+
assert.deepEqual(qs.parse('foo=bar&foo=baz'), { foo: ['bar', 'baz'] });
|
195
|
+
assert.deepEqual(qs.parse('foo=bar&foo=baz', { duplicates: 'combine' }), { foo: ['bar', 'baz'] });
|
196
|
+
assert.deepEqual(qs.parse('foo=bar&foo=baz', { duplicates: 'first' }), { foo: 'bar' });
|
197
|
+
assert.deepEqual(qs.parse('foo=bar&foo=baz', { duplicates: 'last' }), { foo: 'baz' });
|
198
|
+
```
|
199
|
+
|
200
|
+
If you have to deal with legacy browsers or services, there's also support for decoding percent-encoded octets as iso-8859-1:
|
152
201
|
|
153
202
|
```javascript
|
154
203
|
var oldCharset = qs.parse('a=%A7', { charset: 'iso-8859-1' });
|
155
204
|
assert.deepEqual(oldCharset, { a: '§' });
|
156
205
|
```
|
157
206
|
|
158
|
-
Some services add an initial `utf8=✓` value to forms so that old
|
159
|
-
|
160
|
-
utf-8. Additionally, the server can check the value against wrong
|
161
|
-
encodings of the checkmark character and detect that a query string
|
162
|
-
or `application/x-www-form-urlencoded` body was *not* sent as
|
163
|
-
utf-8, eg. if the form had an `accept-charset` parameter or the
|
164
|
-
containing page had a different character set.
|
207
|
+
Some services add an initial `utf8=✓` value to forms so that old Internet Explorer versions are more likely to submit the form as utf-8.
|
208
|
+
Additionally, the server can check the value against wrong encodings of the checkmark character and detect that a query string or `application/x-www-form-urlencoded` body was *not* sent as utf-8, eg. if the form had an `accept-charset` parameter or the containing page had a different character set.
|
165
209
|
|
166
210
|
**qs** supports this mechanism via the `charsetSentinel` option.
|
167
|
-
If specified, the `utf8` parameter will be omitted from the
|
168
|
-
|
169
|
-
mode depending on how the checkmark is encoded.
|
211
|
+
If specified, the `utf8` parameter will be omitted from the returned object.
|
212
|
+
It will be used to switch to `iso-8859-1`/`utf-8` mode depending on how the checkmark is encoded.
|
170
213
|
|
171
|
-
**Important**: When you specify both the `charset` option and the
|
172
|
-
|
173
|
-
the request contains a `utf8` parameter from which the actual
|
174
|
-
charset can be deduced. In that sense the `charset` will behave
|
175
|
-
as the default charset rather than the authoritative charset.
|
214
|
+
**Important**: When you specify both the `charset` option and the `charsetSentinel` option, the `charset` will be overridden when the request contains a `utf8` parameter from which the actual charset can be deduced.
|
215
|
+
In that sense the `charset` will behave as the default charset rather than the authoritative charset.
|
176
216
|
|
177
217
|
```javascript
|
178
218
|
var detectedAsUtf8 = qs.parse('utf8=%E2%9C%93&a=%C3%B8', {
|
@@ -189,8 +229,7 @@ var detectedAsIso8859_1 = qs.parse('utf8=%26%2310003%3B&a=%F8', {
|
|
189
229
|
assert.deepEqual(detectedAsIso8859_1, { a: 'ø' });
|
190
230
|
```
|
191
231
|
|
192
|
-
If you want to decode the `&#...;` syntax to the actual character,
|
193
|
-
you can specify the `interpretNumericEntities` option as well:
|
232
|
+
If you want to decode the `&#...;` syntax to the actual character, you can specify the `interpretNumericEntities` option as well:
|
194
233
|
|
195
234
|
```javascript
|
196
235
|
var detectedAsIso8859_1 = qs.parse('a=%26%239786%3B', {
|
@@ -200,8 +239,7 @@ var detectedAsIso8859_1 = qs.parse('a=%26%239786%3B', {
|
|
200
239
|
assert.deepEqual(detectedAsIso8859_1, { a: '☺' });
|
201
240
|
```
|
202
241
|
|
203
|
-
It also works when the charset has been detected in `charsetSentinel`
|
204
|
-
mode.
|
242
|
+
It also works when the charset has been detected in `charsetSentinel` mode.
|
205
243
|
|
206
244
|
### Parsing Arrays
|
207
245
|
|
@@ -219,9 +257,8 @@ var withIndexes = qs.parse('a[1]=c&a[0]=b');
|
|
219
257
|
assert.deepEqual(withIndexes, { a: ['b', 'c'] });
|
220
258
|
```
|
221
259
|
|
222
|
-
Note that the only difference between an index in an array and a key in an object is that the value between the brackets must be a number
|
223
|
-
|
224
|
-
their order:
|
260
|
+
Note that the only difference between an index in an array and a key in an object is that the value between the brackets must be a number to create an array.
|
261
|
+
When creating arrays with specific indices, **qs** will compact a sparse array to only the existing values preserving their order:
|
225
262
|
|
226
263
|
```javascript
|
227
264
|
var noSparse = qs.parse('a[1]=b&a[15]=c');
|
@@ -245,8 +282,9 @@ var withIndexedEmptyString = qs.parse('a[0]=b&a[1]=&a[2]=c');
|
|
245
282
|
assert.deepEqual(withIndexedEmptyString, { a: ['b', '', 'c'] });
|
246
283
|
```
|
247
284
|
|
248
|
-
**qs** will also limit specifying indices in an array to a maximum index of `20`.
|
249
|
-
|
285
|
+
**qs** will also limit specifying indices in an array to a maximum index of `20`.
|
286
|
+
Any array members with an index of greater than `20` will instead be converted to an object with the index as the key.
|
287
|
+
This is needed to handle cases when someone sent, for example, `a[999999999]` and it will take significant time to iterate over this huge array.
|
250
288
|
|
251
289
|
```javascript
|
252
290
|
var withMaxIndex = qs.parse('a[100]=b');
|
@@ -260,6 +298,18 @@ var withArrayLimit = qs.parse('a[1]=b', { arrayLimit: 0 });
|
|
260
298
|
assert.deepEqual(withArrayLimit, { a: { '1': 'b' } });
|
261
299
|
```
|
262
300
|
|
301
|
+
If you want to throw an error whenever the array limit is exceeded, set the `throwOnLimitExceeded` option to `true`. This option will generate a descriptive error if the query string exceeds a configured limit.
|
302
|
+
```javascript
|
303
|
+
try {
|
304
|
+
qs.parse('a[1]=b', { arrayLimit: 0, throwOnLimitExceeded: true });
|
305
|
+
} catch (err) {
|
306
|
+
assert(err instanceof Error);
|
307
|
+
assert.strictEqual(err.message, 'Array limit exceeded. Only 0 elements allowed in an array.');
|
308
|
+
}
|
309
|
+
```
|
310
|
+
|
311
|
+
When `throwOnLimitExceeded` is set to `false` (default), **qs** will parse up to the specified `arrayLimit` and if the limit is exceeded, the array will instead be converted to an object with the index as the key
|
312
|
+
|
263
313
|
To disable array parsing entirely, set `parseArrays` to `false`.
|
264
314
|
|
265
315
|
```javascript
|
@@ -290,7 +340,8 @@ assert.deepEqual(arraysOfObjects, { a: ['b', 'c'] })
|
|
290
340
|
|
291
341
|
### Parsing primitive/scalar values (numbers, booleans, null, etc)
|
292
342
|
|
293
|
-
By default, all values are parsed as strings.
|
343
|
+
By default, all values are parsed as strings.
|
344
|
+
This behavior will not change and is explained in [issue #91](https://github.com/ljharb/qs/issues/91).
|
294
345
|
|
295
346
|
```javascript
|
296
347
|
var primitiveValues = qs.parse('a=15&b=true&c=null');
|
@@ -373,16 +424,17 @@ var decoded = qs.parse('x=z', { decoder: function (str, defaultDecoder, charset,
|
|
373
424
|
}})
|
374
425
|
```
|
375
426
|
|
376
|
-
Examples beyond this point will be shown as though the output is not URI encoded for clarity.
|
427
|
+
Examples beyond this point will be shown as though the output is not URI encoded for clarity.
|
428
|
+
Please note that the return values in these cases *will* be URI encoded during real usage.
|
377
429
|
|
378
|
-
When arrays are stringified,
|
430
|
+
When arrays are stringified, they follow the `arrayFormat` option, which defaults to `indices`:
|
379
431
|
|
380
432
|
```javascript
|
381
433
|
qs.stringify({ a: ['b', 'c', 'd'] });
|
382
434
|
// 'a[0]=b&a[1]=c&a[2]=d'
|
383
435
|
```
|
384
436
|
|
385
|
-
You may override this by setting the `indices` option to `false`:
|
437
|
+
You may override this by setting the `indices` option to `false`, or to be more explicit, the `arrayFormat` option to `repeat`:
|
386
438
|
|
387
439
|
```javascript
|
388
440
|
qs.stringify({ a: ['b', 'c', 'd'] }, { indices: false });
|
@@ -418,6 +470,20 @@ qs.stringify({ a: { b: { c: 'd', e: 'f' } } }, { allowDots: true });
|
|
418
470
|
// 'a.b.c=d&a.b.e=f'
|
419
471
|
```
|
420
472
|
|
473
|
+
You may encode the dot notation in the keys of object with option `encodeDotInKeys` by setting it to `true`:
|
474
|
+
Note: it implies `allowDots`, so `stringify` will error if you set `decodeDotInKeys` to `true`, and `allowDots` to `false`.
|
475
|
+
Caveat: when `encodeValuesOnly` is `true` as well as `encodeDotInKeys`, only dots in keys and nothing else will be encoded.
|
476
|
+
```javascript
|
477
|
+
qs.stringify({ "name.obj": { "first": "John", "last": "Doe" } }, { allowDots: true, encodeDotInKeys: true })
|
478
|
+
// 'name%252Eobj.first=John&name%252Eobj.last=Doe'
|
479
|
+
```
|
480
|
+
|
481
|
+
You may allow empty array values by setting the `allowEmptyArrays` option to `true`:
|
482
|
+
```javascript
|
483
|
+
qs.stringify({ foo: [], bar: 'baz' }, { allowEmptyArrays: true });
|
484
|
+
// 'foo[]&bar=baz'
|
485
|
+
```
|
486
|
+
|
421
487
|
Empty strings and null values will omit the value, but the equals sign (=) remains in place:
|
422
488
|
|
423
489
|
```javascript
|
@@ -473,8 +539,8 @@ assert.equal(qs.stringify({ a: 'c', z: 'y', b : 'f' }, { sort: alphabeticalSort
|
|
473
539
|
```
|
474
540
|
|
475
541
|
Finally, you can use the `filter` option to restrict which keys will be included in the stringified output.
|
476
|
-
If you pass a function, it will be called for each key to obtain the replacement value.
|
477
|
-
pass an array, it will be used to select properties and array indices for stringification:
|
542
|
+
If you pass a function, it will be called for each key to obtain the replacement value.
|
543
|
+
Otherwise, if you pass an array, it will be used to select properties and array indices for stringification:
|
478
544
|
|
479
545
|
```javascript
|
480
546
|
function filterFunc(prefix, value) {
|
@@ -498,6 +564,44 @@ qs.stringify({ a: ['b', 'c', 'd'], e: 'f' }, { filter: ['a', 0, 2] });
|
|
498
564
|
// 'a[0]=b&a[2]=d'
|
499
565
|
```
|
500
566
|
|
567
|
+
You could also use `filter` to inject custom serialization for user defined types.
|
568
|
+
Consider you're working with some api that expects query strings of the format for ranges:
|
569
|
+
|
570
|
+
```
|
571
|
+
https://domain.com/endpoint?range=30...70
|
572
|
+
```
|
573
|
+
|
574
|
+
For which you model as:
|
575
|
+
|
576
|
+
```javascript
|
577
|
+
class Range {
|
578
|
+
constructor(from, to) {
|
579
|
+
this.from = from;
|
580
|
+
this.to = to;
|
581
|
+
}
|
582
|
+
}
|
583
|
+
```
|
584
|
+
|
585
|
+
You could _inject_ a custom serializer to handle values of this type:
|
586
|
+
|
587
|
+
```javascript
|
588
|
+
qs.stringify(
|
589
|
+
{
|
590
|
+
range: new Range(30, 70),
|
591
|
+
},
|
592
|
+
{
|
593
|
+
filter: (prefix, value) => {
|
594
|
+
if (value instanceof Range) {
|
595
|
+
return `${value.from}...${value.to}`;
|
596
|
+
}
|
597
|
+
// serialize the usual way
|
598
|
+
return value;
|
599
|
+
},
|
600
|
+
}
|
601
|
+
);
|
602
|
+
// range=30...70
|
603
|
+
```
|
604
|
+
|
501
605
|
### Handling of `null` values
|
502
606
|
|
503
607
|
By default, `null` values are treated like empty strings:
|
@@ -507,7 +611,8 @@ var withNull = qs.stringify({ a: null, b: '' });
|
|
507
611
|
assert.equal(withNull, 'a=&b=');
|
508
612
|
```
|
509
613
|
|
510
|
-
Parsing does not distinguish between parameters with and without equal signs.
|
614
|
+
Parsing does not distinguish between parameters with and without equal signs.
|
615
|
+
Both are converted to empty strings.
|
511
616
|
|
512
617
|
```javascript
|
513
618
|
var equalsInsensitive = qs.parse('a&b=');
|
@@ -536,25 +641,21 @@ var nullsSkipped = qs.stringify({ a: 'b', c: null}, { skipNulls: true });
|
|
536
641
|
assert.equal(nullsSkipped, 'a=b');
|
537
642
|
```
|
538
643
|
|
539
|
-
If you're communicating with legacy systems, you can switch to `iso-8859-1`
|
540
|
-
using the `charset` option:
|
644
|
+
If you're communicating with legacy systems, you can switch to `iso-8859-1` using the `charset` option:
|
541
645
|
|
542
646
|
```javascript
|
543
647
|
var iso = qs.stringify({ æ: 'æ' }, { charset: 'iso-8859-1' });
|
544
648
|
assert.equal(iso, '%E6=%E6');
|
545
649
|
```
|
546
650
|
|
547
|
-
Characters that don't exist in `iso-8859-1` will be converted to numeric
|
548
|
-
entities, similar to what browsers do:
|
651
|
+
Characters that don't exist in `iso-8859-1` will be converted to numeric entities, similar to what browsers do:
|
549
652
|
|
550
653
|
```javascript
|
551
654
|
var numeric = qs.stringify({ a: '☺' }, { charset: 'iso-8859-1' });
|
552
655
|
assert.equal(numeric, 'a=%26%239786%3B');
|
553
656
|
```
|
554
657
|
|
555
|
-
You can use the `charsetSentinel` option to announce the character by
|
556
|
-
including an `utf8=✓` parameter with the proper encoding if the checkmark,
|
557
|
-
similar to what Ruby on Rails and others do when submitting forms.
|
658
|
+
You can use the `charsetSentinel` option to announce the character by including an `utf8=✓` parameter with the proper encoding if the checkmark, similar to what Ruby on Rails and others do when submitting forms.
|
558
659
|
|
559
660
|
```javascript
|
560
661
|
var sentinel = qs.stringify({ a: '☺' }, { charsetSentinel: true });
|
@@ -566,8 +667,7 @@ assert.equal(isoSentinel, 'utf8=%26%2310003%3B&a=%E6');
|
|
566
667
|
|
567
668
|
### Dealing with special character sets
|
568
669
|
|
569
|
-
By default the encoding and decoding of characters is done in `utf-8`,
|
570
|
-
and `iso-8859-1` support is also built in via the `charset` parameter.
|
670
|
+
By default the encoding and decoding of characters is done in `utf-8`, and `iso-8859-1` support is also built in via the `charset` parameter.
|
571
671
|
|
572
672
|
If you wish to encode querystrings to a different character set (i.e.
|
573
673
|
[Shift JIS](https://en.wikipedia.org/wiki/Shift_JIS)) you can use the
|
@@ -606,7 +706,9 @@ Please email [@ljharb](https://github.com/ljharb) or see https://tidelift.com/se
|
|
606
706
|
|
607
707
|
Available as part of the Tidelift Subscription
|
608
708
|
|
609
|
-
The maintainers of qs and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications.
|
709
|
+
The maintainers of qs and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications.
|
710
|
+
Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use.
|
711
|
+
[Learn more.](https://tidelift.com/subscription/pkg/npm-qs?utm_source=npm-qs&utm_medium=referral&utm_campaign=enterprise&utm_term=repo)
|
610
712
|
|
611
713
|
[package-url]: https://npmjs.org/package/qs
|
612
714
|
[npm-version-svg]: https://versionbadg.es/ljharb/qs.svg
|
@@ -623,3 +725,9 @@ The maintainers of qs and thousands of other packages are working with Tidelift
|
|
623
725
|
[codecov-url]: https://app.codecov.io/gh/ljharb/qs/
|
624
726
|
[actions-image]: https://img.shields.io/endpoint?url=https://github-actions-badge-u3jn4tfpocch.runkit.sh/ljharb/qs
|
625
727
|
[actions-url]: https://github.com/ljharb/qs/actions
|
728
|
+
|
729
|
+
## Acknowledgements
|
730
|
+
|
731
|
+
qs logo by [NUMI](https://github.com/numi-hq/open-design):
|
732
|
+
|
733
|
+
[<img src="https://raw.githubusercontent.com/numi-hq/open-design/main/assets/numi-lockup.png" alt="NUMI Logo" style="width: 200px;"/>](https://numi.tech/?ref=qs)
|