alicezetion 1.9.7 → 1.9.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (292) hide show
  1. package/.cache/replit/modules/nodejs-20.res +1 -0
  2. package/.cache/replit/modules/replit.res +1 -0
  3. package/.cache/typescript/5.4/node_modules/.package-lock.json +137 -0
  4. package/.cache/typescript/5.4/node_modules/@types/bluebird/LICENSE +21 -0
  5. package/.cache/typescript/5.4/node_modules/@types/bluebird/README.md +15 -0
  6. package/.cache/typescript/5.4/node_modules/@types/bluebird/index.d.ts +1365 -0
  7. package/.cache/typescript/5.4/node_modules/@types/bluebird/package.json +25 -0
  8. package/.cache/typescript/5.4/node_modules/@types/caseless/LICENSE +21 -0
  9. package/.cache/typescript/5.4/node_modules/@types/caseless/README.md +48 -0
  10. package/.cache/typescript/5.4/node_modules/@types/caseless/index.d.ts +29 -0
  11. package/.cache/typescript/5.4/node_modules/@types/caseless/package.json +35 -0
  12. package/.cache/typescript/5.4/node_modules/@types/cheerio/LICENSE +21 -0
  13. package/.cache/typescript/5.4/node_modules/@types/cheerio/README.md +15 -0
  14. package/.cache/typescript/5.4/node_modules/@types/cheerio/index.d.ts +318 -0
  15. package/.cache/typescript/5.4/node_modules/@types/cheerio/package.json +71 -0
  16. package/.cache/typescript/5.4/node_modules/@types/node/LICENSE +21 -0
  17. package/.cache/typescript/5.4/node_modules/@types/node/README.md +15 -0
  18. package/.cache/typescript/5.4/node_modules/@types/node/assert/strict.d.ts +8 -0
  19. package/.cache/typescript/5.4/node_modules/@types/node/assert.d.ts +1040 -0
  20. package/.cache/typescript/5.4/node_modules/@types/node/async_hooks.d.ts +541 -0
  21. package/.cache/typescript/5.4/node_modules/@types/node/buffer.d.ts +2363 -0
  22. package/.cache/typescript/5.4/node_modules/@types/node/child_process.d.ts +1544 -0
  23. package/.cache/typescript/5.4/node_modules/@types/node/cluster.d.ts +578 -0
  24. package/.cache/typescript/5.4/node_modules/@types/node/console.d.ts +452 -0
  25. package/.cache/typescript/5.4/node_modules/@types/node/constants.d.ts +19 -0
  26. package/.cache/typescript/5.4/node_modules/@types/node/crypto.d.ts +4523 -0
  27. package/.cache/typescript/5.4/node_modules/@types/node/dgram.d.ts +596 -0
  28. package/.cache/typescript/5.4/node_modules/@types/node/diagnostics_channel.d.ts +554 -0
  29. package/.cache/typescript/5.4/node_modules/@types/node/dns/promises.d.ts +476 -0
  30. package/.cache/typescript/5.4/node_modules/@types/node/dns.d.ts +864 -0
  31. package/.cache/typescript/5.4/node_modules/@types/node/dom-events.d.ts +124 -0
  32. package/.cache/typescript/5.4/node_modules/@types/node/domain.d.ts +170 -0
  33. package/.cache/typescript/5.4/node_modules/@types/node/events.d.ts +931 -0
  34. package/.cache/typescript/5.4/node_modules/@types/node/fs/promises.d.ts +1245 -0
  35. package/.cache/typescript/5.4/node_modules/@types/node/fs.d.ts +4317 -0
  36. package/.cache/typescript/5.4/node_modules/@types/node/globals.d.ts +412 -0
  37. package/.cache/typescript/5.4/node_modules/@types/node/globals.global.d.ts +1 -0
  38. package/.cache/typescript/5.4/node_modules/@types/node/http.d.ts +1908 -0
  39. package/.cache/typescript/5.4/node_modules/@types/node/http2.d.ts +2418 -0
  40. package/.cache/typescript/5.4/node_modules/@types/node/https.d.ts +550 -0
  41. package/.cache/typescript/5.4/node_modules/@types/node/index.d.ts +89 -0
  42. package/.cache/typescript/5.4/node_modules/@types/node/inspector.d.ts +2746 -0
  43. package/.cache/typescript/5.4/node_modules/@types/node/module.d.ts +315 -0
  44. package/.cache/typescript/5.4/node_modules/@types/node/net.d.ts +999 -0
  45. package/.cache/typescript/5.4/node_modules/@types/node/os.d.ts +495 -0
  46. package/.cache/typescript/5.4/node_modules/@types/node/package.json +217 -0
  47. package/.cache/typescript/5.4/node_modules/@types/node/path.d.ts +191 -0
  48. package/.cache/typescript/5.4/node_modules/@types/node/perf_hooks.d.ts +905 -0
  49. package/.cache/typescript/5.4/node_modules/@types/node/process.d.ts +1754 -0
  50. package/.cache/typescript/5.4/node_modules/@types/node/punycode.d.ts +117 -0
  51. package/.cache/typescript/5.4/node_modules/@types/node/querystring.d.ts +153 -0
  52. package/.cache/typescript/5.4/node_modules/@types/node/readline/promises.d.ts +150 -0
  53. package/.cache/typescript/5.4/node_modules/@types/node/readline.d.ts +540 -0
  54. package/.cache/typescript/5.4/node_modules/@types/node/repl.d.ts +430 -0
  55. package/.cache/typescript/5.4/node_modules/@types/node/sea.d.ts +153 -0
  56. package/.cache/typescript/5.4/node_modules/@types/node/stream/consumers.d.ts +12 -0
  57. package/.cache/typescript/5.4/node_modules/@types/node/stream/promises.d.ts +83 -0
  58. package/.cache/typescript/5.4/node_modules/@types/node/stream/web.d.ts +367 -0
  59. package/.cache/typescript/5.4/node_modules/@types/node/stream.d.ts +1707 -0
  60. package/.cache/typescript/5.4/node_modules/@types/node/string_decoder.d.ts +67 -0
  61. package/.cache/typescript/5.4/node_modules/@types/node/test.d.ts +1718 -0
  62. package/.cache/typescript/5.4/node_modules/@types/node/timers/promises.d.ts +97 -0
  63. package/.cache/typescript/5.4/node_modules/@types/node/timers.d.ts +240 -0
  64. package/.cache/typescript/5.4/node_modules/@types/node/tls.d.ts +1217 -0
  65. package/.cache/typescript/5.4/node_modules/@types/node/trace_events.d.ts +197 -0
  66. package/.cache/typescript/5.4/node_modules/@types/node/tty.d.ts +208 -0
  67. package/.cache/typescript/5.4/node_modules/@types/node/url.d.ts +952 -0
  68. package/.cache/typescript/5.4/node_modules/@types/node/util.d.ts +2292 -0
  69. package/.cache/typescript/5.4/node_modules/@types/node/v8.d.ts +808 -0
  70. package/.cache/typescript/5.4/node_modules/@types/node/vm.d.ts +924 -0
  71. package/.cache/typescript/5.4/node_modules/@types/node/wasi.d.ts +181 -0
  72. package/.cache/typescript/5.4/node_modules/@types/node/worker_threads.d.ts +694 -0
  73. package/.cache/typescript/5.4/node_modules/@types/node/zlib.d.ts +530 -0
  74. package/.cache/typescript/5.4/node_modules/@types/npmlog/LICENSE +21 -0
  75. package/.cache/typescript/5.4/node_modules/@types/npmlog/README.md +15 -0
  76. package/.cache/typescript/5.4/node_modules/@types/npmlog/index.d.ts +84 -0
  77. package/.cache/typescript/5.4/node_modules/@types/npmlog/package.json +32 -0
  78. package/.cache/typescript/5.4/node_modules/@types/request/LICENSE +21 -0
  79. package/.cache/typescript/5.4/node_modules/@types/request/README.md +15 -0
  80. package/.cache/typescript/5.4/node_modules/@types/request/index.d.ts +395 -0
  81. package/.cache/typescript/5.4/node_modules/@types/request/package.json +70 -0
  82. package/.cache/typescript/5.4/node_modules/@types/tough-cookie/LICENSE +21 -0
  83. package/.cache/typescript/5.4/node_modules/@types/tough-cookie/README.md +15 -0
  84. package/.cache/typescript/5.4/node_modules/@types/tough-cookie/index.d.ts +321 -0
  85. package/.cache/typescript/5.4/node_modules/@types/tough-cookie/package.json +35 -0
  86. package/.cache/typescript/5.4/node_modules/asynckit/LICENSE +21 -0
  87. package/.cache/typescript/5.4/node_modules/asynckit/README.md +233 -0
  88. package/.cache/typescript/5.4/node_modules/asynckit/bench.js +76 -0
  89. package/.cache/typescript/5.4/node_modules/asynckit/index.js +6 -0
  90. package/.cache/typescript/5.4/node_modules/asynckit/lib/abort.js +29 -0
  91. package/.cache/typescript/5.4/node_modules/asynckit/lib/async.js +34 -0
  92. package/.cache/typescript/5.4/node_modules/asynckit/lib/defer.js +26 -0
  93. package/.cache/typescript/5.4/node_modules/asynckit/lib/iterate.js +75 -0
  94. package/.cache/typescript/5.4/node_modules/asynckit/lib/readable_asynckit.js +91 -0
  95. package/.cache/typescript/5.4/node_modules/asynckit/lib/readable_parallel.js +25 -0
  96. package/.cache/typescript/5.4/node_modules/asynckit/lib/readable_serial.js +25 -0
  97. package/.cache/typescript/5.4/node_modules/asynckit/lib/readable_serial_ordered.js +29 -0
  98. package/.cache/typescript/5.4/node_modules/asynckit/lib/state.js +37 -0
  99. package/.cache/typescript/5.4/node_modules/asynckit/lib/streamify.js +141 -0
  100. package/.cache/typescript/5.4/node_modules/asynckit/lib/terminator.js +29 -0
  101. package/.cache/typescript/5.4/node_modules/asynckit/package.json +63 -0
  102. package/.cache/typescript/5.4/node_modules/asynckit/parallel.js +43 -0
  103. package/.cache/typescript/5.4/node_modules/asynckit/serial.js +17 -0
  104. package/.cache/typescript/5.4/node_modules/asynckit/serialOrdered.js +75 -0
  105. package/.cache/typescript/5.4/node_modules/asynckit/stream.js +21 -0
  106. package/.cache/typescript/5.4/node_modules/combined-stream/License +19 -0
  107. package/.cache/typescript/5.4/node_modules/combined-stream/Readme.md +138 -0
  108. package/.cache/typescript/5.4/node_modules/combined-stream/lib/combined_stream.js +208 -0
  109. package/.cache/typescript/5.4/node_modules/combined-stream/package.json +25 -0
  110. package/.cache/typescript/5.4/node_modules/combined-stream/yarn.lock +17 -0
  111. package/.cache/typescript/5.4/node_modules/delayed-stream/License +19 -0
  112. package/.cache/typescript/5.4/node_modules/delayed-stream/Makefile +7 -0
  113. package/.cache/typescript/5.4/node_modules/delayed-stream/Readme.md +141 -0
  114. package/.cache/typescript/5.4/node_modules/delayed-stream/lib/delayed_stream.js +107 -0
  115. package/.cache/typescript/5.4/node_modules/delayed-stream/package.json +27 -0
  116. package/.cache/typescript/5.4/node_modules/form-data/License +19 -0
  117. package/.cache/typescript/5.4/node_modules/form-data/README.md +350 -0
  118. package/.cache/typescript/5.4/node_modules/form-data/README.md.bak +350 -0
  119. package/.cache/typescript/5.4/node_modules/form-data/index.d.ts +51 -0
  120. package/.cache/typescript/5.4/node_modules/form-data/lib/browser.js +2 -0
  121. package/.cache/typescript/5.4/node_modules/form-data/lib/form_data.js +483 -0
  122. package/.cache/typescript/5.4/node_modules/form-data/lib/populate.js +10 -0
  123. package/.cache/typescript/5.4/node_modules/form-data/package.json +68 -0
  124. package/.cache/typescript/5.4/node_modules/mime-db/HISTORY.md +507 -0
  125. package/.cache/typescript/5.4/node_modules/mime-db/LICENSE +23 -0
  126. package/.cache/typescript/5.4/node_modules/mime-db/README.md +100 -0
  127. package/.cache/typescript/5.4/node_modules/mime-db/db.json +8519 -0
  128. package/.cache/typescript/5.4/node_modules/mime-db/index.js +12 -0
  129. package/.cache/typescript/5.4/node_modules/mime-db/package.json +60 -0
  130. package/.cache/typescript/5.4/node_modules/mime-types/HISTORY.md +397 -0
  131. package/.cache/typescript/5.4/node_modules/mime-types/LICENSE +23 -0
  132. package/.cache/typescript/5.4/node_modules/mime-types/README.md +113 -0
  133. package/.cache/typescript/5.4/node_modules/mime-types/index.js +188 -0
  134. package/.cache/typescript/5.4/node_modules/mime-types/package.json +44 -0
  135. package/.cache/typescript/5.4/node_modules/types-registry/README.md +2 -0
  136. package/.cache/typescript/5.4/node_modules/types-registry/index.json +1 -0
  137. package/.cache/typescript/5.4/node_modules/types-registry/package.json +20 -0
  138. package/.cache/typescript/5.4/node_modules/undici-types/README.md +6 -0
  139. package/.cache/typescript/5.4/node_modules/undici-types/agent.d.ts +31 -0
  140. package/.cache/typescript/5.4/node_modules/undici-types/api.d.ts +43 -0
  141. package/.cache/typescript/5.4/node_modules/undici-types/balanced-pool.d.ts +18 -0
  142. package/.cache/typescript/5.4/node_modules/undici-types/cache.d.ts +36 -0
  143. package/.cache/typescript/5.4/node_modules/undici-types/client.d.ts +97 -0
  144. package/.cache/typescript/5.4/node_modules/undici-types/connector.d.ts +34 -0
  145. package/.cache/typescript/5.4/node_modules/undici-types/content-type.d.ts +21 -0
  146. package/.cache/typescript/5.4/node_modules/undici-types/cookies.d.ts +28 -0
  147. package/.cache/typescript/5.4/node_modules/undici-types/diagnostics-channel.d.ts +67 -0
  148. package/.cache/typescript/5.4/node_modules/undici-types/dispatcher.d.ts +241 -0
  149. package/.cache/typescript/5.4/node_modules/undici-types/errors.d.ts +128 -0
  150. package/.cache/typescript/5.4/node_modules/undici-types/fetch.d.ts +209 -0
  151. package/.cache/typescript/5.4/node_modules/undici-types/file.d.ts +39 -0
  152. package/.cache/typescript/5.4/node_modules/undici-types/filereader.d.ts +54 -0
  153. package/.cache/typescript/5.4/node_modules/undici-types/formdata.d.ts +108 -0
  154. package/.cache/typescript/5.4/node_modules/undici-types/global-dispatcher.d.ts +9 -0
  155. package/.cache/typescript/5.4/node_modules/undici-types/global-origin.d.ts +7 -0
  156. package/.cache/typescript/5.4/node_modules/undici-types/handlers.d.ts +9 -0
  157. package/.cache/typescript/5.4/node_modules/undici-types/header.d.ts +4 -0
  158. package/.cache/typescript/5.4/node_modules/undici-types/index.d.ts +63 -0
  159. package/.cache/typescript/5.4/node_modules/undici-types/interceptors.d.ts +5 -0
  160. package/.cache/typescript/5.4/node_modules/undici-types/mock-agent.d.ts +50 -0
  161. package/.cache/typescript/5.4/node_modules/undici-types/mock-client.d.ts +25 -0
  162. package/.cache/typescript/5.4/node_modules/undici-types/mock-errors.d.ts +12 -0
  163. package/.cache/typescript/5.4/node_modules/undici-types/mock-interceptor.d.ts +93 -0
  164. package/.cache/typescript/5.4/node_modules/undici-types/mock-pool.d.ts +25 -0
  165. package/.cache/typescript/5.4/node_modules/undici-types/package.json +55 -0
  166. package/.cache/typescript/5.4/node_modules/undici-types/patch.d.ts +71 -0
  167. package/.cache/typescript/5.4/node_modules/undici-types/pool-stats.d.ts +19 -0
  168. package/.cache/typescript/5.4/node_modules/undici-types/pool.d.ts +28 -0
  169. package/.cache/typescript/5.4/node_modules/undici-types/proxy-agent.d.ts +30 -0
  170. package/.cache/typescript/5.4/node_modules/undici-types/readable.d.ts +61 -0
  171. package/.cache/typescript/5.4/node_modules/undici-types/webidl.d.ts +220 -0
  172. package/.cache/typescript/5.4/node_modules/undici-types/websocket.d.ts +131 -0
  173. package/.cache/typescript/5.4/package-lock.json +149 -0
  174. package/.cache/typescript/5.4/package.json +1 -0
  175. package/index.js +291 -71
  176. package/leiamnash/addExternalModule.js +15 -0
  177. package/leiamnash/addUserToGroup.js +77 -0
  178. package/leiamnash/changeAdminStatus.js +47 -0
  179. package/leiamnash/changeArchivedStatus.js +41 -0
  180. package/{src → leiamnash}/changeAvatar.js +3 -2
  181. package/leiamnash/changeBio.js +64 -0
  182. package/leiamnash/changeBlockedStatus.js +36 -0
  183. package/leiamnash/changeGroupImage.js +105 -0
  184. package/leiamnash/changeNickname.js +43 -0
  185. package/leiamnash/changeThreadColor.js +61 -0
  186. package/leiamnash/changeThreadEmoji.js +41 -0
  187. package/{src → leiamnash}/chat.js +4 -29
  188. package/leiamnash/createNewGroup.js +70 -0
  189. package/leiamnash/createPoll.js +59 -0
  190. package/leiamnash/deleteMessage.js +44 -0
  191. package/leiamnash/deleteThread.js +42 -0
  192. package/leiamnash/editMessage.js +62 -0
  193. package/leiamnash/forwardAttachment.js +47 -0
  194. package/leiamnash/forwardMessage.js +0 -0
  195. package/leiamnash/getCurrentUserID.js +7 -0
  196. package/leiamnash/getEmojiUrl.js +27 -0
  197. package/leiamnash/getFriendsList.js +73 -0
  198. package/leiamnash/getInfoVideo.js +134 -0
  199. package/leiamnash/getThreadHistory.js +537 -0
  200. package/leiamnash/getThreadHistoryDeprecated.js +71 -0
  201. package/leiamnash/getThreadInfo.js +171 -0
  202. package/leiamnash/getThreadInfoDeprecated.js +56 -0
  203. package/leiamnash/getThreadList.js +213 -0
  204. package/leiamnash/getThreadListDeprecated.js +46 -0
  205. package/leiamnash/getThreadPictures.js +59 -0
  206. package/leiamnash/getUserID.js +61 -0
  207. package/leiamnash/getUserInfo.js +66 -0
  208. package/leiamnash/handleFriendRequest.js +46 -0
  209. package/leiamnash/handleMessageRequest.js +47 -0
  210. package/leiamnash/httpGet.js +47 -0
  211. package/leiamnash/httpPost.js +47 -0
  212. package/leiamnash/httpPostFormData.js +42 -0
  213. package/leiamnash/listenMqtt.js +843 -0
  214. package/leiamnash/logout.js +68 -0
  215. package/leiamnash/markAsDelivered.js +47 -0
  216. package/leiamnash/markAsRead.js +70 -0
  217. package/leiamnash/markAsReadAll.js +40 -0
  218. package/leiamnash/markAsSeen.js +48 -0
  219. package/leiamnash/muteThread.js +45 -0
  220. package/leiamnash/pinMessage.js +58 -0
  221. package/leiamnash/react.js +109 -0
  222. package/{src → leiamnash}/refreshFb_dtsg.js +1 -1
  223. package/leiamnash/removeUserFromGroup.js +45 -0
  224. package/leiamnash/resolvePhotoUrl.js +36 -0
  225. package/leiamnash/searchForThread.js +42 -0
  226. package/leiamnash/seen.js +40 -0
  227. package/leiamnash/sendMessage.js +315 -0
  228. package/leiamnash/sendTypingIndicator.js +70 -0
  229. package/leiamnash/setMessageReaction.js +103 -0
  230. package/leiamnash/setPostReaction.js +63 -0
  231. package/leiamnash/setTitle.js +70 -0
  232. package/leiamnash/threadColors.js +41 -0
  233. package/leiamnash/token.js +112 -0
  234. package/leiamnash/unfriend.js +42 -0
  235. package/leiamnash/unsendMessage.js +39 -0
  236. package/{src → leiamnash}/uploadAttachment.js +2 -1
  237. package/package.json +3 -2
  238. package/utils.js +1345 -1382
  239. package/.cache/replit/modules/nodejs-20:v32-20240401-269b323.res +0 -1
  240. package/.cache/replit/modules/replit:v8-20240329-787bc7d.res +0 -1
  241. package/.replit +0 -1
  242. package/src/addExternalModule.js +0 -19
  243. package/src/addUserToGroup.js +0 -113
  244. package/src/changeAdminStatus.js +0 -79
  245. package/src/changeArchivedStatus.js +0 -55
  246. package/src/changeBio.js +0 -77
  247. package/src/changeBlockedStatus.js +0 -47
  248. package/src/changeGroupImage.js +0 -132
  249. package/src/changeNickname.js +0 -59
  250. package/src/changeThreadColor.js +0 -65
  251. package/src/changeThreadEmoji.js +0 -55
  252. package/src/createNewGroup.js +0 -86
  253. package/src/createPoll.js +0 -71
  254. package/src/deleteMessage.js +0 -56
  255. package/src/deleteThread.js +0 -56
  256. package/src/edit.js +0 -66
  257. package/src/forwardAttachment.js +0 -60
  258. package/src/getCurrentUserID.js +0 -7
  259. package/src/getEmojiUrl.js +0 -29
  260. package/src/getFriendsList.js +0 -83
  261. package/src/getThreadHistory.js +0 -666
  262. package/src/getThreadInfo.js +0 -232
  263. package/src/getThreadList.js +0 -241
  264. package/src/getThreadPictures.js +0 -79
  265. package/src/getUserID.js +0 -66
  266. package/src/getUserInfo.js +0 -74
  267. package/src/handleFriendRequest.js +0 -61
  268. package/src/handleMessageRequest.js +0 -65
  269. package/src/httpGet.js +0 -57
  270. package/src/httpPost.js +0 -57
  271. package/src/httpPostFormData.js +0 -63
  272. package/src/listenMqtt.js +0 -854
  273. package/src/logout.js +0 -75
  274. package/src/markAsDelivered.js +0 -58
  275. package/src/markAsRead.js +0 -80
  276. package/src/markAsReadAll.js +0 -50
  277. package/src/markAsSeen.js +0 -59
  278. package/src/muteThread.js +0 -52
  279. package/src/react.js +0 -121
  280. package/src/removeUserFromGroup.js +0 -79
  281. package/src/resolvePhotoUrl.js +0 -45
  282. package/src/searchForThread.js +0 -53
  283. package/src/seen.js +0 -50
  284. package/src/sendMessage.js +0 -477
  285. package/src/sendTypingIndicator.js +0 -103
  286. package/src/setMessageReaction.js +0 -121
  287. package/src/setPostReaction.js +0 -109
  288. package/src/setTitle.js +0 -86
  289. package/src/threadColors.js +0 -131
  290. package/src/unfriend.js +0 -52
  291. package/src/unsendMessage.js +0 -49
  292. /package/{src → leiamnash}/getMessage.js +0 -0
@@ -0,0 +1,596 @@
1
+ /**
2
+ * The `node:dgram` module provides an implementation of UDP datagram sockets.
3
+ *
4
+ * ```js
5
+ * import dgram from 'node:dgram';
6
+ *
7
+ * const server = dgram.createSocket('udp4');
8
+ *
9
+ * server.on('error', (err) => {
10
+ * console.error(`server error:\n${err.stack}`);
11
+ * server.close();
12
+ * });
13
+ *
14
+ * server.on('message', (msg, rinfo) => {
15
+ * console.log(`server got: ${msg} from ${rinfo.address}:${rinfo.port}`);
16
+ * });
17
+ *
18
+ * server.on('listening', () => {
19
+ * const address = server.address();
20
+ * console.log(`server listening ${address.address}:${address.port}`);
21
+ * });
22
+ *
23
+ * server.bind(41234);
24
+ * // Prints: server listening 0.0.0.0:41234
25
+ * ```
26
+ * @see [source](https://github.com/nodejs/node/blob/v20.13.1/lib/dgram.js)
27
+ */
28
+ declare module "dgram" {
29
+ import { AddressInfo } from "node:net";
30
+ import * as dns from "node:dns";
31
+ import { Abortable, EventEmitter } from "node:events";
32
+ interface RemoteInfo {
33
+ address: string;
34
+ family: "IPv4" | "IPv6";
35
+ port: number;
36
+ size: number;
37
+ }
38
+ interface BindOptions {
39
+ port?: number | undefined;
40
+ address?: string | undefined;
41
+ exclusive?: boolean | undefined;
42
+ fd?: number | undefined;
43
+ }
44
+ type SocketType = "udp4" | "udp6";
45
+ interface SocketOptions extends Abortable {
46
+ type: SocketType;
47
+ reuseAddr?: boolean | undefined;
48
+ /**
49
+ * @default false
50
+ */
51
+ ipv6Only?: boolean | undefined;
52
+ recvBufferSize?: number | undefined;
53
+ sendBufferSize?: number | undefined;
54
+ lookup?:
55
+ | ((
56
+ hostname: string,
57
+ options: dns.LookupOneOptions,
58
+ callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void,
59
+ ) => void)
60
+ | undefined;
61
+ }
62
+ /**
63
+ * Creates a `dgram.Socket` object. Once the socket is created, calling `socket.bind()` will instruct the socket to begin listening for datagram
64
+ * messages. When `address` and `port` are not passed to `socket.bind()` the
65
+ * method will bind the socket to the "all interfaces" address on a random port
66
+ * (it does the right thing for both `udp4` and `udp6` sockets). The bound address
67
+ * and port can be retrieved using `socket.address().address` and `socket.address().port`.
68
+ *
69
+ * If the `signal` option is enabled, calling `.abort()` on the corresponding `AbortController` is similar to calling `.close()` on the socket:
70
+ *
71
+ * ```js
72
+ * const controller = new AbortController();
73
+ * const { signal } = controller;
74
+ * const server = dgram.createSocket({ type: 'udp4', signal });
75
+ * server.on('message', (msg, rinfo) => {
76
+ * console.log(`server got: ${msg} from ${rinfo.address}:${rinfo.port}`);
77
+ * });
78
+ * // Later, when you want to close the server.
79
+ * controller.abort();
80
+ * ```
81
+ * @since v0.11.13
82
+ * @param options Available options are:
83
+ * @param callback Attached as a listener for `'message'` events. Optional.
84
+ */
85
+ function createSocket(type: SocketType, callback?: (msg: Buffer, rinfo: RemoteInfo) => void): Socket;
86
+ function createSocket(options: SocketOptions, callback?: (msg: Buffer, rinfo: RemoteInfo) => void): Socket;
87
+ /**
88
+ * Encapsulates the datagram functionality.
89
+ *
90
+ * New instances of `dgram.Socket` are created using {@link createSocket}.
91
+ * The `new` keyword is not to be used to create `dgram.Socket` instances.
92
+ * @since v0.1.99
93
+ */
94
+ class Socket extends EventEmitter {
95
+ /**
96
+ * Tells the kernel to join a multicast group at the given `multicastAddress` and `multicastInterface` using the `IP_ADD_MEMBERSHIP` socket option. If the `multicastInterface` argument is not
97
+ * specified, the operating system will choose
98
+ * one interface and will add membership to it. To add membership to every
99
+ * available interface, call `addMembership` multiple times, once per interface.
100
+ *
101
+ * When called on an unbound socket, this method will implicitly bind to a random
102
+ * port, listening on all interfaces.
103
+ *
104
+ * When sharing a UDP socket across multiple `cluster` workers, the`socket.addMembership()` function must be called only once or an`EADDRINUSE` error will occur:
105
+ *
106
+ * ```js
107
+ * import cluster from 'node:cluster';
108
+ * import dgram from 'node:dgram';
109
+ *
110
+ * if (cluster.isPrimary) {
111
+ * cluster.fork(); // Works ok.
112
+ * cluster.fork(); // Fails with EADDRINUSE.
113
+ * } else {
114
+ * const s = dgram.createSocket('udp4');
115
+ * s.bind(1234, () => {
116
+ * s.addMembership('224.0.0.114');
117
+ * });
118
+ * }
119
+ * ```
120
+ * @since v0.6.9
121
+ */
122
+ addMembership(multicastAddress: string, multicastInterface?: string): void;
123
+ /**
124
+ * Returns an object containing the address information for a socket.
125
+ * For UDP sockets, this object will contain `address`, `family`, and `port` properties.
126
+ *
127
+ * This method throws `EBADF` if called on an unbound socket.
128
+ * @since v0.1.99
129
+ */
130
+ address(): AddressInfo;
131
+ /**
132
+ * For UDP sockets, causes the `dgram.Socket` to listen for datagram
133
+ * messages on a named `port` and optional `address`. If `port` is not
134
+ * specified or is `0`, the operating system will attempt to bind to a
135
+ * random port. If `address` is not specified, the operating system will
136
+ * attempt to listen on all addresses. Once binding is complete, a `'listening'` event is emitted and the optional `callback` function is
137
+ * called.
138
+ *
139
+ * Specifying both a `'listening'` event listener and passing a `callback` to the `socket.bind()` method is not harmful but not very
140
+ * useful.
141
+ *
142
+ * A bound datagram socket keeps the Node.js process running to receive
143
+ * datagram messages.
144
+ *
145
+ * If binding fails, an `'error'` event is generated. In rare case (e.g.
146
+ * attempting to bind with a closed socket), an `Error` may be thrown.
147
+ *
148
+ * Example of a UDP server listening on port 41234:
149
+ *
150
+ * ```js
151
+ * import dgram from 'node:dgram';
152
+ *
153
+ * const server = dgram.createSocket('udp4');
154
+ *
155
+ * server.on('error', (err) => {
156
+ * console.error(`server error:\n${err.stack}`);
157
+ * server.close();
158
+ * });
159
+ *
160
+ * server.on('message', (msg, rinfo) => {
161
+ * console.log(`server got: ${msg} from ${rinfo.address}:${rinfo.port}`);
162
+ * });
163
+ *
164
+ * server.on('listening', () => {
165
+ * const address = server.address();
166
+ * console.log(`server listening ${address.address}:${address.port}`);
167
+ * });
168
+ *
169
+ * server.bind(41234);
170
+ * // Prints: server listening 0.0.0.0:41234
171
+ * ```
172
+ * @since v0.1.99
173
+ * @param callback with no parameters. Called when binding is complete.
174
+ */
175
+ bind(port?: number, address?: string, callback?: () => void): this;
176
+ bind(port?: number, callback?: () => void): this;
177
+ bind(callback?: () => void): this;
178
+ bind(options: BindOptions, callback?: () => void): this;
179
+ /**
180
+ * Close the underlying socket and stop listening for data on it. If a callback is
181
+ * provided, it is added as a listener for the `'close'` event.
182
+ * @since v0.1.99
183
+ * @param callback Called when the socket has been closed.
184
+ */
185
+ close(callback?: () => void): this;
186
+ /**
187
+ * Associates the `dgram.Socket` to a remote address and port. Every
188
+ * message sent by this handle is automatically sent to that destination. Also,
189
+ * the socket will only receive messages from that remote peer.
190
+ * Trying to call `connect()` on an already connected socket will result
191
+ * in an `ERR_SOCKET_DGRAM_IS_CONNECTED` exception. If `address` is not
192
+ * provided, `'127.0.0.1'` (for `udp4` sockets) or `'::1'` (for `udp6` sockets)
193
+ * will be used by default. Once the connection is complete, a `'connect'` event
194
+ * is emitted and the optional `callback` function is called. In case of failure,
195
+ * the `callback` is called or, failing this, an `'error'` event is emitted.
196
+ * @since v12.0.0
197
+ * @param callback Called when the connection is completed or on error.
198
+ */
199
+ connect(port: number, address?: string, callback?: () => void): void;
200
+ connect(port: number, callback: () => void): void;
201
+ /**
202
+ * A synchronous function that disassociates a connected `dgram.Socket` from
203
+ * its remote address. Trying to call `disconnect()` on an unbound or already
204
+ * disconnected socket will result in an `ERR_SOCKET_DGRAM_NOT_CONNECTED` exception.
205
+ * @since v12.0.0
206
+ */
207
+ disconnect(): void;
208
+ /**
209
+ * Instructs the kernel to leave a multicast group at `multicastAddress` using the `IP_DROP_MEMBERSHIP` socket option. This method is automatically called by the
210
+ * kernel when the socket is closed or the process terminates, so most apps will
211
+ * never have reason to call this.
212
+ *
213
+ * If `multicastInterface` is not specified, the operating system will attempt to
214
+ * drop membership on all valid interfaces.
215
+ * @since v0.6.9
216
+ */
217
+ dropMembership(multicastAddress: string, multicastInterface?: string): void;
218
+ /**
219
+ * This method throws `ERR_SOCKET_BUFFER_SIZE` if called on an unbound socket.
220
+ * @since v8.7.0
221
+ * @return the `SO_RCVBUF` socket receive buffer size in bytes.
222
+ */
223
+ getRecvBufferSize(): number;
224
+ /**
225
+ * This method throws `ERR_SOCKET_BUFFER_SIZE` if called on an unbound socket.
226
+ * @since v8.7.0
227
+ * @return the `SO_SNDBUF` socket send buffer size in bytes.
228
+ */
229
+ getSendBufferSize(): number;
230
+ /**
231
+ * @since v18.8.0, v16.19.0
232
+ * @return Number of bytes queued for sending.
233
+ */
234
+ getSendQueueSize(): number;
235
+ /**
236
+ * @since v18.8.0, v16.19.0
237
+ * @return Number of send requests currently in the queue awaiting to be processed.
238
+ */
239
+ getSendQueueCount(): number;
240
+ /**
241
+ * By default, binding a socket will cause it to block the Node.js process from
242
+ * exiting as long as the socket is open. The `socket.unref()` method can be used
243
+ * to exclude the socket from the reference counting that keeps the Node.js
244
+ * process active. The `socket.ref()` method adds the socket back to the reference
245
+ * counting and restores the default behavior.
246
+ *
247
+ * Calling `socket.ref()` multiples times will have no additional effect.
248
+ *
249
+ * The `socket.ref()` method returns a reference to the socket so calls can be
250
+ * chained.
251
+ * @since v0.9.1
252
+ */
253
+ ref(): this;
254
+ /**
255
+ * Returns an object containing the `address`, `family`, and `port` of the remote
256
+ * endpoint. This method throws an `ERR_SOCKET_DGRAM_NOT_CONNECTED` exception
257
+ * if the socket is not connected.
258
+ * @since v12.0.0
259
+ */
260
+ remoteAddress(): AddressInfo;
261
+ /**
262
+ * Broadcasts a datagram on the socket.
263
+ * For connectionless sockets, the destination `port` and `address` must be
264
+ * specified. Connected sockets, on the other hand, will use their associated
265
+ * remote endpoint, so the `port` and `address` arguments must not be set.
266
+ *
267
+ * The `msg` argument contains the message to be sent.
268
+ * Depending on its type, different behavior can apply. If `msg` is a `Buffer`,
269
+ * any `TypedArray` or a `DataView`,
270
+ * the `offset` and `length` specify the offset within the `Buffer` where the
271
+ * message begins and the number of bytes in the message, respectively.
272
+ * If `msg` is a `String`, then it is automatically converted to a `Buffer` with `'utf8'` encoding. With messages that
273
+ * contain multi-byte characters, `offset` and `length` will be calculated with
274
+ * respect to `byte length` and not the character position.
275
+ * If `msg` is an array, `offset` and `length` must not be specified.
276
+ *
277
+ * The `address` argument is a string. If the value of `address` is a host name,
278
+ * DNS will be used to resolve the address of the host. If `address` is not
279
+ * provided or otherwise nullish, `'127.0.0.1'` (for `udp4` sockets) or `'::1'` (for `udp6` sockets) will be used by default.
280
+ *
281
+ * If the socket has not been previously bound with a call to `bind`, the socket
282
+ * is assigned a random port number and is bound to the "all interfaces" address
283
+ * (`'0.0.0.0'` for `udp4` sockets, `'::0'` for `udp6` sockets.)
284
+ *
285
+ * An optional `callback` function may be specified to as a way of reporting
286
+ * DNS errors or for determining when it is safe to reuse the `buf` object.
287
+ * DNS lookups delay the time to send for at least one tick of the
288
+ * Node.js event loop.
289
+ *
290
+ * The only way to know for sure that the datagram has been sent is by using a `callback`. If an error occurs and a `callback` is given, the error will be
291
+ * passed as the first argument to the `callback`. If a `callback` is not given,
292
+ * the error is emitted as an `'error'` event on the `socket` object.
293
+ *
294
+ * Offset and length are optional but both _must_ be set if either are used.
295
+ * They are supported only when the first argument is a `Buffer`, a `TypedArray`,
296
+ * or a `DataView`.
297
+ *
298
+ * This method throws `ERR_SOCKET_BAD_PORT` if called on an unbound socket.
299
+ *
300
+ * Example of sending a UDP packet to a port on `localhost`;
301
+ *
302
+ * ```js
303
+ * import dgram from 'node:dgram';
304
+ * import { Buffer } from 'node:buffer';
305
+ *
306
+ * const message = Buffer.from('Some bytes');
307
+ * const client = dgram.createSocket('udp4');
308
+ * client.send(message, 41234, 'localhost', (err) => {
309
+ * client.close();
310
+ * });
311
+ * ```
312
+ *
313
+ * Example of sending a UDP packet composed of multiple buffers to a port on`127.0.0.1`;
314
+ *
315
+ * ```js
316
+ * import dgram from 'node:dgram';
317
+ * import { Buffer } from 'node:buffer';
318
+ *
319
+ * const buf1 = Buffer.from('Some ');
320
+ * const buf2 = Buffer.from('bytes');
321
+ * const client = dgram.createSocket('udp4');
322
+ * client.send([buf1, buf2], 41234, (err) => {
323
+ * client.close();
324
+ * });
325
+ * ```
326
+ *
327
+ * Sending multiple buffers might be faster or slower depending on the
328
+ * application and operating system. Run benchmarks to
329
+ * determine the optimal strategy on a case-by-case basis. Generally speaking,
330
+ * however, sending multiple buffers is faster.
331
+ *
332
+ * Example of sending a UDP packet using a socket connected to a port on `localhost`:
333
+ *
334
+ * ```js
335
+ * import dgram from 'node:dgram';
336
+ * import { Buffer } from 'node:buffer';
337
+ *
338
+ * const message = Buffer.from('Some bytes');
339
+ * const client = dgram.createSocket('udp4');
340
+ * client.connect(41234, 'localhost', (err) => {
341
+ * client.send(message, (err) => {
342
+ * client.close();
343
+ * });
344
+ * });
345
+ * ```
346
+ * @since v0.1.99
347
+ * @param msg Message to be sent.
348
+ * @param offset Offset in the buffer where the message starts.
349
+ * @param length Number of bytes in the message.
350
+ * @param port Destination port.
351
+ * @param address Destination host name or IP address.
352
+ * @param callback Called when the message has been sent.
353
+ */
354
+ send(
355
+ msg: string | Uint8Array | readonly any[],
356
+ port?: number,
357
+ address?: string,
358
+ callback?: (error: Error | null, bytes: number) => void,
359
+ ): void;
360
+ send(
361
+ msg: string | Uint8Array | readonly any[],
362
+ port?: number,
363
+ callback?: (error: Error | null, bytes: number) => void,
364
+ ): void;
365
+ send(
366
+ msg: string | Uint8Array | readonly any[],
367
+ callback?: (error: Error | null, bytes: number) => void,
368
+ ): void;
369
+ send(
370
+ msg: string | Uint8Array,
371
+ offset: number,
372
+ length: number,
373
+ port?: number,
374
+ address?: string,
375
+ callback?: (error: Error | null, bytes: number) => void,
376
+ ): void;
377
+ send(
378
+ msg: string | Uint8Array,
379
+ offset: number,
380
+ length: number,
381
+ port?: number,
382
+ callback?: (error: Error | null, bytes: number) => void,
383
+ ): void;
384
+ send(
385
+ msg: string | Uint8Array,
386
+ offset: number,
387
+ length: number,
388
+ callback?: (error: Error | null, bytes: number) => void,
389
+ ): void;
390
+ /**
391
+ * Sets or clears the `SO_BROADCAST` socket option. When set to `true`, UDP
392
+ * packets may be sent to a local interface's broadcast address.
393
+ *
394
+ * This method throws `EBADF` if called on an unbound socket.
395
+ * @since v0.6.9
396
+ */
397
+ setBroadcast(flag: boolean): void;
398
+ /**
399
+ * _All references to scope in this section are referring to [IPv6 Zone Indices](https://en.wikipedia.org/wiki/IPv6_address#Scoped_literal_IPv6_addresses), which are defined by [RFC
400
+ * 4007](https://tools.ietf.org/html/rfc4007). In string form, an IP_
401
+ * _with a scope index is written as `'IP%scope'` where scope is an interface name_
402
+ * _or interface number._
403
+ *
404
+ * Sets the default outgoing multicast interface of the socket to a chosen
405
+ * interface or back to system interface selection. The `multicastInterface` must
406
+ * be a valid string representation of an IP from the socket's family.
407
+ *
408
+ * For IPv4 sockets, this should be the IP configured for the desired physical
409
+ * interface. All packets sent to multicast on the socket will be sent on the
410
+ * interface determined by the most recent successful use of this call.
411
+ *
412
+ * For IPv6 sockets, `multicastInterface` should include a scope to indicate the
413
+ * interface as in the examples that follow. In IPv6, individual `send` calls can
414
+ * also use explicit scope in addresses, so only packets sent to a multicast
415
+ * address without specifying an explicit scope are affected by the most recent
416
+ * successful use of this call.
417
+ *
418
+ * This method throws `EBADF` if called on an unbound socket.
419
+ *
420
+ * #### Example: IPv6 outgoing multicast interface
421
+ *
422
+ * On most systems, where scope format uses the interface name:
423
+ *
424
+ * ```js
425
+ * const socket = dgram.createSocket('udp6');
426
+ *
427
+ * socket.bind(1234, () => {
428
+ * socket.setMulticastInterface('::%eth1');
429
+ * });
430
+ * ```
431
+ *
432
+ * On Windows, where scope format uses an interface number:
433
+ *
434
+ * ```js
435
+ * const socket = dgram.createSocket('udp6');
436
+ *
437
+ * socket.bind(1234, () => {
438
+ * socket.setMulticastInterface('::%2');
439
+ * });
440
+ * ```
441
+ *
442
+ * #### Example: IPv4 outgoing multicast interface
443
+ *
444
+ * All systems use an IP of the host on the desired physical interface:
445
+ *
446
+ * ```js
447
+ * const socket = dgram.createSocket('udp4');
448
+ *
449
+ * socket.bind(1234, () => {
450
+ * socket.setMulticastInterface('10.0.0.2');
451
+ * });
452
+ * ```
453
+ * @since v8.6.0
454
+ */
455
+ setMulticastInterface(multicastInterface: string): void;
456
+ /**
457
+ * Sets or clears the `IP_MULTICAST_LOOP` socket option. When set to `true`,
458
+ * multicast packets will also be received on the local interface.
459
+ *
460
+ * This method throws `EBADF` if called on an unbound socket.
461
+ * @since v0.3.8
462
+ */
463
+ setMulticastLoopback(flag: boolean): boolean;
464
+ /**
465
+ * Sets the `IP_MULTICAST_TTL` socket option. While TTL generally stands for
466
+ * "Time to Live", in this context it specifies the number of IP hops that a
467
+ * packet is allowed to travel through, specifically for multicast traffic. Each
468
+ * router or gateway that forwards a packet decrements the TTL. If the TTL is
469
+ * decremented to 0 by a router, it will not be forwarded.
470
+ *
471
+ * The `ttl` argument may be between 0 and 255\. The default on most systems is `1`.
472
+ *
473
+ * This method throws `EBADF` if called on an unbound socket.
474
+ * @since v0.3.8
475
+ */
476
+ setMulticastTTL(ttl: number): number;
477
+ /**
478
+ * Sets the `SO_RCVBUF` socket option. Sets the maximum socket receive buffer
479
+ * in bytes.
480
+ *
481
+ * This method throws `ERR_SOCKET_BUFFER_SIZE` if called on an unbound socket.
482
+ * @since v8.7.0
483
+ */
484
+ setRecvBufferSize(size: number): void;
485
+ /**
486
+ * Sets the `SO_SNDBUF` socket option. Sets the maximum socket send buffer
487
+ * in bytes.
488
+ *
489
+ * This method throws `ERR_SOCKET_BUFFER_SIZE` if called on an unbound socket.
490
+ * @since v8.7.0
491
+ */
492
+ setSendBufferSize(size: number): void;
493
+ /**
494
+ * Sets the `IP_TTL` socket option. While TTL generally stands for "Time to Live",
495
+ * in this context it specifies the number of IP hops that a packet is allowed to
496
+ * travel through. Each router or gateway that forwards a packet decrements the
497
+ * TTL. If the TTL is decremented to 0 by a router, it will not be forwarded.
498
+ * Changing TTL values is typically done for network probes or when multicasting.
499
+ *
500
+ * The `ttl` argument may be between 1 and 255\. The default on most systems
501
+ * is 64.
502
+ *
503
+ * This method throws `EBADF` if called on an unbound socket.
504
+ * @since v0.1.101
505
+ */
506
+ setTTL(ttl: number): number;
507
+ /**
508
+ * By default, binding a socket will cause it to block the Node.js process from
509
+ * exiting as long as the socket is open. The `socket.unref()` method can be used
510
+ * to exclude the socket from the reference counting that keeps the Node.js
511
+ * process active, allowing the process to exit even if the socket is still
512
+ * listening.
513
+ *
514
+ * Calling `socket.unref()` multiple times will have no additional effect.
515
+ *
516
+ * The `socket.unref()` method returns a reference to the socket so calls can be
517
+ * chained.
518
+ * @since v0.9.1
519
+ */
520
+ unref(): this;
521
+ /**
522
+ * Tells the kernel to join a source-specific multicast channel at the given `sourceAddress` and `groupAddress`, using the `multicastInterface` with the `IP_ADD_SOURCE_MEMBERSHIP` socket
523
+ * option. If the `multicastInterface` argument
524
+ * is not specified, the operating system will choose one interface and will add
525
+ * membership to it. To add membership to every available interface, call `socket.addSourceSpecificMembership()` multiple times, once per interface.
526
+ *
527
+ * When called on an unbound socket, this method will implicitly bind to a random
528
+ * port, listening on all interfaces.
529
+ * @since v13.1.0, v12.16.0
530
+ */
531
+ addSourceSpecificMembership(sourceAddress: string, groupAddress: string, multicastInterface?: string): void;
532
+ /**
533
+ * Instructs the kernel to leave a source-specific multicast channel at the given `sourceAddress` and `groupAddress` using the `IP_DROP_SOURCE_MEMBERSHIP` socket option. This method is
534
+ * automatically called by the kernel when the
535
+ * socket is closed or the process terminates, so most apps will never have
536
+ * reason to call this.
537
+ *
538
+ * If `multicastInterface` is not specified, the operating system will attempt to
539
+ * drop membership on all valid interfaces.
540
+ * @since v13.1.0, v12.16.0
541
+ */
542
+ dropSourceSpecificMembership(sourceAddress: string, groupAddress: string, multicastInterface?: string): void;
543
+ /**
544
+ * events.EventEmitter
545
+ * 1. close
546
+ * 2. connect
547
+ * 3. error
548
+ * 4. listening
549
+ * 5. message
550
+ */
551
+ addListener(event: string, listener: (...args: any[]) => void): this;
552
+ addListener(event: "close", listener: () => void): this;
553
+ addListener(event: "connect", listener: () => void): this;
554
+ addListener(event: "error", listener: (err: Error) => void): this;
555
+ addListener(event: "listening", listener: () => void): this;
556
+ addListener(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
557
+ emit(event: string | symbol, ...args: any[]): boolean;
558
+ emit(event: "close"): boolean;
559
+ emit(event: "connect"): boolean;
560
+ emit(event: "error", err: Error): boolean;
561
+ emit(event: "listening"): boolean;
562
+ emit(event: "message", msg: Buffer, rinfo: RemoteInfo): boolean;
563
+ on(event: string, listener: (...args: any[]) => void): this;
564
+ on(event: "close", listener: () => void): this;
565
+ on(event: "connect", listener: () => void): this;
566
+ on(event: "error", listener: (err: Error) => void): this;
567
+ on(event: "listening", listener: () => void): this;
568
+ on(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
569
+ once(event: string, listener: (...args: any[]) => void): this;
570
+ once(event: "close", listener: () => void): this;
571
+ once(event: "connect", listener: () => void): this;
572
+ once(event: "error", listener: (err: Error) => void): this;
573
+ once(event: "listening", listener: () => void): this;
574
+ once(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
575
+ prependListener(event: string, listener: (...args: any[]) => void): this;
576
+ prependListener(event: "close", listener: () => void): this;
577
+ prependListener(event: "connect", listener: () => void): this;
578
+ prependListener(event: "error", listener: (err: Error) => void): this;
579
+ prependListener(event: "listening", listener: () => void): this;
580
+ prependListener(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
581
+ prependOnceListener(event: string, listener: (...args: any[]) => void): this;
582
+ prependOnceListener(event: "close", listener: () => void): this;
583
+ prependOnceListener(event: "connect", listener: () => void): this;
584
+ prependOnceListener(event: "error", listener: (err: Error) => void): this;
585
+ prependOnceListener(event: "listening", listener: () => void): this;
586
+ prependOnceListener(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
587
+ /**
588
+ * Calls `socket.close()` and returns a promise that fulfills when the socket has closed.
589
+ * @since v20.5.0
590
+ */
591
+ [Symbol.asyncDispose](): Promise<void>;
592
+ }
593
+ }
594
+ declare module "node:dgram" {
595
+ export * from "dgram";
596
+ }