pnpm 11.0.6 → 11.0.8

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.
Files changed (377) hide show
  1. package/dist/node_modules/node-gyp/.release-please-manifest.json +1 -1
  2. package/dist/node_modules/node-gyp/gyp/.release-please-manifest.json +1 -1
  3. package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSVersion.py +11 -3
  4. package/dist/node_modules/node-gyp/gyp/pylib/gyp/__init__.py +2 -3
  5. package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs.py +1 -1
  6. package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja.py +2 -1
  7. package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja_test.py +26 -16
  8. package/dist/node_modules/node-gyp/gyp/pylib/gyp/mac_tool.py +1 -1
  9. package/dist/node_modules/node-gyp/gyp/pylib/gyp/msvs_emulation.py +1 -1
  10. package/dist/node_modules/node-gyp/gyp/pylib/gyp/simple_copy.py +2 -2
  11. package/dist/node_modules/node-gyp/gyp/pylib/packaging/metadata.py +3 -20
  12. package/dist/node_modules/node-gyp/gyp/pylib/packaging/tags.py +2 -14
  13. package/dist/node_modules/node-gyp/gyp/pyproject.toml +5 -3
  14. package/dist/node_modules/node-gyp/lib/download.js +55 -8
  15. package/dist/node_modules/node-gyp/lib/find-visualstudio.js +1 -1
  16. package/dist/node_modules/node-gyp/lib/process-release.js +17 -19
  17. package/dist/node_modules/node-gyp/package.json +3 -3
  18. package/dist/node_modules/{safer-buffer → undici}/LICENSE +1 -1
  19. package/dist/node_modules/undici/index-fetch.js +35 -0
  20. package/dist/node_modules/undici/index.js +169 -0
  21. package/dist/node_modules/undici/lib/api/abort-signal.js +57 -0
  22. package/dist/node_modules/undici/lib/api/api-connect.js +108 -0
  23. package/dist/node_modules/undici/lib/api/api-pipeline.js +251 -0
  24. package/dist/node_modules/undici/lib/api/api-request.js +214 -0
  25. package/dist/node_modules/undici/lib/api/api-stream.js +220 -0
  26. package/dist/node_modules/undici/lib/api/api-upgrade.js +108 -0
  27. package/dist/node_modules/undici/lib/api/index.js +7 -0
  28. package/dist/node_modules/undici/lib/api/readable.js +385 -0
  29. package/dist/node_modules/undici/lib/api/util.js +93 -0
  30. package/dist/node_modules/undici/lib/core/connect.js +240 -0
  31. package/dist/node_modules/undici/lib/core/constants.js +118 -0
  32. package/dist/node_modules/undici/lib/core/diagnostics.js +202 -0
  33. package/dist/node_modules/undici/lib/core/errors.js +425 -0
  34. package/dist/node_modules/undici/lib/core/request.js +405 -0
  35. package/dist/node_modules/undici/lib/core/symbols.js +67 -0
  36. package/dist/node_modules/undici/lib/core/tree.js +152 -0
  37. package/dist/node_modules/undici/lib/core/util.js +719 -0
  38. package/dist/node_modules/undici/lib/dispatcher/agent.js +130 -0
  39. package/dist/node_modules/undici/lib/dispatcher/balanced-pool.js +209 -0
  40. package/dist/node_modules/undici/lib/dispatcher/client-h1.js +1370 -0
  41. package/dist/node_modules/undici/lib/dispatcher/client-h2.js +744 -0
  42. package/dist/node_modules/undici/lib/dispatcher/client.js +623 -0
  43. package/dist/node_modules/undici/lib/dispatcher/dispatcher-base.js +198 -0
  44. package/dist/node_modules/undici/lib/dispatcher/dispatcher.js +65 -0
  45. package/dist/node_modules/undici/lib/dispatcher/env-http-proxy-agent.js +160 -0
  46. package/dist/node_modules/undici/lib/dispatcher/fixed-queue.js +117 -0
  47. package/dist/node_modules/undici/lib/dispatcher/pool-base.js +194 -0
  48. package/dist/node_modules/undici/lib/dispatcher/pool-stats.js +34 -0
  49. package/dist/node_modules/undici/lib/dispatcher/pool.js +107 -0
  50. package/dist/node_modules/undici/lib/dispatcher/proxy-agent.js +274 -0
  51. package/dist/node_modules/undici/lib/dispatcher/retry-agent.js +35 -0
  52. package/dist/node_modules/undici/lib/global.js +32 -0
  53. package/dist/node_modules/undici/lib/handler/decorator-handler.js +44 -0
  54. package/dist/node_modules/undici/lib/handler/redirect-handler.js +232 -0
  55. package/dist/node_modules/undici/lib/handler/retry-handler.js +374 -0
  56. package/dist/node_modules/undici/lib/interceptor/dns.js +375 -0
  57. package/dist/node_modules/undici/lib/interceptor/dump.js +123 -0
  58. package/dist/node_modules/undici/lib/interceptor/redirect-interceptor.js +21 -0
  59. package/dist/node_modules/undici/lib/interceptor/redirect.js +24 -0
  60. package/dist/node_modules/undici/lib/interceptor/response-error.js +86 -0
  61. package/dist/node_modules/undici/lib/interceptor/retry.js +19 -0
  62. package/dist/node_modules/undici/lib/llhttp/.gitkeep +0 -0
  63. package/dist/node_modules/undici/lib/llhttp/constants.js +278 -0
  64. package/dist/node_modules/undici/lib/llhttp/llhttp-wasm.js +5 -0
  65. package/dist/node_modules/undici/lib/llhttp/llhttp_simd-wasm.js +5 -0
  66. package/dist/node_modules/undici/lib/llhttp/utils.js +15 -0
  67. package/dist/node_modules/undici/lib/mock/mock-agent.js +160 -0
  68. package/dist/node_modules/undici/lib/mock/mock-client.js +59 -0
  69. package/dist/node_modules/undici/lib/mock/mock-errors.js +28 -0
  70. package/dist/node_modules/undici/lib/mock/mock-interceptor.js +207 -0
  71. package/dist/node_modules/undici/lib/mock/mock-pool.js +59 -0
  72. package/dist/node_modules/undici/lib/mock/mock-symbols.js +23 -0
  73. package/dist/node_modules/undici/lib/mock/mock-utils.js +367 -0
  74. package/dist/node_modules/undici/lib/mock/pending-interceptors-formatter.js +43 -0
  75. package/dist/node_modules/undici/lib/mock/pluralizer.js +29 -0
  76. package/dist/node_modules/undici/lib/util/timers.js +423 -0
  77. package/dist/node_modules/undici/lib/web/cache/cache.js +859 -0
  78. package/dist/node_modules/undici/lib/web/cache/cachestorage.js +152 -0
  79. package/dist/node_modules/undici/lib/web/cache/symbols.js +5 -0
  80. package/dist/node_modules/undici/lib/web/cache/util.js +45 -0
  81. package/dist/node_modules/undici/lib/web/cookies/constants.js +12 -0
  82. package/dist/node_modules/undici/lib/web/cookies/index.js +184 -0
  83. package/dist/node_modules/undici/lib/web/cookies/parse.js +317 -0
  84. package/dist/node_modules/undici/lib/web/cookies/util.js +282 -0
  85. package/dist/node_modules/undici/lib/web/eventsource/eventsource-stream.js +398 -0
  86. package/dist/node_modules/undici/lib/web/eventsource/eventsource.js +480 -0
  87. package/dist/node_modules/undici/lib/web/eventsource/util.js +37 -0
  88. package/dist/node_modules/{@npmcli/redact → undici/lib/web/fetch}/LICENSE +1 -1
  89. package/dist/node_modules/undici/lib/web/fetch/body.js +529 -0
  90. package/dist/node_modules/undici/lib/web/fetch/constants.js +124 -0
  91. package/dist/node_modules/undici/lib/web/fetch/data-url.js +744 -0
  92. package/dist/node_modules/undici/lib/web/fetch/dispatcher-weakref.js +46 -0
  93. package/dist/node_modules/undici/lib/web/fetch/file.js +126 -0
  94. package/dist/node_modules/undici/lib/web/fetch/formdata-parser.js +474 -0
  95. package/dist/node_modules/undici/lib/web/fetch/formdata.js +252 -0
  96. package/dist/node_modules/undici/lib/web/fetch/global.js +40 -0
  97. package/dist/node_modules/undici/lib/web/fetch/headers.js +687 -0
  98. package/dist/node_modules/undici/lib/web/fetch/index.js +2272 -0
  99. package/dist/node_modules/undici/lib/web/fetch/request.js +1037 -0
  100. package/dist/node_modules/undici/lib/web/fetch/response.js +610 -0
  101. package/dist/node_modules/undici/lib/web/fetch/symbols.js +9 -0
  102. package/dist/node_modules/undici/lib/web/fetch/util.js +1632 -0
  103. package/dist/node_modules/undici/lib/web/fetch/webidl.js +695 -0
  104. package/dist/node_modules/undici/lib/web/fileapi/encoding.js +290 -0
  105. package/dist/node_modules/undici/lib/web/fileapi/filereader.js +344 -0
  106. package/dist/node_modules/undici/lib/web/fileapi/progressevent.js +78 -0
  107. package/dist/node_modules/undici/lib/web/fileapi/symbols.js +10 -0
  108. package/dist/node_modules/undici/lib/web/fileapi/util.js +391 -0
  109. package/dist/node_modules/undici/lib/web/websocket/connection.js +371 -0
  110. package/dist/node_modules/undici/lib/web/websocket/constants.js +66 -0
  111. package/dist/node_modules/undici/lib/web/websocket/events.js +329 -0
  112. package/dist/node_modules/undici/lib/web/websocket/frame.js +96 -0
  113. package/dist/node_modules/undici/lib/web/websocket/permessage-deflate.js +100 -0
  114. package/dist/node_modules/undici/lib/web/websocket/receiver.js +490 -0
  115. package/dist/node_modules/undici/lib/web/websocket/sender.js +104 -0
  116. package/dist/node_modules/undici/lib/web/websocket/symbols.js +12 -0
  117. package/dist/node_modules/undici/lib/web/websocket/util.js +322 -0
  118. package/dist/node_modules/undici/lib/web/websocket/websocket.js +592 -0
  119. package/dist/node_modules/undici/package.json +160 -0
  120. package/dist/node_modules/undici/scripts/strip-comments.js +8 -0
  121. package/dist/node_modules/yallist/package.json +51 -12
  122. package/dist/pnpm.mjs +4529 -3898
  123. package/dist/worker.js +76 -73
  124. package/package.json +1 -1
  125. package/dist/node_modules/@gar/promise-retry/LICENSE +0 -20
  126. package/dist/node_modules/@gar/promise-retry/lib/index.js +0 -62
  127. package/dist/node_modules/@gar/promise-retry/lib/retry.js +0 -109
  128. package/dist/node_modules/@gar/promise-retry/package.json +0 -45
  129. package/dist/node_modules/@npmcli/agent/lib/agents.js +0 -206
  130. package/dist/node_modules/@npmcli/agent/lib/dns.js +0 -53
  131. package/dist/node_modules/@npmcli/agent/lib/errors.js +0 -61
  132. package/dist/node_modules/@npmcli/agent/lib/index.js +0 -56
  133. package/dist/node_modules/@npmcli/agent/lib/options.js +0 -86
  134. package/dist/node_modules/@npmcli/agent/lib/proxy.js +0 -88
  135. package/dist/node_modules/@npmcli/agent/package.json +0 -60
  136. package/dist/node_modules/@npmcli/fs/lib/common/get-options.js +0 -20
  137. package/dist/node_modules/@npmcli/fs/lib/common/node.js +0 -9
  138. package/dist/node_modules/@npmcli/fs/lib/cp/LICENSE +0 -15
  139. package/dist/node_modules/@npmcli/fs/lib/cp/errors.js +0 -129
  140. package/dist/node_modules/@npmcli/fs/lib/cp/index.js +0 -22
  141. package/dist/node_modules/@npmcli/fs/lib/cp/polyfill.js +0 -428
  142. package/dist/node_modules/@npmcli/fs/lib/index.js +0 -13
  143. package/dist/node_modules/@npmcli/fs/lib/move-file.js +0 -78
  144. package/dist/node_modules/@npmcli/fs/lib/readdir-scoped.js +0 -20
  145. package/dist/node_modules/@npmcli/fs/lib/with-temp-dir.js +0 -39
  146. package/dist/node_modules/@npmcli/fs/package.json +0 -54
  147. package/dist/node_modules/@npmcli/redact/lib/deep-map.js +0 -71
  148. package/dist/node_modules/@npmcli/redact/lib/error.js +0 -28
  149. package/dist/node_modules/@npmcli/redact/lib/index.js +0 -44
  150. package/dist/node_modules/@npmcli/redact/lib/matchers.js +0 -88
  151. package/dist/node_modules/@npmcli/redact/lib/server.js +0 -59
  152. package/dist/node_modules/@npmcli/redact/lib/utils.js +0 -202
  153. package/dist/node_modules/@npmcli/redact/package.json +0 -52
  154. package/dist/node_modules/agent-base/LICENSE +0 -22
  155. package/dist/node_modules/agent-base/dist/helpers.js +0 -66
  156. package/dist/node_modules/agent-base/dist/index.js +0 -178
  157. package/dist/node_modules/agent-base/package.json +0 -46
  158. package/dist/node_modules/balanced-match/dist/commonjs/index.js +0 -59
  159. package/dist/node_modules/balanced-match/dist/esm/index.js +0 -54
  160. package/dist/node_modules/balanced-match/package.json +0 -68
  161. package/dist/node_modules/brace-expansion/LICENSE +0 -23
  162. package/dist/node_modules/brace-expansion/dist/commonjs/index.js +0 -201
  163. package/dist/node_modules/brace-expansion/dist/commonjs/package.json +0 -3
  164. package/dist/node_modules/brace-expansion/dist/esm/index.js +0 -197
  165. package/dist/node_modules/brace-expansion/dist/esm/package.json +0 -3
  166. package/dist/node_modules/brace-expansion/package.json +0 -64
  167. package/dist/node_modules/cacache/lib/content/path.js +0 -29
  168. package/dist/node_modules/cacache/lib/content/read.js +0 -165
  169. package/dist/node_modules/cacache/lib/content/rm.js +0 -18
  170. package/dist/node_modules/cacache/lib/content/write.js +0 -206
  171. package/dist/node_modules/cacache/lib/entry-index.js +0 -336
  172. package/dist/node_modules/cacache/lib/get.js +0 -170
  173. package/dist/node_modules/cacache/lib/index.js +0 -42
  174. package/dist/node_modules/cacache/lib/memoization.js +0 -72
  175. package/dist/node_modules/cacache/lib/put.js +0 -80
  176. package/dist/node_modules/cacache/lib/rm.js +0 -31
  177. package/dist/node_modules/cacache/lib/util/glob.js +0 -7
  178. package/dist/node_modules/cacache/lib/util/hash-to-segments.js +0 -7
  179. package/dist/node_modules/cacache/lib/util/tmp.js +0 -32
  180. package/dist/node_modules/cacache/lib/verify.js +0 -258
  181. package/dist/node_modules/cacache/package.json +0 -81
  182. package/dist/node_modules/debug/LICENSE +0 -20
  183. package/dist/node_modules/debug/package.json +0 -64
  184. package/dist/node_modules/debug/src/browser.js +0 -272
  185. package/dist/node_modules/debug/src/common.js +0 -292
  186. package/dist/node_modules/debug/src/index.js +0 -10
  187. package/dist/node_modules/debug/src/node.js +0 -263
  188. package/dist/node_modules/fs-minipass/LICENSE +0 -15
  189. package/dist/node_modules/fs-minipass/lib/index.js +0 -443
  190. package/dist/node_modules/fs-minipass/package.json +0 -54
  191. package/dist/node_modules/glob/dist/commonjs/glob.js +0 -248
  192. package/dist/node_modules/glob/dist/commonjs/has-magic.js +0 -27
  193. package/dist/node_modules/glob/dist/commonjs/ignore.js +0 -119
  194. package/dist/node_modules/glob/dist/commonjs/index.js +0 -68
  195. package/dist/node_modules/glob/dist/commonjs/index.min.js +0 -4
  196. package/dist/node_modules/glob/dist/commonjs/package.json +0 -3
  197. package/dist/node_modules/glob/dist/commonjs/pattern.js +0 -223
  198. package/dist/node_modules/glob/dist/commonjs/processor.js +0 -301
  199. package/dist/node_modules/glob/dist/commonjs/walker.js +0 -387
  200. package/dist/node_modules/glob/dist/esm/glob.js +0 -244
  201. package/dist/node_modules/glob/dist/esm/has-magic.js +0 -23
  202. package/dist/node_modules/glob/dist/esm/ignore.js +0 -115
  203. package/dist/node_modules/glob/dist/esm/index.js +0 -55
  204. package/dist/node_modules/glob/dist/esm/index.min.js +0 -4
  205. package/dist/node_modules/glob/dist/esm/package.json +0 -3
  206. package/dist/node_modules/glob/dist/esm/pattern.js +0 -219
  207. package/dist/node_modules/glob/dist/esm/processor.js +0 -294
  208. package/dist/node_modules/glob/dist/esm/walker.js +0 -381
  209. package/dist/node_modules/glob/package.json +0 -98
  210. package/dist/node_modules/http-cache-semantics/LICENSE +0 -9
  211. package/dist/node_modules/http-cache-semantics/index.js +0 -928
  212. package/dist/node_modules/http-cache-semantics/package.json +0 -22
  213. package/dist/node_modules/http-proxy-agent/LICENSE +0 -22
  214. package/dist/node_modules/http-proxy-agent/dist/index.js +0 -148
  215. package/dist/node_modules/http-proxy-agent/package.json +0 -47
  216. package/dist/node_modules/https-proxy-agent/LICENSE +0 -22
  217. package/dist/node_modules/https-proxy-agent/dist/index.js +0 -180
  218. package/dist/node_modules/https-proxy-agent/dist/parse-proxy-response.js +0 -101
  219. package/dist/node_modules/https-proxy-agent/package.json +0 -50
  220. package/dist/node_modules/iconv-lite/LICENSE +0 -21
  221. package/dist/node_modules/iconv-lite/encodings/dbcs-codec.js +0 -532
  222. package/dist/node_modules/iconv-lite/encodings/dbcs-data.js +0 -185
  223. package/dist/node_modules/iconv-lite/encodings/index.js +0 -23
  224. package/dist/node_modules/iconv-lite/encodings/internal.js +0 -218
  225. package/dist/node_modules/iconv-lite/encodings/sbcs-codec.js +0 -75
  226. package/dist/node_modules/iconv-lite/encodings/sbcs-data-generated.js +0 -451
  227. package/dist/node_modules/iconv-lite/encodings/sbcs-data.js +0 -178
  228. package/dist/node_modules/iconv-lite/encodings/tables/big5-added.json +0 -122
  229. package/dist/node_modules/iconv-lite/encodings/tables/cp936.json +0 -264
  230. package/dist/node_modules/iconv-lite/encodings/tables/cp949.json +0 -273
  231. package/dist/node_modules/iconv-lite/encodings/tables/cp950.json +0 -177
  232. package/dist/node_modules/iconv-lite/encodings/tables/eucjp.json +0 -182
  233. package/dist/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json +0 -1
  234. package/dist/node_modules/iconv-lite/encodings/tables/gbk-added.json +0 -56
  235. package/dist/node_modules/iconv-lite/encodings/tables/shiftjis.json +0 -125
  236. package/dist/node_modules/iconv-lite/encodings/utf16.js +0 -187
  237. package/dist/node_modules/iconv-lite/encodings/utf32.js +0 -307
  238. package/dist/node_modules/iconv-lite/encodings/utf7.js +0 -283
  239. package/dist/node_modules/iconv-lite/lib/bom-handling.js +0 -48
  240. package/dist/node_modules/iconv-lite/lib/helpers/merge-exports.js +0 -13
  241. package/dist/node_modules/iconv-lite/lib/index.js +0 -182
  242. package/dist/node_modules/iconv-lite/lib/streams.js +0 -105
  243. package/dist/node_modules/iconv-lite/package.json +0 -70
  244. package/dist/node_modules/ip-address/LICENSE +0 -19
  245. package/dist/node_modules/ip-address/dist/address-error.js +0 -12
  246. package/dist/node_modules/ip-address/dist/common.js +0 -46
  247. package/dist/node_modules/ip-address/dist/ip-address.js +0 -35
  248. package/dist/node_modules/ip-address/dist/ipv4.js +0 -360
  249. package/dist/node_modules/ip-address/dist/ipv6.js +0 -1003
  250. package/dist/node_modules/ip-address/dist/v4/constants.js +0 -8
  251. package/dist/node_modules/ip-address/dist/v6/constants.js +0 -76
  252. package/dist/node_modules/ip-address/dist/v6/helpers.js +0 -45
  253. package/dist/node_modules/ip-address/dist/v6/regular-expressions.js +0 -95
  254. package/dist/node_modules/ip-address/package.json +0 -78
  255. package/dist/node_modules/lru-cache/dist/commonjs/diagnostics-channel.js +0 -10
  256. package/dist/node_modules/lru-cache/dist/commonjs/index.js +0 -1692
  257. package/dist/node_modules/lru-cache/dist/commonjs/index.min.js +0 -2
  258. package/dist/node_modules/lru-cache/dist/commonjs/package.json +0 -3
  259. package/dist/node_modules/lru-cache/dist/esm/browser/diagnostics-channel.js +0 -4
  260. package/dist/node_modules/lru-cache/dist/esm/browser/index.js +0 -1688
  261. package/dist/node_modules/lru-cache/dist/esm/browser/index.min.js +0 -2
  262. package/dist/node_modules/lru-cache/dist/esm/diagnostics-channel.js +0 -19
  263. package/dist/node_modules/lru-cache/dist/esm/index.js +0 -1688
  264. package/dist/node_modules/lru-cache/dist/esm/index.min.js +0 -2
  265. package/dist/node_modules/lru-cache/dist/esm/node/diagnostics-channel.js +0 -7
  266. package/dist/node_modules/lru-cache/dist/esm/node/index.js +0 -1688
  267. package/dist/node_modules/lru-cache/dist/esm/node/index.min.js +0 -2
  268. package/dist/node_modules/lru-cache/dist/esm/package.json +0 -3
  269. package/dist/node_modules/lru-cache/package.json +0 -126
  270. package/dist/node_modules/make-fetch-happen/LICENSE +0 -16
  271. package/dist/node_modules/make-fetch-happen/lib/cache/entry.js +0 -471
  272. package/dist/node_modules/make-fetch-happen/lib/cache/errors.js +0 -11
  273. package/dist/node_modules/make-fetch-happen/lib/cache/index.js +0 -49
  274. package/dist/node_modules/make-fetch-happen/lib/cache/key.js +0 -17
  275. package/dist/node_modules/make-fetch-happen/lib/cache/policy.js +0 -161
  276. package/dist/node_modules/make-fetch-happen/lib/fetch.js +0 -118
  277. package/dist/node_modules/make-fetch-happen/lib/index.js +0 -41
  278. package/dist/node_modules/make-fetch-happen/lib/options.js +0 -59
  279. package/dist/node_modules/make-fetch-happen/lib/pipeline.js +0 -41
  280. package/dist/node_modules/make-fetch-happen/lib/remote.js +0 -134
  281. package/dist/node_modules/make-fetch-happen/package.json +0 -75
  282. package/dist/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +0 -14
  283. package/dist/node_modules/minimatch/dist/commonjs/ast.js +0 -845
  284. package/dist/node_modules/minimatch/dist/commonjs/brace-expressions.js +0 -150
  285. package/dist/node_modules/minimatch/dist/commonjs/escape.js +0 -30
  286. package/dist/node_modules/minimatch/dist/commonjs/index.js +0 -1127
  287. package/dist/node_modules/minimatch/dist/commonjs/package.json +0 -3
  288. package/dist/node_modules/minimatch/dist/commonjs/unescape.js +0 -38
  289. package/dist/node_modules/minimatch/dist/esm/assert-valid-pattern.js +0 -10
  290. package/dist/node_modules/minimatch/dist/esm/ast.js +0 -841
  291. package/dist/node_modules/minimatch/dist/esm/brace-expressions.js +0 -146
  292. package/dist/node_modules/minimatch/dist/esm/escape.js +0 -26
  293. package/dist/node_modules/minimatch/dist/esm/index.js +0 -1114
  294. package/dist/node_modules/minimatch/dist/esm/package.json +0 -3
  295. package/dist/node_modules/minimatch/dist/esm/unescape.js +0 -34
  296. package/dist/node_modules/minimatch/package.json +0 -73
  297. package/dist/node_modules/minipass-collect/LICENSE +0 -15
  298. package/dist/node_modules/minipass-collect/index.js +0 -71
  299. package/dist/node_modules/minipass-collect/package.json +0 -30
  300. package/dist/node_modules/minipass-fetch/LICENSE +0 -28
  301. package/dist/node_modules/minipass-fetch/lib/abort-error.js +0 -17
  302. package/dist/node_modules/minipass-fetch/lib/blob.js +0 -97
  303. package/dist/node_modules/minipass-fetch/lib/body.js +0 -360
  304. package/dist/node_modules/minipass-fetch/lib/fetch-error.js +0 -32
  305. package/dist/node_modules/minipass-fetch/lib/headers.js +0 -267
  306. package/dist/node_modules/minipass-fetch/lib/index.js +0 -376
  307. package/dist/node_modules/minipass-fetch/lib/request.js +0 -282
  308. package/dist/node_modules/minipass-fetch/lib/response.js +0 -90
  309. package/dist/node_modules/minipass-fetch/package.json +0 -70
  310. package/dist/node_modules/minipass-flush/index.js +0 -39
  311. package/dist/node_modules/minipass-flush/node_modules/minipass/LICENSE +0 -15
  312. package/dist/node_modules/minipass-flush/node_modules/minipass/index.js +0 -649
  313. package/dist/node_modules/minipass-flush/node_modules/minipass/package.json +0 -56
  314. package/dist/node_modules/minipass-flush/package.json +0 -42
  315. package/dist/node_modules/minipass-pipeline/LICENSE +0 -15
  316. package/dist/node_modules/minipass-pipeline/index.js +0 -128
  317. package/dist/node_modules/minipass-pipeline/node_modules/minipass/LICENSE +0 -15
  318. package/dist/node_modules/minipass-pipeline/node_modules/minipass/index.js +0 -649
  319. package/dist/node_modules/minipass-pipeline/node_modules/minipass/package.json +0 -56
  320. package/dist/node_modules/minipass-pipeline/package.json +0 -29
  321. package/dist/node_modules/minipass-sized/LICENSE +0 -15
  322. package/dist/node_modules/minipass-sized/dist/commonjs/index.js +0 -69
  323. package/dist/node_modules/minipass-sized/dist/commonjs/package.json +0 -3
  324. package/dist/node_modules/minipass-sized/dist/esm/index.js +0 -64
  325. package/dist/node_modules/minipass-sized/dist/esm/package.json +0 -3
  326. package/dist/node_modules/minipass-sized/package.json +0 -69
  327. package/dist/node_modules/ms/index.js +0 -162
  328. package/dist/node_modules/ms/package.json +0 -38
  329. package/dist/node_modules/negotiator/LICENSE +0 -24
  330. package/dist/node_modules/negotiator/index.js +0 -83
  331. package/dist/node_modules/negotiator/lib/charset.js +0 -169
  332. package/dist/node_modules/negotiator/lib/encoding.js +0 -205
  333. package/dist/node_modules/negotiator/lib/language.js +0 -179
  334. package/dist/node_modules/negotiator/lib/mediaType.js +0 -294
  335. package/dist/node_modules/negotiator/package.json +0 -43
  336. package/dist/node_modules/p-map/index.js +0 -283
  337. package/dist/node_modules/p-map/license +0 -9
  338. package/dist/node_modules/p-map/package.json +0 -57
  339. package/dist/node_modules/path-scurry/dist/commonjs/index.js +0 -2018
  340. package/dist/node_modules/path-scurry/dist/commonjs/package.json +0 -3
  341. package/dist/node_modules/path-scurry/dist/esm/index.js +0 -1983
  342. package/dist/node_modules/path-scurry/dist/esm/package.json +0 -3
  343. package/dist/node_modules/path-scurry/package.json +0 -72
  344. package/dist/node_modules/safer-buffer/dangerous.js +0 -58
  345. package/dist/node_modules/safer-buffer/package.json +0 -34
  346. package/dist/node_modules/safer-buffer/safer.js +0 -77
  347. package/dist/node_modules/safer-buffer/tests.js +0 -406
  348. package/dist/node_modules/smart-buffer/.prettierrc.yaml +0 -5
  349. package/dist/node_modules/smart-buffer/LICENSE +0 -20
  350. package/dist/node_modules/smart-buffer/build/smartbuffer.js +0 -1233
  351. package/dist/node_modules/smart-buffer/build/utils.js +0 -108
  352. package/dist/node_modules/smart-buffer/package.json +0 -79
  353. package/dist/node_modules/socks/.eslintrc.cjs +0 -11
  354. package/dist/node_modules/socks/.prettierrc.yaml +0 -7
  355. package/dist/node_modules/socks/LICENSE +0 -20
  356. package/dist/node_modules/socks/build/client/socksclient.js +0 -793
  357. package/dist/node_modules/socks/build/common/constants.js +0 -108
  358. package/dist/node_modules/socks/build/common/helpers.js +0 -167
  359. package/dist/node_modules/socks/build/common/receivebuffer.js +0 -43
  360. package/dist/node_modules/socks/build/common/util.js +0 -25
  361. package/dist/node_modules/socks/build/index.js +0 -18
  362. package/dist/node_modules/socks/package.json +0 -58
  363. package/dist/node_modules/socks-proxy-agent/LICENSE +0 -22
  364. package/dist/node_modules/socks-proxy-agent/dist/index.js +0 -195
  365. package/dist/node_modules/socks-proxy-agent/package.json +0 -142
  366. package/dist/node_modules/ssri/lib/index.js +0 -550
  367. package/dist/node_modules/ssri/package.json +0 -66
  368. package/dist/node_modules/tar/node_modules/yallist/dist/commonjs/package.json +0 -3
  369. package/dist/node_modules/tar/node_modules/yallist/dist/esm/package.json +0 -3
  370. package/dist/node_modules/tar/node_modules/yallist/package.json +0 -68
  371. package/dist/node_modules/yallist/LICENSE +0 -15
  372. package/dist/node_modules/yallist/iterator.js +0 -8
  373. package/dist/node_modules/yallist/yallist.js +0 -426
  374. /package/dist/node_modules/{tar/node_modules/yallist → yallist}/dist/commonjs/index.js +0 -0
  375. /package/dist/node_modules/{balanced-match → yallist}/dist/commonjs/package.json +0 -0
  376. /package/dist/node_modules/{tar/node_modules/yallist → yallist}/dist/esm/index.js +0 -0
  377. /package/dist/node_modules/{balanced-match → yallist}/dist/esm/package.json +0 -0
@@ -0,0 +1,385 @@
1
+ // Ported from https://github.com/nodejs/undici/pull/907
2
+
3
+ 'use strict'
4
+
5
+ const assert = require('node:assert')
6
+ const { Readable } = require('node:stream')
7
+ const { RequestAbortedError, NotSupportedError, InvalidArgumentError, AbortError } = require('../core/errors')
8
+ const util = require('../core/util')
9
+ const { ReadableStreamFrom } = require('../core/util')
10
+
11
+ const kConsume = Symbol('kConsume')
12
+ const kReading = Symbol('kReading')
13
+ const kBody = Symbol('kBody')
14
+ const kAbort = Symbol('kAbort')
15
+ const kContentType = Symbol('kContentType')
16
+ const kContentLength = Symbol('kContentLength')
17
+
18
+ const noop = () => {}
19
+
20
+ class BodyReadable extends Readable {
21
+ constructor ({
22
+ resume,
23
+ abort,
24
+ contentType = '',
25
+ contentLength,
26
+ highWaterMark = 64 * 1024 // Same as nodejs fs streams.
27
+ }) {
28
+ super({
29
+ autoDestroy: true,
30
+ read: resume,
31
+ highWaterMark
32
+ })
33
+
34
+ this._readableState.dataEmitted = false
35
+
36
+ this[kAbort] = abort
37
+ this[kConsume] = null
38
+ this[kBody] = null
39
+ this[kContentType] = contentType
40
+ this[kContentLength] = contentLength
41
+
42
+ // Is stream being consumed through Readable API?
43
+ // This is an optimization so that we avoid checking
44
+ // for 'data' and 'readable' listeners in the hot path
45
+ // inside push().
46
+ this[kReading] = false
47
+ }
48
+
49
+ destroy (err) {
50
+ if (!err && !this._readableState.endEmitted) {
51
+ err = new RequestAbortedError()
52
+ }
53
+
54
+ if (err) {
55
+ this[kAbort]()
56
+ }
57
+
58
+ return super.destroy(err)
59
+ }
60
+
61
+ _destroy (err, callback) {
62
+ // Workaround for Node "bug". If the stream is destroyed in same
63
+ // tick as it is created, then a user who is waiting for a
64
+ // promise (i.e micro tick) for installing a 'error' listener will
65
+ // never get a chance and will always encounter an unhandled exception.
66
+ if (!this[kReading]) {
67
+ setImmediate(() => {
68
+ callback(err)
69
+ })
70
+ } else {
71
+ callback(err)
72
+ }
73
+ }
74
+
75
+ on (ev, ...args) {
76
+ if (ev === 'data' || ev === 'readable') {
77
+ this[kReading] = true
78
+ }
79
+ return super.on(ev, ...args)
80
+ }
81
+
82
+ addListener (ev, ...args) {
83
+ return this.on(ev, ...args)
84
+ }
85
+
86
+ off (ev, ...args) {
87
+ const ret = super.off(ev, ...args)
88
+ if (ev === 'data' || ev === 'readable') {
89
+ this[kReading] = (
90
+ this.listenerCount('data') > 0 ||
91
+ this.listenerCount('readable') > 0
92
+ )
93
+ }
94
+ return ret
95
+ }
96
+
97
+ removeListener (ev, ...args) {
98
+ return this.off(ev, ...args)
99
+ }
100
+
101
+ push (chunk) {
102
+ if (this[kConsume] && chunk !== null) {
103
+ consumePush(this[kConsume], chunk)
104
+ return this[kReading] ? super.push(chunk) : true
105
+ }
106
+ return super.push(chunk)
107
+ }
108
+
109
+ // https://fetch.spec.whatwg.org/#dom-body-text
110
+ async text () {
111
+ return consume(this, 'text')
112
+ }
113
+
114
+ // https://fetch.spec.whatwg.org/#dom-body-json
115
+ async json () {
116
+ return consume(this, 'json')
117
+ }
118
+
119
+ // https://fetch.spec.whatwg.org/#dom-body-blob
120
+ async blob () {
121
+ return consume(this, 'blob')
122
+ }
123
+
124
+ // https://fetch.spec.whatwg.org/#dom-body-bytes
125
+ async bytes () {
126
+ return consume(this, 'bytes')
127
+ }
128
+
129
+ // https://fetch.spec.whatwg.org/#dom-body-arraybuffer
130
+ async arrayBuffer () {
131
+ return consume(this, 'arrayBuffer')
132
+ }
133
+
134
+ // https://fetch.spec.whatwg.org/#dom-body-formdata
135
+ async formData () {
136
+ // TODO: Implement.
137
+ throw new NotSupportedError()
138
+ }
139
+
140
+ // https://fetch.spec.whatwg.org/#dom-body-bodyused
141
+ get bodyUsed () {
142
+ return util.isDisturbed(this)
143
+ }
144
+
145
+ // https://fetch.spec.whatwg.org/#dom-body-body
146
+ get body () {
147
+ if (!this[kBody]) {
148
+ this[kBody] = ReadableStreamFrom(this)
149
+ if (this[kConsume]) {
150
+ // TODO: Is this the best way to force a lock?
151
+ this[kBody].getReader() // Ensure stream is locked.
152
+ assert(this[kBody].locked)
153
+ }
154
+ }
155
+ return this[kBody]
156
+ }
157
+
158
+ async dump (opts) {
159
+ let limit = Number.isFinite(opts?.limit) ? opts.limit : 128 * 1024
160
+ const signal = opts?.signal
161
+
162
+ if (signal != null && (typeof signal !== 'object' || !('aborted' in signal))) {
163
+ throw new InvalidArgumentError('signal must be an AbortSignal')
164
+ }
165
+
166
+ signal?.throwIfAborted()
167
+
168
+ if (this._readableState.closeEmitted) {
169
+ return null
170
+ }
171
+
172
+ return await new Promise((resolve, reject) => {
173
+ if (this[kContentLength] > limit) {
174
+ this.destroy(new AbortError())
175
+ }
176
+
177
+ const onAbort = () => {
178
+ this.destroy(signal.reason ?? new AbortError())
179
+ }
180
+ signal?.addEventListener('abort', onAbort)
181
+
182
+ this
183
+ .on('close', function () {
184
+ signal?.removeEventListener('abort', onAbort)
185
+ if (signal?.aborted) {
186
+ reject(signal.reason ?? new AbortError())
187
+ } else {
188
+ resolve(null)
189
+ }
190
+ })
191
+ .on('error', noop)
192
+ .on('data', function (chunk) {
193
+ limit -= chunk.length
194
+ if (limit <= 0) {
195
+ this.destroy()
196
+ }
197
+ })
198
+ .resume()
199
+ })
200
+ }
201
+ }
202
+
203
+ // https://streams.spec.whatwg.org/#readablestream-locked
204
+ function isLocked (self) {
205
+ // Consume is an implicit lock.
206
+ return (self[kBody] && self[kBody].locked === true) || self[kConsume]
207
+ }
208
+
209
+ // https://fetch.spec.whatwg.org/#body-unusable
210
+ function isUnusable (self) {
211
+ return util.isDisturbed(self) || isLocked(self)
212
+ }
213
+
214
+ async function consume (stream, type) {
215
+ assert(!stream[kConsume])
216
+
217
+ return new Promise((resolve, reject) => {
218
+ if (isUnusable(stream)) {
219
+ const rState = stream._readableState
220
+ if (rState.destroyed && rState.closeEmitted === false) {
221
+ stream
222
+ .on('error', err => {
223
+ reject(err)
224
+ })
225
+ .on('close', () => {
226
+ reject(new TypeError('unusable'))
227
+ })
228
+ } else {
229
+ reject(rState.errored ?? new TypeError('unusable'))
230
+ }
231
+ } else {
232
+ queueMicrotask(() => {
233
+ stream[kConsume] = {
234
+ type,
235
+ stream,
236
+ resolve,
237
+ reject,
238
+ length: 0,
239
+ body: []
240
+ }
241
+
242
+ stream
243
+ .on('error', function (err) {
244
+ consumeFinish(this[kConsume], err)
245
+ })
246
+ .on('close', function () {
247
+ if (this[kConsume].body !== null) {
248
+ consumeFinish(this[kConsume], new RequestAbortedError())
249
+ }
250
+ })
251
+
252
+ consumeStart(stream[kConsume])
253
+ })
254
+ }
255
+ })
256
+ }
257
+
258
+ function consumeStart (consume) {
259
+ if (consume.body === null) {
260
+ return
261
+ }
262
+
263
+ const { _readableState: state } = consume.stream
264
+
265
+ if (state.bufferIndex) {
266
+ const start = state.bufferIndex
267
+ const end = state.buffer.length
268
+ for (let n = start; n < end; n++) {
269
+ consumePush(consume, state.buffer[n])
270
+ }
271
+ } else {
272
+ for (const chunk of state.buffer) {
273
+ consumePush(consume, chunk)
274
+ }
275
+ }
276
+
277
+ if (state.endEmitted) {
278
+ consumeEnd(this[kConsume])
279
+ } else {
280
+ consume.stream.on('end', function () {
281
+ consumeEnd(this[kConsume])
282
+ })
283
+ }
284
+
285
+ consume.stream.resume()
286
+
287
+ while (consume.stream.read() != null) {
288
+ // Loop
289
+ }
290
+ }
291
+
292
+ /**
293
+ * @param {Buffer[]} chunks
294
+ * @param {number} length
295
+ */
296
+ function chunksDecode (chunks, length) {
297
+ if (chunks.length === 0 || length === 0) {
298
+ return ''
299
+ }
300
+ const buffer = chunks.length === 1 ? chunks[0] : Buffer.concat(chunks, length)
301
+ const bufferLength = buffer.length
302
+
303
+ // Skip BOM.
304
+ const start =
305
+ bufferLength > 2 &&
306
+ buffer[0] === 0xef &&
307
+ buffer[1] === 0xbb &&
308
+ buffer[2] === 0xbf
309
+ ? 3
310
+ : 0
311
+ return buffer.utf8Slice(start, bufferLength)
312
+ }
313
+
314
+ /**
315
+ * @param {Buffer[]} chunks
316
+ * @param {number} length
317
+ * @returns {Uint8Array}
318
+ */
319
+ function chunksConcat (chunks, length) {
320
+ if (chunks.length === 0 || length === 0) {
321
+ return new Uint8Array(0)
322
+ }
323
+ if (chunks.length === 1) {
324
+ // fast-path
325
+ return new Uint8Array(chunks[0])
326
+ }
327
+ const buffer = new Uint8Array(Buffer.allocUnsafeSlow(length).buffer)
328
+
329
+ let offset = 0
330
+ for (let i = 0; i < chunks.length; ++i) {
331
+ const chunk = chunks[i]
332
+ buffer.set(chunk, offset)
333
+ offset += chunk.length
334
+ }
335
+
336
+ return buffer
337
+ }
338
+
339
+ function consumeEnd (consume) {
340
+ const { type, body, resolve, stream, length } = consume
341
+
342
+ try {
343
+ if (type === 'text') {
344
+ resolve(chunksDecode(body, length))
345
+ } else if (type === 'json') {
346
+ resolve(JSON.parse(chunksDecode(body, length)))
347
+ } else if (type === 'arrayBuffer') {
348
+ resolve(chunksConcat(body, length).buffer)
349
+ } else if (type === 'blob') {
350
+ resolve(new Blob(body, { type: stream[kContentType] }))
351
+ } else if (type === 'bytes') {
352
+ resolve(chunksConcat(body, length))
353
+ }
354
+
355
+ consumeFinish(consume)
356
+ } catch (err) {
357
+ stream.destroy(err)
358
+ }
359
+ }
360
+
361
+ function consumePush (consume, chunk) {
362
+ consume.length += chunk.length
363
+ consume.body.push(chunk)
364
+ }
365
+
366
+ function consumeFinish (consume, err) {
367
+ if (consume.body === null) {
368
+ return
369
+ }
370
+
371
+ if (err) {
372
+ consume.reject(err)
373
+ } else {
374
+ consume.resolve()
375
+ }
376
+
377
+ consume.type = null
378
+ consume.stream = null
379
+ consume.resolve = null
380
+ consume.reject = null
381
+ consume.length = 0
382
+ consume.body = null
383
+ }
384
+
385
+ module.exports = { Readable: BodyReadable, chunksDecode }
@@ -0,0 +1,93 @@
1
+ const assert = require('node:assert')
2
+ const {
3
+ ResponseStatusCodeError
4
+ } = require('../core/errors')
5
+
6
+ const { chunksDecode } = require('./readable')
7
+ const CHUNK_LIMIT = 128 * 1024
8
+
9
+ async function getResolveErrorBodyCallback ({ callback, body, contentType, statusCode, statusMessage, headers }) {
10
+ assert(body)
11
+
12
+ let chunks = []
13
+ let length = 0
14
+
15
+ try {
16
+ for await (const chunk of body) {
17
+ chunks.push(chunk)
18
+ length += chunk.length
19
+ if (length > CHUNK_LIMIT) {
20
+ chunks = []
21
+ length = 0
22
+ break
23
+ }
24
+ }
25
+ } catch {
26
+ chunks = []
27
+ length = 0
28
+ // Do nothing....
29
+ }
30
+
31
+ const message = `Response status code ${statusCode}${statusMessage ? `: ${statusMessage}` : ''}`
32
+
33
+ if (statusCode === 204 || !contentType || !length) {
34
+ queueMicrotask(() => callback(new ResponseStatusCodeError(message, statusCode, headers)))
35
+ return
36
+ }
37
+
38
+ const stackTraceLimit = Error.stackTraceLimit
39
+ Error.stackTraceLimit = 0
40
+ let payload
41
+
42
+ try {
43
+ if (isContentTypeApplicationJson(contentType)) {
44
+ payload = JSON.parse(chunksDecode(chunks, length))
45
+ } else if (isContentTypeText(contentType)) {
46
+ payload = chunksDecode(chunks, length)
47
+ }
48
+ } catch {
49
+ // process in a callback to avoid throwing in the microtask queue
50
+ } finally {
51
+ Error.stackTraceLimit = stackTraceLimit
52
+ }
53
+ queueMicrotask(() => callback(new ResponseStatusCodeError(message, statusCode, headers, payload)))
54
+ }
55
+
56
+ const isContentTypeApplicationJson = (contentType) => {
57
+ return (
58
+ contentType.length > 15 &&
59
+ contentType[11] === '/' &&
60
+ contentType[0] === 'a' &&
61
+ contentType[1] === 'p' &&
62
+ contentType[2] === 'p' &&
63
+ contentType[3] === 'l' &&
64
+ contentType[4] === 'i' &&
65
+ contentType[5] === 'c' &&
66
+ contentType[6] === 'a' &&
67
+ contentType[7] === 't' &&
68
+ contentType[8] === 'i' &&
69
+ contentType[9] === 'o' &&
70
+ contentType[10] === 'n' &&
71
+ contentType[12] === 'j' &&
72
+ contentType[13] === 's' &&
73
+ contentType[14] === 'o' &&
74
+ contentType[15] === 'n'
75
+ )
76
+ }
77
+
78
+ const isContentTypeText = (contentType) => {
79
+ return (
80
+ contentType.length > 4 &&
81
+ contentType[4] === '/' &&
82
+ contentType[0] === 't' &&
83
+ contentType[1] === 'e' &&
84
+ contentType[2] === 'x' &&
85
+ contentType[3] === 't'
86
+ )
87
+ }
88
+
89
+ module.exports = {
90
+ getResolveErrorBodyCallback,
91
+ isContentTypeApplicationJson,
92
+ isContentTypeText
93
+ }
@@ -0,0 +1,240 @@
1
+ 'use strict'
2
+
3
+ const net = require('node:net')
4
+ const assert = require('node:assert')
5
+ const util = require('./util')
6
+ const { InvalidArgumentError, ConnectTimeoutError } = require('./errors')
7
+ const timers = require('../util/timers')
8
+
9
+ function noop () {}
10
+
11
+ let tls // include tls conditionally since it is not always available
12
+
13
+ // TODO: session re-use does not wait for the first
14
+ // connection to resolve the session and might therefore
15
+ // resolve the same servername multiple times even when
16
+ // re-use is enabled.
17
+
18
+ let SessionCache
19
+ // FIXME: remove workaround when the Node bug is fixed
20
+ // https://github.com/nodejs/node/issues/49344#issuecomment-1741776308
21
+ if (global.FinalizationRegistry && !(process.env.NODE_V8_COVERAGE || process.env.UNDICI_NO_FG)) {
22
+ SessionCache = class WeakSessionCache {
23
+ constructor (maxCachedSessions) {
24
+ this._maxCachedSessions = maxCachedSessions
25
+ this._sessionCache = new Map()
26
+ this._sessionRegistry = new global.FinalizationRegistry((key) => {
27
+ if (this._sessionCache.size < this._maxCachedSessions) {
28
+ return
29
+ }
30
+
31
+ const ref = this._sessionCache.get(key)
32
+ if (ref !== undefined && ref.deref() === undefined) {
33
+ this._sessionCache.delete(key)
34
+ }
35
+ })
36
+ }
37
+
38
+ get (sessionKey) {
39
+ const ref = this._sessionCache.get(sessionKey)
40
+ return ref ? ref.deref() : null
41
+ }
42
+
43
+ set (sessionKey, session) {
44
+ if (this._maxCachedSessions === 0) {
45
+ return
46
+ }
47
+
48
+ this._sessionCache.set(sessionKey, new WeakRef(session))
49
+ this._sessionRegistry.register(session, sessionKey)
50
+ }
51
+ }
52
+ } else {
53
+ SessionCache = class SimpleSessionCache {
54
+ constructor (maxCachedSessions) {
55
+ this._maxCachedSessions = maxCachedSessions
56
+ this._sessionCache = new Map()
57
+ }
58
+
59
+ get (sessionKey) {
60
+ return this._sessionCache.get(sessionKey)
61
+ }
62
+
63
+ set (sessionKey, session) {
64
+ if (this._maxCachedSessions === 0) {
65
+ return
66
+ }
67
+
68
+ if (this._sessionCache.size >= this._maxCachedSessions) {
69
+ // remove the oldest session
70
+ const { value: oldestKey } = this._sessionCache.keys().next()
71
+ this._sessionCache.delete(oldestKey)
72
+ }
73
+
74
+ this._sessionCache.set(sessionKey, session)
75
+ }
76
+ }
77
+ }
78
+
79
+ function buildConnector ({ allowH2, maxCachedSessions, socketPath, timeout, session: customSession, ...opts }) {
80
+ if (maxCachedSessions != null && (!Number.isInteger(maxCachedSessions) || maxCachedSessions < 0)) {
81
+ throw new InvalidArgumentError('maxCachedSessions must be a positive integer or zero')
82
+ }
83
+
84
+ const options = { path: socketPath, ...opts }
85
+ const sessionCache = new SessionCache(maxCachedSessions == null ? 100 : maxCachedSessions)
86
+ timeout = timeout == null ? 10e3 : timeout
87
+ allowH2 = allowH2 != null ? allowH2 : false
88
+ return function connect ({ hostname, host, protocol, port, servername, localAddress, httpSocket }, callback) {
89
+ let socket
90
+ if (protocol === 'https:') {
91
+ if (!tls) {
92
+ tls = require('node:tls')
93
+ }
94
+ servername = servername || options.servername || util.getServerName(host) || null
95
+
96
+ const sessionKey = servername || hostname
97
+ assert(sessionKey)
98
+
99
+ const session = customSession || sessionCache.get(sessionKey) || null
100
+
101
+ port = port || 443
102
+
103
+ socket = tls.connect({
104
+ highWaterMark: 16384, // TLS in node can't have bigger HWM anyway...
105
+ ...options,
106
+ servername,
107
+ session,
108
+ localAddress,
109
+ // TODO(HTTP/2): Add support for h2c
110
+ ALPNProtocols: allowH2 ? ['http/1.1', 'h2'] : ['http/1.1'],
111
+ socket: httpSocket, // upgrade socket connection
112
+ port,
113
+ host: hostname
114
+ })
115
+
116
+ socket
117
+ .on('session', function (session) {
118
+ // TODO (fix): Can a session become invalid once established? Don't think so?
119
+ sessionCache.set(sessionKey, session)
120
+ })
121
+ } else {
122
+ assert(!httpSocket, 'httpSocket can only be sent on TLS update')
123
+
124
+ port = port || 80
125
+
126
+ socket = net.connect({
127
+ highWaterMark: 64 * 1024, // Same as nodejs fs streams.
128
+ ...options,
129
+ localAddress,
130
+ port,
131
+ host: hostname
132
+ })
133
+ }
134
+
135
+ // Set TCP keep alive options on the socket here instead of in connect() for the case of assigning the socket
136
+ if (options.keepAlive == null || options.keepAlive) {
137
+ const keepAliveInitialDelay = options.keepAliveInitialDelay === undefined ? 60e3 : options.keepAliveInitialDelay
138
+ socket.setKeepAlive(true, keepAliveInitialDelay)
139
+ }
140
+
141
+ const clearConnectTimeout = setupConnectTimeout(new WeakRef(socket), { timeout, hostname, port })
142
+
143
+ socket
144
+ .setNoDelay(true)
145
+ .once(protocol === 'https:' ? 'secureConnect' : 'connect', function () {
146
+ queueMicrotask(clearConnectTimeout)
147
+
148
+ if (callback) {
149
+ const cb = callback
150
+ callback = null
151
+ cb(null, this)
152
+ }
153
+ })
154
+ .on('error', function (err) {
155
+ queueMicrotask(clearConnectTimeout)
156
+
157
+ if (callback) {
158
+ const cb = callback
159
+ callback = null
160
+ cb(err)
161
+ }
162
+ })
163
+
164
+ return socket
165
+ }
166
+ }
167
+
168
+ /**
169
+ * @param {WeakRef<net.Socket>} socketWeakRef
170
+ * @param {object} opts
171
+ * @param {number} opts.timeout
172
+ * @param {string} opts.hostname
173
+ * @param {number} opts.port
174
+ * @returns {() => void}
175
+ */
176
+ const setupConnectTimeout = process.platform === 'win32'
177
+ ? (socketWeakRef, opts) => {
178
+ if (!opts.timeout) {
179
+ return noop
180
+ }
181
+
182
+ let s1 = null
183
+ let s2 = null
184
+ const fastTimer = timers.setFastTimeout(() => {
185
+ // setImmediate is added to make sure that we prioritize socket error events over timeouts
186
+ s1 = setImmediate(() => {
187
+ // Windows needs an extra setImmediate probably due to implementation differences in the socket logic
188
+ s2 = setImmediate(() => onConnectTimeout(socketWeakRef.deref(), opts))
189
+ })
190
+ }, opts.timeout)
191
+ return () => {
192
+ timers.clearFastTimeout(fastTimer)
193
+ clearImmediate(s1)
194
+ clearImmediate(s2)
195
+ }
196
+ }
197
+ : (socketWeakRef, opts) => {
198
+ if (!opts.timeout) {
199
+ return noop
200
+ }
201
+
202
+ let s1 = null
203
+ const fastTimer = timers.setFastTimeout(() => {
204
+ // setImmediate is added to make sure that we prioritize socket error events over timeouts
205
+ s1 = setImmediate(() => {
206
+ onConnectTimeout(socketWeakRef.deref(), opts)
207
+ })
208
+ }, opts.timeout)
209
+ return () => {
210
+ timers.clearFastTimeout(fastTimer)
211
+ clearImmediate(s1)
212
+ }
213
+ }
214
+
215
+ /**
216
+ * @param {net.Socket} socket
217
+ * @param {object} opts
218
+ * @param {number} opts.timeout
219
+ * @param {string} opts.hostname
220
+ * @param {number} opts.port
221
+ */
222
+ function onConnectTimeout (socket, opts) {
223
+ // The socket could be already garbage collected
224
+ if (socket == null) {
225
+ return
226
+ }
227
+
228
+ let message = 'Connect Timeout Error'
229
+ if (Array.isArray(socket.autoSelectFamilyAttemptedAddresses)) {
230
+ message += ` (attempted addresses: ${socket.autoSelectFamilyAttemptedAddresses.join(', ')},`
231
+ } else {
232
+ message += ` (attempted address: ${opts.hostname}:${opts.port},`
233
+ }
234
+
235
+ message += ` timeout: ${opts.timeout}ms)`
236
+
237
+ util.destroy(socket, new ConnectTimeoutError(message))
238
+ }
239
+
240
+ module.exports = buildConnector