imran-downloader-servar 0.0.1-security → 2.3.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.

Potentially problematic release.


This version of imran-downloader-servar might be problematic. Click here for more details.

Files changed (229) hide show
  1. package/.cache/nix/binary-cache-v6.sqlite +0 -0
  2. package/.cache/nix/binary-cache-v6.sqlite-journal +0 -0
  3. package/.cache/replit/__replit_disk_meta.json +1 -0
  4. package/.cache/replit/modules/nodejs-20:v32-20240401-269b323.res +1 -0
  5. package/.cache/replit/modules/replit:v8-20240329-787bc7d.res +1 -0
  6. package/.cache/replit/modules.stamp +0 -0
  7. package/.cache/replit/nix/env.json +1 -0
  8. package/.cache/typescript/5.0/node_modules/.package-lock.json +12 -0
  9. package/.cache/typescript/5.0/node_modules/types-registry/README.md +2 -0
  10. package/.cache/typescript/5.0/node_modules/types-registry/index.json +1 -0
  11. package/.cache/typescript/5.0/node_modules/types-registry/package.json +20 -0
  12. package/.cache/typescript/5.0/package.json +1 -0
  13. package/.cache/typescript/5.3/node_modules/.package-lock.json +114 -0
  14. package/.cache/typescript/5.3/node_modules/@types/cheerio/LICENSE +21 -0
  15. package/.cache/typescript/5.3/node_modules/@types/cheerio/README.md +15 -0
  16. package/.cache/typescript/5.3/node_modules/@types/cheerio/index.d.ts +318 -0
  17. package/.cache/typescript/5.3/node_modules/@types/cheerio/package.json +71 -0
  18. package/.cache/typescript/5.3/node_modules/@types/node/LICENSE +21 -0
  19. package/.cache/typescript/5.3/node_modules/@types/node/README.md +15 -0
  20. package/.cache/typescript/5.3/node_modules/@types/node/assert/strict.d.ts +8 -0
  21. package/.cache/typescript/5.3/node_modules/@types/node/assert.d.ts +996 -0
  22. package/.cache/typescript/5.3/node_modules/@types/node/async_hooks.d.ts +539 -0
  23. package/.cache/typescript/5.3/node_modules/@types/node/buffer.d.ts +2362 -0
  24. package/.cache/typescript/5.3/node_modules/@types/node/child_process.d.ts +1540 -0
  25. package/.cache/typescript/5.3/node_modules/@types/node/cluster.d.ts +432 -0
  26. package/.cache/typescript/5.3/node_modules/@types/node/console.d.ts +415 -0
  27. package/.cache/typescript/5.3/node_modules/@types/node/constants.d.ts +19 -0
  28. package/.cache/typescript/5.3/node_modules/@types/node/crypto.d.ts +4456 -0
  29. package/.cache/typescript/5.3/node_modules/@types/node/dgram.d.ts +586 -0
  30. package/.cache/typescript/5.3/node_modules/@types/node/diagnostics_channel.d.ts +191 -0
  31. package/.cache/typescript/5.3/node_modules/@types/node/dns/promises.d.ts +425 -0
  32. package/.cache/typescript/5.3/node_modules/@types/node/dns.d.ts +809 -0
  33. package/.cache/typescript/5.3/node_modules/@types/node/dom-events.d.ts +122 -0
  34. package/.cache/typescript/5.3/node_modules/@types/node/domain.d.ts +170 -0
  35. package/.cache/typescript/5.3/node_modules/@types/node/events.d.ts +879 -0
  36. package/.cache/typescript/5.3/node_modules/@types/node/fs/promises.d.ts +1239 -0
  37. package/.cache/typescript/5.3/node_modules/@types/node/fs.d.ts +4291 -0
  38. package/.cache/typescript/5.3/node_modules/@types/node/globals.d.ts +385 -0
  39. package/.cache/typescript/5.3/node_modules/@types/node/globals.global.d.ts +1 -0
  40. package/.cache/typescript/5.3/node_modules/@types/node/http.d.ts +1888 -0
  41. package/.cache/typescript/5.3/node_modules/@types/node/http2.d.ts +2382 -0
  42. package/.cache/typescript/5.3/node_modules/@types/node/https.d.ts +550 -0
  43. package/.cache/typescript/5.3/node_modules/@types/node/index.d.ts +88 -0
  44. package/.cache/typescript/5.3/node_modules/@types/node/inspector.d.ts +2747 -0
  45. package/.cache/typescript/5.3/node_modules/@types/node/module.d.ts +301 -0
  46. package/.cache/typescript/5.3/node_modules/@types/node/net.d.ts +949 -0
  47. package/.cache/typescript/5.3/node_modules/@types/node/os.d.ts +478 -0
  48. package/.cache/typescript/5.3/node_modules/@types/node/package.json +230 -0
  49. package/.cache/typescript/5.3/node_modules/@types/node/path.d.ts +191 -0
  50. package/.cache/typescript/5.3/node_modules/@types/node/perf_hooks.d.ts +639 -0
  51. package/.cache/typescript/5.3/node_modules/@types/node/process.d.ts +1539 -0
  52. package/.cache/typescript/5.3/node_modules/@types/node/punycode.d.ts +117 -0
  53. package/.cache/typescript/5.3/node_modules/@types/node/querystring.d.ts +141 -0
  54. package/.cache/typescript/5.3/node_modules/@types/node/readline/promises.d.ts +150 -0
  55. package/.cache/typescript/5.3/node_modules/@types/node/readline.d.ts +539 -0
  56. package/.cache/typescript/5.3/node_modules/@types/node/repl.d.ts +430 -0
  57. package/.cache/typescript/5.3/node_modules/@types/node/stream/consumers.d.ts +12 -0
  58. package/.cache/typescript/5.3/node_modules/@types/node/stream/promises.d.ts +83 -0
  59. package/.cache/typescript/5.3/node_modules/@types/node/stream/web.d.ts +350 -0
  60. package/.cache/typescript/5.3/node_modules/@types/node/stream.d.ts +1701 -0
  61. package/.cache/typescript/5.3/node_modules/@types/node/string_decoder.d.ts +67 -0
  62. package/.cache/typescript/5.3/node_modules/@types/node/test.d.ts +1382 -0
  63. package/.cache/typescript/5.3/node_modules/@types/node/timers/promises.d.ts +93 -0
  64. package/.cache/typescript/5.3/node_modules/@types/node/timers.d.ts +240 -0
  65. package/.cache/typescript/5.3/node_modules/@types/node/tls.d.ts +1210 -0
  66. package/.cache/typescript/5.3/node_modules/@types/node/trace_events.d.ts +182 -0
  67. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/assert/strict.d.ts +8 -0
  68. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/assert.d.ts +996 -0
  69. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/async_hooks.d.ts +539 -0
  70. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/buffer.d.ts +2362 -0
  71. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/child_process.d.ts +1540 -0
  72. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/cluster.d.ts +432 -0
  73. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/console.d.ts +415 -0
  74. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/constants.d.ts +19 -0
  75. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/crypto.d.ts +4455 -0
  76. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/dgram.d.ts +586 -0
  77. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/diagnostics_channel.d.ts +191 -0
  78. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/dns/promises.d.ts +425 -0
  79. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/dns.d.ts +809 -0
  80. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/dom-events.d.ts +122 -0
  81. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/domain.d.ts +170 -0
  82. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/events.d.ts +879 -0
  83. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/fs/promises.d.ts +1239 -0
  84. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/fs.d.ts +4291 -0
  85. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/globals.d.ts +385 -0
  86. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/globals.global.d.ts +1 -0
  87. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/http.d.ts +1888 -0
  88. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/http2.d.ts +2382 -0
  89. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/https.d.ts +550 -0
  90. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/index.d.ts +88 -0
  91. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/inspector.d.ts +2747 -0
  92. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/module.d.ts +301 -0
  93. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/net.d.ts +949 -0
  94. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/os.d.ts +478 -0
  95. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/path.d.ts +191 -0
  96. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/perf_hooks.d.ts +639 -0
  97. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/process.d.ts +1539 -0
  98. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/punycode.d.ts +117 -0
  99. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/querystring.d.ts +141 -0
  100. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/readline/promises.d.ts +150 -0
  101. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/readline.d.ts +539 -0
  102. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/repl.d.ts +430 -0
  103. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/stream/consumers.d.ts +12 -0
  104. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/stream/promises.d.ts +83 -0
  105. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/stream/web.d.ts +350 -0
  106. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/stream.d.ts +1701 -0
  107. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/string_decoder.d.ts +67 -0
  108. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/test.d.ts +1382 -0
  109. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/timers/promises.d.ts +93 -0
  110. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/timers.d.ts +240 -0
  111. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/tls.d.ts +1210 -0
  112. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/trace_events.d.ts +182 -0
  113. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/tty.d.ts +208 -0
  114. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/url.d.ts +927 -0
  115. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/util.d.ts +2183 -0
  116. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/v8.d.ts +635 -0
  117. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/vm.d.ts +903 -0
  118. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/wasi.d.ts +158 -0
  119. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/worker_threads.d.ts +691 -0
  120. package/.cache/typescript/5.3/node_modules/@types/node/ts4.8/zlib.d.ts +517 -0
  121. package/.cache/typescript/5.3/node_modules/@types/node/tty.d.ts +208 -0
  122. package/.cache/typescript/5.3/node_modules/@types/node/url.d.ts +927 -0
  123. package/.cache/typescript/5.3/node_modules/@types/node/util.d.ts +2183 -0
  124. package/.cache/typescript/5.3/node_modules/@types/node/v8.d.ts +635 -0
  125. package/.cache/typescript/5.3/node_modules/@types/node/vm.d.ts +903 -0
  126. package/.cache/typescript/5.3/node_modules/@types/node/wasi.d.ts +158 -0
  127. package/.cache/typescript/5.3/node_modules/@types/node/worker_threads.d.ts +691 -0
  128. package/.cache/typescript/5.3/node_modules/@types/node/zlib.d.ts +517 -0
  129. package/.cache/typescript/5.3/node_modules/@types/node-fetch/LICENSE +21 -0
  130. package/.cache/typescript/5.3/node_modules/@types/node-fetch/README.md +15 -0
  131. package/.cache/typescript/5.3/node_modules/@types/node-fetch/externals.d.ts +32 -0
  132. package/.cache/typescript/5.3/node_modules/@types/node-fetch/index.d.ts +214 -0
  133. package/.cache/typescript/5.3/node_modules/@types/node-fetch/package.json +83 -0
  134. package/.cache/typescript/5.3/node_modules/@types/qs/LICENSE +21 -0
  135. package/.cache/typescript/5.3/node_modules/@types/qs/README.md +15 -0
  136. package/.cache/typescript/5.3/node_modules/@types/qs/index.d.ts +79 -0
  137. package/.cache/typescript/5.3/node_modules/@types/qs/package.json +65 -0
  138. package/.cache/typescript/5.3/node_modules/asynckit/LICENSE +21 -0
  139. package/.cache/typescript/5.3/node_modules/asynckit/README.md +233 -0
  140. package/.cache/typescript/5.3/node_modules/asynckit/bench.js +76 -0
  141. package/.cache/typescript/5.3/node_modules/asynckit/index.js +6 -0
  142. package/.cache/typescript/5.3/node_modules/asynckit/lib/abort.js +29 -0
  143. package/.cache/typescript/5.3/node_modules/asynckit/lib/async.js +34 -0
  144. package/.cache/typescript/5.3/node_modules/asynckit/lib/defer.js +26 -0
  145. package/.cache/typescript/5.3/node_modules/asynckit/lib/iterate.js +75 -0
  146. package/.cache/typescript/5.3/node_modules/asynckit/lib/readable_asynckit.js +91 -0
  147. package/.cache/typescript/5.3/node_modules/asynckit/lib/readable_parallel.js +25 -0
  148. package/.cache/typescript/5.3/node_modules/asynckit/lib/readable_serial.js +25 -0
  149. package/.cache/typescript/5.3/node_modules/asynckit/lib/readable_serial_ordered.js +29 -0
  150. package/.cache/typescript/5.3/node_modules/asynckit/lib/state.js +37 -0
  151. package/.cache/typescript/5.3/node_modules/asynckit/lib/streamify.js +141 -0
  152. package/.cache/typescript/5.3/node_modules/asynckit/lib/terminator.js +29 -0
  153. package/.cache/typescript/5.3/node_modules/asynckit/package.json +63 -0
  154. package/.cache/typescript/5.3/node_modules/asynckit/parallel.js +43 -0
  155. package/.cache/typescript/5.3/node_modules/asynckit/serial.js +17 -0
  156. package/.cache/typescript/5.3/node_modules/asynckit/serialOrdered.js +75 -0
  157. package/.cache/typescript/5.3/node_modules/asynckit/stream.js +21 -0
  158. package/.cache/typescript/5.3/node_modules/combined-stream/License +19 -0
  159. package/.cache/typescript/5.3/node_modules/combined-stream/Readme.md +138 -0
  160. package/.cache/typescript/5.3/node_modules/combined-stream/lib/combined_stream.js +208 -0
  161. package/.cache/typescript/5.3/node_modules/combined-stream/package.json +25 -0
  162. package/.cache/typescript/5.3/node_modules/combined-stream/yarn.lock +17 -0
  163. package/.cache/typescript/5.3/node_modules/delayed-stream/License +19 -0
  164. package/.cache/typescript/5.3/node_modules/delayed-stream/Makefile +7 -0
  165. package/.cache/typescript/5.3/node_modules/delayed-stream/Readme.md +141 -0
  166. package/.cache/typescript/5.3/node_modules/delayed-stream/lib/delayed_stream.js +107 -0
  167. package/.cache/typescript/5.3/node_modules/delayed-stream/package.json +27 -0
  168. package/.cache/typescript/5.3/node_modules/form-data/License +19 -0
  169. package/.cache/typescript/5.3/node_modules/form-data/README.md.bak +358 -0
  170. package/.cache/typescript/5.3/node_modules/form-data/Readme.md +358 -0
  171. package/.cache/typescript/5.3/node_modules/form-data/index.d.ts +62 -0
  172. package/.cache/typescript/5.3/node_modules/form-data/lib/browser.js +2 -0
  173. package/.cache/typescript/5.3/node_modules/form-data/lib/form_data.js +501 -0
  174. package/.cache/typescript/5.3/node_modules/form-data/lib/populate.js +10 -0
  175. package/.cache/typescript/5.3/node_modules/form-data/package.json +68 -0
  176. package/.cache/typescript/5.3/node_modules/mime-db/HISTORY.md +507 -0
  177. package/.cache/typescript/5.3/node_modules/mime-db/LICENSE +23 -0
  178. package/.cache/typescript/5.3/node_modules/mime-db/README.md +100 -0
  179. package/.cache/typescript/5.3/node_modules/mime-db/db.json +8519 -0
  180. package/.cache/typescript/5.3/node_modules/mime-db/index.js +12 -0
  181. package/.cache/typescript/5.3/node_modules/mime-db/package.json +60 -0
  182. package/.cache/typescript/5.3/node_modules/mime-types/HISTORY.md +397 -0
  183. package/.cache/typescript/5.3/node_modules/mime-types/LICENSE +23 -0
  184. package/.cache/typescript/5.3/node_modules/mime-types/README.md +113 -0
  185. package/.cache/typescript/5.3/node_modules/mime-types/index.js +188 -0
  186. package/.cache/typescript/5.3/node_modules/mime-types/package.json +44 -0
  187. package/.cache/typescript/5.3/node_modules/types-registry/README.md +2 -0
  188. package/.cache/typescript/5.3/node_modules/types-registry/index.json +1 -0
  189. package/.cache/typescript/5.3/node_modules/types-registry/package.json +20 -0
  190. package/.cache/typescript/5.3/node_modules/undici-types/README.md +6 -0
  191. package/.cache/typescript/5.3/node_modules/undici-types/agent.d.ts +31 -0
  192. package/.cache/typescript/5.3/node_modules/undici-types/api.d.ts +43 -0
  193. package/.cache/typescript/5.3/node_modules/undici-types/balanced-pool.d.ts +18 -0
  194. package/.cache/typescript/5.3/node_modules/undici-types/cache.d.ts +36 -0
  195. package/.cache/typescript/5.3/node_modules/undici-types/client.d.ts +97 -0
  196. package/.cache/typescript/5.3/node_modules/undici-types/connector.d.ts +34 -0
  197. package/.cache/typescript/5.3/node_modules/undici-types/content-type.d.ts +21 -0
  198. package/.cache/typescript/5.3/node_modules/undici-types/cookies.d.ts +28 -0
  199. package/.cache/typescript/5.3/node_modules/undici-types/diagnostics-channel.d.ts +67 -0
  200. package/.cache/typescript/5.3/node_modules/undici-types/dispatcher.d.ts +241 -0
  201. package/.cache/typescript/5.3/node_modules/undici-types/errors.d.ts +128 -0
  202. package/.cache/typescript/5.3/node_modules/undici-types/fetch.d.ts +209 -0
  203. package/.cache/typescript/5.3/node_modules/undici-types/file.d.ts +39 -0
  204. package/.cache/typescript/5.3/node_modules/undici-types/filereader.d.ts +54 -0
  205. package/.cache/typescript/5.3/node_modules/undici-types/formdata.d.ts +108 -0
  206. package/.cache/typescript/5.3/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  207. package/.cache/typescript/5.3/node_modules/undici-types/global-origin.d.ts +7 -0
  208. package/.cache/typescript/5.3/node_modules/undici-types/handlers.d.ts +9 -0
  209. package/.cache/typescript/5.3/node_modules/undici-types/header.d.ts +4 -0
  210. package/.cache/typescript/5.3/node_modules/undici-types/index.d.ts +63 -0
  211. package/.cache/typescript/5.3/node_modules/undici-types/interceptors.d.ts +5 -0
  212. package/.cache/typescript/5.3/node_modules/undici-types/mock-agent.d.ts +50 -0
  213. package/.cache/typescript/5.3/node_modules/undici-types/mock-client.d.ts +25 -0
  214. package/.cache/typescript/5.3/node_modules/undici-types/mock-errors.d.ts +12 -0
  215. package/.cache/typescript/5.3/node_modules/undici-types/mock-interceptor.d.ts +93 -0
  216. package/.cache/typescript/5.3/node_modules/undici-types/mock-pool.d.ts +25 -0
  217. package/.cache/typescript/5.3/node_modules/undici-types/package.json +55 -0
  218. package/.cache/typescript/5.3/node_modules/undici-types/patch.d.ts +71 -0
  219. package/.cache/typescript/5.3/node_modules/undici-types/pool-stats.d.ts +19 -0
  220. package/.cache/typescript/5.3/node_modules/undici-types/pool.d.ts +28 -0
  221. package/.cache/typescript/5.3/node_modules/undici-types/proxy-agent.d.ts +30 -0
  222. package/.cache/typescript/5.3/node_modules/undici-types/readable.d.ts +61 -0
  223. package/.cache/typescript/5.3/node_modules/undici-types/webidl.d.ts +220 -0
  224. package/.cache/typescript/5.3/node_modules/undici-types/websocket.d.ts +131 -0
  225. package/.cache/typescript/5.3/package.json +1 -0
  226. package/IMRAN/module.js +275 -0
  227. package/README.md +76 -3
  228. package/index.js +13 -0
  229. package/package.json +45 -3
@@ -0,0 +1,927 @@
1
+ /**
2
+ * The `node:url` module provides utilities for URL resolution and parsing. It can
3
+ * be accessed using:
4
+ *
5
+ * ```js
6
+ * import url from 'node:url';
7
+ * ```
8
+ * @see [source](https://github.com/nodejs/node/blob/v20.2.0/lib/url.js)
9
+ */
10
+ declare module "url" {
11
+ import { Blob as NodeBlob } from "node:buffer";
12
+ import { ClientRequestArgs } from "node:http";
13
+ import { ParsedUrlQuery, ParsedUrlQueryInput } from "node:querystring";
14
+ // Input to `url.format`
15
+ interface UrlObject {
16
+ auth?: string | null | undefined;
17
+ hash?: string | null | undefined;
18
+ host?: string | null | undefined;
19
+ hostname?: string | null | undefined;
20
+ href?: string | null | undefined;
21
+ pathname?: string | null | undefined;
22
+ protocol?: string | null | undefined;
23
+ search?: string | null | undefined;
24
+ slashes?: boolean | null | undefined;
25
+ port?: string | number | null | undefined;
26
+ query?: string | null | ParsedUrlQueryInput | undefined;
27
+ }
28
+ // Output of `url.parse`
29
+ interface Url {
30
+ auth: string | null;
31
+ hash: string | null;
32
+ host: string | null;
33
+ hostname: string | null;
34
+ href: string;
35
+ path: string | null;
36
+ pathname: string | null;
37
+ protocol: string | null;
38
+ search: string | null;
39
+ slashes: boolean | null;
40
+ port: string | null;
41
+ query: string | null | ParsedUrlQuery;
42
+ }
43
+ interface UrlWithParsedQuery extends Url {
44
+ query: ParsedUrlQuery;
45
+ }
46
+ interface UrlWithStringQuery extends Url {
47
+ query: string | null;
48
+ }
49
+ /**
50
+ * The `url.parse()` method takes a URL string, parses it, and returns a URL
51
+ * object.
52
+ *
53
+ * A `TypeError` is thrown if `urlString` is not a string.
54
+ *
55
+ * A `URIError` is thrown if the `auth` property is present but cannot be decoded.
56
+ *
57
+ * `url.parse()` uses a lenient, non-standard algorithm for parsing URL
58
+ * strings. It is prone to security issues such as [host name spoofing](https://hackerone.com/reports/678487) and incorrect handling of usernames and passwords. Do not use with untrusted
59
+ * input. CVEs are not issued for `url.parse()` vulnerabilities. Use the `WHATWG URL` API instead.
60
+ * @since v0.1.25
61
+ * @deprecated Use the WHATWG URL API instead.
62
+ * @param urlString The URL string to parse.
63
+ * @param [parseQueryString=false] If `true`, the `query` property will always be set to an object returned by the {@link querystring} module's `parse()` method. If `false`, the `query` property
64
+ * on the returned URL object will be an unparsed, undecoded string.
65
+ * @param [slashesDenoteHost=false] If `true`, the first token after the literal string `//` and preceding the next `/` will be interpreted as the `host`. For instance, given `//foo/bar`, the
66
+ * result would be `{host: 'foo', pathname: '/bar'}` rather than `{pathname: '//foo/bar'}`.
67
+ */
68
+ function parse(urlString: string): UrlWithStringQuery;
69
+ function parse(
70
+ urlString: string,
71
+ parseQueryString: false | undefined,
72
+ slashesDenoteHost?: boolean,
73
+ ): UrlWithStringQuery;
74
+ function parse(urlString: string, parseQueryString: true, slashesDenoteHost?: boolean): UrlWithParsedQuery;
75
+ function parse(urlString: string, parseQueryString: boolean, slashesDenoteHost?: boolean): Url;
76
+ /**
77
+ * The `url.format()` method returns a formatted URL string derived from`urlObject`.
78
+ *
79
+ * ```js
80
+ * const url = require('node:url');
81
+ * url.format({
82
+ * protocol: 'https',
83
+ * hostname: 'example.com',
84
+ * pathname: '/some/path',
85
+ * query: {
86
+ * page: 1,
87
+ * format: 'json',
88
+ * },
89
+ * });
90
+ *
91
+ * // => 'https://example.com/some/path?page=1&format=json'
92
+ * ```
93
+ *
94
+ * If `urlObject` is not an object or a string, `url.format()` will throw a `TypeError`.
95
+ *
96
+ * The formatting process operates as follows:
97
+ *
98
+ * * A new empty string `result` is created.
99
+ * * If `urlObject.protocol` is a string, it is appended as-is to `result`.
100
+ * * Otherwise, if `urlObject.protocol` is not `undefined` and is not a string, an `Error` is thrown.
101
+ * * For all string values of `urlObject.protocol` that _do not end_ with an ASCII
102
+ * colon (`:`) character, the literal string `:` will be appended to `result`.
103
+ * * If either of the following conditions is true, then the literal string `//`will be appended to `result`:
104
+ * * `urlObject.slashes` property is true;
105
+ * * `urlObject.protocol` begins with `http`, `https`, `ftp`, `gopher`, or`file`;
106
+ * * If the value of the `urlObject.auth` property is truthy, and either`urlObject.host` or `urlObject.hostname` are not `undefined`, the value of`urlObject.auth` will be coerced into a string
107
+ * and appended to `result`followed by the literal string `@`.
108
+ * * If the `urlObject.host` property is `undefined` then:
109
+ * * If the `urlObject.hostname` is a string, it is appended to `result`.
110
+ * * Otherwise, if `urlObject.hostname` is not `undefined` and is not a string,
111
+ * an `Error` is thrown.
112
+ * * If the `urlObject.port` property value is truthy, and `urlObject.hostname`is not `undefined`:
113
+ * * The literal string `:` is appended to `result`, and
114
+ * * The value of `urlObject.port` is coerced to a string and appended to`result`.
115
+ * * Otherwise, if the `urlObject.host` property value is truthy, the value of`urlObject.host` is coerced to a string and appended to `result`.
116
+ * * If the `urlObject.pathname` property is a string that is not an empty string:
117
+ * * If the `urlObject.pathname`_does not start_ with an ASCII forward slash
118
+ * (`/`), then the literal string `'/'` is appended to `result`.
119
+ * * The value of `urlObject.pathname` is appended to `result`.
120
+ * * Otherwise, if `urlObject.pathname` is not `undefined` and is not a string, an `Error` is thrown.
121
+ * * If the `urlObject.search` property is `undefined` and if the `urlObject.query`property is an `Object`, the literal string `?` is appended to `result`followed by the output of calling the
122
+ * `querystring` module's `stringify()`method passing the value of `urlObject.query`.
123
+ * * Otherwise, if `urlObject.search` is a string:
124
+ * * If the value of `urlObject.search`_does not start_ with the ASCII question
125
+ * mark (`?`) character, the literal string `?` is appended to `result`.
126
+ * * The value of `urlObject.search` is appended to `result`.
127
+ * * Otherwise, if `urlObject.search` is not `undefined` and is not a string, an `Error` is thrown.
128
+ * * If the `urlObject.hash` property is a string:
129
+ * * If the value of `urlObject.hash`_does not start_ with the ASCII hash (`#`)
130
+ * character, the literal string `#` is appended to `result`.
131
+ * * The value of `urlObject.hash` is appended to `result`.
132
+ * * Otherwise, if the `urlObject.hash` property is not `undefined` and is not a
133
+ * string, an `Error` is thrown.
134
+ * * `result` is returned.
135
+ * @since v0.1.25
136
+ * @legacy Use the WHATWG URL API instead.
137
+ * @param urlObject A URL object (as returned by `url.parse()` or constructed otherwise). If a string, it is converted to an object by passing it to `url.parse()`.
138
+ */
139
+ function format(urlObject: URL, options?: URLFormatOptions): string;
140
+ /**
141
+ * The `url.format()` method returns a formatted URL string derived from`urlObject`.
142
+ *
143
+ * ```js
144
+ * const url = require('url');
145
+ * url.format({
146
+ * protocol: 'https',
147
+ * hostname: 'example.com',
148
+ * pathname: '/some/path',
149
+ * query: {
150
+ * page: 1,
151
+ * format: 'json'
152
+ * }
153
+ * });
154
+ *
155
+ * // => 'https://example.com/some/path?page=1&format=json'
156
+ * ```
157
+ *
158
+ * If `urlObject` is not an object or a string, `url.format()` will throw a `TypeError`.
159
+ *
160
+ * The formatting process operates as follows:
161
+ *
162
+ * * A new empty string `result` is created.
163
+ * * If `urlObject.protocol` is a string, it is appended as-is to `result`.
164
+ * * Otherwise, if `urlObject.protocol` is not `undefined` and is not a string, an `Error` is thrown.
165
+ * * For all string values of `urlObject.protocol` that _do not end_ with an ASCII
166
+ * colon (`:`) character, the literal string `:` will be appended to `result`.
167
+ * * If either of the following conditions is true, then the literal string `//`will be appended to `result`:
168
+ * * `urlObject.slashes` property is true;
169
+ * * `urlObject.protocol` begins with `http`, `https`, `ftp`, `gopher`, or`file`;
170
+ * * If the value of the `urlObject.auth` property is truthy, and either`urlObject.host` or `urlObject.hostname` are not `undefined`, the value of`urlObject.auth` will be coerced into a string
171
+ * and appended to `result`followed by the literal string `@`.
172
+ * * If the `urlObject.host` property is `undefined` then:
173
+ * * If the `urlObject.hostname` is a string, it is appended to `result`.
174
+ * * Otherwise, if `urlObject.hostname` is not `undefined` and is not a string,
175
+ * an `Error` is thrown.
176
+ * * If the `urlObject.port` property value is truthy, and `urlObject.hostname`is not `undefined`:
177
+ * * The literal string `:` is appended to `result`, and
178
+ * * The value of `urlObject.port` is coerced to a string and appended to`result`.
179
+ * * Otherwise, if the `urlObject.host` property value is truthy, the value of`urlObject.host` is coerced to a string and appended to `result`.
180
+ * * If the `urlObject.pathname` property is a string that is not an empty string:
181
+ * * If the `urlObject.pathname`_does not start_ with an ASCII forward slash
182
+ * (`/`), then the literal string `'/'` is appended to `result`.
183
+ * * The value of `urlObject.pathname` is appended to `result`.
184
+ * * Otherwise, if `urlObject.pathname` is not `undefined` and is not a string, an `Error` is thrown.
185
+ * * If the `urlObject.search` property is `undefined` and if the `urlObject.query`property is an `Object`, the literal string `?` is appended to `result`followed by the output of calling the
186
+ * `querystring` module's `stringify()`method passing the value of `urlObject.query`.
187
+ * * Otherwise, if `urlObject.search` is a string:
188
+ * * If the value of `urlObject.search`_does not start_ with the ASCII question
189
+ * mark (`?`) character, the literal string `?` is appended to `result`.
190
+ * * The value of `urlObject.search` is appended to `result`.
191
+ * * Otherwise, if `urlObject.search` is not `undefined` and is not a string, an `Error` is thrown.
192
+ * * If the `urlObject.hash` property is a string:
193
+ * * If the value of `urlObject.hash`_does not start_ with the ASCII hash (`#`)
194
+ * character, the literal string `#` is appended to `result`.
195
+ * * The value of `urlObject.hash` is appended to `result`.
196
+ * * Otherwise, if the `urlObject.hash` property is not `undefined` and is not a
197
+ * string, an `Error` is thrown.
198
+ * * `result` is returned.
199
+ * @since v0.1.25
200
+ * @legacy Use the WHATWG URL API instead.
201
+ * @param urlObject A URL object (as returned by `url.parse()` or constructed otherwise). If a string, it is converted to an object by passing it to `url.parse()`.
202
+ */
203
+ function format(urlObject: UrlObject | string): string;
204
+ /**
205
+ * The `url.resolve()` method resolves a target URL relative to a base URL in a
206
+ * manner similar to that of a web browser resolving an anchor tag.
207
+ *
208
+ * ```js
209
+ * const url = require('node:url');
210
+ * url.resolve('/one/two/three', 'four'); // '/one/two/four'
211
+ * url.resolve('http://example.com/', '/one'); // 'http://example.com/one'
212
+ * url.resolve('http://example.com/one', '/two'); // 'http://example.com/two'
213
+ * ```
214
+ *
215
+ * To achieve the same result using the WHATWG URL API:
216
+ *
217
+ * ```js
218
+ * function resolve(from, to) {
219
+ * const resolvedUrl = new URL(to, new URL(from, 'resolve://'));
220
+ * if (resolvedUrl.protocol === 'resolve:') {
221
+ * // `from` is a relative URL.
222
+ * const { pathname, search, hash } = resolvedUrl;
223
+ * return pathname + search + hash;
224
+ * }
225
+ * return resolvedUrl.toString();
226
+ * }
227
+ *
228
+ * resolve('/one/two/three', 'four'); // '/one/two/four'
229
+ * resolve('http://example.com/', '/one'); // 'http://example.com/one'
230
+ * resolve('http://example.com/one', '/two'); // 'http://example.com/two'
231
+ * ```
232
+ * @since v0.1.25
233
+ * @legacy Use the WHATWG URL API instead.
234
+ * @param from The base URL to use if `to` is a relative URL.
235
+ * @param to The target URL to resolve.
236
+ */
237
+ function resolve(from: string, to: string): string;
238
+ /**
239
+ * Returns the [Punycode](https://tools.ietf.org/html/rfc5891#section-4.4) ASCII serialization of the `domain`. If `domain` is an
240
+ * invalid domain, the empty string is returned.
241
+ *
242
+ * It performs the inverse operation to {@link domainToUnicode}.
243
+ *
244
+ * ```js
245
+ * import url from 'node:url';
246
+ *
247
+ * console.log(url.domainToASCII('español.com'));
248
+ * // Prints xn--espaol-zwa.com
249
+ * console.log(url.domainToASCII('中文.com'));
250
+ * // Prints xn--fiq228c.com
251
+ * console.log(url.domainToASCII('xn--iñvalid.com'));
252
+ * // Prints an empty string
253
+ * ```
254
+ * @since v7.4.0, v6.13.0
255
+ */
256
+ function domainToASCII(domain: string): string;
257
+ /**
258
+ * Returns the Unicode serialization of the `domain`. If `domain` is an invalid
259
+ * domain, the empty string is returned.
260
+ *
261
+ * It performs the inverse operation to {@link domainToASCII}.
262
+ *
263
+ * ```js
264
+ * import url from 'node:url';
265
+ *
266
+ * console.log(url.domainToUnicode('xn--espaol-zwa.com'));
267
+ * // Prints español.com
268
+ * console.log(url.domainToUnicode('xn--fiq228c.com'));
269
+ * // Prints 中文.com
270
+ * console.log(url.domainToUnicode('xn--iñvalid.com'));
271
+ * // Prints an empty string
272
+ * ```
273
+ * @since v7.4.0, v6.13.0
274
+ */
275
+ function domainToUnicode(domain: string): string;
276
+ /**
277
+ * This function ensures the correct decodings of percent-encoded characters as
278
+ * well as ensuring a cross-platform valid absolute path string.
279
+ *
280
+ * ```js
281
+ * import { fileURLToPath } from 'node:url';
282
+ *
283
+ * const __filename = fileURLToPath(import.meta.url);
284
+ *
285
+ * new URL('file:///C:/path/').pathname; // Incorrect: /C:/path/
286
+ * fileURLToPath('file:///C:/path/'); // Correct: C:\path\ (Windows)
287
+ *
288
+ * new URL('file://nas/foo.txt').pathname; // Incorrect: /foo.txt
289
+ * fileURLToPath('file://nas/foo.txt'); // Correct: \\nas\foo.txt (Windows)
290
+ *
291
+ * new URL('file:///你好.txt').pathname; // Incorrect: /%E4%BD%A0%E5%A5%BD.txt
292
+ * fileURLToPath('file:///你好.txt'); // Correct: /你好.txt (POSIX)
293
+ *
294
+ * new URL('file:///hello world').pathname; // Incorrect: /hello%20world
295
+ * fileURLToPath('file:///hello world'); // Correct: /hello world (POSIX)
296
+ * ```
297
+ * @since v10.12.0
298
+ * @param url The file URL string or URL object to convert to a path.
299
+ * @return The fully-resolved platform-specific Node.js file path.
300
+ */
301
+ function fileURLToPath(url: string | URL): string;
302
+ /**
303
+ * This function ensures that `path` is resolved absolutely, and that the URL
304
+ * control characters are correctly encoded when converting into a File URL.
305
+ *
306
+ * ```js
307
+ * import { pathToFileURL } from 'node:url';
308
+ *
309
+ * new URL('/foo#1', 'file:'); // Incorrect: file:///foo#1
310
+ * pathToFileURL('/foo#1'); // Correct: file:///foo%231 (POSIX)
311
+ *
312
+ * new URL('/some/path%.c', 'file:'); // Incorrect: file:///some/path%.c
313
+ * pathToFileURL('/some/path%.c'); // Correct: file:///some/path%25.c (POSIX)
314
+ * ```
315
+ * @since v10.12.0
316
+ * @param path The path to convert to a File URL.
317
+ * @return The file URL object.
318
+ */
319
+ function pathToFileURL(path: string): URL;
320
+ /**
321
+ * This utility function converts a URL object into an ordinary options object as
322
+ * expected by the `http.request()` and `https.request()` APIs.
323
+ *
324
+ * ```js
325
+ * import { urlToHttpOptions } from 'node:url';
326
+ * const myURL = new URL('https://a:b@測試?abc#foo');
327
+ *
328
+ * console.log(urlToHttpOptions(myURL));
329
+ * /*
330
+ * {
331
+ * protocol: 'https:',
332
+ * hostname: 'xn--g6w251d',
333
+ * hash: '#foo',
334
+ * search: '?abc',
335
+ * pathname: '/',
336
+ * path: '/?abc',
337
+ * href: 'https://a:b@xn--g6w251d/?abc#foo',
338
+ * auth: 'a:b'
339
+ * }
340
+ *
341
+ * ```
342
+ * @since v15.7.0, v14.18.0
343
+ * @param url The `WHATWG URL` object to convert to an options object.
344
+ * @return Options object
345
+ */
346
+ function urlToHttpOptions(url: URL): ClientRequestArgs;
347
+ interface URLFormatOptions {
348
+ auth?: boolean | undefined;
349
+ fragment?: boolean | undefined;
350
+ search?: boolean | undefined;
351
+ unicode?: boolean | undefined;
352
+ }
353
+ /**
354
+ * Browser-compatible `URL` class, implemented by following the WHATWG URL
355
+ * Standard. [Examples of parsed URLs](https://url.spec.whatwg.org/#example-url-parsing) may be found in the Standard itself.
356
+ * The `URL` class is also available on the global object.
357
+ *
358
+ * In accordance with browser conventions, all properties of `URL` objects
359
+ * are implemented as getters and setters on the class prototype, rather than as
360
+ * data properties on the object itself. Thus, unlike `legacy urlObject` s,
361
+ * using the `delete` keyword on any properties of `URL` objects (e.g. `delete myURL.protocol`, `delete myURL.pathname`, etc) has no effect but will still
362
+ * return `true`.
363
+ * @since v7.0.0, v6.13.0
364
+ */
365
+ class URL {
366
+ /**
367
+ * Creates a `'blob:nodedata:...'` URL string that represents the given `Blob` object and can be used to retrieve the `Blob` later.
368
+ *
369
+ * ```js
370
+ * const {
371
+ * Blob,
372
+ * resolveObjectURL,
373
+ * } = require('node:buffer');
374
+ *
375
+ * const blob = new Blob(['hello']);
376
+ * const id = URL.createObjectURL(blob);
377
+ *
378
+ * // later...
379
+ *
380
+ * const otherBlob = resolveObjectURL(id);
381
+ * console.log(otherBlob.size);
382
+ * ```
383
+ *
384
+ * The data stored by the registered `Blob` will be retained in memory until`URL.revokeObjectURL()` is called to remove it.
385
+ *
386
+ * `Blob` objects are registered within the current thread. If using Worker
387
+ * Threads, `Blob` objects registered within one Worker will not be available
388
+ * to other workers or the main thread.
389
+ * @since v16.7.0
390
+ * @experimental
391
+ */
392
+ static createObjectURL(blob: NodeBlob): string;
393
+ /**
394
+ * Removes the stored `Blob` identified by the given ID. Attempting to revoke a
395
+ * ID that isn't registered will silently fail.
396
+ * @since v16.7.0
397
+ * @experimental
398
+ * @param id A `'blob:nodedata:...` URL string returned by a prior call to `URL.createObjectURL()`.
399
+ */
400
+ static revokeObjectURL(objectUrl: string): void;
401
+ /**
402
+ * Checks if an `input` relative to the `base` can be parsed to a `URL`.
403
+ *
404
+ * ```js
405
+ * const isValid = URL.canParse('/foo', 'https://example.org/'); // true
406
+ *
407
+ * const isNotValid = URL.canParse('/foo'); // false
408
+ * ```
409
+ * @since v19.9.0
410
+ * @param input The absolute or relative input URL to parse. If `input` is relative, then `base` is required. If `input` is absolute, the `base` is ignored. If `input` is not a string, it is
411
+ * `converted to a string` first.
412
+ * @param base The base URL to resolve against if the `input` is not absolute. If `base` is not a string, it is `converted to a string` first.
413
+ */
414
+ static canParse(input: string, base?: string): boolean;
415
+ constructor(input: string, base?: string | URL);
416
+ /**
417
+ * Gets and sets the fragment portion of the URL.
418
+ *
419
+ * ```js
420
+ * const myURL = new URL('https://example.org/foo#bar');
421
+ * console.log(myURL.hash);
422
+ * // Prints #bar
423
+ *
424
+ * myURL.hash = 'baz';
425
+ * console.log(myURL.href);
426
+ * // Prints https://example.org/foo#baz
427
+ * ```
428
+ *
429
+ * Invalid URL characters included in the value assigned to the `hash` property
430
+ * are `percent-encoded`. The selection of which characters to
431
+ * percent-encode may vary somewhat from what the {@link parse} and {@link format} methods would produce.
432
+ */
433
+ hash: string;
434
+ /**
435
+ * Gets and sets the host portion of the URL.
436
+ *
437
+ * ```js
438
+ * const myURL = new URL('https://example.org:81/foo');
439
+ * console.log(myURL.host);
440
+ * // Prints example.org:81
441
+ *
442
+ * myURL.host = 'example.com:82';
443
+ * console.log(myURL.href);
444
+ * // Prints https://example.com:82/foo
445
+ * ```
446
+ *
447
+ * Invalid host values assigned to the `host` property are ignored.
448
+ */
449
+ host: string;
450
+ /**
451
+ * Gets and sets the host name portion of the URL. The key difference between`url.host` and `url.hostname` is that `url.hostname` does _not_ include the
452
+ * port.
453
+ *
454
+ * ```js
455
+ * const myURL = new URL('https://example.org:81/foo');
456
+ * console.log(myURL.hostname);
457
+ * // Prints example.org
458
+ *
459
+ * // Setting the hostname does not change the port
460
+ * myURL.hostname = 'example.com';
461
+ * console.log(myURL.href);
462
+ * // Prints https://example.com:81/foo
463
+ *
464
+ * // Use myURL.host to change the hostname and port
465
+ * myURL.host = 'example.org:82';
466
+ * console.log(myURL.href);
467
+ * // Prints https://example.org:82/foo
468
+ * ```
469
+ *
470
+ * Invalid host name values assigned to the `hostname` property are ignored.
471
+ */
472
+ hostname: string;
473
+ /**
474
+ * Gets and sets the serialized URL.
475
+ *
476
+ * ```js
477
+ * const myURL = new URL('https://example.org/foo');
478
+ * console.log(myURL.href);
479
+ * // Prints https://example.org/foo
480
+ *
481
+ * myURL.href = 'https://example.com/bar';
482
+ * console.log(myURL.href);
483
+ * // Prints https://example.com/bar
484
+ * ```
485
+ *
486
+ * Getting the value of the `href` property is equivalent to calling {@link toString}.
487
+ *
488
+ * Setting the value of this property to a new value is equivalent to creating a
489
+ * new `URL` object using `new URL(value)`. Each of the `URL`object's properties will be modified.
490
+ *
491
+ * If the value assigned to the `href` property is not a valid URL, a `TypeError`will be thrown.
492
+ */
493
+ href: string;
494
+ /**
495
+ * Gets the read-only serialization of the URL's origin.
496
+ *
497
+ * ```js
498
+ * const myURL = new URL('https://example.org/foo/bar?baz');
499
+ * console.log(myURL.origin);
500
+ * // Prints https://example.org
501
+ * ```
502
+ *
503
+ * ```js
504
+ * const idnURL = new URL('https://測試');
505
+ * console.log(idnURL.origin);
506
+ * // Prints https://xn--g6w251d
507
+ *
508
+ * console.log(idnURL.hostname);
509
+ * // Prints xn--g6w251d
510
+ * ```
511
+ */
512
+ readonly origin: string;
513
+ /**
514
+ * Gets and sets the password portion of the URL.
515
+ *
516
+ * ```js
517
+ * const myURL = new URL('https://abc:xyz@example.com');
518
+ * console.log(myURL.password);
519
+ * // Prints xyz
520
+ *
521
+ * myURL.password = '123';
522
+ * console.log(myURL.href);
523
+ * // Prints https://abc:123@example.com/
524
+ * ```
525
+ *
526
+ * Invalid URL characters included in the value assigned to the `password` property
527
+ * are `percent-encoded`. The selection of which characters to
528
+ * percent-encode may vary somewhat from what the {@link parse} and {@link format} methods would produce.
529
+ */
530
+ password: string;
531
+ /**
532
+ * Gets and sets the path portion of the URL.
533
+ *
534
+ * ```js
535
+ * const myURL = new URL('https://example.org/abc/xyz?123');
536
+ * console.log(myURL.pathname);
537
+ * // Prints /abc/xyz
538
+ *
539
+ * myURL.pathname = '/abcdef';
540
+ * console.log(myURL.href);
541
+ * // Prints https://example.org/abcdef?123
542
+ * ```
543
+ *
544
+ * Invalid URL characters included in the value assigned to the `pathname`property are `percent-encoded`. The selection of which characters
545
+ * to percent-encode may vary somewhat from what the {@link parse} and {@link format} methods would produce.
546
+ */
547
+ pathname: string;
548
+ /**
549
+ * Gets and sets the port portion of the URL.
550
+ *
551
+ * The port value may be a number or a string containing a number in the range`0` to `65535` (inclusive). Setting the value to the default port of the`URL` objects given `protocol` will
552
+ * result in the `port` value becoming
553
+ * the empty string (`''`).
554
+ *
555
+ * The port value can be an empty string in which case the port depends on
556
+ * the protocol/scheme:
557
+ *
558
+ * <omitted>
559
+ *
560
+ * Upon assigning a value to the port, the value will first be converted to a
561
+ * string using `.toString()`.
562
+ *
563
+ * If that string is invalid but it begins with a number, the leading number is
564
+ * assigned to `port`.
565
+ * If the number lies outside the range denoted above, it is ignored.
566
+ *
567
+ * ```js
568
+ * const myURL = new URL('https://example.org:8888');
569
+ * console.log(myURL.port);
570
+ * // Prints 8888
571
+ *
572
+ * // Default ports are automatically transformed to the empty string
573
+ * // (HTTPS protocol's default port is 443)
574
+ * myURL.port = '443';
575
+ * console.log(myURL.port);
576
+ * // Prints the empty string
577
+ * console.log(myURL.href);
578
+ * // Prints https://example.org/
579
+ *
580
+ * myURL.port = 1234;
581
+ * console.log(myURL.port);
582
+ * // Prints 1234
583
+ * console.log(myURL.href);
584
+ * // Prints https://example.org:1234/
585
+ *
586
+ * // Completely invalid port strings are ignored
587
+ * myURL.port = 'abcd';
588
+ * console.log(myURL.port);
589
+ * // Prints 1234
590
+ *
591
+ * // Leading numbers are treated as a port number
592
+ * myURL.port = '5678abcd';
593
+ * console.log(myURL.port);
594
+ * // Prints 5678
595
+ *
596
+ * // Non-integers are truncated
597
+ * myURL.port = 1234.5678;
598
+ * console.log(myURL.port);
599
+ * // Prints 1234
600
+ *
601
+ * // Out-of-range numbers which are not represented in scientific notation
602
+ * // will be ignored.
603
+ * myURL.port = 1e10; // 10000000000, will be range-checked as described below
604
+ * console.log(myURL.port);
605
+ * // Prints 1234
606
+ * ```
607
+ *
608
+ * Numbers which contain a decimal point,
609
+ * such as floating-point numbers or numbers in scientific notation,
610
+ * are not an exception to this rule.
611
+ * Leading numbers up to the decimal point will be set as the URL's port,
612
+ * assuming they are valid:
613
+ *
614
+ * ```js
615
+ * myURL.port = 4.567e21;
616
+ * console.log(myURL.port);
617
+ * // Prints 4 (because it is the leading number in the string '4.567e21')
618
+ * ```
619
+ */
620
+ port: string;
621
+ /**
622
+ * Gets and sets the protocol portion of the URL.
623
+ *
624
+ * ```js
625
+ * const myURL = new URL('https://example.org');
626
+ * console.log(myURL.protocol);
627
+ * // Prints https:
628
+ *
629
+ * myURL.protocol = 'ftp';
630
+ * console.log(myURL.href);
631
+ * // Prints ftp://example.org/
632
+ * ```
633
+ *
634
+ * Invalid URL protocol values assigned to the `protocol` property are ignored.
635
+ */
636
+ protocol: string;
637
+ /**
638
+ * Gets and sets the serialized query portion of the URL.
639
+ *
640
+ * ```js
641
+ * const myURL = new URL('https://example.org/abc?123');
642
+ * console.log(myURL.search);
643
+ * // Prints ?123
644
+ *
645
+ * myURL.search = 'abc=xyz';
646
+ * console.log(myURL.href);
647
+ * // Prints https://example.org/abc?abc=xyz
648
+ * ```
649
+ *
650
+ * Any invalid URL characters appearing in the value assigned the `search`property will be `percent-encoded`. The selection of which
651
+ * characters to percent-encode may vary somewhat from what the {@link parse} and {@link format} methods would produce.
652
+ */
653
+ search: string;
654
+ /**
655
+ * Gets the `URLSearchParams` object representing the query parameters of the
656
+ * URL. This property is read-only but the `URLSearchParams` object it provides
657
+ * can be used to mutate the URL instance; to replace the entirety of query
658
+ * parameters of the URL, use the {@link search} setter. See `URLSearchParams` documentation for details.
659
+ *
660
+ * Use care when using `.searchParams` to modify the `URL` because,
661
+ * per the WHATWG specification, the `URLSearchParams` object uses
662
+ * different rules to determine which characters to percent-encode. For
663
+ * instance, the `URL` object will not percent encode the ASCII tilde (`~`)
664
+ * character, while `URLSearchParams` will always encode it:
665
+ *
666
+ * ```js
667
+ * const myURL = new URL('https://example.org/abc?foo=~bar');
668
+ *
669
+ * console.log(myURL.search); // prints ?foo=~bar
670
+ *
671
+ * // Modify the URL via searchParams...
672
+ * myURL.searchParams.sort();
673
+ *
674
+ * console.log(myURL.search); // prints ?foo=%7Ebar
675
+ * ```
676
+ */
677
+ readonly searchParams: URLSearchParams;
678
+ /**
679
+ * Gets and sets the username portion of the URL.
680
+ *
681
+ * ```js
682
+ * const myURL = new URL('https://abc:xyz@example.com');
683
+ * console.log(myURL.username);
684
+ * // Prints abc
685
+ *
686
+ * myURL.username = '123';
687
+ * console.log(myURL.href);
688
+ * // Prints https://123:xyz@example.com/
689
+ * ```
690
+ *
691
+ * Any invalid URL characters appearing in the value assigned the `username`property will be `percent-encoded`. The selection of which
692
+ * characters to percent-encode may vary somewhat from what the {@link parse} and {@link format} methods would produce.
693
+ */
694
+ username: string;
695
+ /**
696
+ * The `toString()` method on the `URL` object returns the serialized URL. The
697
+ * value returned is equivalent to that of {@link href} and {@link toJSON}.
698
+ */
699
+ toString(): string;
700
+ /**
701
+ * The `toJSON()` method on the `URL` object returns the serialized URL. The
702
+ * value returned is equivalent to that of {@link href} and {@link toString}.
703
+ *
704
+ * This method is automatically called when an `URL` object is serialized
705
+ * with [`JSON.stringify()`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify).
706
+ *
707
+ * ```js
708
+ * const myURLs = [
709
+ * new URL('https://www.example.com'),
710
+ * new URL('https://test.example.org'),
711
+ * ];
712
+ * console.log(JSON.stringify(myURLs));
713
+ * // Prints ["https://www.example.com/","https://test.example.org/"]
714
+ * ```
715
+ */
716
+ toJSON(): string;
717
+ }
718
+ /**
719
+ * The `URLSearchParams` API provides read and write access to the query of a`URL`. The `URLSearchParams` class can also be used standalone with one of the
720
+ * four following constructors.
721
+ * The `URLSearchParams` class is also available on the global object.
722
+ *
723
+ * The WHATWG `URLSearchParams` interface and the `querystring` module have
724
+ * similar purpose, but the purpose of the `querystring` module is more
725
+ * general, as it allows the customization of delimiter characters (`&#x26;` and `=`).
726
+ * On the other hand, this API is designed purely for URL query strings.
727
+ *
728
+ * ```js
729
+ * const myURL = new URL('https://example.org/?abc=123');
730
+ * console.log(myURL.searchParams.get('abc'));
731
+ * // Prints 123
732
+ *
733
+ * myURL.searchParams.append('abc', 'xyz');
734
+ * console.log(myURL.href);
735
+ * // Prints https://example.org/?abc=123&#x26;abc=xyz
736
+ *
737
+ * myURL.searchParams.delete('abc');
738
+ * myURL.searchParams.set('a', 'b');
739
+ * console.log(myURL.href);
740
+ * // Prints https://example.org/?a=b
741
+ *
742
+ * const newSearchParams = new URLSearchParams(myURL.searchParams);
743
+ * // The above is equivalent to
744
+ * // const newSearchParams = new URLSearchParams(myURL.search);
745
+ *
746
+ * newSearchParams.append('a', 'c');
747
+ * console.log(myURL.href);
748
+ * // Prints https://example.org/?a=b
749
+ * console.log(newSearchParams.toString());
750
+ * // Prints a=b&#x26;a=c
751
+ *
752
+ * // newSearchParams.toString() is implicitly called
753
+ * myURL.search = newSearchParams;
754
+ * console.log(myURL.href);
755
+ * // Prints https://example.org/?a=b&#x26;a=c
756
+ * newSearchParams.delete('a');
757
+ * console.log(myURL.href);
758
+ * // Prints https://example.org/?a=b&#x26;a=c
759
+ * ```
760
+ * @since v7.5.0, v6.13.0
761
+ */
762
+ class URLSearchParams implements Iterable<[string, string]> {
763
+ constructor(
764
+ init?:
765
+ | URLSearchParams
766
+ | string
767
+ | Record<string, string | readonly string[]>
768
+ | Iterable<[string, string]>
769
+ | ReadonlyArray<[string, string]>,
770
+ );
771
+ /**
772
+ * Append a new name-value pair to the query string.
773
+ */
774
+ append(name: string, value: string): void;
775
+ /**
776
+ * If `value` is provided, removes all name-value pairs
777
+ * where name is `name` and value is `value`..
778
+ *
779
+ * If `value` is not provided, removes all name-value pairs whose name is `name`.
780
+ */
781
+ delete(name: string, value?: string): void;
782
+ /**
783
+ * Returns an ES6 `Iterator` over each of the name-value pairs in the query.
784
+ * Each item of the iterator is a JavaScript `Array`. The first item of the `Array`is the `name`, the second item of the `Array` is the `value`.
785
+ *
786
+ * Alias for `urlSearchParams[@@iterator]()`.
787
+ */
788
+ entries(): IterableIterator<[string, string]>;
789
+ /**
790
+ * Iterates over each name-value pair in the query and invokes the given function.
791
+ *
792
+ * ```js
793
+ * const myURL = new URL('https://example.org/?a=b&#x26;c=d');
794
+ * myURL.searchParams.forEach((value, name, searchParams) => {
795
+ * console.log(name, value, myURL.searchParams === searchParams);
796
+ * });
797
+ * // Prints:
798
+ * // a b true
799
+ * // c d true
800
+ * ```
801
+ * @param fn Invoked for each name-value pair in the query
802
+ * @param thisArg To be used as `this` value for when `fn` is called
803
+ */
804
+ forEach<TThis = this>(
805
+ callback: (this: TThis, value: string, name: string, searchParams: URLSearchParams) => void,
806
+ thisArg?: TThis,
807
+ ): void;
808
+ /**
809
+ * Returns the value of the first name-value pair whose name is `name`. If there
810
+ * are no such pairs, `null` is returned.
811
+ * @return or `null` if there is no name-value pair with the given `name`.
812
+ */
813
+ get(name: string): string | null;
814
+ /**
815
+ * Returns the values of all name-value pairs whose name is `name`. If there are
816
+ * no such pairs, an empty array is returned.
817
+ */
818
+ getAll(name: string): string[];
819
+ /**
820
+ * Checks if the `URLSearchParams` object contains key-value pair(s) based on`name` and an optional `value` argument.
821
+ *
822
+ * If `value` is provided, returns `true` when name-value pair with
823
+ * same `name` and `value` exists.
824
+ *
825
+ * If `value` is not provided, returns `true` if there is at least one name-value
826
+ * pair whose name is `name`.
827
+ */
828
+ has(name: string, value?: string): boolean;
829
+ /**
830
+ * Returns an ES6 `Iterator` over the names of each name-value pair.
831
+ *
832
+ * ```js
833
+ * const params = new URLSearchParams('foo=bar&#x26;foo=baz');
834
+ * for (const name of params.keys()) {
835
+ * console.log(name);
836
+ * }
837
+ * // Prints:
838
+ * // foo
839
+ * // foo
840
+ * ```
841
+ */
842
+ keys(): IterableIterator<string>;
843
+ /**
844
+ * Sets the value in the `URLSearchParams` object associated with `name` to`value`. If there are any pre-existing name-value pairs whose names are `name`,
845
+ * set the first such pair's value to `value` and remove all others. If not,
846
+ * append the name-value pair to the query string.
847
+ *
848
+ * ```js
849
+ * const params = new URLSearchParams();
850
+ * params.append('foo', 'bar');
851
+ * params.append('foo', 'baz');
852
+ * params.append('abc', 'def');
853
+ * console.log(params.toString());
854
+ * // Prints foo=bar&#x26;foo=baz&#x26;abc=def
855
+ *
856
+ * params.set('foo', 'def');
857
+ * params.set('xyz', 'opq');
858
+ * console.log(params.toString());
859
+ * // Prints foo=def&#x26;abc=def&#x26;xyz=opq
860
+ * ```
861
+ */
862
+ set(name: string, value: string): void;
863
+ /**
864
+ * The total number of parameter entries.
865
+ * @since v19.8.0
866
+ */
867
+ readonly size: number;
868
+ /**
869
+ * Sort all existing name-value pairs in-place by their names. Sorting is done
870
+ * with a [stable sorting algorithm](https://en.wikipedia.org/wiki/Sorting_algorithm#Stability), so relative order between name-value pairs
871
+ * with the same name is preserved.
872
+ *
873
+ * This method can be used, in particular, to increase cache hits.
874
+ *
875
+ * ```js
876
+ * const params = new URLSearchParams('query[]=abc&#x26;type=search&#x26;query[]=123');
877
+ * params.sort();
878
+ * console.log(params.toString());
879
+ * // Prints query%5B%5D=abc&#x26;query%5B%5D=123&#x26;type=search
880
+ * ```
881
+ * @since v7.7.0, v6.13.0
882
+ */
883
+ sort(): void;
884
+ /**
885
+ * Returns the search parameters serialized as a string, with characters
886
+ * percent-encoded where necessary.
887
+ */
888
+ toString(): string;
889
+ /**
890
+ * Returns an ES6 `Iterator` over the values of each name-value pair.
891
+ */
892
+ values(): IterableIterator<string>;
893
+ [Symbol.iterator](): IterableIterator<[string, string]>;
894
+ }
895
+ import { URL as _URL, URLSearchParams as _URLSearchParams } from "url";
896
+ global {
897
+ interface URLSearchParams extends _URLSearchParams {}
898
+ interface URL extends _URL {}
899
+ interface Global {
900
+ URL: typeof _URL;
901
+ URLSearchParams: typeof _URLSearchParams;
902
+ }
903
+ /**
904
+ * `URL` class is a global reference for `require('url').URL`
905
+ * https://nodejs.org/api/url.html#the-whatwg-url-api
906
+ * @since v10.0.0
907
+ */
908
+ var URL: typeof globalThis extends {
909
+ onmessage: any;
910
+ URL: infer T;
911
+ } ? T
912
+ : typeof _URL;
913
+ /**
914
+ * `URLSearchParams` class is a global reference for `require('url').URLSearchParams`
915
+ * https://nodejs.org/api/url.html#class-urlsearchparams
916
+ * @since v10.0.0
917
+ */
918
+ var URLSearchParams: typeof globalThis extends {
919
+ onmessage: any;
920
+ URLSearchParams: infer T;
921
+ } ? T
922
+ : typeof _URLSearchParams;
923
+ }
924
+ }
925
+ declare module "node:url" {
926
+ export * from "url";
927
+ }