@pnpm/exe 11.0.0-dev.1003 → 11.0.0-rc.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/dist/node-gyp-bin/node-gyp +6 -0
- package/dist/node-gyp-bin/node-gyp.cmd +5 -0
- package/dist/node_modules/@gar/promise-retry/LICENSE +20 -0
- package/dist/node_modules/@gar/promise-retry/lib/index.js +62 -0
- package/dist/node_modules/@gar/promise-retry/lib/retry.js +109 -0
- package/dist/node_modules/@gar/promise-retry/package.json +45 -0
- package/dist/node_modules/@isaacs/fs-minipass/LICENSE +15 -0
- package/dist/node_modules/@isaacs/fs-minipass/dist/commonjs/index.js +430 -0
- package/dist/node_modules/@isaacs/fs-minipass/dist/commonjs/package.json +3 -0
- package/dist/node_modules/@isaacs/fs-minipass/dist/esm/index.js +420 -0
- package/dist/node_modules/@isaacs/fs-minipass/dist/esm/package.json +3 -0
- package/dist/node_modules/@isaacs/fs-minipass/package.json +72 -0
- package/dist/node_modules/@npmcli/agent/lib/agents.js +206 -0
- package/dist/node_modules/@npmcli/agent/lib/dns.js +53 -0
- package/dist/node_modules/@npmcli/agent/lib/errors.js +61 -0
- package/dist/node_modules/@npmcli/agent/lib/index.js +56 -0
- package/dist/node_modules/@npmcli/agent/lib/options.js +86 -0
- package/dist/node_modules/@npmcli/agent/lib/proxy.js +88 -0
- package/dist/node_modules/@npmcli/agent/package.json +60 -0
- package/dist/node_modules/@npmcli/fs/lib/common/get-options.js +20 -0
- package/dist/node_modules/@npmcli/fs/lib/common/node.js +9 -0
- package/dist/node_modules/@npmcli/fs/lib/cp/LICENSE +15 -0
- package/dist/node_modules/@npmcli/fs/lib/cp/errors.js +129 -0
- package/dist/node_modules/@npmcli/fs/lib/cp/index.js +22 -0
- package/dist/node_modules/@npmcli/fs/lib/cp/polyfill.js +428 -0
- package/dist/node_modules/@npmcli/fs/lib/index.js +13 -0
- package/dist/node_modules/@npmcli/fs/lib/move-file.js +78 -0
- package/dist/node_modules/@npmcli/fs/lib/readdir-scoped.js +20 -0
- package/dist/node_modules/@npmcli/fs/lib/with-temp-dir.js +39 -0
- package/dist/node_modules/@npmcli/fs/package.json +54 -0
- package/dist/node_modules/@npmcli/redact/LICENSE +21 -0
- package/dist/node_modules/@npmcli/redact/lib/deep-map.js +71 -0
- package/dist/node_modules/@npmcli/redact/lib/error.js +28 -0
- package/dist/node_modules/@npmcli/redact/lib/index.js +44 -0
- package/dist/node_modules/@npmcli/redact/lib/matchers.js +88 -0
- package/dist/node_modules/@npmcli/redact/lib/server.js +59 -0
- package/dist/node_modules/@npmcli/redact/lib/utils.js +202 -0
- package/dist/node_modules/@npmcli/redact/package.json +52 -0
- package/dist/node_modules/abbrev/LICENSE +46 -0
- package/dist/node_modules/abbrev/lib/index.js +53 -0
- package/dist/node_modules/abbrev/package.json +41 -0
- package/dist/node_modules/agent-base/LICENSE +22 -0
- package/dist/node_modules/agent-base/dist/helpers.js +66 -0
- package/dist/node_modules/agent-base/dist/index.js +178 -0
- package/dist/node_modules/agent-base/package.json +46 -0
- package/dist/node_modules/balanced-match/dist/commonjs/index.js +59 -0
- package/dist/node_modules/balanced-match/dist/commonjs/package.json +3 -0
- package/dist/node_modules/balanced-match/dist/esm/index.js +54 -0
- package/dist/node_modules/balanced-match/dist/esm/package.json +3 -0
- package/dist/node_modules/balanced-match/package.json +68 -0
- package/dist/node_modules/brace-expansion/LICENSE +23 -0
- package/dist/node_modules/brace-expansion/dist/commonjs/index.js +201 -0
- package/dist/node_modules/brace-expansion/dist/commonjs/package.json +3 -0
- package/dist/node_modules/brace-expansion/dist/esm/index.js +197 -0
- package/dist/node_modules/brace-expansion/dist/esm/package.json +3 -0
- package/dist/node_modules/brace-expansion/package.json +64 -0
- package/dist/node_modules/cacache/lib/content/path.js +29 -0
- package/dist/node_modules/cacache/lib/content/read.js +165 -0
- package/dist/node_modules/cacache/lib/content/rm.js +18 -0
- package/dist/node_modules/cacache/lib/content/write.js +206 -0
- package/dist/node_modules/cacache/lib/entry-index.js +336 -0
- package/dist/node_modules/cacache/lib/get.js +170 -0
- package/dist/node_modules/cacache/lib/index.js +42 -0
- package/dist/node_modules/cacache/lib/memoization.js +72 -0
- package/dist/node_modules/cacache/lib/put.js +80 -0
- package/dist/node_modules/cacache/lib/rm.js +31 -0
- package/dist/node_modules/cacache/lib/util/glob.js +7 -0
- package/dist/node_modules/cacache/lib/util/hash-to-segments.js +7 -0
- package/dist/node_modules/cacache/lib/util/tmp.js +32 -0
- package/dist/node_modules/cacache/lib/verify.js +258 -0
- package/dist/node_modules/cacache/package.json +81 -0
- package/dist/node_modules/chownr/dist/commonjs/index.js +93 -0
- package/dist/node_modules/chownr/dist/commonjs/package.json +3 -0
- package/dist/node_modules/chownr/dist/esm/index.js +85 -0
- package/dist/node_modules/chownr/dist/esm/package.json +3 -0
- package/dist/node_modules/chownr/package.json +69 -0
- package/dist/node_modules/debug/LICENSE +20 -0
- package/dist/node_modules/debug/package.json +64 -0
- package/dist/node_modules/debug/src/browser.js +272 -0
- package/dist/node_modules/debug/src/common.js +292 -0
- package/dist/node_modules/debug/src/index.js +10 -0
- package/dist/node_modules/debug/src/node.js +263 -0
- package/dist/node_modules/env-paths/index.js +74 -0
- package/dist/node_modules/env-paths/license +9 -0
- package/dist/node_modules/env-paths/package.json +45 -0
- package/dist/node_modules/exponential-backoff/LICENSE +202 -0
- package/dist/node_modules/exponential-backoff/dist/backoff.js +124 -0
- package/dist/node_modules/exponential-backoff/dist/delay/always/always.delay.js +25 -0
- package/dist/node_modules/exponential-backoff/dist/delay/delay.base.js +45 -0
- package/dist/node_modules/exponential-backoff/dist/delay/delay.factory.js +17 -0
- package/dist/node_modules/exponential-backoff/dist/delay/delay.interface.js +3 -0
- package/dist/node_modules/exponential-backoff/dist/delay/skip-first/skip-first.delay.js +82 -0
- package/dist/node_modules/exponential-backoff/dist/jitter/full/full.jitter.js +8 -0
- package/dist/node_modules/exponential-backoff/dist/jitter/jitter.factory.js +15 -0
- package/dist/node_modules/exponential-backoff/dist/jitter/no/no.jitter.js +7 -0
- package/dist/node_modules/exponential-backoff/dist/options.js +31 -0
- package/dist/node_modules/exponential-backoff/package.json +62 -0
- package/dist/node_modules/fdir/LICENSE +7 -0
- package/dist/node_modules/fdir/dist/index.cjs +588 -0
- package/dist/node_modules/fdir/dist/index.d.cts +155 -0
- package/dist/node_modules/fdir/dist/index.d.mts +155 -0
- package/dist/node_modules/fdir/dist/index.mjs +570 -0
- package/dist/node_modules/fdir/package.json +103 -0
- package/dist/node_modules/fs-minipass/LICENSE +15 -0
- package/dist/node_modules/fs-minipass/lib/index.js +443 -0
- package/dist/node_modules/fs-minipass/package.json +54 -0
- package/dist/node_modules/glob/dist/commonjs/glob.js +248 -0
- package/dist/node_modules/glob/dist/commonjs/has-magic.js +27 -0
- package/dist/node_modules/glob/dist/commonjs/ignore.js +119 -0
- package/dist/node_modules/glob/dist/commonjs/index.js +68 -0
- package/dist/node_modules/glob/dist/commonjs/index.min.js +4 -0
- package/dist/node_modules/glob/dist/commonjs/package.json +3 -0
- package/dist/node_modules/glob/dist/commonjs/pattern.js +223 -0
- package/dist/node_modules/glob/dist/commonjs/processor.js +301 -0
- package/dist/node_modules/glob/dist/commonjs/walker.js +387 -0
- package/dist/node_modules/glob/dist/esm/glob.js +244 -0
- package/dist/node_modules/glob/dist/esm/has-magic.js +23 -0
- package/dist/node_modules/glob/dist/esm/ignore.js +115 -0
- package/dist/node_modules/glob/dist/esm/index.js +55 -0
- package/dist/node_modules/glob/dist/esm/index.min.js +4 -0
- package/dist/node_modules/glob/dist/esm/package.json +3 -0
- package/dist/node_modules/glob/dist/esm/pattern.js +219 -0
- package/dist/node_modules/glob/dist/esm/processor.js +294 -0
- package/dist/node_modules/glob/dist/esm/walker.js +381 -0
- package/dist/node_modules/glob/package.json +98 -0
- package/dist/node_modules/graceful-fs/LICENSE +15 -0
- package/dist/node_modules/graceful-fs/clone.js +23 -0
- package/dist/node_modules/graceful-fs/graceful-fs.js +448 -0
- package/dist/node_modules/graceful-fs/legacy-streams.js +118 -0
- package/dist/node_modules/graceful-fs/package.json +53 -0
- package/dist/node_modules/graceful-fs/polyfills.js +355 -0
- package/dist/node_modules/http-cache-semantics/LICENSE +9 -0
- package/dist/node_modules/http-cache-semantics/index.js +928 -0
- package/dist/node_modules/http-cache-semantics/package.json +22 -0
- package/dist/node_modules/http-proxy-agent/LICENSE +22 -0
- package/dist/node_modules/http-proxy-agent/dist/index.js +148 -0
- package/dist/node_modules/http-proxy-agent/package.json +47 -0
- package/dist/node_modules/https-proxy-agent/LICENSE +22 -0
- package/dist/node_modules/https-proxy-agent/dist/index.js +180 -0
- package/dist/node_modules/https-proxy-agent/dist/parse-proxy-response.js +101 -0
- package/dist/node_modules/https-proxy-agent/package.json +50 -0
- package/dist/node_modules/iconv-lite/LICENSE +21 -0
- package/dist/node_modules/iconv-lite/encodings/dbcs-codec.js +532 -0
- package/dist/node_modules/iconv-lite/encodings/dbcs-data.js +185 -0
- package/dist/node_modules/iconv-lite/encodings/index.js +23 -0
- package/dist/node_modules/iconv-lite/encodings/internal.js +218 -0
- package/dist/node_modules/iconv-lite/encodings/sbcs-codec.js +75 -0
- package/dist/node_modules/iconv-lite/encodings/sbcs-data-generated.js +451 -0
- package/dist/node_modules/iconv-lite/encodings/sbcs-data.js +178 -0
- package/dist/node_modules/iconv-lite/encodings/tables/big5-added.json +122 -0
- package/dist/node_modules/iconv-lite/encodings/tables/cp936.json +264 -0
- package/dist/node_modules/iconv-lite/encodings/tables/cp949.json +273 -0
- package/dist/node_modules/iconv-lite/encodings/tables/cp950.json +177 -0
- package/dist/node_modules/iconv-lite/encodings/tables/eucjp.json +182 -0
- package/dist/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json +1 -0
- package/dist/node_modules/iconv-lite/encodings/tables/gbk-added.json +56 -0
- package/dist/node_modules/iconv-lite/encodings/tables/shiftjis.json +125 -0
- package/dist/node_modules/iconv-lite/encodings/utf16.js +187 -0
- package/dist/node_modules/iconv-lite/encodings/utf32.js +307 -0
- package/dist/node_modules/iconv-lite/encodings/utf7.js +283 -0
- package/dist/node_modules/iconv-lite/lib/bom-handling.js +48 -0
- package/dist/node_modules/iconv-lite/lib/helpers/merge-exports.js +13 -0
- package/dist/node_modules/iconv-lite/lib/index.js +182 -0
- package/dist/node_modules/iconv-lite/lib/streams.js +105 -0
- package/dist/node_modules/iconv-lite/package.json +70 -0
- package/dist/node_modules/ip-address/LICENSE +19 -0
- package/dist/node_modules/ip-address/dist/address-error.js +12 -0
- package/dist/node_modules/ip-address/dist/common.js +46 -0
- package/dist/node_modules/ip-address/dist/ip-address.js +35 -0
- package/dist/node_modules/ip-address/dist/ipv4.js +360 -0
- package/dist/node_modules/ip-address/dist/ipv6.js +1003 -0
- package/dist/node_modules/ip-address/dist/v4/constants.js +8 -0
- package/dist/node_modules/ip-address/dist/v6/constants.js +76 -0
- package/dist/node_modules/ip-address/dist/v6/helpers.js +45 -0
- package/dist/node_modules/ip-address/dist/v6/regular-expressions.js +95 -0
- package/dist/node_modules/ip-address/package.json +78 -0
- package/dist/node_modules/isexe/dist/commonjs/index.js +56 -0
- package/dist/node_modules/isexe/dist/commonjs/index.min.js +2 -0
- package/dist/node_modules/isexe/dist/commonjs/options.js +3 -0
- package/dist/node_modules/isexe/dist/commonjs/package.json +3 -0
- package/dist/node_modules/isexe/dist/commonjs/posix.js +67 -0
- package/dist/node_modules/isexe/dist/commonjs/win32.js +63 -0
- package/dist/node_modules/isexe/dist/esm/index.js +16 -0
- package/dist/node_modules/isexe/dist/esm/index.min.js +2 -0
- package/dist/node_modules/isexe/dist/esm/options.js +2 -0
- package/dist/node_modules/isexe/dist/esm/package.json +3 -0
- package/dist/node_modules/isexe/dist/esm/posix.js +62 -0
- package/dist/node_modules/isexe/dist/esm/win32.js +58 -0
- package/dist/node_modules/isexe/package.json +78 -0
- package/dist/node_modules/lru-cache/dist/commonjs/index.js +1595 -0
- package/dist/node_modules/lru-cache/dist/commonjs/index.min.js +2 -0
- package/dist/node_modules/lru-cache/dist/commonjs/package.json +3 -0
- package/dist/node_modules/lru-cache/dist/esm/index.js +1591 -0
- package/dist/node_modules/lru-cache/dist/esm/index.min.js +2 -0
- package/dist/node_modules/lru-cache/dist/esm/package.json +3 -0
- package/dist/node_modules/lru-cache/package.json +93 -0
- package/dist/node_modules/make-fetch-happen/LICENSE +16 -0
- package/dist/node_modules/make-fetch-happen/lib/cache/entry.js +471 -0
- package/dist/node_modules/make-fetch-happen/lib/cache/errors.js +11 -0
- package/dist/node_modules/make-fetch-happen/lib/cache/index.js +49 -0
- package/dist/node_modules/make-fetch-happen/lib/cache/key.js +17 -0
- package/dist/node_modules/make-fetch-happen/lib/cache/policy.js +161 -0
- package/dist/node_modules/make-fetch-happen/lib/fetch.js +118 -0
- package/dist/node_modules/make-fetch-happen/lib/index.js +41 -0
- package/dist/node_modules/make-fetch-happen/lib/options.js +59 -0
- package/dist/node_modules/make-fetch-happen/lib/pipeline.js +41 -0
- package/dist/node_modules/make-fetch-happen/lib/remote.js +134 -0
- package/dist/node_modules/make-fetch-happen/package.json +75 -0
- package/dist/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +14 -0
- package/dist/node_modules/minimatch/dist/commonjs/ast.js +846 -0
- package/dist/node_modules/minimatch/dist/commonjs/brace-expressions.js +150 -0
- package/dist/node_modules/minimatch/dist/commonjs/escape.js +30 -0
- package/dist/node_modules/minimatch/dist/commonjs/index.js +1121 -0
- package/dist/node_modules/minimatch/dist/commonjs/package.json +3 -0
- package/dist/node_modules/minimatch/dist/commonjs/unescape.js +38 -0
- package/dist/node_modules/minimatch/dist/esm/assert-valid-pattern.js +10 -0
- package/dist/node_modules/minimatch/dist/esm/ast.js +842 -0
- package/dist/node_modules/minimatch/dist/esm/brace-expressions.js +146 -0
- package/dist/node_modules/minimatch/dist/esm/escape.js +26 -0
- package/dist/node_modules/minimatch/dist/esm/index.js +1108 -0
- package/dist/node_modules/minimatch/dist/esm/package.json +3 -0
- package/dist/node_modules/minimatch/dist/esm/unescape.js +34 -0
- package/dist/node_modules/minimatch/package.json +67 -0
- package/dist/node_modules/minipass/dist/commonjs/index.js +1038 -0
- package/dist/node_modules/minipass/dist/commonjs/package.json +3 -0
- package/dist/node_modules/minipass/dist/esm/index.js +1020 -0
- package/dist/node_modules/minipass/dist/esm/package.json +3 -0
- package/dist/node_modules/minipass/package.json +77 -0
- package/dist/node_modules/minipass-collect/LICENSE +15 -0
- package/dist/node_modules/minipass-collect/index.js +71 -0
- package/dist/node_modules/minipass-collect/package.json +30 -0
- package/dist/node_modules/minipass-fetch/LICENSE +28 -0
- package/dist/node_modules/minipass-fetch/lib/abort-error.js +17 -0
- package/dist/node_modules/minipass-fetch/lib/blob.js +97 -0
- package/dist/node_modules/minipass-fetch/lib/body.js +360 -0
- package/dist/node_modules/minipass-fetch/lib/fetch-error.js +32 -0
- package/dist/node_modules/minipass-fetch/lib/headers.js +267 -0
- package/dist/node_modules/minipass-fetch/lib/index.js +376 -0
- package/dist/node_modules/minipass-fetch/lib/request.js +282 -0
- package/dist/node_modules/minipass-fetch/lib/response.js +90 -0
- package/dist/node_modules/minipass-fetch/package.json +70 -0
- package/dist/node_modules/minipass-flush/LICENSE +15 -0
- package/dist/node_modules/minipass-flush/index.js +39 -0
- package/dist/node_modules/minipass-flush/node_modules/minipass/LICENSE +15 -0
- package/dist/node_modules/minipass-flush/node_modules/minipass/index.js +649 -0
- package/dist/node_modules/minipass-flush/node_modules/minipass/package.json +56 -0
- package/dist/node_modules/minipass-flush/package.json +39 -0
- package/dist/node_modules/minipass-pipeline/LICENSE +15 -0
- package/dist/node_modules/minipass-pipeline/index.js +128 -0
- package/dist/node_modules/minipass-pipeline/node_modules/minipass/LICENSE +15 -0
- package/dist/node_modules/minipass-pipeline/node_modules/minipass/index.js +649 -0
- package/dist/node_modules/minipass-pipeline/node_modules/minipass/package.json +56 -0
- package/dist/node_modules/minipass-pipeline/package.json +29 -0
- package/dist/node_modules/minipass-sized/LICENSE +15 -0
- package/dist/node_modules/minipass-sized/dist/commonjs/index.js +69 -0
- package/dist/node_modules/minipass-sized/dist/commonjs/package.json +3 -0
- package/dist/node_modules/minipass-sized/dist/esm/index.js +64 -0
- package/dist/node_modules/minipass-sized/dist/esm/package.json +3 -0
- package/dist/node_modules/minipass-sized/package.json +69 -0
- package/dist/node_modules/minizlib/LICENSE +26 -0
- package/dist/node_modules/minizlib/dist/commonjs/constants.js +123 -0
- package/dist/node_modules/minizlib/dist/commonjs/index.js +416 -0
- package/dist/node_modules/minizlib/dist/commonjs/package.json +3 -0
- package/dist/node_modules/minizlib/dist/esm/constants.js +117 -0
- package/dist/node_modules/minizlib/dist/esm/index.js +363 -0
- package/dist/node_modules/minizlib/dist/esm/package.json +3 -0
- package/dist/node_modules/minizlib/package.json +80 -0
- package/dist/node_modules/ms/index.js +162 -0
- package/dist/node_modules/ms/package.json +38 -0
- package/dist/node_modules/negotiator/LICENSE +24 -0
- package/dist/node_modules/negotiator/index.js +83 -0
- package/dist/node_modules/negotiator/lib/charset.js +169 -0
- package/dist/node_modules/negotiator/lib/encoding.js +205 -0
- package/dist/node_modules/negotiator/lib/language.js +179 -0
- package/dist/node_modules/negotiator/lib/mediaType.js +294 -0
- package/dist/node_modules/negotiator/package.json +43 -0
- package/dist/node_modules/node-gyp/.release-please-manifest.json +3 -0
- package/dist/node_modules/node-gyp/LICENSE +24 -0
- package/dist/node_modules/node-gyp/addon.gypi +204 -0
- package/dist/node_modules/node-gyp/bin/node-gyp.js +145 -0
- package/dist/node_modules/node-gyp/eslint.config.js +3 -0
- package/dist/node_modules/node-gyp/gyp/.release-please-manifest.json +3 -0
- package/dist/node_modules/node-gyp/gyp/LICENSE +28 -0
- package/dist/node_modules/node-gyp/gyp/data/ninja/build.ninja +4 -0
- package/dist/node_modules/node-gyp/gyp/data/win/large-pdb-shim.cc +12 -0
- package/dist/node_modules/node-gyp/gyp/gyp +8 -0
- package/dist/node_modules/node-gyp/gyp/gyp.bat +5 -0
- package/dist/node_modules/node-gyp/gyp/gyp_main.py +45 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSNew.py +365 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSProject.py +206 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings.py +1283 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSSettings_test.py +1545 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSToolFile.py +59 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSUserFile.py +152 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSUtil.py +270 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSVersion.py +599 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/__init__.py +707 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/common.py +725 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/common_test.py +186 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/easy_xml.py +170 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/easy_xml_test.py +113 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/flock_tool.py +55 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/__init__.py +0 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/analyzer.py +805 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/android.py +1169 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/cmake.py +1316 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/compile_commands_json.py +128 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/dump_dependency_json.py +104 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/eclipse.py +461 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/gypd.py +88 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/gypsh.py +55 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/make.py +2755 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs.py +3970 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs_test.py +44 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja.py +2956 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja_test.py +67 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode.py +1389 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/xcode_test.py +26 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/input.py +3097 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/input_test.py +99 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/mac_tool.py +765 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/msvs_emulation.py +1255 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/ninja_syntax.py +174 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/simple_copy.py +61 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/win_tool.py +371 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/xcode_emulation.py +1936 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/xcode_emulation_test.py +54 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/xcode_ninja.py +301 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/xcodeproj_file.py +3180 -0
- package/dist/node_modules/node-gyp/gyp/pylib/gyp/xml_fix.py +64 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/LICENSE +3 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/LICENSE.APACHE +177 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/LICENSE.BSD +23 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/__init__.py +15 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/_elffile.py +107 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/_manylinux.py +252 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/_musllinux.py +83 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/_parser.py +359 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/_structures.py +61 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/_tokenizer.py +192 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/markers.py +251 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/metadata.py +824 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/py.typed +0 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/requirements.py +90 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/specifiers.py +1030 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/tags.py +553 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/utils.py +172 -0
- package/dist/node_modules/node-gyp/gyp/pylib/packaging/version.py +563 -0
- package/dist/node_modules/node-gyp/gyp/pyproject.toml +114 -0
- package/dist/node_modules/node-gyp/gyp/release-please-config.json +11 -0
- package/dist/node_modules/node-gyp/gyp/test_gyp.py +260 -0
- package/dist/node_modules/node-gyp/lib/Find-VisualStudio.cs +250 -0
- package/dist/node_modules/node-gyp/lib/build.js +230 -0
- package/dist/node_modules/node-gyp/lib/clean.js +15 -0
- package/dist/node_modules/node-gyp/lib/configure.js +328 -0
- package/dist/node_modules/node-gyp/lib/create-config-gypi.js +153 -0
- package/dist/node_modules/node-gyp/lib/download.js +39 -0
- package/dist/node_modules/node-gyp/lib/find-node-directory.js +63 -0
- package/dist/node_modules/node-gyp/lib/find-python.js +304 -0
- package/dist/node_modules/node-gyp/lib/find-visualstudio.js +606 -0
- package/dist/node_modules/node-gyp/lib/install.js +411 -0
- package/dist/node_modules/node-gyp/lib/list.js +26 -0
- package/dist/node_modules/node-gyp/lib/log.js +168 -0
- package/dist/node_modules/node-gyp/lib/node-gyp.js +199 -0
- package/dist/node_modules/node-gyp/lib/process-release.js +146 -0
- package/dist/node_modules/node-gyp/lib/rebuild.js +12 -0
- package/dist/node_modules/node-gyp/lib/remove.js +43 -0
- package/dist/node_modules/node-gyp/lib/util.js +81 -0
- package/dist/node_modules/node-gyp/macOS_Catalina_acid_test.sh +21 -0
- package/dist/node_modules/node-gyp/package.json +52 -0
- package/dist/node_modules/node-gyp/release-please-config.json +40 -0
- package/dist/node_modules/node-gyp/src/win_delay_load_hook.cc +41 -0
- package/dist/node_modules/nopt/LICENSE +15 -0
- package/dist/node_modules/nopt/bin/nopt.js +29 -0
- package/dist/node_modules/nopt/lib/debug.js +5 -0
- package/dist/node_modules/nopt/lib/nopt-lib.js +514 -0
- package/dist/node_modules/nopt/lib/nopt.js +34 -0
- package/dist/node_modules/nopt/lib/type-defs.js +91 -0
- package/dist/node_modules/nopt/package.json +52 -0
- package/dist/node_modules/p-map/index.js +283 -0
- package/dist/node_modules/p-map/license +9 -0
- package/dist/node_modules/p-map/package.json +57 -0
- package/dist/node_modules/path-scurry/dist/commonjs/index.js +2018 -0
- package/dist/node_modules/path-scurry/dist/commonjs/package.json +3 -0
- package/dist/node_modules/path-scurry/dist/esm/index.js +1983 -0
- package/dist/node_modules/path-scurry/dist/esm/package.json +3 -0
- package/dist/node_modules/path-scurry/package.json +72 -0
- package/dist/node_modules/picomatch/LICENSE +21 -0
- package/dist/node_modules/picomatch/index.js +17 -0
- package/dist/node_modules/picomatch/lib/constants.js +184 -0
- package/dist/node_modules/picomatch/lib/parse.js +1386 -0
- package/dist/node_modules/picomatch/lib/picomatch.js +349 -0
- package/dist/node_modules/picomatch/lib/scan.js +391 -0
- package/dist/node_modules/picomatch/lib/utils.js +72 -0
- package/dist/node_modules/picomatch/package.json +82 -0
- package/dist/node_modules/picomatch/posix.js +3 -0
- package/dist/node_modules/proc-log/LICENSE +15 -0
- package/dist/node_modules/proc-log/lib/index.js +158 -0
- package/dist/node_modules/proc-log/package.json +46 -0
- package/dist/node_modules/safer-buffer/LICENSE +21 -0
- package/dist/node_modules/safer-buffer/dangerous.js +58 -0
- package/dist/node_modules/safer-buffer/package.json +34 -0
- package/dist/node_modules/safer-buffer/safer.js +77 -0
- package/dist/node_modules/safer-buffer/tests.js +406 -0
- package/dist/node_modules/semver/LICENSE +15 -0
- package/dist/node_modules/semver/bin/semver.js +191 -0
- package/dist/node_modules/semver/classes/comparator.js +143 -0
- package/dist/node_modules/semver/classes/index.js +7 -0
- package/dist/node_modules/semver/classes/range.js +557 -0
- package/dist/node_modules/semver/classes/semver.js +333 -0
- package/dist/node_modules/semver/functions/clean.js +8 -0
- package/dist/node_modules/semver/functions/cmp.js +54 -0
- package/dist/node_modules/semver/functions/coerce.js +62 -0
- package/dist/node_modules/semver/functions/compare-build.js +9 -0
- package/dist/node_modules/semver/functions/compare-loose.js +5 -0
- package/dist/node_modules/semver/functions/compare.js +7 -0
- package/dist/node_modules/semver/functions/diff.js +60 -0
- package/dist/node_modules/semver/functions/eq.js +5 -0
- package/dist/node_modules/semver/functions/gt.js +5 -0
- package/dist/node_modules/semver/functions/gte.js +5 -0
- package/dist/node_modules/semver/functions/inc.js +21 -0
- package/dist/node_modules/semver/functions/lt.js +5 -0
- package/dist/node_modules/semver/functions/lte.js +5 -0
- package/dist/node_modules/semver/functions/major.js +5 -0
- package/dist/node_modules/semver/functions/minor.js +5 -0
- package/dist/node_modules/semver/functions/neq.js +5 -0
- package/dist/node_modules/semver/functions/parse.js +18 -0
- package/dist/node_modules/semver/functions/patch.js +5 -0
- package/dist/node_modules/semver/functions/prerelease.js +8 -0
- package/dist/node_modules/semver/functions/rcompare.js +5 -0
- package/dist/node_modules/semver/functions/rsort.js +5 -0
- package/dist/node_modules/semver/functions/satisfies.js +12 -0
- package/dist/node_modules/semver/functions/sort.js +5 -0
- package/dist/node_modules/semver/functions/valid.js +8 -0
- package/dist/node_modules/semver/index.js +91 -0
- package/dist/node_modules/semver/internal/constants.js +37 -0
- package/dist/node_modules/semver/internal/debug.js +11 -0
- package/dist/node_modules/semver/internal/identifiers.js +29 -0
- package/dist/node_modules/semver/internal/lrucache.js +42 -0
- package/dist/node_modules/semver/internal/parse-options.js +17 -0
- package/dist/node_modules/semver/internal/re.js +223 -0
- package/dist/node_modules/semver/package.json +78 -0
- package/dist/node_modules/semver/preload.js +4 -0
- package/dist/node_modules/semver/range.bnf +16 -0
- package/dist/node_modules/semver/ranges/gtr.js +6 -0
- package/dist/node_modules/semver/ranges/intersects.js +9 -0
- package/dist/node_modules/semver/ranges/ltr.js +6 -0
- package/dist/node_modules/semver/ranges/max-satisfying.js +27 -0
- package/dist/node_modules/semver/ranges/min-satisfying.js +26 -0
- package/dist/node_modules/semver/ranges/min-version.js +63 -0
- package/dist/node_modules/semver/ranges/outside.js +82 -0
- package/dist/node_modules/semver/ranges/simplify.js +49 -0
- package/dist/node_modules/semver/ranges/subset.js +249 -0
- package/dist/node_modules/semver/ranges/to-comparators.js +10 -0
- package/dist/node_modules/semver/ranges/valid.js +13 -0
- package/dist/node_modules/smart-buffer/.prettierrc.yaml +5 -0
- package/dist/node_modules/smart-buffer/LICENSE +20 -0
- package/dist/node_modules/smart-buffer/build/smartbuffer.js +1233 -0
- package/dist/node_modules/smart-buffer/build/utils.js +108 -0
- package/dist/node_modules/smart-buffer/package.json +79 -0
- package/dist/node_modules/socks/.eslintrc.cjs +11 -0
- package/dist/node_modules/socks/.prettierrc.yaml +7 -0
- package/dist/node_modules/socks/LICENSE +20 -0
- package/dist/node_modules/socks/build/client/socksclient.js +793 -0
- package/dist/node_modules/socks/build/common/constants.js +108 -0
- package/dist/node_modules/socks/build/common/helpers.js +167 -0
- package/dist/node_modules/socks/build/common/receivebuffer.js +43 -0
- package/dist/node_modules/socks/build/common/util.js +25 -0
- package/dist/node_modules/socks/build/index.js +18 -0
- package/dist/node_modules/socks/package.json +58 -0
- package/dist/node_modules/socks-proxy-agent/LICENSE +22 -0
- package/dist/node_modules/socks-proxy-agent/dist/index.js +195 -0
- package/dist/node_modules/socks-proxy-agent/package.json +142 -0
- package/dist/node_modules/ssri/lib/index.js +550 -0
- package/dist/node_modules/ssri/package.json +66 -0
- package/dist/node_modules/tar/dist/commonjs/create.js +82 -0
- package/dist/node_modules/tar/dist/commonjs/cwd-error.js +18 -0
- package/dist/node_modules/tar/dist/commonjs/extract.js +88 -0
- package/dist/node_modules/tar/dist/commonjs/get-write-flag.js +32 -0
- package/dist/node_modules/tar/dist/commonjs/header.js +312 -0
- package/dist/node_modules/tar/dist/commonjs/index.js +64 -0
- package/dist/node_modules/tar/dist/commonjs/index.min.js +4 -0
- package/dist/node_modules/tar/dist/commonjs/large-numbers.js +99 -0
- package/dist/node_modules/tar/dist/commonjs/list.js +145 -0
- package/dist/node_modules/tar/dist/commonjs/make-command.js +52 -0
- package/dist/node_modules/tar/dist/commonjs/mkdir.js +187 -0
- package/dist/node_modules/tar/dist/commonjs/mode-fix.js +29 -0
- package/dist/node_modules/tar/dist/commonjs/normalize-unicode.js +38 -0
- package/dist/node_modules/tar/dist/commonjs/normalize-windows-path.js +12 -0
- package/dist/node_modules/tar/dist/commonjs/options.js +66 -0
- package/dist/node_modules/tar/dist/commonjs/pack.js +511 -0
- package/dist/node_modules/tar/dist/commonjs/package.json +3 -0
- package/dist/node_modules/tar/dist/commonjs/parse.js +610 -0
- package/dist/node_modules/tar/dist/commonjs/path-reservations.js +170 -0
- package/dist/node_modules/tar/dist/commonjs/pax.js +158 -0
- package/dist/node_modules/tar/dist/commonjs/process-umask.js +7 -0
- package/dist/node_modules/tar/dist/commonjs/read-entry.js +136 -0
- package/dist/node_modules/tar/dist/commonjs/replace.js +227 -0
- package/dist/node_modules/tar/dist/commonjs/strip-absolute-path.js +29 -0
- package/dist/node_modules/tar/dist/commonjs/strip-trailing-slashes.js +18 -0
- package/dist/node_modules/tar/dist/commonjs/symlink-error.js +19 -0
- package/dist/node_modules/tar/dist/commonjs/types.js +50 -0
- package/dist/node_modules/tar/dist/commonjs/unpack.js +932 -0
- package/dist/node_modules/tar/dist/commonjs/update.js +33 -0
- package/dist/node_modules/tar/dist/commonjs/warn-method.js +31 -0
- package/dist/node_modules/tar/dist/commonjs/winchars.js +14 -0
- package/dist/node_modules/tar/dist/commonjs/write-entry.js +698 -0
- package/dist/node_modules/tar/dist/esm/create.js +76 -0
- package/dist/node_modules/tar/dist/esm/cwd-error.js +14 -0
- package/dist/node_modules/tar/dist/esm/extract.js +49 -0
- package/dist/node_modules/tar/dist/esm/get-write-flag.js +26 -0
- package/dist/node_modules/tar/dist/esm/header.js +275 -0
- package/dist/node_modules/tar/dist/esm/index.js +20 -0
- package/dist/node_modules/tar/dist/esm/index.min.js +4 -0
- package/dist/node_modules/tar/dist/esm/large-numbers.js +94 -0
- package/dist/node_modules/tar/dist/esm/list.js +105 -0
- package/dist/node_modules/tar/dist/esm/make-command.js +48 -0
- package/dist/node_modules/tar/dist/esm/mkdir.js +179 -0
- package/dist/node_modules/tar/dist/esm/mode-fix.js +25 -0
- package/dist/node_modules/tar/dist/esm/normalize-unicode.js +34 -0
- package/dist/node_modules/tar/dist/esm/normalize-windows-path.js +9 -0
- package/dist/node_modules/tar/dist/esm/options.js +54 -0
- package/dist/node_modules/tar/dist/esm/pack.js +469 -0
- package/dist/node_modules/tar/dist/esm/package.json +3 -0
- package/dist/node_modules/tar/dist/esm/parse.js +606 -0
- package/dist/node_modules/tar/dist/esm/path-reservations.js +166 -0
- package/dist/node_modules/tar/dist/esm/pax.js +154 -0
- package/dist/node_modules/tar/dist/esm/process-umask.js +3 -0
- package/dist/node_modules/tar/dist/esm/read-entry.js +132 -0
- package/dist/node_modules/tar/dist/esm/replace.js +221 -0
- package/dist/node_modules/tar/dist/esm/strip-absolute-path.js +25 -0
- package/dist/node_modules/tar/dist/esm/strip-trailing-slashes.js +14 -0
- package/dist/node_modules/tar/dist/esm/symlink-error.js +15 -0
- package/dist/node_modules/tar/dist/esm/types.js +45 -0
- package/dist/node_modules/tar/dist/esm/unpack.js +891 -0
- package/dist/node_modules/tar/dist/esm/update.js +30 -0
- package/dist/node_modules/tar/dist/esm/warn-method.js +27 -0
- package/dist/node_modules/tar/dist/esm/winchars.js +9 -0
- package/dist/node_modules/tar/dist/esm/write-entry.js +656 -0
- package/dist/node_modules/tar/node_modules/yallist/dist/commonjs/index.js +384 -0
- package/dist/node_modules/tar/node_modules/yallist/dist/commonjs/package.json +3 -0
- package/dist/node_modules/tar/node_modules/yallist/dist/esm/index.js +379 -0
- package/dist/node_modules/tar/node_modules/yallist/dist/esm/package.json +3 -0
- package/dist/node_modules/tar/node_modules/yallist/package.json +68 -0
- package/dist/node_modules/tar/package.json +297 -0
- package/dist/node_modules/tinyglobby/LICENSE +21 -0
- package/dist/node_modules/tinyglobby/dist/index.cjs +350 -0
- package/dist/node_modules/tinyglobby/dist/index.d.cts +147 -0
- package/dist/node_modules/tinyglobby/dist/index.d.mts +147 -0
- package/dist/node_modules/tinyglobby/dist/index.mjs +318 -0
- package/dist/node_modules/tinyglobby/package.json +73 -0
- package/{LICENSE → dist/node_modules/v8-compile-cache/LICENSE} +1 -2
- package/dist/node_modules/v8-compile-cache/package.json +34 -0
- package/dist/node_modules/v8-compile-cache/v8-compile-cache.js +373 -0
- package/dist/node_modules/which/LICENSE +15 -0
- package/dist/node_modules/which/bin/which.js +52 -0
- package/dist/node_modules/which/lib/index.js +111 -0
- package/dist/node_modules/which/package.json +52 -0
- package/dist/node_modules/yallist/LICENSE +15 -0
- package/dist/node_modules/yallist/iterator.js +8 -0
- package/dist/node_modules/yallist/package.json +29 -0
- package/dist/node_modules/yallist/yallist.js +426 -0
- package/dist/pnpm.mjs +266382 -0
- package/dist/pnpmrc +2 -0
- package/dist/templates/completion.bash +31 -0
- package/dist/templates/completion.fish +22 -0
- package/dist/templates/completion.ps1 +193 -0
- package/dist/templates/completion.zsh +27 -0
- package/dist/vendor/fastlist-0.3.0-x64.exe +0 -0
- package/dist/vendor/fastlist-0.3.0-x86.exe +0 -0
- package/dist/worker.js +10958 -0
- package/package.json +34 -12
- package/pn +2 -0
- package/pn.cmd +2 -0
- package/pn.ps1 +1 -0
- package/pnpx +2 -0
- package/pnpx.cmd +2 -0
- package/pnpx.ps1 +1 -0
- package/pnx +2 -0
- package/pnx.cmd +2 -0
- package/pnx.ps1 +1 -0
- package/prepare.js +26 -3
- package/setup.js +22 -11
- package/CHANGELOG.md +0 -15
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
const { NotCachedError } = require('./errors.js')
|
|
2
|
+
const CacheEntry = require('./entry.js')
|
|
3
|
+
const remote = require('../remote.js')
|
|
4
|
+
|
|
5
|
+
// do whatever is necessary to get a Response and return it
|
|
6
|
+
const cacheFetch = async (request, options) => {
|
|
7
|
+
// try to find a cached entry that satisfies this request
|
|
8
|
+
const entry = await CacheEntry.find(request, options)
|
|
9
|
+
if (!entry) {
|
|
10
|
+
// no cached result, if the cache mode is 'only-if-cached' that's a failure
|
|
11
|
+
if (options.cache === 'only-if-cached') {
|
|
12
|
+
throw new NotCachedError(request.url)
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
// otherwise, we make a request, store it and return it
|
|
16
|
+
const response = await remote(request, options)
|
|
17
|
+
const newEntry = new CacheEntry({ request, response, options })
|
|
18
|
+
return newEntry.store('miss')
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
// we have a cached response that satisfies this request, however if the cache
|
|
22
|
+
// mode is 'no-cache' then we send the revalidation request no matter what
|
|
23
|
+
if (options.cache === 'no-cache') {
|
|
24
|
+
return entry.revalidate(request, options)
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// if the cached entry is not stale, or if the cache mode is 'force-cache' or
|
|
28
|
+
// 'only-if-cached' we can respond with the cached entry. set the status
|
|
29
|
+
// based on the result of needsRevalidation and respond
|
|
30
|
+
const _needsRevalidation = entry.policy.needsRevalidation(request)
|
|
31
|
+
if (options.cache === 'force-cache' ||
|
|
32
|
+
options.cache === 'only-if-cached' ||
|
|
33
|
+
!_needsRevalidation) {
|
|
34
|
+
return entry.respond(request.method, options, _needsRevalidation ? 'stale' : 'hit')
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
// if we got here, the cache entry is stale so revalidate it
|
|
38
|
+
return entry.revalidate(request, options)
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
cacheFetch.invalidate = async (request, options) => {
|
|
42
|
+
if (!options.cachePath) {
|
|
43
|
+
return
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
return CacheEntry.invalidate(request, options)
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
module.exports = cacheFetch
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
const { URL, format } = require('url')
|
|
2
|
+
|
|
3
|
+
// options passed to url.format() when generating a key
|
|
4
|
+
const formatOptions = {
|
|
5
|
+
auth: false,
|
|
6
|
+
fragment: false,
|
|
7
|
+
search: true,
|
|
8
|
+
unicode: false,
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
// returns a string to be used as the cache key for the Request
|
|
12
|
+
const cacheKey = (request) => {
|
|
13
|
+
const parsed = new URL(request.url)
|
|
14
|
+
return `make-fetch-happen:request-cache:${format(parsed, formatOptions)}`
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
module.exports = cacheKey
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
const CacheSemantics = require('http-cache-semantics')
|
|
2
|
+
const Negotiator = require('negotiator')
|
|
3
|
+
const ssri = require('ssri')
|
|
4
|
+
|
|
5
|
+
// options passed to http-cache-semantics constructor
|
|
6
|
+
const policyOptions = {
|
|
7
|
+
shared: false,
|
|
8
|
+
ignoreCargoCult: true,
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
// a fake empty response, used when only testing the
|
|
12
|
+
// request for storability
|
|
13
|
+
const emptyResponse = { status: 200, headers: {} }
|
|
14
|
+
|
|
15
|
+
// returns a plain object representation of the Request
|
|
16
|
+
const requestObject = (request) => {
|
|
17
|
+
const _obj = {
|
|
18
|
+
method: request.method,
|
|
19
|
+
url: request.url,
|
|
20
|
+
headers: {},
|
|
21
|
+
compress: request.compress,
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
request.headers.forEach((value, key) => {
|
|
25
|
+
_obj.headers[key] = value
|
|
26
|
+
})
|
|
27
|
+
|
|
28
|
+
return _obj
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
// returns a plain object representation of the Response
|
|
32
|
+
const responseObject = (response) => {
|
|
33
|
+
const _obj = {
|
|
34
|
+
status: response.status,
|
|
35
|
+
headers: {},
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
response.headers.forEach((value, key) => {
|
|
39
|
+
_obj.headers[key] = value
|
|
40
|
+
})
|
|
41
|
+
|
|
42
|
+
return _obj
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
class CachePolicy {
|
|
46
|
+
constructor ({ entry, request, response, options }) {
|
|
47
|
+
this.entry = entry
|
|
48
|
+
this.request = requestObject(request)
|
|
49
|
+
this.response = responseObject(response)
|
|
50
|
+
this.options = options
|
|
51
|
+
this.policy = new CacheSemantics(this.request, this.response, policyOptions)
|
|
52
|
+
|
|
53
|
+
if (this.entry) {
|
|
54
|
+
// if we have an entry, copy the timestamp to the _responseTime
|
|
55
|
+
// this is necessary because the CacheSemantics constructor forces
|
|
56
|
+
// the value to Date.now() which means a policy created from a
|
|
57
|
+
// cache entry is likely to always identify itself as stale
|
|
58
|
+
this.policy._responseTime = this.entry.metadata.time
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// static method to quickly determine if a request alone is storable
|
|
63
|
+
static storable (request, options) {
|
|
64
|
+
// no cachePath means no caching
|
|
65
|
+
if (!options.cachePath) {
|
|
66
|
+
return false
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// user explicitly asked not to cache
|
|
70
|
+
if (options.cache === 'no-store') {
|
|
71
|
+
return false
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
// we only cache GET and HEAD requests
|
|
75
|
+
if (!['GET', 'HEAD'].includes(request.method)) {
|
|
76
|
+
return false
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// otherwise, let http-cache-semantics make the decision
|
|
80
|
+
// based on the request's headers
|
|
81
|
+
const policy = new CacheSemantics(requestObject(request), emptyResponse, policyOptions)
|
|
82
|
+
return policy.storable()
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// returns true if the policy satisfies the request
|
|
86
|
+
satisfies (request) {
|
|
87
|
+
const _req = requestObject(request)
|
|
88
|
+
if (this.request.headers.host !== _req.headers.host) {
|
|
89
|
+
return false
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
if (this.request.compress !== _req.compress) {
|
|
93
|
+
return false
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
const negotiatorA = new Negotiator(this.request)
|
|
97
|
+
const negotiatorB = new Negotiator(_req)
|
|
98
|
+
|
|
99
|
+
if (JSON.stringify(negotiatorA.mediaTypes()) !== JSON.stringify(negotiatorB.mediaTypes())) {
|
|
100
|
+
return false
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
if (JSON.stringify(negotiatorA.languages()) !== JSON.stringify(negotiatorB.languages())) {
|
|
104
|
+
return false
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
if (JSON.stringify(negotiatorA.encodings()) !== JSON.stringify(negotiatorB.encodings())) {
|
|
108
|
+
return false
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
if (this.options.integrity) {
|
|
112
|
+
return ssri.parse(this.options.integrity).match(this.entry.integrity)
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
return true
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
// returns true if the request and response allow caching
|
|
119
|
+
storable () {
|
|
120
|
+
return this.policy.storable()
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
// NOTE: this is a hack to avoid parsing the cache-control
|
|
124
|
+
// header ourselves, it returns true if the response's
|
|
125
|
+
// cache-control contains must-revalidate
|
|
126
|
+
get mustRevalidate () {
|
|
127
|
+
return !!this.policy._rescc['must-revalidate']
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
// returns true if the cached response requires revalidation
|
|
131
|
+
// for the given request
|
|
132
|
+
needsRevalidation (request) {
|
|
133
|
+
const _req = requestObject(request)
|
|
134
|
+
// force method to GET because we only cache GETs
|
|
135
|
+
// but can serve a HEAD from a cached GET
|
|
136
|
+
_req.method = 'GET'
|
|
137
|
+
return !this.policy.satisfiesWithoutRevalidation(_req)
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
responseHeaders () {
|
|
141
|
+
return this.policy.responseHeaders()
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
// returns a new object containing the appropriate headers
|
|
145
|
+
// to send a revalidation request
|
|
146
|
+
revalidationHeaders (request) {
|
|
147
|
+
const _req = requestObject(request)
|
|
148
|
+
return this.policy.revalidationHeaders(_req)
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
// returns true if the request/response was revalidated
|
|
152
|
+
// successfully. returns false if a new response was received
|
|
153
|
+
revalidated (request, response) {
|
|
154
|
+
const _req = requestObject(request)
|
|
155
|
+
const _res = responseObject(response)
|
|
156
|
+
const policy = this.policy.revalidatedPolicy(_req, _res)
|
|
157
|
+
return !policy.modified
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
module.exports = CachePolicy
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
'use strict'
|
|
2
|
+
|
|
3
|
+
const { FetchError, Request, isRedirect } = require('minipass-fetch')
|
|
4
|
+
const url = require('url')
|
|
5
|
+
|
|
6
|
+
const CachePolicy = require('./cache/policy.js')
|
|
7
|
+
const cache = require('./cache/index.js')
|
|
8
|
+
const remote = require('./remote.js')
|
|
9
|
+
|
|
10
|
+
// given a Request, a Response and user options
|
|
11
|
+
// return true if the response is a redirect that
|
|
12
|
+
// can be followed. we throw errors that will result
|
|
13
|
+
// in the fetch being rejected if the redirect is
|
|
14
|
+
// possible but invalid for some reason
|
|
15
|
+
const canFollowRedirect = (request, response, options) => {
|
|
16
|
+
if (!isRedirect(response.status)) {
|
|
17
|
+
return false
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
if (options.redirect === 'manual') {
|
|
21
|
+
return false
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
if (options.redirect === 'error') {
|
|
25
|
+
throw new FetchError(`redirect mode is set to error: ${request.url}`,
|
|
26
|
+
'no-redirect', { code: 'ENOREDIRECT' })
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
if (!response.headers.has('location')) {
|
|
30
|
+
throw new FetchError(`redirect location header missing for: ${request.url}`,
|
|
31
|
+
'no-location', { code: 'EINVALIDREDIRECT' })
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
if (request.counter >= request.follow) {
|
|
35
|
+
throw new FetchError(`maximum redirect reached at: ${request.url}`,
|
|
36
|
+
'max-redirect', { code: 'EMAXREDIRECT' })
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
return true
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// given a Request, a Response, and the user's options return an object
|
|
43
|
+
// with a new Request and a new options object that will be used for
|
|
44
|
+
// following the redirect
|
|
45
|
+
const getRedirect = (request, response, options) => {
|
|
46
|
+
const _opts = { ...options }
|
|
47
|
+
const location = response.headers.get('location')
|
|
48
|
+
const redirectUrl = new url.URL(location, /^https?:/.test(location) ? undefined : request.url)
|
|
49
|
+
// Comment below is used under the following license:
|
|
50
|
+
/**
|
|
51
|
+
* @license
|
|
52
|
+
* Copyright (c) 2010-2012 Mikeal Rogers
|
|
53
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
54
|
+
* you may not use this file except in compliance with the License.
|
|
55
|
+
* You may obtain a copy of the License at
|
|
56
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
57
|
+
* Unless required by applicable law or agreed to in writing,
|
|
58
|
+
* software distributed under the License is distributed on an "AS
|
|
59
|
+
* IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
|
|
60
|
+
* express or implied. See the License for the specific language
|
|
61
|
+
* governing permissions and limitations under the License.
|
|
62
|
+
*/
|
|
63
|
+
|
|
64
|
+
// Remove authorization if changing hostnames (but not if just
|
|
65
|
+
// changing ports or protocols). This matches the behavior of request:
|
|
66
|
+
// https://github.com/request/request/blob/b12a6245/lib/redirect.js#L134-L138
|
|
67
|
+
if (new url.URL(request.url).hostname !== redirectUrl.hostname) {
|
|
68
|
+
request.headers.delete('authorization')
|
|
69
|
+
request.headers.delete('cookie')
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// for POST request with 301/302 response, or any request with 303 response,
|
|
73
|
+
// use GET when following redirect
|
|
74
|
+
if (
|
|
75
|
+
response.status === 303 ||
|
|
76
|
+
(request.method === 'POST' && [301, 302].includes(response.status))
|
|
77
|
+
) {
|
|
78
|
+
_opts.method = 'GET'
|
|
79
|
+
_opts.body = null
|
|
80
|
+
request.headers.delete('content-length')
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
_opts.headers = {}
|
|
84
|
+
request.headers.forEach((value, key) => {
|
|
85
|
+
_opts.headers[key] = value
|
|
86
|
+
})
|
|
87
|
+
|
|
88
|
+
_opts.counter = ++request.counter
|
|
89
|
+
const redirectReq = new Request(url.format(redirectUrl), _opts)
|
|
90
|
+
return {
|
|
91
|
+
request: redirectReq,
|
|
92
|
+
options: _opts,
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
const fetch = async (request, options) => {
|
|
97
|
+
const response = CachePolicy.storable(request, options)
|
|
98
|
+
? await cache(request, options)
|
|
99
|
+
: await remote(request, options)
|
|
100
|
+
|
|
101
|
+
// if the request wasn't a GET or HEAD, and the response
|
|
102
|
+
// status is between 200 and 399 inclusive, invalidate the
|
|
103
|
+
// request url
|
|
104
|
+
if (!['GET', 'HEAD'].includes(request.method) &&
|
|
105
|
+
response.status >= 200 &&
|
|
106
|
+
response.status <= 399) {
|
|
107
|
+
await cache.invalidate(request, options)
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
if (!canFollowRedirect(request, response, options)) {
|
|
111
|
+
return response
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
const redirect = getRedirect(request, response, options)
|
|
115
|
+
return fetch(redirect.request, redirect.options)
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
module.exports = fetch
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
const { FetchError, Headers, Request, Response } = require('minipass-fetch')
|
|
2
|
+
|
|
3
|
+
const configureOptions = require('./options.js')
|
|
4
|
+
const fetch = require('./fetch.js')
|
|
5
|
+
|
|
6
|
+
const makeFetchHappen = (url, opts) => {
|
|
7
|
+
const options = configureOptions(opts)
|
|
8
|
+
|
|
9
|
+
const request = new Request(url, options)
|
|
10
|
+
return fetch(request, options)
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
makeFetchHappen.defaults = (defaultUrl, defaultOptions = {}, wrappedFetch = makeFetchHappen) => {
|
|
14
|
+
if (typeof defaultUrl === 'object') {
|
|
15
|
+
defaultOptions = defaultUrl
|
|
16
|
+
defaultUrl = null
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
const defaultedFetch = (url, options = {}) => {
|
|
20
|
+
const finalUrl = url || defaultUrl
|
|
21
|
+
const finalOptions = {
|
|
22
|
+
...defaultOptions,
|
|
23
|
+
...options,
|
|
24
|
+
headers: {
|
|
25
|
+
...defaultOptions.headers,
|
|
26
|
+
...options.headers,
|
|
27
|
+
},
|
|
28
|
+
}
|
|
29
|
+
return wrappedFetch(finalUrl, finalOptions)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
defaultedFetch.defaults = (defaultUrl1, defaultOptions1 = {}) =>
|
|
33
|
+
makeFetchHappen.defaults(defaultUrl1, defaultOptions1, defaultedFetch)
|
|
34
|
+
return defaultedFetch
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
module.exports = makeFetchHappen
|
|
38
|
+
module.exports.FetchError = FetchError
|
|
39
|
+
module.exports.Headers = Headers
|
|
40
|
+
module.exports.Request = Request
|
|
41
|
+
module.exports.Response = Response
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
const dns = require('dns')
|
|
2
|
+
|
|
3
|
+
const conditionalHeaders = [
|
|
4
|
+
'if-modified-since',
|
|
5
|
+
'if-none-match',
|
|
6
|
+
'if-unmodified-since',
|
|
7
|
+
'if-match',
|
|
8
|
+
'if-range',
|
|
9
|
+
]
|
|
10
|
+
|
|
11
|
+
const configureOptions = (opts) => {
|
|
12
|
+
const { strictSSL, ...options } = { ...opts }
|
|
13
|
+
options.method = options.method ? options.method.toUpperCase() : 'GET'
|
|
14
|
+
|
|
15
|
+
if (strictSSL === undefined || strictSSL === null) {
|
|
16
|
+
options.rejectUnauthorized = process.env.NODE_TLS_REJECT_UNAUTHORIZED !== '0'
|
|
17
|
+
} else {
|
|
18
|
+
options.rejectUnauthorized = strictSSL !== false
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
if (!options.retry) {
|
|
22
|
+
options.retry = { retries: 0 }
|
|
23
|
+
} else if (typeof options.retry === 'string') {
|
|
24
|
+
const retries = parseInt(options.retry, 10)
|
|
25
|
+
if (isFinite(retries)) {
|
|
26
|
+
options.retry = { retries }
|
|
27
|
+
} else {
|
|
28
|
+
options.retry = { retries: 0 }
|
|
29
|
+
}
|
|
30
|
+
} else if (typeof options.retry === 'number') {
|
|
31
|
+
options.retry = { retries: options.retry }
|
|
32
|
+
} else {
|
|
33
|
+
options.retry = { retries: 0, ...options.retry }
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
options.dns = { ttl: 5 * 60 * 1000, lookup: dns.lookup, ...options.dns }
|
|
37
|
+
|
|
38
|
+
options.cache = options.cache || 'default'
|
|
39
|
+
if (options.cache === 'default') {
|
|
40
|
+
const hasConditionalHeader = Object.keys(options.headers || {}).some((name) => {
|
|
41
|
+
return conditionalHeaders.includes(name.toLowerCase())
|
|
42
|
+
})
|
|
43
|
+
if (hasConditionalHeader) {
|
|
44
|
+
options.cache = 'no-store'
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
options.cacheAdditionalHeaders = options.cacheAdditionalHeaders || []
|
|
49
|
+
|
|
50
|
+
// cacheManager is deprecated, but if it's set and
|
|
51
|
+
// cachePath is not we should copy it to the new field
|
|
52
|
+
if (options.cacheManager && !options.cachePath) {
|
|
53
|
+
options.cachePath = options.cacheManager
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return options
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
module.exports = configureOptions
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
'use strict'
|
|
2
|
+
|
|
3
|
+
const MinipassPipeline = require('minipass-pipeline')
|
|
4
|
+
|
|
5
|
+
class CachingMinipassPipeline extends MinipassPipeline {
|
|
6
|
+
#events = []
|
|
7
|
+
#data = new Map()
|
|
8
|
+
|
|
9
|
+
constructor (opts, ...streams) {
|
|
10
|
+
// CRITICAL: do NOT pass the streams to the call to super(), this will start
|
|
11
|
+
// the flow of data and potentially cause the events we need to catch to emit
|
|
12
|
+
// before we've finished our own setup. instead we call super() with no args,
|
|
13
|
+
// finish our setup, and then push the streams into ourselves to start the
|
|
14
|
+
// data flow
|
|
15
|
+
super()
|
|
16
|
+
this.#events = opts.events
|
|
17
|
+
|
|
18
|
+
/* istanbul ignore next - coverage disabled because this is pointless to test here */
|
|
19
|
+
if (streams.length) {
|
|
20
|
+
this.push(...streams)
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
on (event, handler) {
|
|
25
|
+
if (this.#events.includes(event) && this.#data.has(event)) {
|
|
26
|
+
return handler(...this.#data.get(event))
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
return super.on(event, handler)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
emit (event, ...data) {
|
|
33
|
+
if (this.#events.includes(event)) {
|
|
34
|
+
this.#data.set(event, data)
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
return super.emit(event, ...data)
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
module.exports = CachingMinipassPipeline
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
const { Minipass } = require('minipass')
|
|
2
|
+
const fetch = require('minipass-fetch')
|
|
3
|
+
const { promiseRetry } = require('@gar/promise-retry')
|
|
4
|
+
const ssri = require('ssri')
|
|
5
|
+
const { log } = require('proc-log')
|
|
6
|
+
const { redact: cleanUrl } = require('@npmcli/redact')
|
|
7
|
+
|
|
8
|
+
const CachingMinipassPipeline = require('./pipeline.js')
|
|
9
|
+
const { getAgent } = require('@npmcli/agent')
|
|
10
|
+
const pkg = require('../package.json')
|
|
11
|
+
|
|
12
|
+
const USER_AGENT = `${pkg.name}/${pkg.version} (+https://npm.im/${pkg.name})`
|
|
13
|
+
|
|
14
|
+
const RETRY_ERRORS = [
|
|
15
|
+
'ECONNRESET', // remote socket closed on us
|
|
16
|
+
'ECONNREFUSED', // remote host refused to open connection
|
|
17
|
+
'EADDRINUSE', // failed to bind to a local port (proxy?)
|
|
18
|
+
'ETIMEDOUT', // someone in the transaction is WAY TOO SLOW
|
|
19
|
+
// from @npmcli/agent
|
|
20
|
+
'ECONNECTIONTIMEOUT',
|
|
21
|
+
'EIDLETIMEOUT',
|
|
22
|
+
'ERESPONSETIMEOUT',
|
|
23
|
+
'ETRANSFERTIMEOUT',
|
|
24
|
+
// Known codes we do NOT retry on:
|
|
25
|
+
// ENOTFOUND (getaddrinfo failure. Either bad hostname, or offline)
|
|
26
|
+
// EINVALIDPROXY // invalid protocol from @npmcli/agent
|
|
27
|
+
// EINVALIDRESPONSE // invalid status code from @npmcli/agent
|
|
28
|
+
]
|
|
29
|
+
|
|
30
|
+
const RETRY_TYPES = [
|
|
31
|
+
'request-timeout',
|
|
32
|
+
]
|
|
33
|
+
|
|
34
|
+
// make a request directly to the remote source,
|
|
35
|
+
// retrying certain classes of errors as well as
|
|
36
|
+
// following redirects (through the cache if necessary)
|
|
37
|
+
// and verifying response integrity
|
|
38
|
+
const remoteFetch = (request, options) => {
|
|
39
|
+
// options.signal is intended for the fetch itself, not the agent. Attaching it to the agent will re-use that signal across multiple requests, which prevents any connections beyond the first one.
|
|
40
|
+
const agent = getAgent(request.url, { ...options, signal: undefined })
|
|
41
|
+
if (!request.headers.has('connection')) {
|
|
42
|
+
request.headers.set('connection', agent ? 'keep-alive' : 'close')
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
if (!request.headers.has('user-agent')) {
|
|
46
|
+
request.headers.set('user-agent', USER_AGENT)
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// keep our own options since we're overriding the agent
|
|
50
|
+
// and the redirect mode
|
|
51
|
+
const _opts = {
|
|
52
|
+
...options,
|
|
53
|
+
agent,
|
|
54
|
+
redirect: 'manual',
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
return promiseRetry(async (retryHandler, attemptNum) => {
|
|
58
|
+
const req = new fetch.Request(request, _opts)
|
|
59
|
+
const url = cleanUrl(req.url)
|
|
60
|
+
try {
|
|
61
|
+
let res = await fetch(req, _opts)
|
|
62
|
+
if (_opts.integrity && res.status === 200) {
|
|
63
|
+
// we got a 200 response and the user has specified an expected
|
|
64
|
+
// integrity value, so wrap the response in an ssri stream to verify it
|
|
65
|
+
const integrityStream = ssri.integrityStream({
|
|
66
|
+
algorithms: _opts.algorithms,
|
|
67
|
+
integrity: _opts.integrity,
|
|
68
|
+
size: _opts.size,
|
|
69
|
+
})
|
|
70
|
+
const pipeline = new CachingMinipassPipeline({
|
|
71
|
+
events: ['integrity', 'size'],
|
|
72
|
+
}, res.body, integrityStream)
|
|
73
|
+
// we also propagate the integrity and size events out to the pipeline so we can use
|
|
74
|
+
// this new response body as an integrityEmitter for cacache
|
|
75
|
+
integrityStream.on('integrity', i => pipeline.emit('integrity', i))
|
|
76
|
+
integrityStream.on('size', s => pipeline.emit('size', s))
|
|
77
|
+
res = new fetch.Response(pipeline, res)
|
|
78
|
+
// set an explicit flag so we know if our response body will emit integrity and size
|
|
79
|
+
res.body.hasIntegrityEmitter = true
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
res.headers.set('x-fetch-attempts', attemptNum)
|
|
83
|
+
|
|
84
|
+
// do not retry POST requests, or requests with a streaming body
|
|
85
|
+
// do retry requests with a 408, 420, 429 or 500+ status in the response
|
|
86
|
+
const isStream = Minipass.isStream(req.body)
|
|
87
|
+
const isRetriable = req.method !== 'POST' &&
|
|
88
|
+
!isStream &&
|
|
89
|
+
([408, 420, 429].includes(res.status) || res.status >= 500)
|
|
90
|
+
|
|
91
|
+
if (isRetriable) {
|
|
92
|
+
if (typeof options.onRetry === 'function') {
|
|
93
|
+
options.onRetry(res)
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
/* eslint-disable-next-line max-len */
|
|
97
|
+
log.http('fetch', `${req.method} ${url} attempt ${attemptNum} failed with ${res.status}`)
|
|
98
|
+
return retryHandler(res)
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
return res
|
|
102
|
+
} catch (err) {
|
|
103
|
+
const code = (err.code === 'EPROMISERETRY')
|
|
104
|
+
? err.retried.code
|
|
105
|
+
: err.code
|
|
106
|
+
|
|
107
|
+
// err.retried will be the thing that was thrown from above
|
|
108
|
+
// if it's a response, we just got a bad status code and we
|
|
109
|
+
// can re-throw to allow the retry
|
|
110
|
+
const isRetryError = err.retried instanceof fetch.Response ||
|
|
111
|
+
(RETRY_ERRORS.includes(code) && RETRY_TYPES.includes(err.type))
|
|
112
|
+
|
|
113
|
+
if (req.method === 'POST' || isRetryError) {
|
|
114
|
+
throw err
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
if (typeof options.onRetry === 'function') {
|
|
118
|
+
options.onRetry(err)
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
log.http('fetch', `${req.method} ${url} attempt ${attemptNum} failed with ${err.code}`)
|
|
122
|
+
return retryHandler(err)
|
|
123
|
+
}
|
|
124
|
+
}, options.retry).catch((err) => {
|
|
125
|
+
// don't reject for http errors, just return them
|
|
126
|
+
if (err.status >= 400 && err.type !== 'system') {
|
|
127
|
+
return err
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
throw err
|
|
131
|
+
})
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
module.exports = remoteFetch
|