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,317 @@
1
+ 'use strict'
2
+
3
+ const { maxNameValuePairSize, maxAttributeValueSize } = require('./constants')
4
+ const { isCTLExcludingHtab } = require('./util')
5
+ const { collectASequenceOfCodePointsFast } = require('../fetch/data-url')
6
+ const assert = require('node:assert')
7
+
8
+ /**
9
+ * @description Parses the field-value attributes of a set-cookie header string.
10
+ * @see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4
11
+ * @param {string} header
12
+ * @returns if the header is invalid, null will be returned
13
+ */
14
+ function parseSetCookie (header) {
15
+ // 1. If the set-cookie-string contains a %x00-08 / %x0A-1F / %x7F
16
+ // character (CTL characters excluding HTAB): Abort these steps and
17
+ // ignore the set-cookie-string entirely.
18
+ if (isCTLExcludingHtab(header)) {
19
+ return null
20
+ }
21
+
22
+ let nameValuePair = ''
23
+ let unparsedAttributes = ''
24
+ let name = ''
25
+ let value = ''
26
+
27
+ // 2. If the set-cookie-string contains a %x3B (";") character:
28
+ if (header.includes(';')) {
29
+ // 1. The name-value-pair string consists of the characters up to,
30
+ // but not including, the first %x3B (";"), and the unparsed-
31
+ // attributes consist of the remainder of the set-cookie-string
32
+ // (including the %x3B (";") in question).
33
+ const position = { position: 0 }
34
+
35
+ nameValuePair = collectASequenceOfCodePointsFast(';', header, position)
36
+ unparsedAttributes = header.slice(position.position)
37
+ } else {
38
+ // Otherwise:
39
+
40
+ // 1. The name-value-pair string consists of all the characters
41
+ // contained in the set-cookie-string, and the unparsed-
42
+ // attributes is the empty string.
43
+ nameValuePair = header
44
+ }
45
+
46
+ // 3. If the name-value-pair string lacks a %x3D ("=") character, then
47
+ // the name string is empty, and the value string is the value of
48
+ // name-value-pair.
49
+ if (!nameValuePair.includes('=')) {
50
+ value = nameValuePair
51
+ } else {
52
+ // Otherwise, the name string consists of the characters up to, but
53
+ // not including, the first %x3D ("=") character, and the (possibly
54
+ // empty) value string consists of the characters after the first
55
+ // %x3D ("=") character.
56
+ const position = { position: 0 }
57
+ name = collectASequenceOfCodePointsFast(
58
+ '=',
59
+ nameValuePair,
60
+ position
61
+ )
62
+ value = nameValuePair.slice(position.position + 1)
63
+ }
64
+
65
+ // 4. Remove any leading or trailing WSP characters from the name
66
+ // string and the value string.
67
+ name = name.trim()
68
+ value = value.trim()
69
+
70
+ // 5. If the sum of the lengths of the name string and the value string
71
+ // is more than 4096 octets, abort these steps and ignore the set-
72
+ // cookie-string entirely.
73
+ if (name.length + value.length > maxNameValuePairSize) {
74
+ return null
75
+ }
76
+
77
+ // 6. The cookie-name is the name string, and the cookie-value is the
78
+ // value string.
79
+ return {
80
+ name, value, ...parseUnparsedAttributes(unparsedAttributes)
81
+ }
82
+ }
83
+
84
+ /**
85
+ * Parses the remaining attributes of a set-cookie header
86
+ * @see https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4
87
+ * @param {string} unparsedAttributes
88
+ * @param {[Object.<string, unknown>]={}} cookieAttributeList
89
+ */
90
+ function parseUnparsedAttributes (unparsedAttributes, cookieAttributeList = {}) {
91
+ // 1. If the unparsed-attributes string is empty, skip the rest of
92
+ // these steps.
93
+ if (unparsedAttributes.length === 0) {
94
+ return cookieAttributeList
95
+ }
96
+
97
+ // 2. Discard the first character of the unparsed-attributes (which
98
+ // will be a %x3B (";") character).
99
+ assert(unparsedAttributes[0] === ';')
100
+ unparsedAttributes = unparsedAttributes.slice(1)
101
+
102
+ let cookieAv = ''
103
+
104
+ // 3. If the remaining unparsed-attributes contains a %x3B (";")
105
+ // character:
106
+ if (unparsedAttributes.includes(';')) {
107
+ // 1. Consume the characters of the unparsed-attributes up to, but
108
+ // not including, the first %x3B (";") character.
109
+ cookieAv = collectASequenceOfCodePointsFast(
110
+ ';',
111
+ unparsedAttributes,
112
+ { position: 0 }
113
+ )
114
+ unparsedAttributes = unparsedAttributes.slice(cookieAv.length)
115
+ } else {
116
+ // Otherwise:
117
+
118
+ // 1. Consume the remainder of the unparsed-attributes.
119
+ cookieAv = unparsedAttributes
120
+ unparsedAttributes = ''
121
+ }
122
+
123
+ // Let the cookie-av string be the characters consumed in this step.
124
+
125
+ let attributeName = ''
126
+ let attributeValue = ''
127
+
128
+ // 4. If the cookie-av string contains a %x3D ("=") character:
129
+ if (cookieAv.includes('=')) {
130
+ // 1. The (possibly empty) attribute-name string consists of the
131
+ // characters up to, but not including, the first %x3D ("=")
132
+ // character, and the (possibly empty) attribute-value string
133
+ // consists of the characters after the first %x3D ("=")
134
+ // character.
135
+ const position = { position: 0 }
136
+
137
+ attributeName = collectASequenceOfCodePointsFast(
138
+ '=',
139
+ cookieAv,
140
+ position
141
+ )
142
+ attributeValue = cookieAv.slice(position.position + 1)
143
+ } else {
144
+ // Otherwise:
145
+
146
+ // 1. The attribute-name string consists of the entire cookie-av
147
+ // string, and the attribute-value string is empty.
148
+ attributeName = cookieAv
149
+ }
150
+
151
+ // 5. Remove any leading or trailing WSP characters from the attribute-
152
+ // name string and the attribute-value string.
153
+ attributeName = attributeName.trim()
154
+ attributeValue = attributeValue.trim()
155
+
156
+ // 6. If the attribute-value is longer than 1024 octets, ignore the
157
+ // cookie-av string and return to Step 1 of this algorithm.
158
+ if (attributeValue.length > maxAttributeValueSize) {
159
+ return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)
160
+ }
161
+
162
+ // 7. Process the attribute-name and attribute-value according to the
163
+ // requirements in the following subsections. (Notice that
164
+ // attributes with unrecognized attribute-names are ignored.)
165
+ const attributeNameLowercase = attributeName.toLowerCase()
166
+
167
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.1
168
+ // If the attribute-name case-insensitively matches the string
169
+ // "Expires", the user agent MUST process the cookie-av as follows.
170
+ if (attributeNameLowercase === 'expires') {
171
+ // 1. Let the expiry-time be the result of parsing the attribute-value
172
+ // as cookie-date (see Section 5.1.1).
173
+ const expiryTime = new Date(attributeValue)
174
+
175
+ // 2. If the attribute-value failed to parse as a cookie date, ignore
176
+ // the cookie-av.
177
+
178
+ cookieAttributeList.expires = expiryTime
179
+ } else if (attributeNameLowercase === 'max-age') {
180
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.2
181
+ // If the attribute-name case-insensitively matches the string "Max-
182
+ // Age", the user agent MUST process the cookie-av as follows.
183
+
184
+ // 1. If the first character of the attribute-value is not a DIGIT or a
185
+ // "-" character, ignore the cookie-av.
186
+ const charCode = attributeValue.charCodeAt(0)
187
+
188
+ if ((charCode < 48 || charCode > 57) && attributeValue[0] !== '-') {
189
+ return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)
190
+ }
191
+
192
+ // 2. If the remainder of attribute-value contains a non-DIGIT
193
+ // character, ignore the cookie-av.
194
+ if (!/^\d+$/.test(attributeValue)) {
195
+ return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)
196
+ }
197
+
198
+ // 3. Let delta-seconds be the attribute-value converted to an integer.
199
+ const deltaSeconds = Number(attributeValue)
200
+
201
+ // 4. Let cookie-age-limit be the maximum age of the cookie (which
202
+ // SHOULD be 400 days or less, see Section 4.1.2.2).
203
+
204
+ // 5. Set delta-seconds to the smaller of its present value and cookie-
205
+ // age-limit.
206
+ // deltaSeconds = Math.min(deltaSeconds * 1000, maxExpiresMs)
207
+
208
+ // 6. If delta-seconds is less than or equal to zero (0), let expiry-
209
+ // time be the earliest representable date and time. Otherwise, let
210
+ // the expiry-time be the current date and time plus delta-seconds
211
+ // seconds.
212
+ // const expiryTime = deltaSeconds <= 0 ? Date.now() : Date.now() + deltaSeconds
213
+
214
+ // 7. Append an attribute to the cookie-attribute-list with an
215
+ // attribute-name of Max-Age and an attribute-value of expiry-time.
216
+ cookieAttributeList.maxAge = deltaSeconds
217
+ } else if (attributeNameLowercase === 'domain') {
218
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.3
219
+ // If the attribute-name case-insensitively matches the string "Domain",
220
+ // the user agent MUST process the cookie-av as follows.
221
+
222
+ // 1. Let cookie-domain be the attribute-value.
223
+ let cookieDomain = attributeValue
224
+
225
+ // 2. If cookie-domain starts with %x2E ("."), let cookie-domain be
226
+ // cookie-domain without its leading %x2E (".").
227
+ if (cookieDomain[0] === '.') {
228
+ cookieDomain = cookieDomain.slice(1)
229
+ }
230
+
231
+ // 3. Convert the cookie-domain to lower case.
232
+ cookieDomain = cookieDomain.toLowerCase()
233
+
234
+ // 4. Append an attribute to the cookie-attribute-list with an
235
+ // attribute-name of Domain and an attribute-value of cookie-domain.
236
+ cookieAttributeList.domain = cookieDomain
237
+ } else if (attributeNameLowercase === 'path') {
238
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.4
239
+ // If the attribute-name case-insensitively matches the string "Path",
240
+ // the user agent MUST process the cookie-av as follows.
241
+
242
+ // 1. If the attribute-value is empty or if the first character of the
243
+ // attribute-value is not %x2F ("/"):
244
+ let cookiePath = ''
245
+ if (attributeValue.length === 0 || attributeValue[0] !== '/') {
246
+ // 1. Let cookie-path be the default-path.
247
+ cookiePath = '/'
248
+ } else {
249
+ // Otherwise:
250
+
251
+ // 1. Let cookie-path be the attribute-value.
252
+ cookiePath = attributeValue
253
+ }
254
+
255
+ // 2. Append an attribute to the cookie-attribute-list with an
256
+ // attribute-name of Path and an attribute-value of cookie-path.
257
+ cookieAttributeList.path = cookiePath
258
+ } else if (attributeNameLowercase === 'secure') {
259
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.5
260
+ // If the attribute-name case-insensitively matches the string "Secure",
261
+ // the user agent MUST append an attribute to the cookie-attribute-list
262
+ // with an attribute-name of Secure and an empty attribute-value.
263
+
264
+ cookieAttributeList.secure = true
265
+ } else if (attributeNameLowercase === 'httponly') {
266
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.6
267
+ // If the attribute-name case-insensitively matches the string
268
+ // "HttpOnly", the user agent MUST append an attribute to the cookie-
269
+ // attribute-list with an attribute-name of HttpOnly and an empty
270
+ // attribute-value.
271
+
272
+ cookieAttributeList.httpOnly = true
273
+ } else if (attributeNameLowercase === 'samesite') {
274
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-rfc6265bis#section-5.4.7
275
+ // If the attribute-name case-insensitively matches the string
276
+ // "SameSite", the user agent MUST process the cookie-av as follows:
277
+
278
+ // 1. Let enforcement be "Default".
279
+ let enforcement = 'Default'
280
+
281
+ const attributeValueLowercase = attributeValue.toLowerCase()
282
+ // 2. If cookie-av's attribute-value is a case-insensitive match for
283
+ // "None", set enforcement to "None".
284
+ if (attributeValueLowercase.includes('none')) {
285
+ enforcement = 'None'
286
+ }
287
+
288
+ // 3. If cookie-av's attribute-value is a case-insensitive match for
289
+ // "Strict", set enforcement to "Strict".
290
+ if (attributeValueLowercase.includes('strict')) {
291
+ enforcement = 'Strict'
292
+ }
293
+
294
+ // 4. If cookie-av's attribute-value is a case-insensitive match for
295
+ // "Lax", set enforcement to "Lax".
296
+ if (attributeValueLowercase.includes('lax')) {
297
+ enforcement = 'Lax'
298
+ }
299
+
300
+ // 5. Append an attribute to the cookie-attribute-list with an
301
+ // attribute-name of "SameSite" and an attribute-value of
302
+ // enforcement.
303
+ cookieAttributeList.sameSite = enforcement
304
+ } else {
305
+ cookieAttributeList.unparsed ??= []
306
+
307
+ cookieAttributeList.unparsed.push(`${attributeName}=${attributeValue}`)
308
+ }
309
+
310
+ // 8. Return to Step 1 of this algorithm.
311
+ return parseUnparsedAttributes(unparsedAttributes, cookieAttributeList)
312
+ }
313
+
314
+ module.exports = {
315
+ parseSetCookie,
316
+ parseUnparsedAttributes
317
+ }
@@ -0,0 +1,282 @@
1
+ 'use strict'
2
+
3
+ /**
4
+ * @param {string} value
5
+ * @returns {boolean}
6
+ */
7
+ function isCTLExcludingHtab (value) {
8
+ for (let i = 0; i < value.length; ++i) {
9
+ const code = value.charCodeAt(i)
10
+
11
+ if (
12
+ (code >= 0x00 && code <= 0x08) ||
13
+ (code >= 0x0A && code <= 0x1F) ||
14
+ code === 0x7F
15
+ ) {
16
+ return true
17
+ }
18
+ }
19
+ return false
20
+ }
21
+
22
+ /**
23
+ CHAR = <any US-ASCII character (octets 0 - 127)>
24
+ token = 1*<any CHAR except CTLs or separators>
25
+ separators = "(" | ")" | "<" | ">" | "@"
26
+ | "," | ";" | ":" | "\" | <">
27
+ | "/" | "[" | "]" | "?" | "="
28
+ | "{" | "}" | SP | HT
29
+ * @param {string} name
30
+ */
31
+ function validateCookieName (name) {
32
+ for (let i = 0; i < name.length; ++i) {
33
+ const code = name.charCodeAt(i)
34
+
35
+ if (
36
+ code < 0x21 || // exclude CTLs (0-31), SP and HT
37
+ code > 0x7E || // exclude non-ascii and DEL
38
+ code === 0x22 || // "
39
+ code === 0x28 || // (
40
+ code === 0x29 || // )
41
+ code === 0x3C || // <
42
+ code === 0x3E || // >
43
+ code === 0x40 || // @
44
+ code === 0x2C || // ,
45
+ code === 0x3B || // ;
46
+ code === 0x3A || // :
47
+ code === 0x5C || // \
48
+ code === 0x2F || // /
49
+ code === 0x5B || // [
50
+ code === 0x5D || // ]
51
+ code === 0x3F || // ?
52
+ code === 0x3D || // =
53
+ code === 0x7B || // {
54
+ code === 0x7D // }
55
+ ) {
56
+ throw new Error('Invalid cookie name')
57
+ }
58
+ }
59
+ }
60
+
61
+ /**
62
+ cookie-value = *cookie-octet / ( DQUOTE *cookie-octet DQUOTE )
63
+ cookie-octet = %x21 / %x23-2B / %x2D-3A / %x3C-5B / %x5D-7E
64
+ ; US-ASCII characters excluding CTLs,
65
+ ; whitespace DQUOTE, comma, semicolon,
66
+ ; and backslash
67
+ * @param {string} value
68
+ */
69
+ function validateCookieValue (value) {
70
+ let len = value.length
71
+ let i = 0
72
+
73
+ // if the value is wrapped in DQUOTE
74
+ if (value[0] === '"') {
75
+ if (len === 1 || value[len - 1] !== '"') {
76
+ throw new Error('Invalid cookie value')
77
+ }
78
+ --len
79
+ ++i
80
+ }
81
+
82
+ while (i < len) {
83
+ const code = value.charCodeAt(i++)
84
+
85
+ if (
86
+ code < 0x21 || // exclude CTLs (0-31)
87
+ code > 0x7E || // non-ascii and DEL (127)
88
+ code === 0x22 || // "
89
+ code === 0x2C || // ,
90
+ code === 0x3B || // ;
91
+ code === 0x5C // \
92
+ ) {
93
+ throw new Error('Invalid cookie value')
94
+ }
95
+ }
96
+ }
97
+
98
+ /**
99
+ * path-value = <any CHAR except CTLs or ";">
100
+ * @param {string} path
101
+ */
102
+ function validateCookiePath (path) {
103
+ for (let i = 0; i < path.length; ++i) {
104
+ const code = path.charCodeAt(i)
105
+
106
+ if (
107
+ code < 0x20 || // exclude CTLs (0-31)
108
+ code === 0x7F || // DEL
109
+ code === 0x3B // ;
110
+ ) {
111
+ throw new Error('Invalid cookie path')
112
+ }
113
+ }
114
+ }
115
+
116
+ /**
117
+ * I have no idea why these values aren't allowed to be honest,
118
+ * but Deno tests these. - Khafra
119
+ * @param {string} domain
120
+ */
121
+ function validateCookieDomain (domain) {
122
+ if (
123
+ domain.startsWith('-') ||
124
+ domain.endsWith('.') ||
125
+ domain.endsWith('-')
126
+ ) {
127
+ throw new Error('Invalid cookie domain')
128
+ }
129
+ }
130
+
131
+ const IMFDays = [
132
+ 'Sun', 'Mon', 'Tue', 'Wed',
133
+ 'Thu', 'Fri', 'Sat'
134
+ ]
135
+
136
+ const IMFMonths = [
137
+ 'Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
138
+ 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'
139
+ ]
140
+
141
+ const IMFPaddedNumbers = Array(61).fill(0).map((_, i) => i.toString().padStart(2, '0'))
142
+
143
+ /**
144
+ * @see https://www.rfc-editor.org/rfc/rfc7231#section-7.1.1.1
145
+ * @param {number|Date} date
146
+ IMF-fixdate = day-name "," SP date1 SP time-of-day SP GMT
147
+ ; fixed length/zone/capitalization subset of the format
148
+ ; see Section 3.3 of [RFC5322]
149
+
150
+ day-name = %x4D.6F.6E ; "Mon", case-sensitive
151
+ / %x54.75.65 ; "Tue", case-sensitive
152
+ / %x57.65.64 ; "Wed", case-sensitive
153
+ / %x54.68.75 ; "Thu", case-sensitive
154
+ / %x46.72.69 ; "Fri", case-sensitive
155
+ / %x53.61.74 ; "Sat", case-sensitive
156
+ / %x53.75.6E ; "Sun", case-sensitive
157
+ date1 = day SP month SP year
158
+ ; e.g., 02 Jun 1982
159
+
160
+ day = 2DIGIT
161
+ month = %x4A.61.6E ; "Jan", case-sensitive
162
+ / %x46.65.62 ; "Feb", case-sensitive
163
+ / %x4D.61.72 ; "Mar", case-sensitive
164
+ / %x41.70.72 ; "Apr", case-sensitive
165
+ / %x4D.61.79 ; "May", case-sensitive
166
+ / %x4A.75.6E ; "Jun", case-sensitive
167
+ / %x4A.75.6C ; "Jul", case-sensitive
168
+ / %x41.75.67 ; "Aug", case-sensitive
169
+ / %x53.65.70 ; "Sep", case-sensitive
170
+ / %x4F.63.74 ; "Oct", case-sensitive
171
+ / %x4E.6F.76 ; "Nov", case-sensitive
172
+ / %x44.65.63 ; "Dec", case-sensitive
173
+ year = 4DIGIT
174
+
175
+ GMT = %x47.4D.54 ; "GMT", case-sensitive
176
+
177
+ time-of-day = hour ":" minute ":" second
178
+ ; 00:00:00 - 23:59:60 (leap second)
179
+
180
+ hour = 2DIGIT
181
+ minute = 2DIGIT
182
+ second = 2DIGIT
183
+ */
184
+ function toIMFDate (date) {
185
+ if (typeof date === 'number') {
186
+ date = new Date(date)
187
+ }
188
+
189
+ return `${IMFDays[date.getUTCDay()]}, ${IMFPaddedNumbers[date.getUTCDate()]} ${IMFMonths[date.getUTCMonth()]} ${date.getUTCFullYear()} ${IMFPaddedNumbers[date.getUTCHours()]}:${IMFPaddedNumbers[date.getUTCMinutes()]}:${IMFPaddedNumbers[date.getUTCSeconds()]} GMT`
190
+ }
191
+
192
+ /**
193
+ max-age-av = "Max-Age=" non-zero-digit *DIGIT
194
+ ; In practice, both expires-av and max-age-av
195
+ ; are limited to dates representable by the
196
+ ; user agent.
197
+ * @param {number} maxAge
198
+ */
199
+ function validateCookieMaxAge (maxAge) {
200
+ if (maxAge < 0) {
201
+ throw new Error('Invalid cookie max-age')
202
+ }
203
+ }
204
+
205
+ /**
206
+ * @see https://www.rfc-editor.org/rfc/rfc6265#section-4.1.1
207
+ * @param {import('./index').Cookie} cookie
208
+ */
209
+ function stringify (cookie) {
210
+ if (cookie.name.length === 0) {
211
+ return null
212
+ }
213
+
214
+ validateCookieName(cookie.name)
215
+ validateCookieValue(cookie.value)
216
+
217
+ const out = [`${cookie.name}=${cookie.value}`]
218
+
219
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-cookie-prefixes-00#section-3.1
220
+ // https://datatracker.ietf.org/doc/html/draft-ietf-httpbis-cookie-prefixes-00#section-3.2
221
+ if (cookie.name.startsWith('__Secure-')) {
222
+ cookie.secure = true
223
+ }
224
+
225
+ if (cookie.name.startsWith('__Host-')) {
226
+ cookie.secure = true
227
+ cookie.domain = null
228
+ cookie.path = '/'
229
+ }
230
+
231
+ if (cookie.secure) {
232
+ out.push('Secure')
233
+ }
234
+
235
+ if (cookie.httpOnly) {
236
+ out.push('HttpOnly')
237
+ }
238
+
239
+ if (typeof cookie.maxAge === 'number') {
240
+ validateCookieMaxAge(cookie.maxAge)
241
+ out.push(`Max-Age=${cookie.maxAge}`)
242
+ }
243
+
244
+ if (cookie.domain) {
245
+ validateCookieDomain(cookie.domain)
246
+ out.push(`Domain=${cookie.domain}`)
247
+ }
248
+
249
+ if (cookie.path) {
250
+ validateCookiePath(cookie.path)
251
+ out.push(`Path=${cookie.path}`)
252
+ }
253
+
254
+ if (cookie.expires && cookie.expires.toString() !== 'Invalid Date') {
255
+ out.push(`Expires=${toIMFDate(cookie.expires)}`)
256
+ }
257
+
258
+ if (cookie.sameSite) {
259
+ out.push(`SameSite=${cookie.sameSite}`)
260
+ }
261
+
262
+ for (const part of cookie.unparsed) {
263
+ if (!part.includes('=')) {
264
+ throw new Error('Invalid unparsed')
265
+ }
266
+
267
+ const [key, ...value] = part.split('=')
268
+
269
+ out.push(`${key.trim()}=${value.join('=')}`)
270
+ }
271
+
272
+ return out.join('; ')
273
+ }
274
+
275
+ module.exports = {
276
+ isCTLExcludingHtab,
277
+ validateCookieName,
278
+ validateCookiePath,
279
+ validateCookieValue,
280
+ toIMFDate,
281
+ stringify
282
+ }