dcs8 1.1.0
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/index.html +314 -0
- package/mod/douban-proxy.js +98 -0
- package/mod/node_modules/.package-lock.json +845 -0
- package/mod/node_modules/accepts/HISTORY.md +250 -0
- package/mod/node_modules/accepts/LICENSE +23 -0
- package/mod/node_modules/accepts/README.md +140 -0
- package/mod/node_modules/accepts/index.js +238 -0
- package/mod/node_modules/accepts/package.json +47 -0
- package/mod/node_modules/body-parser/LICENSE +23 -0
- package/mod/node_modules/body-parser/README.md +494 -0
- package/mod/node_modules/body-parser/index.js +71 -0
- package/mod/node_modules/body-parser/lib/read.js +247 -0
- package/mod/node_modules/body-parser/lib/types/json.js +158 -0
- package/mod/node_modules/body-parser/lib/types/raw.js +42 -0
- package/mod/node_modules/body-parser/lib/types/text.js +36 -0
- package/mod/node_modules/body-parser/lib/types/urlencoded.js +142 -0
- package/mod/node_modules/body-parser/lib/utils.js +98 -0
- package/mod/node_modules/body-parser/package.json +52 -0
- package/mod/node_modules/bytes/History.md +97 -0
- package/mod/node_modules/bytes/LICENSE +23 -0
- package/mod/node_modules/bytes/Readme.md +152 -0
- package/mod/node_modules/bytes/index.js +170 -0
- package/mod/node_modules/bytes/package.json +42 -0
- package/mod/node_modules/call-bind-apply-helpers/.eslintrc +17 -0
- package/mod/node_modules/call-bind-apply-helpers/.github/FUNDING.yml +12 -0
- package/mod/node_modules/call-bind-apply-helpers/.nycrc +9 -0
- package/mod/node_modules/call-bind-apply-helpers/CHANGELOG.md +30 -0
- package/mod/node_modules/call-bind-apply-helpers/LICENSE +21 -0
- package/mod/node_modules/call-bind-apply-helpers/README.md +62 -0
- package/mod/node_modules/call-bind-apply-helpers/actualApply.d.ts +1 -0
- package/mod/node_modules/call-bind-apply-helpers/actualApply.js +10 -0
- package/mod/node_modules/call-bind-apply-helpers/applyBind.d.ts +19 -0
- package/mod/node_modules/call-bind-apply-helpers/applyBind.js +10 -0
- package/mod/node_modules/call-bind-apply-helpers/functionApply.d.ts +1 -0
- package/mod/node_modules/call-bind-apply-helpers/functionApply.js +4 -0
- package/mod/node_modules/call-bind-apply-helpers/functionCall.d.ts +1 -0
- package/mod/node_modules/call-bind-apply-helpers/functionCall.js +4 -0
- package/mod/node_modules/call-bind-apply-helpers/index.d.ts +64 -0
- package/mod/node_modules/call-bind-apply-helpers/index.js +15 -0
- package/mod/node_modules/call-bind-apply-helpers/package.json +85 -0
- package/mod/node_modules/call-bind-apply-helpers/reflectApply.d.ts +3 -0
- package/mod/node_modules/call-bind-apply-helpers/reflectApply.js +4 -0
- package/mod/node_modules/call-bind-apply-helpers/test/index.js +63 -0
- package/mod/node_modules/call-bind-apply-helpers/tsconfig.json +9 -0
- package/mod/node_modules/call-bound/.eslintrc +13 -0
- package/mod/node_modules/call-bound/.github/FUNDING.yml +12 -0
- package/mod/node_modules/call-bound/.nycrc +9 -0
- package/mod/node_modules/call-bound/CHANGELOG.md +42 -0
- package/mod/node_modules/call-bound/LICENSE +21 -0
- package/mod/node_modules/call-bound/README.md +53 -0
- package/mod/node_modules/call-bound/index.d.ts +94 -0
- package/mod/node_modules/call-bound/index.js +19 -0
- package/mod/node_modules/call-bound/package.json +99 -0
- package/mod/node_modules/call-bound/test/index.js +61 -0
- package/mod/node_modules/call-bound/tsconfig.json +10 -0
- package/mod/node_modules/content-disposition/HISTORY.md +72 -0
- package/mod/node_modules/content-disposition/LICENSE +22 -0
- package/mod/node_modules/content-disposition/README.md +142 -0
- package/mod/node_modules/content-disposition/index.js +458 -0
- package/mod/node_modules/content-disposition/package.json +43 -0
- package/mod/node_modules/content-type/HISTORY.md +29 -0
- package/mod/node_modules/content-type/LICENSE +22 -0
- package/mod/node_modules/content-type/README.md +94 -0
- package/mod/node_modules/content-type/index.js +225 -0
- package/mod/node_modules/content-type/package.json +42 -0
- package/mod/node_modules/cookie/LICENSE +24 -0
- package/mod/node_modules/cookie/README.md +317 -0
- package/mod/node_modules/cookie/SECURITY.md +25 -0
- package/mod/node_modules/cookie/index.js +335 -0
- package/mod/node_modules/cookie/package.json +44 -0
- package/mod/node_modules/cookie-signature/History.md +70 -0
- package/mod/node_modules/cookie-signature/LICENSE +22 -0
- package/mod/node_modules/cookie-signature/Readme.md +23 -0
- package/mod/node_modules/cookie-signature/index.js +47 -0
- package/mod/node_modules/cookie-signature/package.json +24 -0
- package/mod/node_modules/cors/LICENSE +22 -0
- package/mod/node_modules/cors/README.md +277 -0
- package/mod/node_modules/cors/lib/index.js +238 -0
- package/mod/node_modules/cors/package.json +42 -0
- package/mod/node_modules/debug/LICENSE +20 -0
- package/mod/node_modules/debug/README.md +481 -0
- package/mod/node_modules/debug/package.json +64 -0
- package/mod/node_modules/debug/src/browser.js +272 -0
- package/mod/node_modules/debug/src/common.js +292 -0
- package/mod/node_modules/debug/src/index.js +10 -0
- package/mod/node_modules/debug/src/node.js +263 -0
- package/mod/node_modules/depd/History.md +103 -0
- package/mod/node_modules/depd/LICENSE +22 -0
- package/mod/node_modules/depd/Readme.md +280 -0
- package/mod/node_modules/depd/index.js +538 -0
- package/mod/node_modules/depd/lib/browser/index.js +77 -0
- package/mod/node_modules/depd/package.json +45 -0
- package/mod/node_modules/dunder-proto/.eslintrc +5 -0
- package/mod/node_modules/dunder-proto/.github/FUNDING.yml +12 -0
- package/mod/node_modules/dunder-proto/.nycrc +13 -0
- package/mod/node_modules/dunder-proto/CHANGELOG.md +24 -0
- package/mod/node_modules/dunder-proto/LICENSE +21 -0
- package/mod/node_modules/dunder-proto/README.md +54 -0
- package/mod/node_modules/dunder-proto/get.d.ts +5 -0
- package/mod/node_modules/dunder-proto/get.js +30 -0
- package/mod/node_modules/dunder-proto/package.json +76 -0
- package/mod/node_modules/dunder-proto/set.d.ts +5 -0
- package/mod/node_modules/dunder-proto/set.js +35 -0
- package/mod/node_modules/dunder-proto/test/get.js +34 -0
- package/mod/node_modules/dunder-proto/test/index.js +4 -0
- package/mod/node_modules/dunder-proto/test/set.js +50 -0
- package/mod/node_modules/dunder-proto/tsconfig.json +9 -0
- package/mod/node_modules/ee-first/LICENSE +22 -0
- package/mod/node_modules/ee-first/README.md +80 -0
- package/mod/node_modules/ee-first/index.js +95 -0
- package/mod/node_modules/ee-first/package.json +29 -0
- package/mod/node_modules/encodeurl/LICENSE +22 -0
- package/mod/node_modules/encodeurl/README.md +109 -0
- package/mod/node_modules/encodeurl/index.js +60 -0
- package/mod/node_modules/encodeurl/package.json +40 -0
- package/mod/node_modules/es-define-property/.eslintrc +13 -0
- package/mod/node_modules/es-define-property/.github/FUNDING.yml +12 -0
- package/mod/node_modules/es-define-property/.nycrc +9 -0
- package/mod/node_modules/es-define-property/CHANGELOG.md +29 -0
- package/mod/node_modules/es-define-property/LICENSE +21 -0
- package/mod/node_modules/es-define-property/README.md +49 -0
- package/mod/node_modules/es-define-property/index.d.ts +3 -0
- package/mod/node_modules/es-define-property/index.js +14 -0
- package/mod/node_modules/es-define-property/package.json +81 -0
- package/mod/node_modules/es-define-property/test/index.js +56 -0
- package/mod/node_modules/es-define-property/tsconfig.json +10 -0
- package/mod/node_modules/es-errors/.eslintrc +5 -0
- package/mod/node_modules/es-errors/.github/FUNDING.yml +12 -0
- package/mod/node_modules/es-errors/CHANGELOG.md +40 -0
- package/mod/node_modules/es-errors/LICENSE +21 -0
- package/mod/node_modules/es-errors/README.md +55 -0
- package/mod/node_modules/es-errors/eval.d.ts +3 -0
- package/mod/node_modules/es-errors/eval.js +4 -0
- package/mod/node_modules/es-errors/index.d.ts +3 -0
- package/mod/node_modules/es-errors/index.js +4 -0
- package/mod/node_modules/es-errors/package.json +80 -0
- package/mod/node_modules/es-errors/range.d.ts +3 -0
- package/mod/node_modules/es-errors/range.js +4 -0
- package/mod/node_modules/es-errors/ref.d.ts +3 -0
- package/mod/node_modules/es-errors/ref.js +4 -0
- package/mod/node_modules/es-errors/syntax.d.ts +3 -0
- package/mod/node_modules/es-errors/syntax.js +4 -0
- package/mod/node_modules/es-errors/test/index.js +19 -0
- package/mod/node_modules/es-errors/tsconfig.json +49 -0
- package/mod/node_modules/es-errors/type.d.ts +3 -0
- package/mod/node_modules/es-errors/type.js +4 -0
- package/mod/node_modules/es-errors/uri.d.ts +3 -0
- package/mod/node_modules/es-errors/uri.js +4 -0
- package/mod/node_modules/es-object-atoms/.eslintrc +16 -0
- package/mod/node_modules/es-object-atoms/.github/FUNDING.yml +12 -0
- package/mod/node_modules/es-object-atoms/CHANGELOG.md +37 -0
- package/mod/node_modules/es-object-atoms/LICENSE +21 -0
- package/mod/node_modules/es-object-atoms/README.md +63 -0
- package/mod/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +3 -0
- package/mod/node_modules/es-object-atoms/RequireObjectCoercible.js +11 -0
- package/mod/node_modules/es-object-atoms/ToObject.d.ts +7 -0
- package/mod/node_modules/es-object-atoms/ToObject.js +10 -0
- package/mod/node_modules/es-object-atoms/index.d.ts +3 -0
- package/mod/node_modules/es-object-atoms/index.js +4 -0
- package/mod/node_modules/es-object-atoms/isObject.d.ts +3 -0
- package/mod/node_modules/es-object-atoms/isObject.js +6 -0
- package/mod/node_modules/es-object-atoms/package.json +80 -0
- package/mod/node_modules/es-object-atoms/test/index.js +38 -0
- package/mod/node_modules/es-object-atoms/tsconfig.json +6 -0
- package/mod/node_modules/escape-html/LICENSE +24 -0
- package/mod/node_modules/escape-html/Readme.md +43 -0
- package/mod/node_modules/escape-html/index.js +78 -0
- package/mod/node_modules/escape-html/package.json +24 -0
- package/mod/node_modules/etag/HISTORY.md +83 -0
- package/mod/node_modules/etag/LICENSE +22 -0
- package/mod/node_modules/etag/README.md +159 -0
- package/mod/node_modules/etag/index.js +131 -0
- package/mod/node_modules/etag/package.json +47 -0
- package/mod/node_modules/express/LICENSE +24 -0
- package/mod/node_modules/express/Readme.md +276 -0
- package/mod/node_modules/express/index.js +11 -0
- package/mod/node_modules/express/lib/application.js +631 -0
- package/mod/node_modules/express/lib/express.js +81 -0
- package/mod/node_modules/express/lib/request.js +514 -0
- package/mod/node_modules/express/lib/response.js +1053 -0
- package/mod/node_modules/express/lib/utils.js +271 -0
- package/mod/node_modules/express/lib/view.js +205 -0
- package/mod/node_modules/express/package.json +99 -0
- package/mod/node_modules/finalhandler/HISTORY.md +239 -0
- package/mod/node_modules/finalhandler/LICENSE +22 -0
- package/mod/node_modules/finalhandler/README.md +150 -0
- package/mod/node_modules/finalhandler/index.js +293 -0
- package/mod/node_modules/finalhandler/package.json +47 -0
- package/mod/node_modules/forwarded/HISTORY.md +21 -0
- package/mod/node_modules/forwarded/LICENSE +22 -0
- package/mod/node_modules/forwarded/README.md +57 -0
- package/mod/node_modules/forwarded/index.js +90 -0
- package/mod/node_modules/forwarded/package.json +45 -0
- package/mod/node_modules/fresh/HISTORY.md +80 -0
- package/mod/node_modules/fresh/LICENSE +23 -0
- package/mod/node_modules/fresh/README.md +117 -0
- package/mod/node_modules/fresh/index.js +136 -0
- package/mod/node_modules/fresh/package.json +46 -0
- package/mod/node_modules/function-bind/.eslintrc +21 -0
- package/mod/node_modules/function-bind/.github/FUNDING.yml +12 -0
- package/mod/node_modules/function-bind/.github/SECURITY.md +3 -0
- package/mod/node_modules/function-bind/.nycrc +13 -0
- package/mod/node_modules/function-bind/CHANGELOG.md +136 -0
- package/mod/node_modules/function-bind/LICENSE +20 -0
- package/mod/node_modules/function-bind/README.md +46 -0
- package/mod/node_modules/function-bind/implementation.js +84 -0
- package/mod/node_modules/function-bind/index.js +5 -0
- package/mod/node_modules/function-bind/package.json +87 -0
- package/mod/node_modules/function-bind/test/.eslintrc +9 -0
- package/mod/node_modules/function-bind/test/index.js +252 -0
- package/mod/node_modules/get-intrinsic/.eslintrc +42 -0
- package/mod/node_modules/get-intrinsic/.github/FUNDING.yml +12 -0
- package/mod/node_modules/get-intrinsic/.nycrc +9 -0
- package/mod/node_modules/get-intrinsic/CHANGELOG.md +186 -0
- package/mod/node_modules/get-intrinsic/LICENSE +21 -0
- package/mod/node_modules/get-intrinsic/README.md +71 -0
- package/mod/node_modules/get-intrinsic/index.js +378 -0
- package/mod/node_modules/get-intrinsic/package.json +97 -0
- package/mod/node_modules/get-intrinsic/test/GetIntrinsic.js +274 -0
- package/mod/node_modules/get-proto/.eslintrc +10 -0
- package/mod/node_modules/get-proto/.github/FUNDING.yml +12 -0
- package/mod/node_modules/get-proto/.nycrc +9 -0
- package/mod/node_modules/get-proto/CHANGELOG.md +21 -0
- package/mod/node_modules/get-proto/LICENSE +21 -0
- package/mod/node_modules/get-proto/Object.getPrototypeOf.d.ts +5 -0
- package/mod/node_modules/get-proto/Object.getPrototypeOf.js +6 -0
- package/mod/node_modules/get-proto/README.md +50 -0
- package/mod/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +3 -0
- package/mod/node_modules/get-proto/Reflect.getPrototypeOf.js +4 -0
- package/mod/node_modules/get-proto/index.d.ts +5 -0
- package/mod/node_modules/get-proto/index.js +27 -0
- package/mod/node_modules/get-proto/package.json +81 -0
- package/mod/node_modules/get-proto/test/index.js +68 -0
- package/mod/node_modules/get-proto/tsconfig.json +9 -0
- package/mod/node_modules/gopd/.eslintrc +16 -0
- package/mod/node_modules/gopd/.github/FUNDING.yml +12 -0
- package/mod/node_modules/gopd/CHANGELOG.md +45 -0
- package/mod/node_modules/gopd/LICENSE +21 -0
- package/mod/node_modules/gopd/README.md +40 -0
- package/mod/node_modules/gopd/gOPD.d.ts +1 -0
- package/mod/node_modules/gopd/gOPD.js +4 -0
- package/mod/node_modules/gopd/index.d.ts +5 -0
- package/mod/node_modules/gopd/index.js +15 -0
- package/mod/node_modules/gopd/package.json +77 -0
- package/mod/node_modules/gopd/test/index.js +36 -0
- package/mod/node_modules/gopd/tsconfig.json +9 -0
- package/mod/node_modules/has-symbols/.eslintrc +11 -0
- package/mod/node_modules/has-symbols/.github/FUNDING.yml +12 -0
- package/mod/node_modules/has-symbols/.nycrc +9 -0
- package/mod/node_modules/has-symbols/CHANGELOG.md +91 -0
- package/mod/node_modules/has-symbols/LICENSE +21 -0
- package/mod/node_modules/has-symbols/README.md +46 -0
- package/mod/node_modules/has-symbols/index.d.ts +3 -0
- package/mod/node_modules/has-symbols/index.js +14 -0
- package/mod/node_modules/has-symbols/package.json +111 -0
- package/mod/node_modules/has-symbols/shams.d.ts +3 -0
- package/mod/node_modules/has-symbols/shams.js +45 -0
- package/mod/node_modules/has-symbols/test/index.js +22 -0
- package/mod/node_modules/has-symbols/test/shams/core-js.js +29 -0
- package/mod/node_modules/has-symbols/test/shams/get-own-property-symbols.js +29 -0
- package/mod/node_modules/has-symbols/test/tests.js +58 -0
- package/mod/node_modules/has-symbols/tsconfig.json +10 -0
- package/mod/node_modules/hasown/.eslintrc +5 -0
- package/mod/node_modules/hasown/.github/FUNDING.yml +12 -0
- package/mod/node_modules/hasown/.nycrc +13 -0
- package/mod/node_modules/hasown/CHANGELOG.md +40 -0
- package/mod/node_modules/hasown/LICENSE +21 -0
- package/mod/node_modules/hasown/README.md +40 -0
- package/mod/node_modules/hasown/index.d.ts +3 -0
- package/mod/node_modules/hasown/index.js +8 -0
- package/mod/node_modules/hasown/package.json +92 -0
- package/mod/node_modules/hasown/tsconfig.json +6 -0
- package/mod/node_modules/http-errors/HISTORY.md +186 -0
- package/mod/node_modules/http-errors/LICENSE +23 -0
- package/mod/node_modules/http-errors/README.md +169 -0
- package/mod/node_modules/http-errors/index.js +290 -0
- package/mod/node_modules/http-errors/package.json +54 -0
- package/mod/node_modules/iconv-lite/LICENSE +21 -0
- package/mod/node_modules/iconv-lite/README.md +138 -0
- package/mod/node_modules/iconv-lite/encodings/dbcs-codec.js +532 -0
- package/mod/node_modules/iconv-lite/encodings/dbcs-data.js +185 -0
- package/mod/node_modules/iconv-lite/encodings/index.js +23 -0
- package/mod/node_modules/iconv-lite/encodings/internal.js +218 -0
- package/mod/node_modules/iconv-lite/encodings/sbcs-codec.js +75 -0
- package/mod/node_modules/iconv-lite/encodings/sbcs-data-generated.js +451 -0
- package/mod/node_modules/iconv-lite/encodings/sbcs-data.js +178 -0
- package/mod/node_modules/iconv-lite/encodings/tables/big5-added.json +122 -0
- package/mod/node_modules/iconv-lite/encodings/tables/cp936.json +264 -0
- package/mod/node_modules/iconv-lite/encodings/tables/cp949.json +273 -0
- package/mod/node_modules/iconv-lite/encodings/tables/cp950.json +177 -0
- package/mod/node_modules/iconv-lite/encodings/tables/eucjp.json +182 -0
- package/mod/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json +1 -0
- package/mod/node_modules/iconv-lite/encodings/tables/gbk-added.json +56 -0
- package/mod/node_modules/iconv-lite/encodings/tables/shiftjis.json +125 -0
- package/mod/node_modules/iconv-lite/encodings/utf16.js +187 -0
- package/mod/node_modules/iconv-lite/encodings/utf32.js +307 -0
- package/mod/node_modules/iconv-lite/encodings/utf7.js +283 -0
- package/mod/node_modules/iconv-lite/lib/bom-handling.js +48 -0
- package/mod/node_modules/iconv-lite/lib/helpers/merge-exports.js +13 -0
- package/mod/node_modules/iconv-lite/lib/index.d.ts +129 -0
- package/mod/node_modules/iconv-lite/lib/index.js +182 -0
- package/mod/node_modules/iconv-lite/lib/streams.js +105 -0
- package/mod/node_modules/iconv-lite/package.json +70 -0
- package/mod/node_modules/iconv-lite/types/encodings.d.ts +423 -0
- package/mod/node_modules/inherits/LICENSE +16 -0
- package/mod/node_modules/inherits/README.md +42 -0
- package/mod/node_modules/inherits/inherits.js +9 -0
- package/mod/node_modules/inherits/inherits_browser.js +27 -0
- package/mod/node_modules/inherits/package.json +29 -0
- package/mod/node_modules/ipaddr.js/LICENSE +19 -0
- package/mod/node_modules/ipaddr.js/README.md +233 -0
- package/mod/node_modules/ipaddr.js/ipaddr.min.js +1 -0
- package/mod/node_modules/ipaddr.js/lib/ipaddr.js +673 -0
- package/mod/node_modules/ipaddr.js/lib/ipaddr.js.d.ts +68 -0
- package/mod/node_modules/ipaddr.js/package.json +35 -0
- package/mod/node_modules/is-promise/LICENSE +19 -0
- package/mod/node_modules/is-promise/index.d.ts +2 -0
- package/mod/node_modules/is-promise/index.js +6 -0
- package/mod/node_modules/is-promise/index.mjs +3 -0
- package/mod/node_modules/is-promise/package.json +30 -0
- package/mod/node_modules/is-promise/readme.md +33 -0
- package/mod/node_modules/math-intrinsics/.eslintrc +16 -0
- package/mod/node_modules/math-intrinsics/.github/FUNDING.yml +12 -0
- package/mod/node_modules/math-intrinsics/CHANGELOG.md +24 -0
- package/mod/node_modules/math-intrinsics/LICENSE +21 -0
- package/mod/node_modules/math-intrinsics/README.md +50 -0
- package/mod/node_modules/math-intrinsics/abs.d.ts +1 -0
- package/mod/node_modules/math-intrinsics/abs.js +4 -0
- package/mod/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +3 -0
- package/mod/node_modules/math-intrinsics/constants/maxArrayLength.js +4 -0
- package/mod/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +3 -0
- package/mod/node_modules/math-intrinsics/constants/maxSafeInteger.js +5 -0
- package/mod/node_modules/math-intrinsics/constants/maxValue.d.ts +3 -0
- package/mod/node_modules/math-intrinsics/constants/maxValue.js +5 -0
- package/mod/node_modules/math-intrinsics/floor.d.ts +1 -0
- package/mod/node_modules/math-intrinsics/floor.js +4 -0
- package/mod/node_modules/math-intrinsics/isFinite.d.ts +3 -0
- package/mod/node_modules/math-intrinsics/isFinite.js +12 -0
- package/mod/node_modules/math-intrinsics/isInteger.d.ts +3 -0
- package/mod/node_modules/math-intrinsics/isInteger.js +16 -0
- package/mod/node_modules/math-intrinsics/isNaN.d.ts +1 -0
- package/mod/node_modules/math-intrinsics/isNaN.js +6 -0
- package/mod/node_modules/math-intrinsics/isNegativeZero.d.ts +3 -0
- package/mod/node_modules/math-intrinsics/isNegativeZero.js +6 -0
- package/mod/node_modules/math-intrinsics/max.d.ts +1 -0
- package/mod/node_modules/math-intrinsics/max.js +4 -0
- package/mod/node_modules/math-intrinsics/min.d.ts +1 -0
- package/mod/node_modules/math-intrinsics/min.js +4 -0
- package/mod/node_modules/math-intrinsics/mod.d.ts +3 -0
- package/mod/node_modules/math-intrinsics/mod.js +9 -0
- package/mod/node_modules/math-intrinsics/package.json +86 -0
- package/mod/node_modules/math-intrinsics/pow.d.ts +1 -0
- package/mod/node_modules/math-intrinsics/pow.js +4 -0
- package/mod/node_modules/math-intrinsics/round.d.ts +1 -0
- package/mod/node_modules/math-intrinsics/round.js +4 -0
- package/mod/node_modules/math-intrinsics/sign.d.ts +3 -0
- package/mod/node_modules/math-intrinsics/sign.js +11 -0
- package/mod/node_modules/math-intrinsics/test/index.js +192 -0
- package/mod/node_modules/math-intrinsics/tsconfig.json +3 -0
- package/mod/node_modules/media-typer/HISTORY.md +50 -0
- package/mod/node_modules/media-typer/LICENSE +22 -0
- package/mod/node_modules/media-typer/README.md +93 -0
- package/mod/node_modules/media-typer/index.js +143 -0
- package/mod/node_modules/media-typer/package.json +33 -0
- package/mod/node_modules/merge-descriptors/index.d.ts +11 -0
- package/mod/node_modules/merge-descriptors/index.js +26 -0
- package/mod/node_modules/merge-descriptors/license +11 -0
- package/mod/node_modules/merge-descriptors/package.json +50 -0
- package/mod/node_modules/merge-descriptors/readme.md +55 -0
- package/mod/node_modules/mime-db/HISTORY.md +541 -0
- package/mod/node_modules/mime-db/LICENSE +23 -0
- package/mod/node_modules/mime-db/README.md +109 -0
- package/mod/node_modules/mime-db/db.json +9342 -0
- package/mod/node_modules/mime-db/index.js +12 -0
- package/mod/node_modules/mime-db/package.json +56 -0
- package/mod/node_modules/mime-types/HISTORY.md +428 -0
- package/mod/node_modules/mime-types/LICENSE +23 -0
- package/mod/node_modules/mime-types/README.md +126 -0
- package/mod/node_modules/mime-types/index.js +211 -0
- package/mod/node_modules/mime-types/mimeScore.js +57 -0
- package/mod/node_modules/mime-types/package.json +49 -0
- package/mod/node_modules/ms/index.js +162 -0
- package/mod/node_modules/ms/license.md +21 -0
- package/mod/node_modules/ms/package.json +38 -0
- package/mod/node_modules/ms/readme.md +59 -0
- package/mod/node_modules/negotiator/HISTORY.md +114 -0
- package/mod/node_modules/negotiator/LICENSE +24 -0
- package/mod/node_modules/negotiator/README.md +212 -0
- package/mod/node_modules/negotiator/index.js +83 -0
- package/mod/node_modules/negotiator/lib/charset.js +169 -0
- package/mod/node_modules/negotiator/lib/encoding.js +205 -0
- package/mod/node_modules/negotiator/lib/language.js +179 -0
- package/mod/node_modules/negotiator/lib/mediaType.js +294 -0
- package/mod/node_modules/negotiator/package.json +43 -0
- package/mod/node_modules/object-assign/index.js +90 -0
- package/mod/node_modules/object-assign/license +21 -0
- package/mod/node_modules/object-assign/package.json +42 -0
- package/mod/node_modules/object-assign/readme.md +61 -0
- package/mod/node_modules/object-inspect/.eslintrc +53 -0
- package/mod/node_modules/object-inspect/.github/FUNDING.yml +12 -0
- package/mod/node_modules/object-inspect/.nycrc +13 -0
- package/mod/node_modules/object-inspect/CHANGELOG.md +424 -0
- package/mod/node_modules/object-inspect/LICENSE +21 -0
- package/mod/node_modules/object-inspect/example/all.js +23 -0
- package/mod/node_modules/object-inspect/example/circular.js +6 -0
- package/mod/node_modules/object-inspect/example/fn.js +5 -0
- package/mod/node_modules/object-inspect/example/inspect.js +10 -0
- package/mod/node_modules/object-inspect/index.js +544 -0
- package/mod/node_modules/object-inspect/package-support.json +20 -0
- package/mod/node_modules/object-inspect/package.json +105 -0
- package/mod/node_modules/object-inspect/readme.markdown +84 -0
- package/mod/node_modules/object-inspect/test/bigint.js +58 -0
- package/mod/node_modules/object-inspect/test/browser/dom.js +15 -0
- package/mod/node_modules/object-inspect/test/circular.js +16 -0
- package/mod/node_modules/object-inspect/test/deep.js +12 -0
- package/mod/node_modules/object-inspect/test/element.js +53 -0
- package/mod/node_modules/object-inspect/test/err.js +48 -0
- package/mod/node_modules/object-inspect/test/fakes.js +29 -0
- package/mod/node_modules/object-inspect/test/fn.js +76 -0
- package/mod/node_modules/object-inspect/test/global.js +17 -0
- package/mod/node_modules/object-inspect/test/has.js +15 -0
- package/mod/node_modules/object-inspect/test/holes.js +15 -0
- package/mod/node_modules/object-inspect/test/indent-option.js +271 -0
- package/mod/node_modules/object-inspect/test/inspect.js +139 -0
- package/mod/node_modules/object-inspect/test/lowbyte.js +12 -0
- package/mod/node_modules/object-inspect/test/number.js +58 -0
- package/mod/node_modules/object-inspect/test/quoteStyle.js +26 -0
- package/mod/node_modules/object-inspect/test/toStringTag.js +40 -0
- package/mod/node_modules/object-inspect/test/undef.js +12 -0
- package/mod/node_modules/object-inspect/test/values.js +261 -0
- package/mod/node_modules/object-inspect/test-core-js.js +26 -0
- package/mod/node_modules/object-inspect/util.inspect.js +1 -0
- package/mod/node_modules/on-finished/HISTORY.md +98 -0
- package/mod/node_modules/on-finished/LICENSE +23 -0
- package/mod/node_modules/on-finished/README.md +162 -0
- package/mod/node_modules/on-finished/index.js +234 -0
- package/mod/node_modules/on-finished/package.json +39 -0
- package/mod/node_modules/once/LICENSE +15 -0
- package/mod/node_modules/once/README.md +79 -0
- package/mod/node_modules/once/once.js +42 -0
- package/mod/node_modules/once/package.json +33 -0
- package/mod/node_modules/parseurl/HISTORY.md +58 -0
- package/mod/node_modules/parseurl/LICENSE +24 -0
- package/mod/node_modules/parseurl/README.md +133 -0
- package/mod/node_modules/parseurl/index.js +158 -0
- package/mod/node_modules/parseurl/package.json +40 -0
- package/mod/node_modules/path-to-regexp/LICENSE +21 -0
- package/mod/node_modules/path-to-regexp/Readme.md +224 -0
- package/mod/node_modules/path-to-regexp/dist/index.d.ts +144 -0
- package/mod/node_modules/path-to-regexp/dist/index.js +409 -0
- package/mod/node_modules/path-to-regexp/dist/index.js.map +1 -0
- package/mod/node_modules/path-to-regexp/package.json +64 -0
- package/mod/node_modules/proxy-addr/HISTORY.md +161 -0
- package/mod/node_modules/proxy-addr/LICENSE +22 -0
- package/mod/node_modules/proxy-addr/README.md +139 -0
- package/mod/node_modules/proxy-addr/index.js +327 -0
- package/mod/node_modules/proxy-addr/package.json +47 -0
- package/mod/node_modules/qs/.editorconfig +46 -0
- package/mod/node_modules/qs/.github/FUNDING.yml +12 -0
- package/mod/node_modules/qs/.github/SECURITY.md +11 -0
- package/mod/node_modules/qs/.github/THREAT_MODEL.md +78 -0
- package/mod/node_modules/qs/.nycrc +13 -0
- package/mod/node_modules/qs/CHANGELOG.md +631 -0
- package/mod/node_modules/qs/LICENSE.md +29 -0
- package/mod/node_modules/qs/README.md +733 -0
- package/mod/node_modules/qs/dist/qs.js +141 -0
- package/mod/node_modules/qs/eslint.config.mjs +56 -0
- package/mod/node_modules/qs/lib/formats.js +23 -0
- package/mod/node_modules/qs/lib/index.js +11 -0
- package/mod/node_modules/qs/lib/parse.js +360 -0
- package/mod/node_modules/qs/lib/stringify.js +356 -0
- package/mod/node_modules/qs/lib/utils.js +320 -0
- package/mod/node_modules/qs/package.json +94 -0
- package/mod/node_modules/qs/test/empty-keys-cases.js +267 -0
- package/mod/node_modules/qs/test/parse.js +1396 -0
- package/mod/node_modules/qs/test/stringify.js +1310 -0
- package/mod/node_modules/qs/test/utils.js +381 -0
- package/mod/node_modules/range-parser/HISTORY.md +56 -0
- package/mod/node_modules/range-parser/LICENSE +23 -0
- package/mod/node_modules/range-parser/README.md +84 -0
- package/mod/node_modules/range-parser/index.js +162 -0
- package/mod/node_modules/range-parser/package.json +44 -0
- package/mod/node_modules/raw-body/LICENSE +22 -0
- package/mod/node_modules/raw-body/README.md +223 -0
- package/mod/node_modules/raw-body/index.d.ts +85 -0
- package/mod/node_modules/raw-body/index.js +336 -0
- package/mod/node_modules/raw-body/package.json +46 -0
- package/mod/node_modules/router/HISTORY.md +228 -0
- package/mod/node_modules/router/LICENSE +23 -0
- package/mod/node_modules/router/README.md +416 -0
- package/mod/node_modules/router/index.js +748 -0
- package/mod/node_modules/router/lib/layer.js +247 -0
- package/mod/node_modules/router/lib/route.js +242 -0
- package/mod/node_modules/router/package.json +44 -0
- package/mod/node_modules/safer-buffer/LICENSE +21 -0
- package/mod/node_modules/safer-buffer/Porting-Buffer.md +268 -0
- package/mod/node_modules/safer-buffer/Readme.md +156 -0
- package/mod/node_modules/safer-buffer/dangerous.js +58 -0
- package/mod/node_modules/safer-buffer/package.json +34 -0
- package/mod/node_modules/safer-buffer/safer.js +77 -0
- package/mod/node_modules/safer-buffer/tests.js +406 -0
- package/mod/node_modules/send/LICENSE +23 -0
- package/mod/node_modules/send/README.md +317 -0
- package/mod/node_modules/send/index.js +997 -0
- package/mod/node_modules/send/package.json +63 -0
- package/mod/node_modules/serve-static/LICENSE +25 -0
- package/mod/node_modules/serve-static/README.md +253 -0
- package/mod/node_modules/serve-static/index.js +208 -0
- package/mod/node_modules/serve-static/package.json +44 -0
- package/mod/node_modules/setprototypeof/LICENSE +13 -0
- package/mod/node_modules/setprototypeof/README.md +31 -0
- package/mod/node_modules/setprototypeof/index.d.ts +2 -0
- package/mod/node_modules/setprototypeof/index.js +17 -0
- package/mod/node_modules/setprototypeof/package.json +38 -0
- package/mod/node_modules/setprototypeof/test/index.js +24 -0
- package/mod/node_modules/side-channel/.editorconfig +9 -0
- package/mod/node_modules/side-channel/.eslintrc +12 -0
- package/mod/node_modules/side-channel/.github/FUNDING.yml +12 -0
- package/mod/node_modules/side-channel/.nycrc +13 -0
- package/mod/node_modules/side-channel/CHANGELOG.md +110 -0
- package/mod/node_modules/side-channel/LICENSE +21 -0
- package/mod/node_modules/side-channel/README.md +61 -0
- package/mod/node_modules/side-channel/index.d.ts +14 -0
- package/mod/node_modules/side-channel/index.js +43 -0
- package/mod/node_modules/side-channel/package.json +85 -0
- package/mod/node_modules/side-channel/test/index.js +104 -0
- package/mod/node_modules/side-channel/tsconfig.json +9 -0
- package/mod/node_modules/side-channel-list/.editorconfig +9 -0
- package/mod/node_modules/side-channel-list/.eslintrc +11 -0
- package/mod/node_modules/side-channel-list/.github/FUNDING.yml +12 -0
- package/mod/node_modules/side-channel-list/.nycrc +13 -0
- package/mod/node_modules/side-channel-list/CHANGELOG.md +15 -0
- package/mod/node_modules/side-channel-list/LICENSE +21 -0
- package/mod/node_modules/side-channel-list/README.md +62 -0
- package/mod/node_modules/side-channel-list/index.d.ts +13 -0
- package/mod/node_modules/side-channel-list/index.js +113 -0
- package/mod/node_modules/side-channel-list/list.d.ts +14 -0
- package/mod/node_modules/side-channel-list/package.json +77 -0
- package/mod/node_modules/side-channel-list/test/index.js +104 -0
- package/mod/node_modules/side-channel-list/tsconfig.json +9 -0
- package/mod/node_modules/side-channel-map/.editorconfig +9 -0
- package/mod/node_modules/side-channel-map/.eslintrc +11 -0
- package/mod/node_modules/side-channel-map/.github/FUNDING.yml +12 -0
- package/mod/node_modules/side-channel-map/.nycrc +13 -0
- package/mod/node_modules/side-channel-map/CHANGELOG.md +22 -0
- package/mod/node_modules/side-channel-map/LICENSE +21 -0
- package/mod/node_modules/side-channel-map/README.md +62 -0
- package/mod/node_modules/side-channel-map/index.d.ts +15 -0
- package/mod/node_modules/side-channel-map/index.js +68 -0
- package/mod/node_modules/side-channel-map/package.json +80 -0
- package/mod/node_modules/side-channel-map/test/index.js +114 -0
- package/mod/node_modules/side-channel-map/tsconfig.json +9 -0
- package/mod/node_modules/side-channel-weakmap/.editorconfig +9 -0
- package/mod/node_modules/side-channel-weakmap/.eslintrc +12 -0
- package/mod/node_modules/side-channel-weakmap/.github/FUNDING.yml +12 -0
- package/mod/node_modules/side-channel-weakmap/.nycrc +13 -0
- package/mod/node_modules/side-channel-weakmap/CHANGELOG.md +28 -0
- package/mod/node_modules/side-channel-weakmap/LICENSE +21 -0
- package/mod/node_modules/side-channel-weakmap/README.md +62 -0
- package/mod/node_modules/side-channel-weakmap/index.d.ts +15 -0
- package/mod/node_modules/side-channel-weakmap/index.js +84 -0
- package/mod/node_modules/side-channel-weakmap/package.json +87 -0
- package/mod/node_modules/side-channel-weakmap/test/index.js +114 -0
- package/mod/node_modules/side-channel-weakmap/tsconfig.json +9 -0
- package/mod/node_modules/statuses/HISTORY.md +87 -0
- package/mod/node_modules/statuses/LICENSE +23 -0
- package/mod/node_modules/statuses/README.md +139 -0
- package/mod/node_modules/statuses/codes.json +65 -0
- package/mod/node_modules/statuses/index.js +146 -0
- package/mod/node_modules/statuses/package.json +49 -0
- package/mod/node_modules/toidentifier/HISTORY.md +9 -0
- package/mod/node_modules/toidentifier/LICENSE +21 -0
- package/mod/node_modules/toidentifier/README.md +61 -0
- package/mod/node_modules/toidentifier/index.js +32 -0
- package/mod/node_modules/toidentifier/package.json +38 -0
- package/mod/node_modules/type-is/HISTORY.md +292 -0
- package/mod/node_modules/type-is/LICENSE +23 -0
- package/mod/node_modules/type-is/README.md +198 -0
- package/mod/node_modules/type-is/index.js +250 -0
- package/mod/node_modules/type-is/package.json +47 -0
- package/mod/node_modules/unpipe/HISTORY.md +4 -0
- package/mod/node_modules/unpipe/LICENSE +22 -0
- package/mod/node_modules/unpipe/README.md +43 -0
- package/mod/node_modules/unpipe/index.js +69 -0
- package/mod/node_modules/unpipe/package.json +27 -0
- package/mod/node_modules/vary/HISTORY.md +39 -0
- package/mod/node_modules/vary/LICENSE +22 -0
- package/mod/node_modules/vary/README.md +101 -0
- package/mod/node_modules/vary/index.js +149 -0
- package/mod/node_modules/vary/package.json +43 -0
- package/mod/node_modules/wrappy/LICENSE +15 -0
- package/mod/node_modules/wrappy/README.md +36 -0
- package/mod/node_modules/wrappy/package.json +29 -0
- package/mod/node_modules/wrappy/wrappy.js +33 -0
- package/mod/package-lock.json +854 -0
- package/mod/package.json +16 -0
- package/package.json +19 -0
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
# http-errors
|
|
2
|
+
|
|
3
|
+
[![NPM Version][npm-version-image]][npm-url]
|
|
4
|
+
[![NPM Downloads][npm-downloads-image]][node-url]
|
|
5
|
+
[![Node.js Version][node-image]][node-url]
|
|
6
|
+
[![Build Status][ci-image]][ci-url]
|
|
7
|
+
[![Test Coverage][coveralls-image]][coveralls-url]
|
|
8
|
+
|
|
9
|
+
Create HTTP errors for Express, Koa, Connect, etc. with ease.
|
|
10
|
+
|
|
11
|
+
## Install
|
|
12
|
+
|
|
13
|
+
This is a [Node.js](https://nodejs.org/en/) module available through the
|
|
14
|
+
[npm registry](https://www.npmjs.com/). Installation is done using the
|
|
15
|
+
[`npm install` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally):
|
|
16
|
+
|
|
17
|
+
```console
|
|
18
|
+
$ npm install http-errors
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
## Example
|
|
22
|
+
|
|
23
|
+
```js
|
|
24
|
+
var createError = require('http-errors')
|
|
25
|
+
var express = require('express')
|
|
26
|
+
var app = express()
|
|
27
|
+
|
|
28
|
+
app.use(function (req, res, next) {
|
|
29
|
+
if (!req.user) return next(createError(401, 'Please login to view this page.'))
|
|
30
|
+
next()
|
|
31
|
+
})
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
## API
|
|
35
|
+
|
|
36
|
+
This is the current API, currently extracted from Koa and subject to change.
|
|
37
|
+
|
|
38
|
+
### Error Properties
|
|
39
|
+
|
|
40
|
+
- `expose` - can be used to signal if `message` should be sent to the client,
|
|
41
|
+
defaulting to `false` when `status` >= 500
|
|
42
|
+
- `headers` - can be an object of header names to values to be sent to the
|
|
43
|
+
client, defaulting to `undefined`. When defined, the key names should all
|
|
44
|
+
be lower-cased
|
|
45
|
+
- `message` - the traditional error message, which should be kept short and all
|
|
46
|
+
single line
|
|
47
|
+
- `status` - the status code of the error, mirroring `statusCode` for general
|
|
48
|
+
compatibility
|
|
49
|
+
- `statusCode` - the status code of the error, defaulting to `500`
|
|
50
|
+
|
|
51
|
+
### createError([status], [message], [properties])
|
|
52
|
+
|
|
53
|
+
Create a new error object with the given message `msg`.
|
|
54
|
+
The error object inherits from `createError.HttpError`.
|
|
55
|
+
|
|
56
|
+
```js
|
|
57
|
+
var err = createError(404, 'This video does not exist!')
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
- `status: 500` - the status code as a number
|
|
61
|
+
- `message` - the message of the error, defaulting to node's text for that status code.
|
|
62
|
+
- `properties` - custom properties to attach to the object
|
|
63
|
+
|
|
64
|
+
### createError([status], [error], [properties])
|
|
65
|
+
|
|
66
|
+
Extend the given `error` object with `createError.HttpError`
|
|
67
|
+
properties. This will not alter the inheritance of the given
|
|
68
|
+
`error` object, and the modified `error` object is the
|
|
69
|
+
return value.
|
|
70
|
+
|
|
71
|
+
<!-- eslint-disable no-redeclare -->
|
|
72
|
+
|
|
73
|
+
```js
|
|
74
|
+
fs.readFile('foo.txt', function (err, buf) {
|
|
75
|
+
if (err) {
|
|
76
|
+
if (err.code === 'ENOENT') {
|
|
77
|
+
var httpError = createError(404, err, { expose: false })
|
|
78
|
+
} else {
|
|
79
|
+
var httpError = createError(500, err)
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
})
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
- `status` - the status code as a number
|
|
86
|
+
- `error` - the error object to extend
|
|
87
|
+
- `properties` - custom properties to attach to the object
|
|
88
|
+
|
|
89
|
+
### createError.isHttpError(val)
|
|
90
|
+
|
|
91
|
+
Determine if the provided `val` is an `HttpError`. This will return `true`
|
|
92
|
+
if the error inherits from the `HttpError` constructor of this module or
|
|
93
|
+
matches the "duck type" for an error this module creates. All outputs from
|
|
94
|
+
the `createError` factory will return `true` for this function, including
|
|
95
|
+
if an non-`HttpError` was passed into the factory.
|
|
96
|
+
|
|
97
|
+
### new createError\[code || name\](\[msg]\))
|
|
98
|
+
|
|
99
|
+
Create a new error object with the given message `msg`.
|
|
100
|
+
The error object inherits from `createError.HttpError`.
|
|
101
|
+
|
|
102
|
+
```js
|
|
103
|
+
var err = new createError.NotFound()
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
- `code` - the status code as a number
|
|
107
|
+
- `name` - the name of the error as a "bumpy case", i.e. `NotFound` or `InternalServerError`.
|
|
108
|
+
|
|
109
|
+
#### List of all constructors
|
|
110
|
+
|
|
111
|
+
|Status Code|Constructor Name |
|
|
112
|
+
|-----------|-----------------------------|
|
|
113
|
+
|400 |BadRequest |
|
|
114
|
+
|401 |Unauthorized |
|
|
115
|
+
|402 |PaymentRequired |
|
|
116
|
+
|403 |Forbidden |
|
|
117
|
+
|404 |NotFound |
|
|
118
|
+
|405 |MethodNotAllowed |
|
|
119
|
+
|406 |NotAcceptable |
|
|
120
|
+
|407 |ProxyAuthenticationRequired |
|
|
121
|
+
|408 |RequestTimeout |
|
|
122
|
+
|409 |Conflict |
|
|
123
|
+
|410 |Gone |
|
|
124
|
+
|411 |LengthRequired |
|
|
125
|
+
|412 |PreconditionFailed |
|
|
126
|
+
|413 |PayloadTooLarge |
|
|
127
|
+
|414 |URITooLong |
|
|
128
|
+
|415 |UnsupportedMediaType |
|
|
129
|
+
|416 |RangeNotSatisfiable |
|
|
130
|
+
|417 |ExpectationFailed |
|
|
131
|
+
|418 |ImATeapot |
|
|
132
|
+
|421 |MisdirectedRequest |
|
|
133
|
+
|422 |UnprocessableEntity |
|
|
134
|
+
|423 |Locked |
|
|
135
|
+
|424 |FailedDependency |
|
|
136
|
+
|425 |TooEarly |
|
|
137
|
+
|426 |UpgradeRequired |
|
|
138
|
+
|428 |PreconditionRequired |
|
|
139
|
+
|429 |TooManyRequests |
|
|
140
|
+
|431 |RequestHeaderFieldsTooLarge |
|
|
141
|
+
|451 |UnavailableForLegalReasons |
|
|
142
|
+
|500 |InternalServerError |
|
|
143
|
+
|501 |NotImplemented |
|
|
144
|
+
|502 |BadGateway |
|
|
145
|
+
|503 |ServiceUnavailable |
|
|
146
|
+
|504 |GatewayTimeout |
|
|
147
|
+
|505 |HTTPVersionNotSupported |
|
|
148
|
+
|506 |VariantAlsoNegotiates |
|
|
149
|
+
|507 |InsufficientStorage |
|
|
150
|
+
|508 |LoopDetected |
|
|
151
|
+
|509 |BandwidthLimitExceeded |
|
|
152
|
+
|510 |NotExtended |
|
|
153
|
+
|511 |NetworkAuthenticationRequired|
|
|
154
|
+
|
|
155
|
+
## License
|
|
156
|
+
|
|
157
|
+
[MIT](LICENSE)
|
|
158
|
+
|
|
159
|
+
[ci-image]: https://badgen.net/github/checks/jshttp/http-errors/master?label=ci
|
|
160
|
+
[ci-url]: https://github.com/jshttp/http-errors/actions?query=workflow%3Aci
|
|
161
|
+
[coveralls-image]: https://badgen.net/coveralls/c/github/jshttp/http-errors/master
|
|
162
|
+
[coveralls-url]: https://coveralls.io/r/jshttp/http-errors?branch=master
|
|
163
|
+
[node-image]: https://badgen.net/npm/node/http-errors
|
|
164
|
+
[node-url]: https://nodejs.org/en/download
|
|
165
|
+
[npm-downloads-image]: https://badgen.net/npm/dm/http-errors
|
|
166
|
+
[npm-url]: https://npmjs.org/package/http-errors
|
|
167
|
+
[npm-version-image]: https://badgen.net/npm/v/http-errors
|
|
168
|
+
[travis-image]: https://badgen.net/travis/jshttp/http-errors/master
|
|
169
|
+
[travis-url]: https://travis-ci.org/jshttp/http-errors
|
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* http-errors
|
|
3
|
+
* Copyright(c) 2014 Jonathan Ong
|
|
4
|
+
* Copyright(c) 2016 Douglas Christopher Wilson
|
|
5
|
+
* MIT Licensed
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
'use strict'
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Module dependencies.
|
|
12
|
+
* @private
|
|
13
|
+
*/
|
|
14
|
+
|
|
15
|
+
var deprecate = require('depd')('http-errors')
|
|
16
|
+
var setPrototypeOf = require('setprototypeof')
|
|
17
|
+
var statuses = require('statuses')
|
|
18
|
+
var inherits = require('inherits')
|
|
19
|
+
var toIdentifier = require('toidentifier')
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Module exports.
|
|
23
|
+
* @public
|
|
24
|
+
*/
|
|
25
|
+
|
|
26
|
+
module.exports = createError
|
|
27
|
+
module.exports.HttpError = createHttpErrorConstructor()
|
|
28
|
+
module.exports.isHttpError = createIsHttpErrorFunction(module.exports.HttpError)
|
|
29
|
+
|
|
30
|
+
// Populate exports for all constructors
|
|
31
|
+
populateConstructorExports(module.exports, statuses.codes, module.exports.HttpError)
|
|
32
|
+
|
|
33
|
+
/**
|
|
34
|
+
* Get the code class of a status code.
|
|
35
|
+
* @private
|
|
36
|
+
*/
|
|
37
|
+
|
|
38
|
+
function codeClass (status) {
|
|
39
|
+
return Number(String(status).charAt(0) + '00')
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Create a new HTTP Error.
|
|
44
|
+
*
|
|
45
|
+
* @returns {Error}
|
|
46
|
+
* @public
|
|
47
|
+
*/
|
|
48
|
+
|
|
49
|
+
function createError () {
|
|
50
|
+
// so much arity going on ~_~
|
|
51
|
+
var err
|
|
52
|
+
var msg
|
|
53
|
+
var status = 500
|
|
54
|
+
var props = {}
|
|
55
|
+
for (var i = 0; i < arguments.length; i++) {
|
|
56
|
+
var arg = arguments[i]
|
|
57
|
+
var type = typeof arg
|
|
58
|
+
if (type === 'object' && arg instanceof Error) {
|
|
59
|
+
err = arg
|
|
60
|
+
status = err.status || err.statusCode || status
|
|
61
|
+
} else if (type === 'number' && i === 0) {
|
|
62
|
+
status = arg
|
|
63
|
+
} else if (type === 'string') {
|
|
64
|
+
msg = arg
|
|
65
|
+
} else if (type === 'object') {
|
|
66
|
+
props = arg
|
|
67
|
+
} else {
|
|
68
|
+
throw new TypeError('argument #' + (i + 1) + ' unsupported type ' + type)
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
if (typeof status === 'number' && (status < 400 || status >= 600)) {
|
|
73
|
+
deprecate('non-error status code; use only 4xx or 5xx status codes')
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
if (typeof status !== 'number' ||
|
|
77
|
+
(!statuses.message[status] && (status < 400 || status >= 600))) {
|
|
78
|
+
status = 500
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
// constructor
|
|
82
|
+
var HttpError = createError[status] || createError[codeClass(status)]
|
|
83
|
+
|
|
84
|
+
if (!err) {
|
|
85
|
+
// create error
|
|
86
|
+
err = HttpError
|
|
87
|
+
? new HttpError(msg)
|
|
88
|
+
: new Error(msg || statuses.message[status])
|
|
89
|
+
Error.captureStackTrace(err, createError)
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
if (!HttpError || !(err instanceof HttpError) || err.status !== status) {
|
|
93
|
+
// add properties to generic error
|
|
94
|
+
err.expose = status < 500
|
|
95
|
+
err.status = err.statusCode = status
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
for (var key in props) {
|
|
99
|
+
if (key !== 'status' && key !== 'statusCode') {
|
|
100
|
+
err[key] = props[key]
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
return err
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* Create HTTP error abstract base class.
|
|
109
|
+
* @private
|
|
110
|
+
*/
|
|
111
|
+
|
|
112
|
+
function createHttpErrorConstructor () {
|
|
113
|
+
function HttpError () {
|
|
114
|
+
throw new TypeError('cannot construct abstract class')
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
inherits(HttpError, Error)
|
|
118
|
+
|
|
119
|
+
return HttpError
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* Create a constructor for a client error.
|
|
124
|
+
* @private
|
|
125
|
+
*/
|
|
126
|
+
|
|
127
|
+
function createClientErrorConstructor (HttpError, name, code) {
|
|
128
|
+
var className = toClassName(name)
|
|
129
|
+
|
|
130
|
+
function ClientError (message) {
|
|
131
|
+
// create the error object
|
|
132
|
+
var msg = message != null ? message : statuses.message[code]
|
|
133
|
+
var err = new Error(msg)
|
|
134
|
+
|
|
135
|
+
// capture a stack trace to the construction point
|
|
136
|
+
Error.captureStackTrace(err, ClientError)
|
|
137
|
+
|
|
138
|
+
// adjust the [[Prototype]]
|
|
139
|
+
setPrototypeOf(err, ClientError.prototype)
|
|
140
|
+
|
|
141
|
+
// redefine the error message
|
|
142
|
+
Object.defineProperty(err, 'message', {
|
|
143
|
+
enumerable: true,
|
|
144
|
+
configurable: true,
|
|
145
|
+
value: msg,
|
|
146
|
+
writable: true
|
|
147
|
+
})
|
|
148
|
+
|
|
149
|
+
// redefine the error name
|
|
150
|
+
Object.defineProperty(err, 'name', {
|
|
151
|
+
enumerable: false,
|
|
152
|
+
configurable: true,
|
|
153
|
+
value: className,
|
|
154
|
+
writable: true
|
|
155
|
+
})
|
|
156
|
+
|
|
157
|
+
return err
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
inherits(ClientError, HttpError)
|
|
161
|
+
nameFunc(ClientError, className)
|
|
162
|
+
|
|
163
|
+
ClientError.prototype.status = code
|
|
164
|
+
ClientError.prototype.statusCode = code
|
|
165
|
+
ClientError.prototype.expose = true
|
|
166
|
+
|
|
167
|
+
return ClientError
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
/**
|
|
171
|
+
* Create function to test is a value is a HttpError.
|
|
172
|
+
* @private
|
|
173
|
+
*/
|
|
174
|
+
|
|
175
|
+
function createIsHttpErrorFunction (HttpError) {
|
|
176
|
+
return function isHttpError (val) {
|
|
177
|
+
if (!val || typeof val !== 'object') {
|
|
178
|
+
return false
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
if (val instanceof HttpError) {
|
|
182
|
+
return true
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
return val instanceof Error &&
|
|
186
|
+
typeof val.expose === 'boolean' &&
|
|
187
|
+
typeof val.statusCode === 'number' && val.status === val.statusCode
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
/**
|
|
192
|
+
* Create a constructor for a server error.
|
|
193
|
+
* @private
|
|
194
|
+
*/
|
|
195
|
+
|
|
196
|
+
function createServerErrorConstructor (HttpError, name, code) {
|
|
197
|
+
var className = toClassName(name)
|
|
198
|
+
|
|
199
|
+
function ServerError (message) {
|
|
200
|
+
// create the error object
|
|
201
|
+
var msg = message != null ? message : statuses.message[code]
|
|
202
|
+
var err = new Error(msg)
|
|
203
|
+
|
|
204
|
+
// capture a stack trace to the construction point
|
|
205
|
+
Error.captureStackTrace(err, ServerError)
|
|
206
|
+
|
|
207
|
+
// adjust the [[Prototype]]
|
|
208
|
+
setPrototypeOf(err, ServerError.prototype)
|
|
209
|
+
|
|
210
|
+
// redefine the error message
|
|
211
|
+
Object.defineProperty(err, 'message', {
|
|
212
|
+
enumerable: true,
|
|
213
|
+
configurable: true,
|
|
214
|
+
value: msg,
|
|
215
|
+
writable: true
|
|
216
|
+
})
|
|
217
|
+
|
|
218
|
+
// redefine the error name
|
|
219
|
+
Object.defineProperty(err, 'name', {
|
|
220
|
+
enumerable: false,
|
|
221
|
+
configurable: true,
|
|
222
|
+
value: className,
|
|
223
|
+
writable: true
|
|
224
|
+
})
|
|
225
|
+
|
|
226
|
+
return err
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
inherits(ServerError, HttpError)
|
|
230
|
+
nameFunc(ServerError, className)
|
|
231
|
+
|
|
232
|
+
ServerError.prototype.status = code
|
|
233
|
+
ServerError.prototype.statusCode = code
|
|
234
|
+
ServerError.prototype.expose = false
|
|
235
|
+
|
|
236
|
+
return ServerError
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
/**
|
|
240
|
+
* Set the name of a function, if possible.
|
|
241
|
+
* @private
|
|
242
|
+
*/
|
|
243
|
+
|
|
244
|
+
function nameFunc (func, name) {
|
|
245
|
+
var desc = Object.getOwnPropertyDescriptor(func, 'name')
|
|
246
|
+
|
|
247
|
+
if (desc && desc.configurable) {
|
|
248
|
+
desc.value = name
|
|
249
|
+
Object.defineProperty(func, 'name', desc)
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
/**
|
|
254
|
+
* Populate the exports object with constructors for every error class.
|
|
255
|
+
* @private
|
|
256
|
+
*/
|
|
257
|
+
|
|
258
|
+
function populateConstructorExports (exports, codes, HttpError) {
|
|
259
|
+
codes.forEach(function forEachCode (code) {
|
|
260
|
+
var CodeError
|
|
261
|
+
var name = toIdentifier(statuses.message[code])
|
|
262
|
+
|
|
263
|
+
switch (codeClass(code)) {
|
|
264
|
+
case 400:
|
|
265
|
+
CodeError = createClientErrorConstructor(HttpError, name, code)
|
|
266
|
+
break
|
|
267
|
+
case 500:
|
|
268
|
+
CodeError = createServerErrorConstructor(HttpError, name, code)
|
|
269
|
+
break
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
if (CodeError) {
|
|
273
|
+
// export the constructor
|
|
274
|
+
exports[code] = CodeError
|
|
275
|
+
exports[name] = CodeError
|
|
276
|
+
}
|
|
277
|
+
})
|
|
278
|
+
}
|
|
279
|
+
|
|
280
|
+
/**
|
|
281
|
+
* Get a class name from a name identifier.
|
|
282
|
+
*
|
|
283
|
+
* @param {string} name
|
|
284
|
+
* @returns {string}
|
|
285
|
+
* @private
|
|
286
|
+
*/
|
|
287
|
+
|
|
288
|
+
function toClassName (name) {
|
|
289
|
+
return name.slice(-5) === 'Error' ? name : name + 'Error'
|
|
290
|
+
}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "http-errors",
|
|
3
|
+
"description": "Create HTTP error objects",
|
|
4
|
+
"version": "2.0.1",
|
|
5
|
+
"author": "Jonathan Ong <me@jongleberry.com> (http://jongleberry.com)",
|
|
6
|
+
"contributors": [
|
|
7
|
+
"Alan Plum <me@pluma.io>",
|
|
8
|
+
"Douglas Christopher Wilson <doug@somethingdoug.com>"
|
|
9
|
+
],
|
|
10
|
+
"license": "MIT",
|
|
11
|
+
"repository": "jshttp/http-errors",
|
|
12
|
+
"funding": {
|
|
13
|
+
"type": "opencollective",
|
|
14
|
+
"url": "https://opencollective.com/express"
|
|
15
|
+
},
|
|
16
|
+
"dependencies": {
|
|
17
|
+
"depd": "~2.0.0",
|
|
18
|
+
"inherits": "~2.0.4",
|
|
19
|
+
"setprototypeof": "~1.2.0",
|
|
20
|
+
"statuses": "~2.0.2",
|
|
21
|
+
"toidentifier": "~1.0.1"
|
|
22
|
+
},
|
|
23
|
+
"devDependencies": {
|
|
24
|
+
"eslint": "7.32.0",
|
|
25
|
+
"eslint-config-standard": "14.1.1",
|
|
26
|
+
"eslint-plugin-import": "2.32.0",
|
|
27
|
+
"eslint-plugin-markdown": "2.2.1",
|
|
28
|
+
"eslint-plugin-node": "11.1.0",
|
|
29
|
+
"eslint-plugin-promise": "5.2.0",
|
|
30
|
+
"eslint-plugin-standard": "4.1.0",
|
|
31
|
+
"mocha": "9.1.3",
|
|
32
|
+
"nyc": "15.1.0"
|
|
33
|
+
},
|
|
34
|
+
"engines": {
|
|
35
|
+
"node": ">= 0.8"
|
|
36
|
+
},
|
|
37
|
+
"scripts": {
|
|
38
|
+
"lint": "eslint . && node ./scripts/lint-readme-list.js",
|
|
39
|
+
"test": "mocha --reporter spec",
|
|
40
|
+
"test-ci": "nyc --reporter=lcov --reporter=text npm test",
|
|
41
|
+
"test-cov": "nyc --reporter=html --reporter=text npm test",
|
|
42
|
+
"version": "node scripts/version-history.js && git add HISTORY.md"
|
|
43
|
+
},
|
|
44
|
+
"keywords": [
|
|
45
|
+
"http",
|
|
46
|
+
"error"
|
|
47
|
+
],
|
|
48
|
+
"files": [
|
|
49
|
+
"index.js",
|
|
50
|
+
"HISTORY.md",
|
|
51
|
+
"LICENSE",
|
|
52
|
+
"README.md"
|
|
53
|
+
]
|
|
54
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
Copyright (c) 2011 Alexander Shtuchkin
|
|
2
|
+
|
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
|
4
|
+
a copy of this software and associated documentation files (the
|
|
5
|
+
"Software"), to deal in the Software without restriction, including
|
|
6
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
|
7
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
|
8
|
+
permit persons to whom the Software is furnished to do so, subject to
|
|
9
|
+
the following conditions:
|
|
10
|
+
|
|
11
|
+
The above copyright notice and this permission notice shall be
|
|
12
|
+
included in all copies or substantial portions of the Software.
|
|
13
|
+
|
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
15
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
16
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
17
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
18
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
19
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
20
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
21
|
+
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
## iconv-lite: Pure JS character encoding conversion
|
|
2
|
+
|
|
3
|
+
[![NPM Version][npm-version-image]][npm-url]
|
|
4
|
+
[![NPM Downloads][npm-downloads-image]][npm-downloads-url]
|
|
5
|
+
[![License][license-image]][license-url]
|
|
6
|
+
[![NPM Install Size][npm-install-size-image]][npm-install-size-url]
|
|
7
|
+
|
|
8
|
+
* No need for native code compilation. Quick to install, works on Windows, Web, and in sandboxed environments.
|
|
9
|
+
* Used in popular projects like [Express.js (body_parser)](https://github.com/expressjs/body-parser),
|
|
10
|
+
[Grunt](http://gruntjs.com/), [Nodemailer](http://www.nodemailer.com/), [Yeoman](http://yeoman.io/) and others.
|
|
11
|
+
* Faster than [node-iconv](https://github.com/bnoordhuis/node-iconv) (see below for performance comparison).
|
|
12
|
+
* Intuitive encode/decode API, including Streaming support.
|
|
13
|
+
* In-browser usage via [browserify](https://github.com/substack/node-browserify) or [webpack](https://webpack.js.org/) (~180kb gzip compressed with Buffer shim included).
|
|
14
|
+
* Typescript [type definition file](https://github.com/ashtuchkin/iconv-lite/blob/master/lib/index.d.ts) included.
|
|
15
|
+
* React Native is supported (need to install `stream` module to enable Streaming API).
|
|
16
|
+
|
|
17
|
+
## Usage
|
|
18
|
+
|
|
19
|
+
### Basic API
|
|
20
|
+
|
|
21
|
+
```javascript
|
|
22
|
+
var iconv = require('iconv-lite');
|
|
23
|
+
|
|
24
|
+
// Convert from an encoded buffer to a js string.
|
|
25
|
+
str = iconv.decode(Buffer.from([0x68, 0x65, 0x6c, 0x6c, 0x6f]), 'win1251');
|
|
26
|
+
|
|
27
|
+
// Convert from a js string to an encoded buffer.
|
|
28
|
+
buf = iconv.encode("Sample input string", 'win1251');
|
|
29
|
+
|
|
30
|
+
// Check if encoding is supported
|
|
31
|
+
iconv.encodingExists("us-ascii")
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
### Streaming API
|
|
35
|
+
|
|
36
|
+
```javascript
|
|
37
|
+
// Decode stream (from binary data stream to js strings)
|
|
38
|
+
http.createServer(function(req, res) {
|
|
39
|
+
var converterStream = iconv.decodeStream('win1251');
|
|
40
|
+
req.pipe(converterStream);
|
|
41
|
+
|
|
42
|
+
converterStream.on('data', function(str) {
|
|
43
|
+
console.log(str); // Do something with decoded strings, chunk-by-chunk.
|
|
44
|
+
});
|
|
45
|
+
});
|
|
46
|
+
|
|
47
|
+
// Convert encoding streaming example
|
|
48
|
+
fs.createReadStream('file-in-win1251.txt')
|
|
49
|
+
.pipe(iconv.decodeStream('win1251'))
|
|
50
|
+
.pipe(iconv.encodeStream('ucs2'))
|
|
51
|
+
.pipe(fs.createWriteStream('file-in-ucs2.txt'));
|
|
52
|
+
|
|
53
|
+
// Sugar: all encode/decode streams have .collect(cb) method to accumulate data.
|
|
54
|
+
http.createServer(function(req, res) {
|
|
55
|
+
req.pipe(iconv.decodeStream('win1251')).collect(function(err, body) {
|
|
56
|
+
assert(typeof body == 'string');
|
|
57
|
+
console.log(body); // full request body string
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
## Supported encodings
|
|
63
|
+
|
|
64
|
+
* All node.js native encodings: utf8, ucs2 / utf16-le, ascii, binary, base64, hex.
|
|
65
|
+
* Additional unicode encodings: utf16, utf16-be, utf-7, utf-7-imap, utf32, utf32-le, and utf32-be.
|
|
66
|
+
* All widespread singlebyte encodings: Windows 125x family, ISO-8859 family,
|
|
67
|
+
IBM/DOS codepages, Macintosh family, KOI8 family, all others supported by iconv library.
|
|
68
|
+
Aliases like 'latin1', 'us-ascii' also supported.
|
|
69
|
+
* All widespread multibyte encodings: CP932, CP936, CP949, CP950, GB2312, GBK, GB18030, Big5, Shift_JIS, EUC-JP.
|
|
70
|
+
|
|
71
|
+
See [all supported encodings on wiki](https://github.com/ashtuchkin/iconv-lite/wiki/Supported-Encodings).
|
|
72
|
+
|
|
73
|
+
Most singlebyte encodings are generated automatically from [node-iconv](https://github.com/bnoordhuis/node-iconv). Thank you Ben Noordhuis and libiconv authors!
|
|
74
|
+
|
|
75
|
+
Multibyte encodings are generated from [Unicode.org mappings](http://www.unicode.org/Public/MAPPINGS/) and [WHATWG Encoding Standard mappings](http://encoding.spec.whatwg.org/). Thank you, respective authors!
|
|
76
|
+
|
|
77
|
+
## Encoding/decoding speed
|
|
78
|
+
|
|
79
|
+
Comparison with node-iconv module (1000x256kb, on MacBook Pro, Core i5/2.6 GHz, Node v0.12.0).
|
|
80
|
+
Note: your results may vary, so please always check on your hardware.
|
|
81
|
+
|
|
82
|
+
operation iconv@2.1.4 iconv-lite@0.4.7
|
|
83
|
+
----------------------------------------------------------
|
|
84
|
+
encode('win1251') ~96 Mb/s ~320 Mb/s
|
|
85
|
+
decode('win1251') ~95 Mb/s ~246 Mb/s
|
|
86
|
+
|
|
87
|
+
## BOM handling
|
|
88
|
+
|
|
89
|
+
* Decoding: BOM is stripped by default, unless overridden by passing `stripBOM: false` in options
|
|
90
|
+
(f.ex. `iconv.decode(buf, enc, {stripBOM: false})`).
|
|
91
|
+
A callback might also be given as a `stripBOM` parameter - it'll be called if BOM character was actually found.
|
|
92
|
+
* If you want to detect UTF-8 BOM when decoding other encodings, use [node-autodetect-decoder-stream](https://github.com/danielgindi/node-autodetect-decoder-stream) module.
|
|
93
|
+
* Encoding: No BOM added, unless overridden by `addBOM: true` option.
|
|
94
|
+
|
|
95
|
+
## UTF-16 Encodings
|
|
96
|
+
|
|
97
|
+
This library supports UTF-16LE, UTF-16BE and UTF-16 encodings. First two are straightforward, but UTF-16 is trying to be
|
|
98
|
+
smart about endianness in the following ways:
|
|
99
|
+
* Decoding: uses BOM and 'spaces heuristic' to determine input endianness. Default is UTF-16LE, but can be
|
|
100
|
+
overridden with `defaultEncoding: 'utf-16be'` option. Strips BOM unless `stripBOM: false`.
|
|
101
|
+
* Encoding: uses UTF-16LE and writes BOM by default. Use `addBOM: false` to override.
|
|
102
|
+
|
|
103
|
+
## UTF-32 Encodings
|
|
104
|
+
|
|
105
|
+
This library supports UTF-32LE, UTF-32BE and UTF-32 encodings. Like the UTF-16 encoding above, UTF-32 defaults to UTF-32LE, but uses BOM and 'spaces heuristics' to determine input endianness.
|
|
106
|
+
* The default of UTF-32LE can be overridden with the `defaultEncoding: 'utf-32be'` option. Strips BOM unless `stripBOM: false`.
|
|
107
|
+
* Encoding: uses UTF-32LE and writes BOM by default. Use `addBOM: false` to override. (`defaultEncoding: 'utf-32be'` can also be used here to change encoding.)
|
|
108
|
+
|
|
109
|
+
## Other notes
|
|
110
|
+
|
|
111
|
+
When decoding, be sure to supply a Buffer to decode() method, otherwise [bad things usually happen](https://github.com/ashtuchkin/iconv-lite/wiki/Use-Buffers-when-decoding).
|
|
112
|
+
Untranslatable characters are set to � or ?. No transliteration is currently supported.
|
|
113
|
+
Node versions 0.10.31 and 0.11.13 are buggy, don't use them (see [#65](https://github.com/ashtuchkin/iconv-lite/issues/65), [#77](https://github.com/ashtuchkin/iconv-lite/issues/77)).
|
|
114
|
+
|
|
115
|
+
## Testing
|
|
116
|
+
|
|
117
|
+
```sh
|
|
118
|
+
git clone git@github.com:ashtuchkin/iconv-lite.git
|
|
119
|
+
cd iconv-lite
|
|
120
|
+
npm install
|
|
121
|
+
npm test
|
|
122
|
+
|
|
123
|
+
# To view performance:
|
|
124
|
+
npm run test:performance
|
|
125
|
+
|
|
126
|
+
# To view test coverage:
|
|
127
|
+
npm run test:cov
|
|
128
|
+
open coverage/index.html
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
[npm-downloads-image]: https://badgen.net/npm/dm/iconv-lite
|
|
132
|
+
[npm-downloads-url]: https://npmcharts.com/compare/iconv-lite?minimal=true
|
|
133
|
+
[npm-url]: https://npmjs.org/package/iconv-lite
|
|
134
|
+
[npm-version-image]: https://badgen.net/npm/v/iconv-lite
|
|
135
|
+
[npm-install-size-image]: https://badgen.net/packagephobia/install/iconv-lite
|
|
136
|
+
[npm-install-size-url]: https://packagephobia.com/result?p=iconv-lite
|
|
137
|
+
[license-image]: https://img.shields.io/npm/l/iconv-lite.svg
|
|
138
|
+
[license-url]: https://github.com/ashtuchkin/iconv-lite/blob/HEAD/LICENSE
|