@pnpm/exe 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 (381) hide show
  1. package/dist/node-gyp-bin/node-gyp +0 -0
  2. package/dist/node-gyp-bin/node-gyp.cmd +0 -0
  3. package/dist/node_modules/node-gyp/.release-please-manifest.json +1 -1
  4. package/dist/node_modules/node-gyp/bin/node-gyp.js +0 -0
  5. package/dist/node_modules/node-gyp/gyp/.release-please-manifest.json +1 -1
  6. package/dist/node_modules/node-gyp/gyp/pylib/gyp/MSVSVersion.py +11 -3
  7. package/dist/node_modules/node-gyp/gyp/pylib/gyp/__init__.py +2 -3
  8. package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/msvs.py +1 -1
  9. package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja.py +2 -1
  10. package/dist/node_modules/node-gyp/gyp/pylib/gyp/generator/ninja_test.py +26 -16
  11. package/dist/node_modules/node-gyp/gyp/pylib/gyp/mac_tool.py +1 -1
  12. package/dist/node_modules/node-gyp/gyp/pylib/gyp/msvs_emulation.py +1 -1
  13. package/dist/node_modules/node-gyp/gyp/pylib/gyp/simple_copy.py +2 -2
  14. package/dist/node_modules/node-gyp/gyp/pylib/packaging/metadata.py +3 -20
  15. package/dist/node_modules/node-gyp/gyp/pylib/packaging/tags.py +2 -14
  16. package/dist/node_modules/node-gyp/gyp/pyproject.toml +5 -3
  17. package/dist/node_modules/node-gyp/lib/download.js +55 -8
  18. package/dist/node_modules/node-gyp/lib/find-visualstudio.js +1 -1
  19. package/dist/node_modules/node-gyp/lib/process-release.js +17 -19
  20. package/dist/node_modules/node-gyp/package.json +3 -3
  21. package/dist/node_modules/{safer-buffer → undici}/LICENSE +1 -1
  22. package/dist/node_modules/undici/index-fetch.js +35 -0
  23. package/dist/node_modules/undici/index.js +169 -0
  24. package/dist/node_modules/undici/lib/api/abort-signal.js +57 -0
  25. package/dist/node_modules/undici/lib/api/api-connect.js +108 -0
  26. package/dist/node_modules/undici/lib/api/api-pipeline.js +251 -0
  27. package/dist/node_modules/undici/lib/api/api-request.js +214 -0
  28. package/dist/node_modules/undici/lib/api/api-stream.js +220 -0
  29. package/dist/node_modules/undici/lib/api/api-upgrade.js +108 -0
  30. package/dist/node_modules/undici/lib/api/index.js +7 -0
  31. package/dist/node_modules/undici/lib/api/readable.js +385 -0
  32. package/dist/node_modules/undici/lib/api/util.js +93 -0
  33. package/dist/node_modules/undici/lib/core/connect.js +240 -0
  34. package/dist/node_modules/undici/lib/core/constants.js +118 -0
  35. package/dist/node_modules/undici/lib/core/diagnostics.js +202 -0
  36. package/dist/node_modules/undici/lib/core/errors.js +425 -0
  37. package/dist/node_modules/undici/lib/core/request.js +405 -0
  38. package/dist/node_modules/undici/lib/core/symbols.js +67 -0
  39. package/dist/node_modules/undici/lib/core/tree.js +152 -0
  40. package/dist/node_modules/undici/lib/core/util.js +719 -0
  41. package/dist/node_modules/undici/lib/dispatcher/agent.js +130 -0
  42. package/dist/node_modules/undici/lib/dispatcher/balanced-pool.js +209 -0
  43. package/dist/node_modules/undici/lib/dispatcher/client-h1.js +1370 -0
  44. package/dist/node_modules/undici/lib/dispatcher/client-h2.js +744 -0
  45. package/dist/node_modules/undici/lib/dispatcher/client.js +623 -0
  46. package/dist/node_modules/undici/lib/dispatcher/dispatcher-base.js +198 -0
  47. package/dist/node_modules/undici/lib/dispatcher/dispatcher.js +65 -0
  48. package/dist/node_modules/undici/lib/dispatcher/env-http-proxy-agent.js +160 -0
  49. package/dist/node_modules/undici/lib/dispatcher/fixed-queue.js +117 -0
  50. package/dist/node_modules/undici/lib/dispatcher/pool-base.js +194 -0
  51. package/dist/node_modules/undici/lib/dispatcher/pool-stats.js +34 -0
  52. package/dist/node_modules/undici/lib/dispatcher/pool.js +107 -0
  53. package/dist/node_modules/undici/lib/dispatcher/proxy-agent.js +274 -0
  54. package/dist/node_modules/undici/lib/dispatcher/retry-agent.js +35 -0
  55. package/dist/node_modules/undici/lib/global.js +32 -0
  56. package/dist/node_modules/undici/lib/handler/decorator-handler.js +44 -0
  57. package/dist/node_modules/undici/lib/handler/redirect-handler.js +232 -0
  58. package/dist/node_modules/undici/lib/handler/retry-handler.js +374 -0
  59. package/dist/node_modules/undici/lib/interceptor/dns.js +375 -0
  60. package/dist/node_modules/undici/lib/interceptor/dump.js +123 -0
  61. package/dist/node_modules/undici/lib/interceptor/redirect-interceptor.js +21 -0
  62. package/dist/node_modules/undici/lib/interceptor/redirect.js +24 -0
  63. package/dist/node_modules/undici/lib/interceptor/response-error.js +86 -0
  64. package/dist/node_modules/undici/lib/interceptor/retry.js +19 -0
  65. package/dist/node_modules/undici/lib/llhttp/.gitkeep +0 -0
  66. package/dist/node_modules/undici/lib/llhttp/constants.js +278 -0
  67. package/dist/node_modules/undici/lib/llhttp/llhttp-wasm.js +5 -0
  68. package/dist/node_modules/undici/lib/llhttp/llhttp_simd-wasm.js +5 -0
  69. package/dist/node_modules/undici/lib/llhttp/utils.js +15 -0
  70. package/dist/node_modules/undici/lib/mock/mock-agent.js +160 -0
  71. package/dist/node_modules/undici/lib/mock/mock-client.js +59 -0
  72. package/dist/node_modules/undici/lib/mock/mock-errors.js +28 -0
  73. package/dist/node_modules/undici/lib/mock/mock-interceptor.js +207 -0
  74. package/dist/node_modules/undici/lib/mock/mock-pool.js +59 -0
  75. package/dist/node_modules/undici/lib/mock/mock-symbols.js +23 -0
  76. package/dist/node_modules/undici/lib/mock/mock-utils.js +367 -0
  77. package/dist/node_modules/undici/lib/mock/pending-interceptors-formatter.js +43 -0
  78. package/dist/node_modules/undici/lib/mock/pluralizer.js +29 -0
  79. package/dist/node_modules/undici/lib/util/timers.js +423 -0
  80. package/dist/node_modules/undici/lib/web/cache/cache.js +859 -0
  81. package/dist/node_modules/undici/lib/web/cache/cachestorage.js +152 -0
  82. package/dist/node_modules/undici/lib/web/cache/symbols.js +5 -0
  83. package/dist/node_modules/undici/lib/web/cache/util.js +45 -0
  84. package/dist/node_modules/undici/lib/web/cookies/constants.js +12 -0
  85. package/dist/node_modules/undici/lib/web/cookies/index.js +184 -0
  86. package/dist/node_modules/undici/lib/web/cookies/parse.js +317 -0
  87. package/dist/node_modules/undici/lib/web/cookies/util.js +282 -0
  88. package/dist/node_modules/undici/lib/web/eventsource/eventsource-stream.js +398 -0
  89. package/dist/node_modules/undici/lib/web/eventsource/eventsource.js +480 -0
  90. package/dist/node_modules/undici/lib/web/eventsource/util.js +37 -0
  91. package/dist/node_modules/{@npmcli/redact → undici/lib/web/fetch}/LICENSE +1 -1
  92. package/dist/node_modules/undici/lib/web/fetch/body.js +529 -0
  93. package/dist/node_modules/undici/lib/web/fetch/constants.js +124 -0
  94. package/dist/node_modules/undici/lib/web/fetch/data-url.js +744 -0
  95. package/dist/node_modules/undici/lib/web/fetch/dispatcher-weakref.js +46 -0
  96. package/dist/node_modules/undici/lib/web/fetch/file.js +126 -0
  97. package/dist/node_modules/undici/lib/web/fetch/formdata-parser.js +474 -0
  98. package/dist/node_modules/undici/lib/web/fetch/formdata.js +252 -0
  99. package/dist/node_modules/undici/lib/web/fetch/global.js +40 -0
  100. package/dist/node_modules/undici/lib/web/fetch/headers.js +687 -0
  101. package/dist/node_modules/undici/lib/web/fetch/index.js +2272 -0
  102. package/dist/node_modules/undici/lib/web/fetch/request.js +1037 -0
  103. package/dist/node_modules/undici/lib/web/fetch/response.js +610 -0
  104. package/dist/node_modules/undici/lib/web/fetch/symbols.js +9 -0
  105. package/dist/node_modules/undici/lib/web/fetch/util.js +1632 -0
  106. package/dist/node_modules/undici/lib/web/fetch/webidl.js +695 -0
  107. package/dist/node_modules/undici/lib/web/fileapi/encoding.js +290 -0
  108. package/dist/node_modules/undici/lib/web/fileapi/filereader.js +344 -0
  109. package/dist/node_modules/undici/lib/web/fileapi/progressevent.js +78 -0
  110. package/dist/node_modules/undici/lib/web/fileapi/symbols.js +10 -0
  111. package/dist/node_modules/undici/lib/web/fileapi/util.js +391 -0
  112. package/dist/node_modules/undici/lib/web/websocket/connection.js +371 -0
  113. package/dist/node_modules/undici/lib/web/websocket/constants.js +66 -0
  114. package/dist/node_modules/undici/lib/web/websocket/events.js +329 -0
  115. package/dist/node_modules/undici/lib/web/websocket/frame.js +96 -0
  116. package/dist/node_modules/undici/lib/web/websocket/permessage-deflate.js +100 -0
  117. package/dist/node_modules/undici/lib/web/websocket/receiver.js +490 -0
  118. package/dist/node_modules/undici/lib/web/websocket/sender.js +104 -0
  119. package/dist/node_modules/undici/lib/web/websocket/symbols.js +12 -0
  120. package/dist/node_modules/undici/lib/web/websocket/util.js +322 -0
  121. package/dist/node_modules/undici/lib/web/websocket/websocket.js +592 -0
  122. package/dist/node_modules/undici/package.json +160 -0
  123. package/dist/node_modules/undici/scripts/strip-comments.js +8 -0
  124. package/dist/node_modules/yallist/package.json +51 -12
  125. package/dist/pnpm.mjs +5915 -5140
  126. package/dist/worker.js +70 -67
  127. package/package.json +21 -13
  128. package/setup.js +17 -3
  129. package/dist/node_modules/@gar/promise-retry/LICENSE +0 -20
  130. package/dist/node_modules/@gar/promise-retry/lib/index.js +0 -62
  131. package/dist/node_modules/@gar/promise-retry/lib/retry.js +0 -109
  132. package/dist/node_modules/@gar/promise-retry/package.json +0 -45
  133. package/dist/node_modules/@npmcli/agent/lib/agents.js +0 -206
  134. package/dist/node_modules/@npmcli/agent/lib/dns.js +0 -53
  135. package/dist/node_modules/@npmcli/agent/lib/errors.js +0 -61
  136. package/dist/node_modules/@npmcli/agent/lib/index.js +0 -56
  137. package/dist/node_modules/@npmcli/agent/lib/options.js +0 -86
  138. package/dist/node_modules/@npmcli/agent/lib/proxy.js +0 -88
  139. package/dist/node_modules/@npmcli/agent/package.json +0 -60
  140. package/dist/node_modules/@npmcli/fs/lib/common/get-options.js +0 -20
  141. package/dist/node_modules/@npmcli/fs/lib/common/node.js +0 -9
  142. package/dist/node_modules/@npmcli/fs/lib/cp/LICENSE +0 -15
  143. package/dist/node_modules/@npmcli/fs/lib/cp/errors.js +0 -129
  144. package/dist/node_modules/@npmcli/fs/lib/cp/index.js +0 -22
  145. package/dist/node_modules/@npmcli/fs/lib/cp/polyfill.js +0 -428
  146. package/dist/node_modules/@npmcli/fs/lib/index.js +0 -13
  147. package/dist/node_modules/@npmcli/fs/lib/move-file.js +0 -78
  148. package/dist/node_modules/@npmcli/fs/lib/readdir-scoped.js +0 -20
  149. package/dist/node_modules/@npmcli/fs/lib/with-temp-dir.js +0 -39
  150. package/dist/node_modules/@npmcli/fs/package.json +0 -54
  151. package/dist/node_modules/@npmcli/redact/lib/deep-map.js +0 -71
  152. package/dist/node_modules/@npmcli/redact/lib/error.js +0 -28
  153. package/dist/node_modules/@npmcli/redact/lib/index.js +0 -44
  154. package/dist/node_modules/@npmcli/redact/lib/matchers.js +0 -88
  155. package/dist/node_modules/@npmcli/redact/lib/server.js +0 -59
  156. package/dist/node_modules/@npmcli/redact/lib/utils.js +0 -202
  157. package/dist/node_modules/@npmcli/redact/package.json +0 -52
  158. package/dist/node_modules/agent-base/LICENSE +0 -22
  159. package/dist/node_modules/agent-base/dist/helpers.js +0 -66
  160. package/dist/node_modules/agent-base/dist/index.js +0 -178
  161. package/dist/node_modules/agent-base/package.json +0 -46
  162. package/dist/node_modules/balanced-match/dist/commonjs/index.js +0 -59
  163. package/dist/node_modules/balanced-match/dist/esm/index.js +0 -54
  164. package/dist/node_modules/balanced-match/package.json +0 -68
  165. package/dist/node_modules/brace-expansion/LICENSE +0 -23
  166. package/dist/node_modules/brace-expansion/dist/commonjs/index.js +0 -201
  167. package/dist/node_modules/brace-expansion/dist/commonjs/package.json +0 -3
  168. package/dist/node_modules/brace-expansion/dist/esm/index.js +0 -197
  169. package/dist/node_modules/brace-expansion/dist/esm/package.json +0 -3
  170. package/dist/node_modules/brace-expansion/package.json +0 -64
  171. package/dist/node_modules/cacache/lib/content/path.js +0 -29
  172. package/dist/node_modules/cacache/lib/content/read.js +0 -165
  173. package/dist/node_modules/cacache/lib/content/rm.js +0 -18
  174. package/dist/node_modules/cacache/lib/content/write.js +0 -206
  175. package/dist/node_modules/cacache/lib/entry-index.js +0 -336
  176. package/dist/node_modules/cacache/lib/get.js +0 -170
  177. package/dist/node_modules/cacache/lib/index.js +0 -42
  178. package/dist/node_modules/cacache/lib/memoization.js +0 -72
  179. package/dist/node_modules/cacache/lib/put.js +0 -80
  180. package/dist/node_modules/cacache/lib/rm.js +0 -31
  181. package/dist/node_modules/cacache/lib/util/glob.js +0 -7
  182. package/dist/node_modules/cacache/lib/util/hash-to-segments.js +0 -7
  183. package/dist/node_modules/cacache/lib/util/tmp.js +0 -32
  184. package/dist/node_modules/cacache/lib/verify.js +0 -258
  185. package/dist/node_modules/cacache/package.json +0 -81
  186. package/dist/node_modules/debug/LICENSE +0 -20
  187. package/dist/node_modules/debug/package.json +0 -64
  188. package/dist/node_modules/debug/src/browser.js +0 -272
  189. package/dist/node_modules/debug/src/common.js +0 -292
  190. package/dist/node_modules/debug/src/index.js +0 -10
  191. package/dist/node_modules/debug/src/node.js +0 -263
  192. package/dist/node_modules/fs-minipass/LICENSE +0 -15
  193. package/dist/node_modules/fs-minipass/lib/index.js +0 -443
  194. package/dist/node_modules/fs-minipass/package.json +0 -54
  195. package/dist/node_modules/glob/dist/commonjs/glob.js +0 -248
  196. package/dist/node_modules/glob/dist/commonjs/has-magic.js +0 -27
  197. package/dist/node_modules/glob/dist/commonjs/ignore.js +0 -119
  198. package/dist/node_modules/glob/dist/commonjs/index.js +0 -68
  199. package/dist/node_modules/glob/dist/commonjs/index.min.js +0 -4
  200. package/dist/node_modules/glob/dist/commonjs/package.json +0 -3
  201. package/dist/node_modules/glob/dist/commonjs/pattern.js +0 -223
  202. package/dist/node_modules/glob/dist/commonjs/processor.js +0 -301
  203. package/dist/node_modules/glob/dist/commonjs/walker.js +0 -387
  204. package/dist/node_modules/glob/dist/esm/glob.js +0 -244
  205. package/dist/node_modules/glob/dist/esm/has-magic.js +0 -23
  206. package/dist/node_modules/glob/dist/esm/ignore.js +0 -115
  207. package/dist/node_modules/glob/dist/esm/index.js +0 -55
  208. package/dist/node_modules/glob/dist/esm/index.min.js +0 -4
  209. package/dist/node_modules/glob/dist/esm/package.json +0 -3
  210. package/dist/node_modules/glob/dist/esm/pattern.js +0 -219
  211. package/dist/node_modules/glob/dist/esm/processor.js +0 -294
  212. package/dist/node_modules/glob/dist/esm/walker.js +0 -381
  213. package/dist/node_modules/glob/package.json +0 -98
  214. package/dist/node_modules/http-cache-semantics/LICENSE +0 -9
  215. package/dist/node_modules/http-cache-semantics/index.js +0 -928
  216. package/dist/node_modules/http-cache-semantics/package.json +0 -22
  217. package/dist/node_modules/http-proxy-agent/LICENSE +0 -22
  218. package/dist/node_modules/http-proxy-agent/dist/index.js +0 -148
  219. package/dist/node_modules/http-proxy-agent/package.json +0 -47
  220. package/dist/node_modules/https-proxy-agent/LICENSE +0 -22
  221. package/dist/node_modules/https-proxy-agent/dist/index.js +0 -180
  222. package/dist/node_modules/https-proxy-agent/dist/parse-proxy-response.js +0 -101
  223. package/dist/node_modules/https-proxy-agent/package.json +0 -50
  224. package/dist/node_modules/iconv-lite/LICENSE +0 -21
  225. package/dist/node_modules/iconv-lite/encodings/dbcs-codec.js +0 -532
  226. package/dist/node_modules/iconv-lite/encodings/dbcs-data.js +0 -185
  227. package/dist/node_modules/iconv-lite/encodings/index.js +0 -23
  228. package/dist/node_modules/iconv-lite/encodings/internal.js +0 -218
  229. package/dist/node_modules/iconv-lite/encodings/sbcs-codec.js +0 -75
  230. package/dist/node_modules/iconv-lite/encodings/sbcs-data-generated.js +0 -451
  231. package/dist/node_modules/iconv-lite/encodings/sbcs-data.js +0 -178
  232. package/dist/node_modules/iconv-lite/encodings/tables/big5-added.json +0 -122
  233. package/dist/node_modules/iconv-lite/encodings/tables/cp936.json +0 -264
  234. package/dist/node_modules/iconv-lite/encodings/tables/cp949.json +0 -273
  235. package/dist/node_modules/iconv-lite/encodings/tables/cp950.json +0 -177
  236. package/dist/node_modules/iconv-lite/encodings/tables/eucjp.json +0 -182
  237. package/dist/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json +0 -1
  238. package/dist/node_modules/iconv-lite/encodings/tables/gbk-added.json +0 -56
  239. package/dist/node_modules/iconv-lite/encodings/tables/shiftjis.json +0 -125
  240. package/dist/node_modules/iconv-lite/encodings/utf16.js +0 -187
  241. package/dist/node_modules/iconv-lite/encodings/utf32.js +0 -307
  242. package/dist/node_modules/iconv-lite/encodings/utf7.js +0 -283
  243. package/dist/node_modules/iconv-lite/lib/bom-handling.js +0 -48
  244. package/dist/node_modules/iconv-lite/lib/helpers/merge-exports.js +0 -13
  245. package/dist/node_modules/iconv-lite/lib/index.js +0 -182
  246. package/dist/node_modules/iconv-lite/lib/streams.js +0 -105
  247. package/dist/node_modules/iconv-lite/package.json +0 -70
  248. package/dist/node_modules/ip-address/LICENSE +0 -19
  249. package/dist/node_modules/ip-address/dist/address-error.js +0 -12
  250. package/dist/node_modules/ip-address/dist/common.js +0 -46
  251. package/dist/node_modules/ip-address/dist/ip-address.js +0 -35
  252. package/dist/node_modules/ip-address/dist/ipv4.js +0 -360
  253. package/dist/node_modules/ip-address/dist/ipv6.js +0 -1003
  254. package/dist/node_modules/ip-address/dist/v4/constants.js +0 -8
  255. package/dist/node_modules/ip-address/dist/v6/constants.js +0 -76
  256. package/dist/node_modules/ip-address/dist/v6/helpers.js +0 -45
  257. package/dist/node_modules/ip-address/dist/v6/regular-expressions.js +0 -95
  258. package/dist/node_modules/ip-address/package.json +0 -78
  259. package/dist/node_modules/lru-cache/dist/commonjs/diagnostics-channel.js +0 -10
  260. package/dist/node_modules/lru-cache/dist/commonjs/index.js +0 -1692
  261. package/dist/node_modules/lru-cache/dist/commonjs/index.min.js +0 -2
  262. package/dist/node_modules/lru-cache/dist/commonjs/package.json +0 -3
  263. package/dist/node_modules/lru-cache/dist/esm/browser/diagnostics-channel.js +0 -4
  264. package/dist/node_modules/lru-cache/dist/esm/browser/index.js +0 -1688
  265. package/dist/node_modules/lru-cache/dist/esm/browser/index.min.js +0 -2
  266. package/dist/node_modules/lru-cache/dist/esm/diagnostics-channel.js +0 -19
  267. package/dist/node_modules/lru-cache/dist/esm/index.js +0 -1688
  268. package/dist/node_modules/lru-cache/dist/esm/index.min.js +0 -2
  269. package/dist/node_modules/lru-cache/dist/esm/node/diagnostics-channel.js +0 -7
  270. package/dist/node_modules/lru-cache/dist/esm/node/index.js +0 -1688
  271. package/dist/node_modules/lru-cache/dist/esm/node/index.min.js +0 -2
  272. package/dist/node_modules/lru-cache/dist/esm/package.json +0 -3
  273. package/dist/node_modules/lru-cache/package.json +0 -126
  274. package/dist/node_modules/make-fetch-happen/LICENSE +0 -16
  275. package/dist/node_modules/make-fetch-happen/lib/cache/entry.js +0 -471
  276. package/dist/node_modules/make-fetch-happen/lib/cache/errors.js +0 -11
  277. package/dist/node_modules/make-fetch-happen/lib/cache/index.js +0 -49
  278. package/dist/node_modules/make-fetch-happen/lib/cache/key.js +0 -17
  279. package/dist/node_modules/make-fetch-happen/lib/cache/policy.js +0 -161
  280. package/dist/node_modules/make-fetch-happen/lib/fetch.js +0 -118
  281. package/dist/node_modules/make-fetch-happen/lib/index.js +0 -41
  282. package/dist/node_modules/make-fetch-happen/lib/options.js +0 -59
  283. package/dist/node_modules/make-fetch-happen/lib/pipeline.js +0 -41
  284. package/dist/node_modules/make-fetch-happen/lib/remote.js +0 -134
  285. package/dist/node_modules/make-fetch-happen/package.json +0 -75
  286. package/dist/node_modules/minimatch/dist/commonjs/assert-valid-pattern.js +0 -14
  287. package/dist/node_modules/minimatch/dist/commonjs/ast.js +0 -845
  288. package/dist/node_modules/minimatch/dist/commonjs/brace-expressions.js +0 -150
  289. package/dist/node_modules/minimatch/dist/commonjs/escape.js +0 -30
  290. package/dist/node_modules/minimatch/dist/commonjs/index.js +0 -1127
  291. package/dist/node_modules/minimatch/dist/commonjs/package.json +0 -3
  292. package/dist/node_modules/minimatch/dist/commonjs/unescape.js +0 -38
  293. package/dist/node_modules/minimatch/dist/esm/assert-valid-pattern.js +0 -10
  294. package/dist/node_modules/minimatch/dist/esm/ast.js +0 -841
  295. package/dist/node_modules/minimatch/dist/esm/brace-expressions.js +0 -146
  296. package/dist/node_modules/minimatch/dist/esm/escape.js +0 -26
  297. package/dist/node_modules/minimatch/dist/esm/index.js +0 -1114
  298. package/dist/node_modules/minimatch/dist/esm/package.json +0 -3
  299. package/dist/node_modules/minimatch/dist/esm/unescape.js +0 -34
  300. package/dist/node_modules/minimatch/package.json +0 -73
  301. package/dist/node_modules/minipass-collect/LICENSE +0 -15
  302. package/dist/node_modules/minipass-collect/index.js +0 -71
  303. package/dist/node_modules/minipass-collect/package.json +0 -30
  304. package/dist/node_modules/minipass-fetch/LICENSE +0 -28
  305. package/dist/node_modules/minipass-fetch/lib/abort-error.js +0 -17
  306. package/dist/node_modules/minipass-fetch/lib/blob.js +0 -97
  307. package/dist/node_modules/minipass-fetch/lib/body.js +0 -360
  308. package/dist/node_modules/minipass-fetch/lib/fetch-error.js +0 -32
  309. package/dist/node_modules/minipass-fetch/lib/headers.js +0 -267
  310. package/dist/node_modules/minipass-fetch/lib/index.js +0 -376
  311. package/dist/node_modules/minipass-fetch/lib/request.js +0 -282
  312. package/dist/node_modules/minipass-fetch/lib/response.js +0 -90
  313. package/dist/node_modules/minipass-fetch/package.json +0 -70
  314. package/dist/node_modules/minipass-flush/index.js +0 -39
  315. package/dist/node_modules/minipass-flush/node_modules/minipass/LICENSE +0 -15
  316. package/dist/node_modules/minipass-flush/node_modules/minipass/index.js +0 -649
  317. package/dist/node_modules/minipass-flush/node_modules/minipass/package.json +0 -56
  318. package/dist/node_modules/minipass-flush/package.json +0 -42
  319. package/dist/node_modules/minipass-pipeline/LICENSE +0 -15
  320. package/dist/node_modules/minipass-pipeline/index.js +0 -128
  321. package/dist/node_modules/minipass-pipeline/node_modules/minipass/LICENSE +0 -15
  322. package/dist/node_modules/minipass-pipeline/node_modules/minipass/index.js +0 -649
  323. package/dist/node_modules/minipass-pipeline/node_modules/minipass/package.json +0 -56
  324. package/dist/node_modules/minipass-pipeline/package.json +0 -29
  325. package/dist/node_modules/minipass-sized/LICENSE +0 -15
  326. package/dist/node_modules/minipass-sized/dist/commonjs/index.js +0 -69
  327. package/dist/node_modules/minipass-sized/dist/commonjs/package.json +0 -3
  328. package/dist/node_modules/minipass-sized/dist/esm/index.js +0 -64
  329. package/dist/node_modules/minipass-sized/dist/esm/package.json +0 -3
  330. package/dist/node_modules/minipass-sized/package.json +0 -69
  331. package/dist/node_modules/ms/index.js +0 -162
  332. package/dist/node_modules/ms/package.json +0 -38
  333. package/dist/node_modules/negotiator/LICENSE +0 -24
  334. package/dist/node_modules/negotiator/index.js +0 -83
  335. package/dist/node_modules/negotiator/lib/charset.js +0 -169
  336. package/dist/node_modules/negotiator/lib/encoding.js +0 -205
  337. package/dist/node_modules/negotiator/lib/language.js +0 -179
  338. package/dist/node_modules/negotiator/lib/mediaType.js +0 -294
  339. package/dist/node_modules/negotiator/package.json +0 -43
  340. package/dist/node_modules/p-map/index.js +0 -283
  341. package/dist/node_modules/p-map/license +0 -9
  342. package/dist/node_modules/p-map/package.json +0 -57
  343. package/dist/node_modules/path-scurry/dist/commonjs/index.js +0 -2018
  344. package/dist/node_modules/path-scurry/dist/commonjs/package.json +0 -3
  345. package/dist/node_modules/path-scurry/dist/esm/index.js +0 -1983
  346. package/dist/node_modules/path-scurry/dist/esm/package.json +0 -3
  347. package/dist/node_modules/path-scurry/package.json +0 -72
  348. package/dist/node_modules/safer-buffer/dangerous.js +0 -58
  349. package/dist/node_modules/safer-buffer/package.json +0 -34
  350. package/dist/node_modules/safer-buffer/safer.js +0 -77
  351. package/dist/node_modules/safer-buffer/tests.js +0 -406
  352. package/dist/node_modules/smart-buffer/.prettierrc.yaml +0 -5
  353. package/dist/node_modules/smart-buffer/LICENSE +0 -20
  354. package/dist/node_modules/smart-buffer/build/smartbuffer.js +0 -1233
  355. package/dist/node_modules/smart-buffer/build/utils.js +0 -108
  356. package/dist/node_modules/smart-buffer/package.json +0 -79
  357. package/dist/node_modules/socks/.eslintrc.cjs +0 -11
  358. package/dist/node_modules/socks/.prettierrc.yaml +0 -7
  359. package/dist/node_modules/socks/LICENSE +0 -20
  360. package/dist/node_modules/socks/build/client/socksclient.js +0 -793
  361. package/dist/node_modules/socks/build/common/constants.js +0 -108
  362. package/dist/node_modules/socks/build/common/helpers.js +0 -167
  363. package/dist/node_modules/socks/build/common/receivebuffer.js +0 -43
  364. package/dist/node_modules/socks/build/common/util.js +0 -25
  365. package/dist/node_modules/socks/build/index.js +0 -18
  366. package/dist/node_modules/socks/package.json +0 -58
  367. package/dist/node_modules/socks-proxy-agent/LICENSE +0 -22
  368. package/dist/node_modules/socks-proxy-agent/dist/index.js +0 -195
  369. package/dist/node_modules/socks-proxy-agent/package.json +0 -142
  370. package/dist/node_modules/ssri/lib/index.js +0 -550
  371. package/dist/node_modules/ssri/package.json +0 -66
  372. package/dist/node_modules/tar/node_modules/yallist/dist/commonjs/package.json +0 -3
  373. package/dist/node_modules/tar/node_modules/yallist/dist/esm/package.json +0 -3
  374. package/dist/node_modules/tar/node_modules/yallist/package.json +0 -68
  375. package/dist/node_modules/yallist/LICENSE +0 -15
  376. package/dist/node_modules/yallist/iterator.js +0 -8
  377. package/dist/node_modules/yallist/yallist.js +0 -426
  378. /package/dist/node_modules/{tar/node_modules/yallist → yallist}/dist/commonjs/index.js +0 -0
  379. /package/dist/node_modules/{balanced-match → yallist}/dist/commonjs/package.json +0 -0
  380. /package/dist/node_modules/{tar/node_modules/yallist → yallist}/dist/esm/index.js +0 -0
  381. /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
+ }