pnpm 11.0.5 → 11.0.7

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 +5915 -5140
  123. package/dist/worker.js +70 -67
  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,687 @@
1
+ // https://github.com/Ethan-Arrowood/undici-fetch
2
+
3
+ 'use strict'
4
+
5
+ const { kConstruct } = require('../../core/symbols')
6
+ const { kEnumerableProperty } = require('../../core/util')
7
+ const {
8
+ iteratorMixin,
9
+ isValidHeaderName,
10
+ isValidHeaderValue
11
+ } = require('./util')
12
+ const { webidl } = require('./webidl')
13
+ const assert = require('node:assert')
14
+ const util = require('node:util')
15
+
16
+ const kHeadersMap = Symbol('headers map')
17
+ const kHeadersSortedMap = Symbol('headers map sorted')
18
+
19
+ /**
20
+ * @param {number} code
21
+ */
22
+ function isHTTPWhiteSpaceCharCode (code) {
23
+ return code === 0x00a || code === 0x00d || code === 0x009 || code === 0x020
24
+ }
25
+
26
+ /**
27
+ * @see https://fetch.spec.whatwg.org/#concept-header-value-normalize
28
+ * @param {string} potentialValue
29
+ */
30
+ function headerValueNormalize (potentialValue) {
31
+ // To normalize a byte sequence potentialValue, remove
32
+ // any leading and trailing HTTP whitespace bytes from
33
+ // potentialValue.
34
+ let i = 0; let j = potentialValue.length
35
+
36
+ while (j > i && isHTTPWhiteSpaceCharCode(potentialValue.charCodeAt(j - 1))) --j
37
+ while (j > i && isHTTPWhiteSpaceCharCode(potentialValue.charCodeAt(i))) ++i
38
+
39
+ return i === 0 && j === potentialValue.length ? potentialValue : potentialValue.substring(i, j)
40
+ }
41
+
42
+ function fill (headers, object) {
43
+ // To fill a Headers object headers with a given object object, run these steps:
44
+
45
+ // 1. If object is a sequence, then for each header in object:
46
+ // Note: webidl conversion to array has already been done.
47
+ if (Array.isArray(object)) {
48
+ for (let i = 0; i < object.length; ++i) {
49
+ const header = object[i]
50
+ // 1. If header does not contain exactly two items, then throw a TypeError.
51
+ if (header.length !== 2) {
52
+ throw webidl.errors.exception({
53
+ header: 'Headers constructor',
54
+ message: `expected name/value pair to be length 2, found ${header.length}.`
55
+ })
56
+ }
57
+
58
+ // 2. Append (header’s first item, header’s second item) to headers.
59
+ appendHeader(headers, header[0], header[1])
60
+ }
61
+ } else if (typeof object === 'object' && object !== null) {
62
+ // Note: null should throw
63
+
64
+ // 2. Otherwise, object is a record, then for each key → value in object,
65
+ // append (key, value) to headers
66
+ const keys = Object.keys(object)
67
+ for (let i = 0; i < keys.length; ++i) {
68
+ appendHeader(headers, keys[i], object[keys[i]])
69
+ }
70
+ } else {
71
+ throw webidl.errors.conversionFailed({
72
+ prefix: 'Headers constructor',
73
+ argument: 'Argument 1',
74
+ types: ['sequence<sequence<ByteString>>', 'record<ByteString, ByteString>']
75
+ })
76
+ }
77
+ }
78
+
79
+ /**
80
+ * @see https://fetch.spec.whatwg.org/#concept-headers-append
81
+ */
82
+ function appendHeader (headers, name, value) {
83
+ // 1. Normalize value.
84
+ value = headerValueNormalize(value)
85
+
86
+ // 2. If name is not a header name or value is not a
87
+ // header value, then throw a TypeError.
88
+ if (!isValidHeaderName(name)) {
89
+ throw webidl.errors.invalidArgument({
90
+ prefix: 'Headers.append',
91
+ value: name,
92
+ type: 'header name'
93
+ })
94
+ } else if (!isValidHeaderValue(value)) {
95
+ throw webidl.errors.invalidArgument({
96
+ prefix: 'Headers.append',
97
+ value,
98
+ type: 'header value'
99
+ })
100
+ }
101
+
102
+ // 3. If headers’s guard is "immutable", then throw a TypeError.
103
+ // 4. Otherwise, if headers’s guard is "request" and name is a
104
+ // forbidden header name, return.
105
+ // 5. Otherwise, if headers’s guard is "request-no-cors":
106
+ // TODO
107
+ // Note: undici does not implement forbidden header names
108
+ if (getHeadersGuard(headers) === 'immutable') {
109
+ throw new TypeError('immutable')
110
+ }
111
+
112
+ // 6. Otherwise, if headers’s guard is "response" and name is a
113
+ // forbidden response-header name, return.
114
+
115
+ // 7. Append (name, value) to headers’s header list.
116
+ return getHeadersList(headers).append(name, value, false)
117
+
118
+ // 8. If headers’s guard is "request-no-cors", then remove
119
+ // privileged no-CORS request headers from headers
120
+ }
121
+
122
+ function compareHeaderName (a, b) {
123
+ return a[0] < b[0] ? -1 : 1
124
+ }
125
+
126
+ class HeadersList {
127
+ /** @type {[string, string][]|null} */
128
+ cookies = null
129
+
130
+ constructor (init) {
131
+ if (init instanceof HeadersList) {
132
+ this[kHeadersMap] = new Map(init[kHeadersMap])
133
+ this[kHeadersSortedMap] = init[kHeadersSortedMap]
134
+ this.cookies = init.cookies === null ? null : [...init.cookies]
135
+ } else {
136
+ this[kHeadersMap] = new Map(init)
137
+ this[kHeadersSortedMap] = null
138
+ }
139
+ }
140
+
141
+ /**
142
+ * @see https://fetch.spec.whatwg.org/#header-list-contains
143
+ * @param {string} name
144
+ * @param {boolean} isLowerCase
145
+ */
146
+ contains (name, isLowerCase) {
147
+ // A header list list contains a header name name if list
148
+ // contains a header whose name is a byte-case-insensitive
149
+ // match for name.
150
+
151
+ return this[kHeadersMap].has(isLowerCase ? name : name.toLowerCase())
152
+ }
153
+
154
+ clear () {
155
+ this[kHeadersMap].clear()
156
+ this[kHeadersSortedMap] = null
157
+ this.cookies = null
158
+ }
159
+
160
+ /**
161
+ * @see https://fetch.spec.whatwg.org/#concept-header-list-append
162
+ * @param {string} name
163
+ * @param {string} value
164
+ * @param {boolean} isLowerCase
165
+ */
166
+ append (name, value, isLowerCase) {
167
+ this[kHeadersSortedMap] = null
168
+
169
+ // 1. If list contains name, then set name to the first such
170
+ // header’s name.
171
+ const lowercaseName = isLowerCase ? name : name.toLowerCase()
172
+ const exists = this[kHeadersMap].get(lowercaseName)
173
+
174
+ // 2. Append (name, value) to list.
175
+ if (exists) {
176
+ const delimiter = lowercaseName === 'cookie' ? '; ' : ', '
177
+ this[kHeadersMap].set(lowercaseName, {
178
+ name: exists.name,
179
+ value: `${exists.value}${delimiter}${value}`
180
+ })
181
+ } else {
182
+ this[kHeadersMap].set(lowercaseName, { name, value })
183
+ }
184
+
185
+ if (lowercaseName === 'set-cookie') {
186
+ (this.cookies ??= []).push(value)
187
+ }
188
+ }
189
+
190
+ /**
191
+ * @see https://fetch.spec.whatwg.org/#concept-header-list-set
192
+ * @param {string} name
193
+ * @param {string} value
194
+ * @param {boolean} isLowerCase
195
+ */
196
+ set (name, value, isLowerCase) {
197
+ this[kHeadersSortedMap] = null
198
+ const lowercaseName = isLowerCase ? name : name.toLowerCase()
199
+
200
+ if (lowercaseName === 'set-cookie') {
201
+ this.cookies = [value]
202
+ }
203
+
204
+ // 1. If list contains name, then set the value of
205
+ // the first such header to value and remove the
206
+ // others.
207
+ // 2. Otherwise, append header (name, value) to list.
208
+ this[kHeadersMap].set(lowercaseName, { name, value })
209
+ }
210
+
211
+ /**
212
+ * @see https://fetch.spec.whatwg.org/#concept-header-list-delete
213
+ * @param {string} name
214
+ * @param {boolean} isLowerCase
215
+ */
216
+ delete (name, isLowerCase) {
217
+ this[kHeadersSortedMap] = null
218
+ if (!isLowerCase) name = name.toLowerCase()
219
+
220
+ if (name === 'set-cookie') {
221
+ this.cookies = null
222
+ }
223
+
224
+ this[kHeadersMap].delete(name)
225
+ }
226
+
227
+ /**
228
+ * @see https://fetch.spec.whatwg.org/#concept-header-list-get
229
+ * @param {string} name
230
+ * @param {boolean} isLowerCase
231
+ * @returns {string | null}
232
+ */
233
+ get (name, isLowerCase) {
234
+ // 1. If list does not contain name, then return null.
235
+ // 2. Return the values of all headers in list whose name
236
+ // is a byte-case-insensitive match for name,
237
+ // separated from each other by 0x2C 0x20, in order.
238
+ return this[kHeadersMap].get(isLowerCase ? name : name.toLowerCase())?.value ?? null
239
+ }
240
+
241
+ * [Symbol.iterator] () {
242
+ // use the lowercased name
243
+ for (const { 0: name, 1: { value } } of this[kHeadersMap]) {
244
+ yield [name, value]
245
+ }
246
+ }
247
+
248
+ get entries () {
249
+ const headers = {}
250
+
251
+ if (this[kHeadersMap].size !== 0) {
252
+ for (const { name, value } of this[kHeadersMap].values()) {
253
+ headers[name] = value
254
+ }
255
+ }
256
+
257
+ return headers
258
+ }
259
+
260
+ rawValues () {
261
+ return this[kHeadersMap].values()
262
+ }
263
+
264
+ get entriesList () {
265
+ const headers = []
266
+
267
+ if (this[kHeadersMap].size !== 0) {
268
+ for (const { 0: lowerName, 1: { name, value } } of this[kHeadersMap]) {
269
+ if (lowerName === 'set-cookie') {
270
+ for (const cookie of this.cookies) {
271
+ headers.push([name, cookie])
272
+ }
273
+ } else {
274
+ headers.push([name, value])
275
+ }
276
+ }
277
+ }
278
+
279
+ return headers
280
+ }
281
+
282
+ // https://fetch.spec.whatwg.org/#convert-header-names-to-a-sorted-lowercase-set
283
+ toSortedArray () {
284
+ const size = this[kHeadersMap].size
285
+ const array = new Array(size)
286
+ // In most cases, you will use the fast-path.
287
+ // fast-path: Use binary insertion sort for small arrays.
288
+ if (size <= 32) {
289
+ if (size === 0) {
290
+ // If empty, it is an empty array. To avoid the first index assignment.
291
+ return array
292
+ }
293
+ // Improve performance by unrolling loop and avoiding double-loop.
294
+ // Double-loop-less version of the binary insertion sort.
295
+ const iterator = this[kHeadersMap][Symbol.iterator]()
296
+ const firstValue = iterator.next().value
297
+ // set [name, value] to first index.
298
+ array[0] = [firstValue[0], firstValue[1].value]
299
+ // https://fetch.spec.whatwg.org/#concept-header-list-sort-and-combine
300
+ // 3.2.2. Assert: value is non-null.
301
+ assert(firstValue[1].value !== null)
302
+ for (
303
+ let i = 1, j = 0, right = 0, left = 0, pivot = 0, x, value;
304
+ i < size;
305
+ ++i
306
+ ) {
307
+ // get next value
308
+ value = iterator.next().value
309
+ // set [name, value] to current index.
310
+ x = array[i] = [value[0], value[1].value]
311
+ // https://fetch.spec.whatwg.org/#concept-header-list-sort-and-combine
312
+ // 3.2.2. Assert: value is non-null.
313
+ assert(x[1] !== null)
314
+ left = 0
315
+ right = i
316
+ // binary search
317
+ while (left < right) {
318
+ // middle index
319
+ pivot = left + ((right - left) >> 1)
320
+ // compare header name
321
+ if (array[pivot][0] <= x[0]) {
322
+ left = pivot + 1
323
+ } else {
324
+ right = pivot
325
+ }
326
+ }
327
+ if (i !== pivot) {
328
+ j = i
329
+ while (j > left) {
330
+ array[j] = array[--j]
331
+ }
332
+ array[left] = x
333
+ }
334
+ }
335
+ /* c8 ignore next 4 */
336
+ if (!iterator.next().done) {
337
+ // This is for debugging and will never be called.
338
+ throw new TypeError('Unreachable')
339
+ }
340
+ return array
341
+ } else {
342
+ // This case would be a rare occurrence.
343
+ // slow-path: fallback
344
+ let i = 0
345
+ for (const { 0: name, 1: { value } } of this[kHeadersMap]) {
346
+ array[i++] = [name, value]
347
+ // https://fetch.spec.whatwg.org/#concept-header-list-sort-and-combine
348
+ // 3.2.2. Assert: value is non-null.
349
+ assert(value !== null)
350
+ }
351
+ return array.sort(compareHeaderName)
352
+ }
353
+ }
354
+ }
355
+
356
+ // https://fetch.spec.whatwg.org/#headers-class
357
+ class Headers {
358
+ #guard
359
+ #headersList
360
+
361
+ constructor (init = undefined) {
362
+ webidl.util.markAsUncloneable(this)
363
+
364
+ if (init === kConstruct) {
365
+ return
366
+ }
367
+
368
+ this.#headersList = new HeadersList()
369
+
370
+ // The new Headers(init) constructor steps are:
371
+
372
+ // 1. Set this’s guard to "none".
373
+ this.#guard = 'none'
374
+
375
+ // 2. If init is given, then fill this with init.
376
+ if (init !== undefined) {
377
+ init = webidl.converters.HeadersInit(init, 'Headers contructor', 'init')
378
+ fill(this, init)
379
+ }
380
+ }
381
+
382
+ // https://fetch.spec.whatwg.org/#dom-headers-append
383
+ append (name, value) {
384
+ webidl.brandCheck(this, Headers)
385
+
386
+ webidl.argumentLengthCheck(arguments, 2, 'Headers.append')
387
+
388
+ const prefix = 'Headers.append'
389
+ name = webidl.converters.ByteString(name, prefix, 'name')
390
+ value = webidl.converters.ByteString(value, prefix, 'value')
391
+
392
+ return appendHeader(this, name, value)
393
+ }
394
+
395
+ // https://fetch.spec.whatwg.org/#dom-headers-delete
396
+ delete (name) {
397
+ webidl.brandCheck(this, Headers)
398
+
399
+ webidl.argumentLengthCheck(arguments, 1, 'Headers.delete')
400
+
401
+ const prefix = 'Headers.delete'
402
+ name = webidl.converters.ByteString(name, prefix, 'name')
403
+
404
+ // 1. If name is not a header name, then throw a TypeError.
405
+ if (!isValidHeaderName(name)) {
406
+ throw webidl.errors.invalidArgument({
407
+ prefix: 'Headers.delete',
408
+ value: name,
409
+ type: 'header name'
410
+ })
411
+ }
412
+
413
+ // 2. If this’s guard is "immutable", then throw a TypeError.
414
+ // 3. Otherwise, if this’s guard is "request" and name is a
415
+ // forbidden header name, return.
416
+ // 4. Otherwise, if this’s guard is "request-no-cors", name
417
+ // is not a no-CORS-safelisted request-header name, and
418
+ // name is not a privileged no-CORS request-header name,
419
+ // return.
420
+ // 5. Otherwise, if this’s guard is "response" and name is
421
+ // a forbidden response-header name, return.
422
+ // Note: undici does not implement forbidden header names
423
+ if (this.#guard === 'immutable') {
424
+ throw new TypeError('immutable')
425
+ }
426
+
427
+ // 6. If this’s header list does not contain name, then
428
+ // return.
429
+ if (!this.#headersList.contains(name, false)) {
430
+ return
431
+ }
432
+
433
+ // 7. Delete name from this’s header list.
434
+ // 8. If this’s guard is "request-no-cors", then remove
435
+ // privileged no-CORS request headers from this.
436
+ this.#headersList.delete(name, false)
437
+ }
438
+
439
+ // https://fetch.spec.whatwg.org/#dom-headers-get
440
+ get (name) {
441
+ webidl.brandCheck(this, Headers)
442
+
443
+ webidl.argumentLengthCheck(arguments, 1, 'Headers.get')
444
+
445
+ const prefix = 'Headers.get'
446
+ name = webidl.converters.ByteString(name, prefix, 'name')
447
+
448
+ // 1. If name is not a header name, then throw a TypeError.
449
+ if (!isValidHeaderName(name)) {
450
+ throw webidl.errors.invalidArgument({
451
+ prefix,
452
+ value: name,
453
+ type: 'header name'
454
+ })
455
+ }
456
+
457
+ // 2. Return the result of getting name from this’s header
458
+ // list.
459
+ return this.#headersList.get(name, false)
460
+ }
461
+
462
+ // https://fetch.spec.whatwg.org/#dom-headers-has
463
+ has (name) {
464
+ webidl.brandCheck(this, Headers)
465
+
466
+ webidl.argumentLengthCheck(arguments, 1, 'Headers.has')
467
+
468
+ const prefix = 'Headers.has'
469
+ name = webidl.converters.ByteString(name, prefix, 'name')
470
+
471
+ // 1. If name is not a header name, then throw a TypeError.
472
+ if (!isValidHeaderName(name)) {
473
+ throw webidl.errors.invalidArgument({
474
+ prefix,
475
+ value: name,
476
+ type: 'header name'
477
+ })
478
+ }
479
+
480
+ // 2. Return true if this’s header list contains name;
481
+ // otherwise false.
482
+ return this.#headersList.contains(name, false)
483
+ }
484
+
485
+ // https://fetch.spec.whatwg.org/#dom-headers-set
486
+ set (name, value) {
487
+ webidl.brandCheck(this, Headers)
488
+
489
+ webidl.argumentLengthCheck(arguments, 2, 'Headers.set')
490
+
491
+ const prefix = 'Headers.set'
492
+ name = webidl.converters.ByteString(name, prefix, 'name')
493
+ value = webidl.converters.ByteString(value, prefix, 'value')
494
+
495
+ // 1. Normalize value.
496
+ value = headerValueNormalize(value)
497
+
498
+ // 2. If name is not a header name or value is not a
499
+ // header value, then throw a TypeError.
500
+ if (!isValidHeaderName(name)) {
501
+ throw webidl.errors.invalidArgument({
502
+ prefix,
503
+ value: name,
504
+ type: 'header name'
505
+ })
506
+ } else if (!isValidHeaderValue(value)) {
507
+ throw webidl.errors.invalidArgument({
508
+ prefix,
509
+ value,
510
+ type: 'header value'
511
+ })
512
+ }
513
+
514
+ // 3. If this’s guard is "immutable", then throw a TypeError.
515
+ // 4. Otherwise, if this’s guard is "request" and name is a
516
+ // forbidden header name, return.
517
+ // 5. Otherwise, if this’s guard is "request-no-cors" and
518
+ // name/value is not a no-CORS-safelisted request-header,
519
+ // return.
520
+ // 6. Otherwise, if this’s guard is "response" and name is a
521
+ // forbidden response-header name, return.
522
+ // Note: undici does not implement forbidden header names
523
+ if (this.#guard === 'immutable') {
524
+ throw new TypeError('immutable')
525
+ }
526
+
527
+ // 7. Set (name, value) in this’s header list.
528
+ // 8. If this’s guard is "request-no-cors", then remove
529
+ // privileged no-CORS request headers from this
530
+ this.#headersList.set(name, value, false)
531
+ }
532
+
533
+ // https://fetch.spec.whatwg.org/#dom-headers-getsetcookie
534
+ getSetCookie () {
535
+ webidl.brandCheck(this, Headers)
536
+
537
+ // 1. If this’s header list does not contain `Set-Cookie`, then return « ».
538
+ // 2. Return the values of all headers in this’s header list whose name is
539
+ // a byte-case-insensitive match for `Set-Cookie`, in order.
540
+
541
+ const list = this.#headersList.cookies
542
+
543
+ if (list) {
544
+ return [...list]
545
+ }
546
+
547
+ return []
548
+ }
549
+
550
+ // https://fetch.spec.whatwg.org/#concept-header-list-sort-and-combine
551
+ get [kHeadersSortedMap] () {
552
+ if (this.#headersList[kHeadersSortedMap]) {
553
+ return this.#headersList[kHeadersSortedMap]
554
+ }
555
+
556
+ // 1. Let headers be an empty list of headers with the key being the name
557
+ // and value the value.
558
+ const headers = []
559
+
560
+ // 2. Let names be the result of convert header names to a sorted-lowercase
561
+ // set with all the names of the headers in list.
562
+ const names = this.#headersList.toSortedArray()
563
+
564
+ const cookies = this.#headersList.cookies
565
+
566
+ // fast-path
567
+ if (cookies === null || cookies.length === 1) {
568
+ // Note: The non-null assertion of value has already been done by `HeadersList#toSortedArray`
569
+ return (this.#headersList[kHeadersSortedMap] = names)
570
+ }
571
+
572
+ // 3. For each name of names:
573
+ for (let i = 0; i < names.length; ++i) {
574
+ const { 0: name, 1: value } = names[i]
575
+ // 1. If name is `set-cookie`, then:
576
+ if (name === 'set-cookie') {
577
+ // 1. Let values be a list of all values of headers in list whose name
578
+ // is a byte-case-insensitive match for name, in order.
579
+
580
+ // 2. For each value of values:
581
+ // 1. Append (name, value) to headers.
582
+ for (let j = 0; j < cookies.length; ++j) {
583
+ headers.push([name, cookies[j]])
584
+ }
585
+ } else {
586
+ // 2. Otherwise:
587
+
588
+ // 1. Let value be the result of getting name from list.
589
+
590
+ // 2. Assert: value is non-null.
591
+ // Note: This operation was done by `HeadersList#toSortedArray`.
592
+
593
+ // 3. Append (name, value) to headers.
594
+ headers.push([name, value])
595
+ }
596
+ }
597
+
598
+ // 4. Return headers.
599
+ return (this.#headersList[kHeadersSortedMap] = headers)
600
+ }
601
+
602
+ [util.inspect.custom] (depth, options) {
603
+ options.depth ??= depth
604
+
605
+ return `Headers ${util.formatWithOptions(options, this.#headersList.entries)}`
606
+ }
607
+
608
+ static getHeadersGuard (o) {
609
+ return o.#guard
610
+ }
611
+
612
+ static setHeadersGuard (o, guard) {
613
+ o.#guard = guard
614
+ }
615
+
616
+ static getHeadersList (o) {
617
+ return o.#headersList
618
+ }
619
+
620
+ static setHeadersList (o, list) {
621
+ o.#headersList = list
622
+ }
623
+ }
624
+
625
+ const { getHeadersGuard, setHeadersGuard, getHeadersList, setHeadersList } = Headers
626
+ Reflect.deleteProperty(Headers, 'getHeadersGuard')
627
+ Reflect.deleteProperty(Headers, 'setHeadersGuard')
628
+ Reflect.deleteProperty(Headers, 'getHeadersList')
629
+ Reflect.deleteProperty(Headers, 'setHeadersList')
630
+
631
+ iteratorMixin('Headers', Headers, kHeadersSortedMap, 0, 1)
632
+
633
+ Object.defineProperties(Headers.prototype, {
634
+ append: kEnumerableProperty,
635
+ delete: kEnumerableProperty,
636
+ get: kEnumerableProperty,
637
+ has: kEnumerableProperty,
638
+ set: kEnumerableProperty,
639
+ getSetCookie: kEnumerableProperty,
640
+ [Symbol.toStringTag]: {
641
+ value: 'Headers',
642
+ configurable: true
643
+ },
644
+ [util.inspect.custom]: {
645
+ enumerable: false
646
+ }
647
+ })
648
+
649
+ webidl.converters.HeadersInit = function (V, prefix, argument) {
650
+ if (webidl.util.Type(V) === 'Object') {
651
+ const iterator = Reflect.get(V, Symbol.iterator)
652
+
653
+ // A work-around to ensure we send the properly-cased Headers when V is a Headers object.
654
+ // Read https://github.com/nodejs/undici/pull/3159#issuecomment-2075537226 before touching, please.
655
+ if (!util.types.isProxy(V) && iterator === Headers.prototype.entries) { // Headers object
656
+ try {
657
+ return getHeadersList(V).entriesList
658
+ } catch {
659
+ // fall-through
660
+ }
661
+ }
662
+
663
+ if (typeof iterator === 'function') {
664
+ return webidl.converters['sequence<sequence<ByteString>>'](V, prefix, argument, iterator.bind(V))
665
+ }
666
+
667
+ return webidl.converters['record<ByteString, ByteString>'](V, prefix, argument)
668
+ }
669
+
670
+ throw webidl.errors.conversionFailed({
671
+ prefix: 'Headers constructor',
672
+ argument: 'Argument 1',
673
+ types: ['sequence<sequence<ByteString>>', 'record<ByteString, ByteString>']
674
+ })
675
+ }
676
+
677
+ module.exports = {
678
+ fill,
679
+ // for test.
680
+ compareHeaderName,
681
+ Headers,
682
+ HeadersList,
683
+ getHeadersGuard,
684
+ setHeadersGuard,
685
+ setHeadersList,
686
+ getHeadersList
687
+ }