@moqtap/codec 0.2.1 → 0.2.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (576) hide show
  1. package/dist/{chunk-LH4NTURO.js → chunk-2GODRVT5.js} +699 -589
  2. package/dist/{chunk-4RIXXEII.js → chunk-2ZT6CVSE.js} +274 -242
  3. package/dist/{chunk-XUUCOLWU.cjs → chunk-4N4INRE7.cjs} +332 -321
  4. package/dist/{chunk-PJRA2TQ5.js → chunk-73MWUKSJ.js} +274 -228
  5. package/dist/{chunk-NGVE2RZT.js → chunk-77MNXX3M.js} +549 -538
  6. package/dist/{chunk-A27S7HW7.js → chunk-7L43FE6P.js} +24 -3
  7. package/dist/{chunk-RVJAGE4S.cjs → chunk-ACQ4CUJP.cjs} +297 -265
  8. package/dist/{chunk-IBVM4DMJ.cjs → chunk-BGWGVINJ.cjs} +332 -321
  9. package/dist/{chunk-KFTCU2P6.js → chunk-C6KUWLQC.js} +0 -3
  10. package/dist/{chunk-CXDHOMHG.js → chunk-CEH7ESNC.js} +549 -538
  11. package/dist/{chunk-ZBKE2QRQ.js → chunk-E6P74GDT.js} +686 -599
  12. package/dist/{chunk-FUFTMAQD.cjs → chunk-FPISPJ5N.cjs} +785 -497
  13. package/dist/{chunk-7IVGHMKJ.cjs → chunk-FZDIEHQL.cjs} +300 -124
  14. package/dist/{chunk-ZSPO2GF2.cjs → chunk-GLBQDG4L.cjs} +971 -884
  15. package/dist/chunk-HDWJ2GDE.js +24 -0
  16. package/dist/{chunk-4YJANAXU.cjs → chunk-JGG7CMSZ.cjs} +469 -434
  17. package/dist/{chunk-IV2H5CFI.cjs → chunk-JTVCOMBI.cjs} +298 -266
  18. package/dist/chunk-KNDYS3DK.cjs +24 -0
  19. package/dist/{chunk-BPNL5YFQ.cjs → chunk-KZCYQ7ED.cjs} +5 -5
  20. package/dist/{chunk-U2B3B42P.js → chunk-MC7W6PMI.js} +709 -421
  21. package/dist/{chunk-MFAP7R6L.js → chunk-MRJWLGYH.js} +1 -1
  22. package/dist/{chunk-RWQ43Z4F.cjs → chunk-MZ7VU52O.cjs} +0 -3
  23. package/dist/{chunk-TMNGRIPL.js → chunk-N2KBF5Q2.js} +285 -109
  24. package/dist/{chunk-IV2HRJVT.js → chunk-PZBPH2D7.js} +274 -242
  25. package/dist/{chunk-FWISIR26.cjs → chunk-RUPCJTC3.cjs} +24 -3
  26. package/dist/{chunk-G26SJ6XS.cjs → chunk-S74DWJE2.cjs} +1001 -925
  27. package/dist/{chunk-NUX5BHWO.js → chunk-U3IPZYPX.js} +1113 -1037
  28. package/dist/{chunk-HSVYF6XX.cjs → chunk-VJUUZ4W2.cjs} +1106 -996
  29. package/dist/{chunk-ST24APEO.js → chunk-XSNX2IUJ.js} +574 -539
  30. package/dist/{chunk-K4OLITS2.cjs → chunk-YIG2C3LF.cjs} +295 -249
  31. package/dist/{drafts/draft15/codec.d.ts → codec-B2cH-f5V.d.cts} +11 -10
  32. package/dist/codec-B5K73Bdj.d.ts +30 -0
  33. package/dist/{codec-C_HMXNK_.d.ts → codec-BFeliJFc.d.ts} +4 -10
  34. package/dist/codec-BUMjz0J4.d.cts +30 -0
  35. package/dist/{codec-D0x8-SCw.d.cts → codec-Bap882Fh.d.cts} +3 -9
  36. package/dist/codec-BdVMRMOI.d.ts +34 -0
  37. package/dist/codec-Bq-tLtfP.d.ts +30 -0
  38. package/dist/codec-BwFgpeQu.d.ts +23 -0
  39. package/dist/{codec-95k8CAu5.d.cts → codec-C4n1PS09.d.cts} +3 -9
  40. package/dist/{codec-BECYPfY8.d.ts → codec-CPlK3Pi5.d.ts} +3 -9
  41. package/dist/{drafts/draft08/codec.d.ts → codec-CPvPq0sb.d.cts} +11 -9
  42. package/dist/codec-DNUIgLqc.d.cts +23 -0
  43. package/dist/codec-DRcsBCsb.d.ts +23 -0
  44. package/dist/{codec-CAevkgf5.d.cts → codec-DY4QH364.d.cts} +4 -10
  45. package/dist/codec-DZhZSIii.d.cts +30 -0
  46. package/dist/{drafts/draft14/codec.d.ts → codec-FvGCxIhr.d.ts} +11 -10
  47. package/dist/codec-HgBgHkFI.d.cts +23 -0
  48. package/dist/codec-KXHvXZVb.d.cts +35 -0
  49. package/dist/{codec-BC5jfvMb.d.ts → codec-R8GrCPt2.d.ts} +3 -9
  50. package/dist/{codec-BsPU1vNC.d.ts → codec-SKBeHQk7.d.ts} +3 -11
  51. package/dist/draft10-session.d.cts +1 -1
  52. package/dist/draft10-session.d.ts +1 -1
  53. package/dist/draft10.cjs +4 -3
  54. package/dist/draft10.d.cts +15 -5
  55. package/dist/draft10.d.ts +15 -5
  56. package/dist/draft10.js +3 -2
  57. package/dist/draft11-session.d.cts +1 -1
  58. package/dist/draft11-session.d.ts +1 -1
  59. package/dist/draft11.cjs +4 -3
  60. package/dist/draft11.d.cts +13 -5
  61. package/dist/draft11.d.ts +13 -5
  62. package/dist/draft11.js +3 -2
  63. package/dist/draft12-session.d.cts +1 -1
  64. package/dist/draft12-session.d.ts +1 -1
  65. package/dist/draft12.cjs +4 -3
  66. package/dist/draft12.d.cts +13 -5
  67. package/dist/draft12.d.ts +13 -5
  68. package/dist/draft12.js +3 -2
  69. package/dist/draft13-session.d.cts +1 -1
  70. package/dist/draft13-session.d.ts +1 -1
  71. package/dist/draft13.cjs +4 -3
  72. package/dist/draft13.d.cts +13 -5
  73. package/dist/draft13.d.ts +13 -5
  74. package/dist/draft13.js +3 -2
  75. package/dist/draft14-session.d.cts +1 -1
  76. package/dist/draft14-session.d.ts +1 -1
  77. package/dist/draft14.cjs +4 -3
  78. package/dist/draft14.d.cts +59 -5
  79. package/dist/draft14.d.ts +59 -5
  80. package/dist/draft14.js +3 -2
  81. package/dist/draft15-session.d.cts +1 -1
  82. package/dist/draft15-session.d.ts +1 -1
  83. package/dist/draft15.cjs +4 -3
  84. package/dist/draft15.d.cts +48 -5
  85. package/dist/draft15.d.ts +48 -5
  86. package/dist/draft15.js +3 -2
  87. package/dist/draft16-session.d.cts +1 -1
  88. package/dist/draft16-session.d.ts +1 -1
  89. package/dist/draft16.cjs +4 -3
  90. package/dist/draft16.d.cts +37 -5
  91. package/dist/draft16.d.ts +37 -5
  92. package/dist/draft16.js +3 -2
  93. package/dist/draft17-session.d.cts +1 -1
  94. package/dist/draft17-session.d.ts +1 -1
  95. package/dist/draft17.cjs +4 -3
  96. package/dist/draft17.d.cts +16 -5
  97. package/dist/draft17.d.ts +16 -5
  98. package/dist/draft17.js +3 -2
  99. package/dist/draft7-session.cjs +3 -3
  100. package/dist/draft7-session.js +2 -2
  101. package/dist/draft7.cjs +18 -6
  102. package/dist/draft7.d.cts +84 -8
  103. package/dist/draft7.d.ts +84 -8
  104. package/dist/draft7.js +15 -3
  105. package/dist/draft8-session.d.cts +1 -1
  106. package/dist/draft8-session.d.ts +1 -1
  107. package/dist/draft8.cjs +4 -3
  108. package/dist/draft8.d.cts +15 -5
  109. package/dist/draft8.d.ts +15 -5
  110. package/dist/draft8.js +3 -2
  111. package/dist/draft9-session.d.cts +1 -1
  112. package/dist/draft9-session.d.ts +1 -1
  113. package/dist/draft9.cjs +4 -3
  114. package/dist/draft9.d.cts +15 -5
  115. package/dist/draft9.d.ts +15 -5
  116. package/dist/draft9.js +3 -2
  117. package/dist/index.cjs +25 -24
  118. package/dist/index.d.cts +20 -20
  119. package/dist/index.d.ts +38 -46
  120. package/dist/index.js +111 -93
  121. package/dist/session.cjs +3 -3
  122. package/dist/session.d.ts +8 -4
  123. package/dist/session.js +26 -32
  124. package/dist/{types-ERexTpT8.d.cts → types-8gUGeMgs.d.cts} +4 -1
  125. package/dist/{types-ERexTpT8.d.ts → types-8gUGeMgs.d.ts} +4 -1
  126. package/dist/{types-Cw4WE9dh.d.ts → types-B0FT5Qs2.d.cts} +9 -1
  127. package/dist/{types-Cw4WE9dh.d.cts → types-B0FT5Qs2.d.ts} +9 -1
  128. package/dist/{types-DqCDFqgB.d.cts → types-B9A2g05r.d.cts} +4 -1
  129. package/dist/{types-DqCDFqgB.d.ts → types-B9A2g05r.d.ts} +4 -1
  130. package/dist/{types-Bg6QYNVt.d.cts → types-BeAVNU-F.d.cts} +7 -2
  131. package/dist/{types-Bg6QYNVt.d.ts → types-BeAVNU-F.d.ts} +7 -2
  132. package/dist/{types-C_1HrqBl.d.ts → types-CDa7F5ct.d.cts} +7 -2
  133. package/dist/{types-C_1HrqBl.d.cts → types-CDa7F5ct.d.ts} +7 -2
  134. package/dist/{types-r-CasCf1.d.cts → types-D1dI_oTX.d.cts} +8 -1
  135. package/dist/{types-r-CasCf1.d.ts → types-D1dI_oTX.d.ts} +8 -1
  136. package/dist/{types-BTFeKYCb.d.ts → types-DKpsfD3i.d.cts} +19 -4
  137. package/dist/{types-BTFeKYCb.d.cts → types-DKpsfD3i.d.ts} +19 -4
  138. package/dist/{types-4VxSL2Ho.d.ts → types-DxSFvL2b.d.cts} +7 -1
  139. package/dist/{types-4VxSL2Ho.d.cts → types-DxSFvL2b.d.ts} +7 -1
  140. package/dist/{types-B2afJZM-.d.ts → types-Pme7sua0.d.cts} +4 -1
  141. package/dist/{types-B2afJZM-.d.cts → types-Pme7sua0.d.ts} +4 -1
  142. package/dist/{types-D5gNQiDj.d.ts → types-gQsr0AAA.d.cts} +9 -1
  143. package/dist/{types-D5gNQiDj.d.cts → types-gQsr0AAA.d.ts} +9 -1
  144. package/package.json +2 -2
  145. package/src/core/buffer-reader.ts +130 -114
  146. package/src/core/buffer-writer.ts +100 -91
  147. package/src/core/hex.ts +7 -3
  148. package/src/drafts/draft07/codec.ts +14 -9
  149. package/src/drafts/draft07/data-streams.ts +240 -240
  150. package/src/drafts/draft07/varint.ts +51 -23
  151. package/src/drafts/draft08/codec.ts +19 -10
  152. package/src/drafts/draft08/data-streams.ts +359 -359
  153. package/src/drafts/draft09/codec.ts +19 -10
  154. package/src/drafts/draft09/data-streams.ts +332 -332
  155. package/src/drafts/draft10/codec.ts +19 -10
  156. package/src/drafts/draft10/data-streams.ts +332 -332
  157. package/src/drafts/draft11/codec.ts +33 -14
  158. package/src/drafts/draft11/data-streams.ts +269 -269
  159. package/src/drafts/draft12/codec.ts +27 -31
  160. package/src/drafts/draft12/data-streams.ts +275 -275
  161. package/src/drafts/draft13/codec.ts +27 -31
  162. package/src/drafts/draft13/data-streams.ts +275 -275
  163. package/src/drafts/draft14/codec.ts +19 -10
  164. package/src/drafts/draft14/data-streams.ts +813 -798
  165. package/src/drafts/draft15/codec.ts +21 -12
  166. package/src/drafts/draft15/data-streams.ts +794 -778
  167. package/src/drafts/draft16/codec.ts +21 -12
  168. package/src/drafts/draft16/data-streams.ts +789 -773
  169. package/src/drafts/draft17/codec.ts +21 -12
  170. package/src/drafts/draft17/data-streams.ts +758 -742
  171. package/dist/codec-AFuOxfsO.d.ts +0 -60
  172. package/dist/codec-B-UJ5Iow.d.cts +0 -75
  173. package/dist/codec-BvpuF-6u.d.cts +0 -39
  174. package/dist/codec-C8jZI5Cx.d.cts +0 -39
  175. package/dist/codec-CSUqCrRs.d.ts +0 -39
  176. package/dist/codec-CpuvYTSV.d.cts +0 -86
  177. package/dist/codec-D7ARhpG1.d.ts +0 -75
  178. package/dist/codec-DNAUGshO.d.cts +0 -60
  179. package/dist/codec-DPx_QNn0.d.ts +0 -31
  180. package/dist/codec-DRhCx_hw.d.ts +0 -86
  181. package/dist/codec-Db7YPe3l.d.ts +0 -31
  182. package/dist/codec-axkJpb7D.d.cts +0 -31
  183. package/dist/codec-ujAbFaep.d.cts +0 -31
  184. package/dist/core/buffer-reader.d.ts +0 -15
  185. package/dist/core/buffer-reader.d.ts.map +0 -1
  186. package/dist/core/buffer-reader.js +0 -98
  187. package/dist/core/buffer-reader.js.map +0 -1
  188. package/dist/core/buffer-writer.d.ts +0 -16
  189. package/dist/core/buffer-writer.d.ts.map +0 -1
  190. package/dist/core/buffer-writer.js +0 -86
  191. package/dist/core/buffer-writer.js.map +0 -1
  192. package/dist/core/errors.d.ts +0 -2
  193. package/dist/core/errors.d.ts.map +0 -1
  194. package/dist/core/errors.js +0 -2
  195. package/dist/core/errors.js.map +0 -1
  196. package/dist/core/hex.d.ts +0 -5
  197. package/dist/core/hex.d.ts.map +0 -1
  198. package/dist/core/hex.js +0 -17
  199. package/dist/core/hex.js.map +0 -1
  200. package/dist/core/session-types.d.ts +0 -99
  201. package/dist/core/session-types.d.ts.map +0 -1
  202. package/dist/core/session-types.js +0 -2
  203. package/dist/core/session-types.js.map +0 -1
  204. package/dist/core/types.d.ts +0 -235
  205. package/dist/core/types.d.ts.map +0 -1
  206. package/dist/core/types.js +0 -11
  207. package/dist/core/types.js.map +0 -1
  208. package/dist/drafts/draft07/announce-fsm.d.ts +0 -2
  209. package/dist/drafts/draft07/announce-fsm.d.ts.map +0 -1
  210. package/dist/drafts/draft07/announce-fsm.js +0 -2
  211. package/dist/drafts/draft07/announce-fsm.js.map +0 -1
  212. package/dist/drafts/draft07/codec.d.ts +0 -17
  213. package/dist/drafts/draft07/codec.d.ts.map +0 -1
  214. package/dist/drafts/draft07/codec.js +0 -722
  215. package/dist/drafts/draft07/codec.js.map +0 -1
  216. package/dist/drafts/draft07/data-streams.d.ts +0 -9
  217. package/dist/drafts/draft07/data-streams.d.ts.map +0 -1
  218. package/dist/drafts/draft07/data-streams.js +0 -228
  219. package/dist/drafts/draft07/data-streams.js.map +0 -1
  220. package/dist/drafts/draft07/index.d.ts +0 -14
  221. package/dist/drafts/draft07/index.d.ts.map +0 -1
  222. package/dist/drafts/draft07/index.js +0 -18
  223. package/dist/drafts/draft07/index.js.map +0 -1
  224. package/dist/drafts/draft07/messages.d.ts +0 -32
  225. package/dist/drafts/draft07/messages.d.ts.map +0 -1
  226. package/dist/drafts/draft07/messages.js +0 -42
  227. package/dist/drafts/draft07/messages.js.map +0 -1
  228. package/dist/drafts/draft07/parameters.d.ts +0 -4
  229. package/dist/drafts/draft07/parameters.d.ts.map +0 -1
  230. package/dist/drafts/draft07/parameters.js +0 -10
  231. package/dist/drafts/draft07/parameters.js.map +0 -1
  232. package/dist/drafts/draft07/rules.d.ts +0 -8
  233. package/dist/drafts/draft07/rules.d.ts.map +0 -1
  234. package/dist/drafts/draft07/rules.js +0 -95
  235. package/dist/drafts/draft07/rules.js.map +0 -1
  236. package/dist/drafts/draft07/session-fsm.d.ts +0 -38
  237. package/dist/drafts/draft07/session-fsm.d.ts.map +0 -1
  238. package/dist/drafts/draft07/session-fsm.js +0 -354
  239. package/dist/drafts/draft07/session-fsm.js.map +0 -1
  240. package/dist/drafts/draft07/session.d.ts +0 -4
  241. package/dist/drafts/draft07/session.d.ts.map +0 -1
  242. package/dist/drafts/draft07/session.js +0 -5
  243. package/dist/drafts/draft07/session.js.map +0 -1
  244. package/dist/drafts/draft07/subscription-fsm.d.ts +0 -2
  245. package/dist/drafts/draft07/subscription-fsm.d.ts.map +0 -1
  246. package/dist/drafts/draft07/subscription-fsm.js +0 -2
  247. package/dist/drafts/draft07/subscription-fsm.js.map +0 -1
  248. package/dist/drafts/draft07/types.d.ts +0 -61
  249. package/dist/drafts/draft07/types.d.ts.map +0 -1
  250. package/dist/drafts/draft07/types.js +0 -4
  251. package/dist/drafts/draft07/types.js.map +0 -1
  252. package/dist/drafts/draft07/varint.d.ts +0 -4
  253. package/dist/drafts/draft07/varint.d.ts.map +0 -1
  254. package/dist/drafts/draft07/varint.js +0 -22
  255. package/dist/drafts/draft07/varint.js.map +0 -1
  256. package/dist/drafts/draft08/codec.d.ts.map +0 -1
  257. package/dist/drafts/draft08/codec.js +0 -729
  258. package/dist/drafts/draft08/codec.js.map +0 -1
  259. package/dist/drafts/draft08/data-streams.d.ts +0 -12
  260. package/dist/drafts/draft08/data-streams.d.ts.map +0 -1
  261. package/dist/drafts/draft08/data-streams.js +0 -345
  262. package/dist/drafts/draft08/data-streams.js.map +0 -1
  263. package/dist/drafts/draft08/index.d.ts +0 -9
  264. package/dist/drafts/draft08/index.d.ts.map +0 -1
  265. package/dist/drafts/draft08/index.js +0 -7
  266. package/dist/drafts/draft08/index.js.map +0 -1
  267. package/dist/drafts/draft08/messages.d.ts +0 -34
  268. package/dist/drafts/draft08/messages.d.ts.map +0 -1
  269. package/dist/drafts/draft08/messages.js +0 -66
  270. package/dist/drafts/draft08/messages.js.map +0 -1
  271. package/dist/drafts/draft08/rules.d.ts +0 -8
  272. package/dist/drafts/draft08/rules.d.ts.map +0 -1
  273. package/dist/drafts/draft08/rules.js +0 -83
  274. package/dist/drafts/draft08/rules.js.map +0 -1
  275. package/dist/drafts/draft08/session-fsm.d.ts +0 -47
  276. package/dist/drafts/draft08/session-fsm.d.ts.map +0 -1
  277. package/dist/drafts/draft08/session-fsm.js +0 -483
  278. package/dist/drafts/draft08/session-fsm.js.map +0 -1
  279. package/dist/drafts/draft08/session.d.ts +0 -5
  280. package/dist/drafts/draft08/session.d.ts.map +0 -1
  281. package/dist/drafts/draft08/session.js +0 -5
  282. package/dist/drafts/draft08/session.js.map +0 -1
  283. package/dist/drafts/draft08/types.d.ts +0 -268
  284. package/dist/drafts/draft08/types.d.ts.map +0 -1
  285. package/dist/drafts/draft08/types.js +0 -4
  286. package/dist/drafts/draft08/types.js.map +0 -1
  287. package/dist/drafts/draft09/codec.d.ts +0 -21
  288. package/dist/drafts/draft09/codec.d.ts.map +0 -1
  289. package/dist/drafts/draft09/codec.js +0 -721
  290. package/dist/drafts/draft09/codec.js.map +0 -1
  291. package/dist/drafts/draft09/data-streams.d.ts +0 -12
  292. package/dist/drafts/draft09/data-streams.d.ts.map +0 -1
  293. package/dist/drafts/draft09/data-streams.js +0 -307
  294. package/dist/drafts/draft09/data-streams.js.map +0 -1
  295. package/dist/drafts/draft09/index.d.ts +0 -9
  296. package/dist/drafts/draft09/index.d.ts.map +0 -1
  297. package/dist/drafts/draft09/index.js +0 -7
  298. package/dist/drafts/draft09/index.js.map +0 -1
  299. package/dist/drafts/draft09/messages.d.ts +0 -34
  300. package/dist/drafts/draft09/messages.d.ts.map +0 -1
  301. package/dist/drafts/draft09/messages.js +0 -66
  302. package/dist/drafts/draft09/messages.js.map +0 -1
  303. package/dist/drafts/draft09/rules.d.ts +0 -8
  304. package/dist/drafts/draft09/rules.d.ts.map +0 -1
  305. package/dist/drafts/draft09/rules.js +0 -83
  306. package/dist/drafts/draft09/rules.js.map +0 -1
  307. package/dist/drafts/draft09/session-fsm.d.ts +0 -47
  308. package/dist/drafts/draft09/session-fsm.d.ts.map +0 -1
  309. package/dist/drafts/draft09/session-fsm.js +0 -483
  310. package/dist/drafts/draft09/session-fsm.js.map +0 -1
  311. package/dist/drafts/draft09/session.d.ts +0 -5
  312. package/dist/drafts/draft09/session.d.ts.map +0 -1
  313. package/dist/drafts/draft09/session.js +0 -5
  314. package/dist/drafts/draft09/session.js.map +0 -1
  315. package/dist/drafts/draft09/types.d.ts +0 -268
  316. package/dist/drafts/draft09/types.d.ts.map +0 -1
  317. package/dist/drafts/draft09/types.js +0 -4
  318. package/dist/drafts/draft09/types.js.map +0 -1
  319. package/dist/drafts/draft10/codec.d.ts +0 -21
  320. package/dist/drafts/draft10/codec.d.ts.map +0 -1
  321. package/dist/drafts/draft10/codec.js +0 -721
  322. package/dist/drafts/draft10/codec.js.map +0 -1
  323. package/dist/drafts/draft10/data-streams.d.ts +0 -12
  324. package/dist/drafts/draft10/data-streams.d.ts.map +0 -1
  325. package/dist/drafts/draft10/data-streams.js +0 -307
  326. package/dist/drafts/draft10/data-streams.js.map +0 -1
  327. package/dist/drafts/draft10/index.d.ts +0 -9
  328. package/dist/drafts/draft10/index.d.ts.map +0 -1
  329. package/dist/drafts/draft10/index.js +0 -7
  330. package/dist/drafts/draft10/index.js.map +0 -1
  331. package/dist/drafts/draft10/messages.d.ts +0 -34
  332. package/dist/drafts/draft10/messages.d.ts.map +0 -1
  333. package/dist/drafts/draft10/messages.js +0 -66
  334. package/dist/drafts/draft10/messages.js.map +0 -1
  335. package/dist/drafts/draft10/rules.d.ts +0 -8
  336. package/dist/drafts/draft10/rules.d.ts.map +0 -1
  337. package/dist/drafts/draft10/rules.js +0 -83
  338. package/dist/drafts/draft10/rules.js.map +0 -1
  339. package/dist/drafts/draft10/session-fsm.d.ts +0 -47
  340. package/dist/drafts/draft10/session-fsm.d.ts.map +0 -1
  341. package/dist/drafts/draft10/session-fsm.js +0 -483
  342. package/dist/drafts/draft10/session-fsm.js.map +0 -1
  343. package/dist/drafts/draft10/session.d.ts +0 -5
  344. package/dist/drafts/draft10/session.d.ts.map +0 -1
  345. package/dist/drafts/draft10/session.js +0 -5
  346. package/dist/drafts/draft10/session.js.map +0 -1
  347. package/dist/drafts/draft10/types.d.ts +0 -268
  348. package/dist/drafts/draft10/types.d.ts.map +0 -1
  349. package/dist/drafts/draft10/types.js +0 -4
  350. package/dist/drafts/draft10/types.js.map +0 -1
  351. package/dist/drafts/draft11/codec.d.ts +0 -25
  352. package/dist/drafts/draft11/codec.d.ts.map +0 -1
  353. package/dist/drafts/draft11/codec.js +0 -775
  354. package/dist/drafts/draft11/codec.js.map +0 -1
  355. package/dist/drafts/draft11/data-streams.d.ts +0 -10
  356. package/dist/drafts/draft11/data-streams.d.ts.map +0 -1
  357. package/dist/drafts/draft11/data-streams.js +0 -253
  358. package/dist/drafts/draft11/data-streams.js.map +0 -1
  359. package/dist/drafts/draft11/index.d.ts +0 -9
  360. package/dist/drafts/draft11/index.d.ts.map +0 -1
  361. package/dist/drafts/draft11/index.js +0 -7
  362. package/dist/drafts/draft11/index.js.map +0 -1
  363. package/dist/drafts/draft11/messages.d.ts +0 -33
  364. package/dist/drafts/draft11/messages.d.ts.map +0 -1
  365. package/dist/drafts/draft11/messages.js +0 -65
  366. package/dist/drafts/draft11/messages.js.map +0 -1
  367. package/dist/drafts/draft11/rules.d.ts +0 -8
  368. package/dist/drafts/draft11/rules.d.ts.map +0 -1
  369. package/dist/drafts/draft11/rules.js +0 -88
  370. package/dist/drafts/draft11/rules.js.map +0 -1
  371. package/dist/drafts/draft11/session-fsm.d.ts +0 -52
  372. package/dist/drafts/draft11/session-fsm.d.ts.map +0 -1
  373. package/dist/drafts/draft11/session-fsm.js +0 -530
  374. package/dist/drafts/draft11/session-fsm.js.map +0 -1
  375. package/dist/drafts/draft11/session.d.ts +0 -5
  376. package/dist/drafts/draft11/session.d.ts.map +0 -1
  377. package/dist/drafts/draft11/session.js +0 -5
  378. package/dist/drafts/draft11/session.js.map +0 -1
  379. package/dist/drafts/draft11/types.d.ts +0 -266
  380. package/dist/drafts/draft11/types.d.ts.map +0 -1
  381. package/dist/drafts/draft11/types.js +0 -4
  382. package/dist/drafts/draft11/types.js.map +0 -1
  383. package/dist/drafts/draft12/codec.d.ts +0 -27
  384. package/dist/drafts/draft12/codec.d.ts.map +0 -1
  385. package/dist/drafts/draft12/codec.js +0 -918
  386. package/dist/drafts/draft12/codec.js.map +0 -1
  387. package/dist/drafts/draft12/data-streams.d.ts +0 -10
  388. package/dist/drafts/draft12/data-streams.d.ts.map +0 -1
  389. package/dist/drafts/draft12/data-streams.js +0 -254
  390. package/dist/drafts/draft12/data-streams.js.map +0 -1
  391. package/dist/drafts/draft12/index.d.ts +0 -9
  392. package/dist/drafts/draft12/index.d.ts.map +0 -1
  393. package/dist/drafts/draft12/index.js +0 -7
  394. package/dist/drafts/draft12/index.js.map +0 -1
  395. package/dist/drafts/draft12/messages.d.ts +0 -37
  396. package/dist/drafts/draft12/messages.d.ts.map +0 -1
  397. package/dist/drafts/draft12/messages.js +0 -77
  398. package/dist/drafts/draft12/messages.js.map +0 -1
  399. package/dist/drafts/draft12/rules.d.ts +0 -8
  400. package/dist/drafts/draft12/rules.d.ts.map +0 -1
  401. package/dist/drafts/draft12/rules.js +0 -94
  402. package/dist/drafts/draft12/rules.js.map +0 -1
  403. package/dist/drafts/draft12/session-fsm.d.ts +0 -55
  404. package/dist/drafts/draft12/session-fsm.d.ts.map +0 -1
  405. package/dist/drafts/draft12/session-fsm.js +0 -569
  406. package/dist/drafts/draft12/session-fsm.js.map +0 -1
  407. package/dist/drafts/draft12/session.d.ts +0 -5
  408. package/dist/drafts/draft12/session.d.ts.map +0 -1
  409. package/dist/drafts/draft12/session.js +0 -5
  410. package/dist/drafts/draft12/session.js.map +0 -1
  411. package/dist/drafts/draft12/types.d.ts +0 -294
  412. package/dist/drafts/draft12/types.d.ts.map +0 -1
  413. package/dist/drafts/draft12/types.js +0 -4
  414. package/dist/drafts/draft12/types.js.map +0 -1
  415. package/dist/drafts/draft13/codec.d.ts +0 -27
  416. package/dist/drafts/draft13/codec.d.ts.map +0 -1
  417. package/dist/drafts/draft13/codec.js +0 -1000
  418. package/dist/drafts/draft13/codec.js.map +0 -1
  419. package/dist/drafts/draft13/data-streams.d.ts +0 -10
  420. package/dist/drafts/draft13/data-streams.d.ts.map +0 -1
  421. package/dist/drafts/draft13/data-streams.js +0 -254
  422. package/dist/drafts/draft13/data-streams.js.map +0 -1
  423. package/dist/drafts/draft13/index.d.ts +0 -9
  424. package/dist/drafts/draft13/index.d.ts.map +0 -1
  425. package/dist/drafts/draft13/index.js +0 -7
  426. package/dist/drafts/draft13/index.js.map +0 -1
  427. package/dist/drafts/draft13/messages.d.ts +0 -38
  428. package/dist/drafts/draft13/messages.d.ts.map +0 -1
  429. package/dist/drafts/draft13/messages.js +0 -79
  430. package/dist/drafts/draft13/messages.js.map +0 -1
  431. package/dist/drafts/draft13/rules.d.ts +0 -8
  432. package/dist/drafts/draft13/rules.d.ts.map +0 -1
  433. package/dist/drafts/draft13/rules.js +0 -96
  434. package/dist/drafts/draft13/rules.js.map +0 -1
  435. package/dist/drafts/draft13/session-fsm.d.ts +0 -56
  436. package/dist/drafts/draft13/session-fsm.d.ts.map +0 -1
  437. package/dist/drafts/draft13/session-fsm.js +0 -581
  438. package/dist/drafts/draft13/session-fsm.js.map +0 -1
  439. package/dist/drafts/draft13/session.d.ts +0 -5
  440. package/dist/drafts/draft13/session.d.ts.map +0 -1
  441. package/dist/drafts/draft13/session.js +0 -5
  442. package/dist/drafts/draft13/session.js.map +0 -1
  443. package/dist/drafts/draft13/types.d.ts +0 -310
  444. package/dist/drafts/draft13/types.d.ts.map +0 -1
  445. package/dist/drafts/draft13/types.js +0 -4
  446. package/dist/drafts/draft13/types.js.map +0 -1
  447. package/dist/drafts/draft14/codec.d.ts.map +0 -1
  448. package/dist/drafts/draft14/codec.js +0 -752
  449. package/dist/drafts/draft14/codec.js.map +0 -1
  450. package/dist/drafts/draft14/data-streams.d.ts +0 -56
  451. package/dist/drafts/draft14/data-streams.d.ts.map +0 -1
  452. package/dist/drafts/draft14/data-streams.js +0 -729
  453. package/dist/drafts/draft14/data-streams.js.map +0 -1
  454. package/dist/drafts/draft14/index.d.ts +0 -9
  455. package/dist/drafts/draft14/index.d.ts.map +0 -1
  456. package/dist/drafts/draft14/index.js +0 -7
  457. package/dist/drafts/draft14/index.js.map +0 -1
  458. package/dist/drafts/draft14/messages.d.ts +0 -36
  459. package/dist/drafts/draft14/messages.d.ts.map +0 -1
  460. package/dist/drafts/draft14/messages.js +0 -71
  461. package/dist/drafts/draft14/messages.js.map +0 -1
  462. package/dist/drafts/draft14/rules.d.ts +0 -8
  463. package/dist/drafts/draft14/rules.d.ts.map +0 -1
  464. package/dist/drafts/draft14/rules.js +0 -101
  465. package/dist/drafts/draft14/rules.js.map +0 -1
  466. package/dist/drafts/draft14/session-fsm.d.ts +0 -58
  467. package/dist/drafts/draft14/session-fsm.d.ts.map +0 -1
  468. package/dist/drafts/draft14/session-fsm.js +0 -648
  469. package/dist/drafts/draft14/session-fsm.js.map +0 -1
  470. package/dist/drafts/draft14/session.d.ts +0 -5
  471. package/dist/drafts/draft14/session.d.ts.map +0 -1
  472. package/dist/drafts/draft14/session.js +0 -5
  473. package/dist/drafts/draft14/session.js.map +0 -1
  474. package/dist/drafts/draft14/types.d.ts +0 -263
  475. package/dist/drafts/draft14/types.d.ts.map +0 -1
  476. package/dist/drafts/draft14/types.js +0 -4
  477. package/dist/drafts/draft14/types.js.map +0 -1
  478. package/dist/drafts/draft15/codec.d.ts.map +0 -1
  479. package/dist/drafts/draft15/codec.js +0 -742
  480. package/dist/drafts/draft15/codec.js.map +0 -1
  481. package/dist/drafts/draft15/data-streams.d.ts +0 -45
  482. package/dist/drafts/draft15/data-streams.d.ts.map +0 -1
  483. package/dist/drafts/draft15/data-streams.js +0 -675
  484. package/dist/drafts/draft15/data-streams.js.map +0 -1
  485. package/dist/drafts/draft15/index.d.ts +0 -9
  486. package/dist/drafts/draft15/index.d.ts.map +0 -1
  487. package/dist/drafts/draft15/index.js +0 -7
  488. package/dist/drafts/draft15/index.js.map +0 -1
  489. package/dist/drafts/draft15/messages.d.ts +0 -31
  490. package/dist/drafts/draft15/messages.d.ts.map +0 -1
  491. package/dist/drafts/draft15/messages.js +0 -59
  492. package/dist/drafts/draft15/messages.js.map +0 -1
  493. package/dist/drafts/draft15/rules.d.ts +0 -8
  494. package/dist/drafts/draft15/rules.d.ts.map +0 -1
  495. package/dist/drafts/draft15/rules.js +0 -83
  496. package/dist/drafts/draft15/rules.js.map +0 -1
  497. package/dist/drafts/draft15/session-fsm.d.ts +0 -48
  498. package/dist/drafts/draft15/session-fsm.d.ts.map +0 -1
  499. package/dist/drafts/draft15/session-fsm.js +0 -479
  500. package/dist/drafts/draft15/session-fsm.js.map +0 -1
  501. package/dist/drafts/draft15/session.d.ts +0 -5
  502. package/dist/drafts/draft15/session.d.ts.map +0 -1
  503. package/dist/drafts/draft15/session.js +0 -5
  504. package/dist/drafts/draft15/session.js.map +0 -1
  505. package/dist/drafts/draft15/types.d.ts +0 -232
  506. package/dist/drafts/draft15/types.d.ts.map +0 -1
  507. package/dist/drafts/draft15/types.js +0 -4
  508. package/dist/drafts/draft15/types.js.map +0 -1
  509. package/dist/drafts/draft16/codec.d.ts +0 -29
  510. package/dist/drafts/draft16/codec.d.ts.map +0 -1
  511. package/dist/drafts/draft16/codec.js +0 -747
  512. package/dist/drafts/draft16/codec.js.map +0 -1
  513. package/dist/drafts/draft16/data-streams.d.ts +0 -34
  514. package/dist/drafts/draft16/data-streams.d.ts.map +0 -1
  515. package/dist/drafts/draft16/data-streams.js +0 -667
  516. package/dist/drafts/draft16/data-streams.js.map +0 -1
  517. package/dist/drafts/draft16/index.d.ts +0 -9
  518. package/dist/drafts/draft16/index.d.ts.map +0 -1
  519. package/dist/drafts/draft16/index.js +0 -7
  520. package/dist/drafts/draft16/index.js.map +0 -1
  521. package/dist/drafts/draft16/messages.d.ts +0 -32
  522. package/dist/drafts/draft16/messages.d.ts.map +0 -1
  523. package/dist/drafts/draft16/messages.js +0 -62
  524. package/dist/drafts/draft16/messages.js.map +0 -1
  525. package/dist/drafts/draft16/rules.d.ts +0 -8
  526. package/dist/drafts/draft16/rules.d.ts.map +0 -1
  527. package/dist/drafts/draft16/rules.js +0 -84
  528. package/dist/drafts/draft16/rules.js.map +0 -1
  529. package/dist/drafts/draft16/session-fsm.d.ts +0 -48
  530. package/dist/drafts/draft16/session-fsm.d.ts.map +0 -1
  531. package/dist/drafts/draft16/session-fsm.js +0 -474
  532. package/dist/drafts/draft16/session-fsm.js.map +0 -1
  533. package/dist/drafts/draft16/session.d.ts +0 -5
  534. package/dist/drafts/draft16/session.d.ts.map +0 -1
  535. package/dist/drafts/draft16/session.js +0 -5
  536. package/dist/drafts/draft16/session.js.map +0 -1
  537. package/dist/drafts/draft16/types.d.ts +0 -238
  538. package/dist/drafts/draft16/types.d.ts.map +0 -1
  539. package/dist/drafts/draft16/types.js +0 -4
  540. package/dist/drafts/draft16/types.js.map +0 -1
  541. package/dist/drafts/draft17/codec.d.ts +0 -29
  542. package/dist/drafts/draft17/codec.d.ts.map +0 -1
  543. package/dist/drafts/draft17/codec.js +0 -799
  544. package/dist/drafts/draft17/codec.js.map +0 -1
  545. package/dist/drafts/draft17/data-streams.d.ts +0 -13
  546. package/dist/drafts/draft17/data-streams.d.ts.map +0 -1
  547. package/dist/drafts/draft17/data-streams.js +0 -633
  548. package/dist/drafts/draft17/data-streams.js.map +0 -1
  549. package/dist/drafts/draft17/index.d.ts +0 -8
  550. package/dist/drafts/draft17/index.d.ts.map +0 -1
  551. package/dist/drafts/draft17/index.js +0 -6
  552. package/dist/drafts/draft17/index.js.map +0 -1
  553. package/dist/drafts/draft17/messages.d.ts +0 -25
  554. package/dist/drafts/draft17/messages.d.ts.map +0 -1
  555. package/dist/drafts/draft17/messages.js +0 -48
  556. package/dist/drafts/draft17/messages.js.map +0 -1
  557. package/dist/drafts/draft17/rules.d.ts +0 -8
  558. package/dist/drafts/draft17/rules.d.ts.map +0 -1
  559. package/dist/drafts/draft17/rules.js +0 -71
  560. package/dist/drafts/draft17/rules.js.map +0 -1
  561. package/dist/drafts/draft17/session-fsm.d.ts +0 -45
  562. package/dist/drafts/draft17/session-fsm.d.ts.map +0 -1
  563. package/dist/drafts/draft17/session-fsm.js +0 -328
  564. package/dist/drafts/draft17/session-fsm.js.map +0 -1
  565. package/dist/drafts/draft17/session.d.ts +0 -5
  566. package/dist/drafts/draft17/session.d.ts.map +0 -1
  567. package/dist/drafts/draft17/session.js +0 -6
  568. package/dist/drafts/draft17/session.js.map +0 -1
  569. package/dist/drafts/draft17/types.d.ts +0 -219
  570. package/dist/drafts/draft17/types.d.ts.map +0 -1
  571. package/dist/drafts/draft17/types.js +0 -3
  572. package/dist/drafts/draft17/types.js.map +0 -1
  573. package/dist/index.d.ts.map +0 -1
  574. package/dist/index.js.map +0 -1
  575. package/dist/session.d.ts.map +0 -1
  576. package/dist/session.js.map +0 -1
@@ -1,722 +0,0 @@
1
- import { BufferReader } from "../../core/buffer-reader.js";
2
- import { BufferWriter } from "../../core/buffer-writer.js";
3
- import { DecodeError } from "../../core/types.js";
4
- import { MESSAGE_TYPE_IDS } from "./messages.js";
5
- import { decodeVarInt, encodeVarInt } from "./varint.js";
6
- // --- FilterType mapping ---
7
- const FILTER_TYPE_TO_WIRE = {
8
- latest_group: 1n,
9
- latest_object: 2n,
10
- absolute_start: 3n,
11
- absolute_range: 4n,
12
- };
13
- const WIRE_TO_FILTER_TYPE = new Map([
14
- [1n, "latest_group"],
15
- [2n, "latest_object"],
16
- [3n, "absolute_start"],
17
- [4n, "absolute_range"],
18
- ]);
19
- // --- GroupOrderValue mapping ---
20
- const GROUP_ORDER_TO_WIRE = {
21
- original: 0,
22
- ascending: 1,
23
- descending: 2,
24
- };
25
- const WIRE_TO_GROUP_ORDER = new Map([
26
- [0, "original"],
27
- [1, "ascending"],
28
- [2, "descending"],
29
- ]);
30
- // --- Encode helpers ---
31
- function writeGroupOrder(writer, value) {
32
- const wire = GROUP_ORDER_TO_WIRE[value];
33
- writer.writeUint8(wire);
34
- }
35
- function readGroupOrder(reader) {
36
- const wire = reader.readUint8();
37
- const value = WIRE_TO_GROUP_ORDER.get(wire);
38
- if (value === undefined) {
39
- throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid group order value: ${wire}`, reader.offset - 1);
40
- }
41
- return value;
42
- }
43
- // Data stream type IDs that NEVER appear as control messages.
44
- // Note: 0x04 (stream_header_subgroup) excluded — shares ID with subscribe_ok.
45
- // Note: 0x05 (fetch_header) excluded — shares ID with subscribe_error.
46
- // Callers must use decodeSubgroupStream/decodeFetchStream directly.
47
- const DATA_STREAM_TYPE_IDS = new Set([
48
- MESSAGE_TYPE_IDS.object_datagram,
49
- ]);
50
- // --- Encode functions for each message type (payload only, no type ID) ---
51
- function encodeClientSetup(msg, writer) {
52
- writer.writeVarInt(msg.supportedVersions.length);
53
- for (const version of msg.supportedVersions) {
54
- writer.writeVarInt(version);
55
- }
56
- writer.writeParameters(msg.parameters);
57
- }
58
- function encodeServerSetup(msg, writer) {
59
- writer.writeVarInt(msg.selectedVersion);
60
- writer.writeParameters(msg.parameters);
61
- }
62
- function encodeSubscribe(msg, writer) {
63
- writer.writeVarInt(msg.subscribeId);
64
- writer.writeVarInt(msg.trackAlias);
65
- writer.writeTuple(msg.trackNamespace);
66
- writer.writeString(msg.trackName);
67
- writer.writeUint8(msg.subscriberPriority);
68
- writeGroupOrder(writer, msg.groupOrder);
69
- writer.writeVarInt(FILTER_TYPE_TO_WIRE[msg.filterType]);
70
- if (msg.filterType === "absolute_start" || msg.filterType === "absolute_range") {
71
- writer.writeVarInt(msg.startGroup);
72
- writer.writeVarInt(msg.startObject);
73
- }
74
- if (msg.filterType === "absolute_range") {
75
- writer.writeVarInt(msg.endGroup);
76
- writer.writeVarInt(msg.endObject);
77
- }
78
- writer.writeParameters(msg.parameters);
79
- }
80
- function encodeSubscribeOk(msg, writer) {
81
- writer.writeVarInt(msg.subscribeId);
82
- writer.writeVarInt(msg.expires);
83
- writeGroupOrder(writer, msg.groupOrder);
84
- writer.writeUint8(msg.contentExists ? 1 : 0);
85
- if (msg.contentExists) {
86
- writer.writeVarInt(msg.largestGroupId);
87
- writer.writeVarInt(msg.largestObjectId);
88
- }
89
- writer.writeParameters(msg.parameters);
90
- }
91
- function encodeSubscribeError(msg, writer) {
92
- writer.writeVarInt(msg.subscribeId);
93
- writer.writeVarInt(msg.errorCode);
94
- writer.writeString(msg.reasonPhrase);
95
- writer.writeVarInt(msg.trackAlias);
96
- }
97
- function encodeSubscribeDone(msg, writer) {
98
- writer.writeVarInt(msg.subscribeId);
99
- writer.writeVarInt(msg.statusCode);
100
- writer.writeString(msg.reasonPhrase);
101
- writer.writeUint8(msg.contentExists ? 1 : 0);
102
- if (msg.contentExists) {
103
- writer.writeVarInt(msg.finalGroupId);
104
- writer.writeVarInt(msg.finalObjectId);
105
- }
106
- }
107
- function encodeSubscribeUpdate(msg, writer) {
108
- writer.writeVarInt(msg.subscribeId);
109
- writer.writeVarInt(msg.startGroup);
110
- writer.writeVarInt(msg.startObject);
111
- writer.writeVarInt(msg.endGroup);
112
- writer.writeVarInt(msg.endObject);
113
- writer.writeUint8(msg.subscriberPriority);
114
- writer.writeParameters(msg.parameters);
115
- }
116
- function encodeUnsubscribe(msg, writer) {
117
- writer.writeVarInt(msg.subscribeId);
118
- }
119
- function encodeAnnounce(msg, writer) {
120
- writer.writeTuple(msg.trackNamespace);
121
- writer.writeParameters(msg.parameters);
122
- }
123
- function encodeAnnounceOk(msg, writer) {
124
- writer.writeTuple(msg.trackNamespace);
125
- }
126
- function encodeAnnounceError(msg, writer) {
127
- writer.writeTuple(msg.trackNamespace);
128
- writer.writeVarInt(msg.errorCode);
129
- writer.writeString(msg.reasonPhrase);
130
- }
131
- function encodeAnnounceCancel(msg, writer) {
132
- writer.writeTuple(msg.trackNamespace);
133
- writer.writeVarInt(msg.errorCode);
134
- writer.writeString(msg.reasonPhrase);
135
- }
136
- function encodeUnannounce(msg, writer) {
137
- writer.writeTuple(msg.trackNamespace);
138
- }
139
- function encodeTrackStatusRequest(msg, writer) {
140
- writer.writeTuple(msg.trackNamespace);
141
- writer.writeString(msg.trackName);
142
- }
143
- function encodeTrackStatus(msg, writer) {
144
- writer.writeTuple(msg.trackNamespace);
145
- writer.writeString(msg.trackName);
146
- writer.writeVarInt(msg.statusCode);
147
- writer.writeVarInt(msg.lastGroupId);
148
- writer.writeVarInt(msg.lastObjectId);
149
- }
150
- function encodeGoAway(msg, writer) {
151
- writer.writeString(msg.newSessionUri);
152
- }
153
- function encodeSubscribeAnnounces(msg, writer) {
154
- writer.writeTuple(msg.trackNamespace);
155
- writer.writeParameters(msg.parameters);
156
- }
157
- function encodeSubscribeAnnouncesOk(msg, writer) {
158
- writer.writeTuple(msg.trackNamespace);
159
- }
160
- function encodeSubscribeAnnouncesError(msg, writer) {
161
- writer.writeTuple(msg.trackNamespace);
162
- writer.writeVarInt(msg.errorCode);
163
- writer.writeString(msg.reasonPhrase);
164
- }
165
- function encodeUnsubscribeAnnounces(msg, writer) {
166
- writer.writeTuple(msg.trackNamespace);
167
- }
168
- function encodeMaxSubscribeId(msg, writer) {
169
- writer.writeVarInt(msg.subscribeId);
170
- }
171
- function encodeFetch(msg, writer) {
172
- writer.writeVarInt(msg.subscribeId);
173
- writer.writeTuple(msg.trackNamespace);
174
- writer.writeString(msg.trackName);
175
- writer.writeUint8(msg.subscriberPriority);
176
- writeGroupOrder(writer, msg.groupOrder);
177
- writer.writeVarInt(msg.startGroup);
178
- writer.writeVarInt(msg.startObject);
179
- writer.writeVarInt(msg.endGroup);
180
- writer.writeVarInt(msg.endObject);
181
- writer.writeParameters(msg.parameters);
182
- }
183
- function encodeFetchOk(msg, writer) {
184
- writer.writeVarInt(msg.subscribeId);
185
- writeGroupOrder(writer, msg.groupOrder);
186
- writer.writeUint8(msg.endOfTrack ? 1 : 0);
187
- writer.writeVarInt(msg.largestGroupId);
188
- writer.writeVarInt(msg.largestObjectId);
189
- writer.writeParameters(msg.parameters);
190
- }
191
- function encodeFetchError(msg, writer) {
192
- writer.writeVarInt(msg.subscribeId);
193
- writer.writeVarInt(msg.errorCode);
194
- writer.writeString(msg.reasonPhrase);
195
- }
196
- function encodeFetchCancel(msg, writer) {
197
- writer.writeVarInt(msg.subscribeId);
198
- }
199
- // Data stream encoders (no type+length framing)
200
- function encodeObjectPayload(msg, writer) {
201
- if (msg.payload.byteLength === 0) {
202
- writer.writeVarInt(0); // payloadLength = 0 signals objectStatus follows
203
- writer.writeVarInt(msg.objectStatus ?? 0);
204
- }
205
- else {
206
- writer.writeVarInt(msg.payload.byteLength);
207
- writer.writeBytes(msg.payload);
208
- }
209
- }
210
- function encodeObjectDatagram(msg, writer) {
211
- writer.writeVarInt(MESSAGE_TYPE_IDS.object_datagram);
212
- writer.writeVarInt(msg.trackAlias);
213
- writer.writeVarInt(msg.groupId);
214
- writer.writeVarInt(msg.objectId);
215
- writer.writeUint8(msg.publisherPriority);
216
- encodeObjectPayload(msg, writer);
217
- }
218
- // --- Encode dispatch ---
219
- // Control message encoders (payload-only, framing added by encodeMessageImpl)
220
- const controlEncoders = {
221
- client_setup: encodeClientSetup,
222
- server_setup: encodeServerSetup,
223
- subscribe: encodeSubscribe,
224
- subscribe_ok: encodeSubscribeOk,
225
- subscribe_error: encodeSubscribeError,
226
- subscribe_done: encodeSubscribeDone,
227
- subscribe_update: encodeSubscribeUpdate,
228
- unsubscribe: encodeUnsubscribe,
229
- announce: encodeAnnounce,
230
- announce_ok: encodeAnnounceOk,
231
- announce_error: encodeAnnounceError,
232
- announce_cancel: encodeAnnounceCancel,
233
- unannounce: encodeUnannounce,
234
- track_status_request: encodeTrackStatusRequest,
235
- track_status: encodeTrackStatus,
236
- goaway: encodeGoAway,
237
- subscribe_announces: encodeSubscribeAnnounces,
238
- subscribe_announces_ok: encodeSubscribeAnnouncesOk,
239
- subscribe_announces_error: encodeSubscribeAnnouncesError,
240
- unsubscribe_announces: encodeUnsubscribeAnnounces,
241
- max_subscribe_id: encodeMaxSubscribeId,
242
- fetch: encodeFetch,
243
- fetch_ok: encodeFetchOk,
244
- fetch_error: encodeFetchError,
245
- fetch_cancel: encodeFetchCancel,
246
- };
247
- // Data stream encoders (write type + fields directly, no length framing)
248
- const dataStreamEncoders = {
249
- object_datagram: encodeObjectDatagram,
250
- };
251
- // --- Decode functions for each message type ---
252
- function decodeClientSetup(reader) {
253
- const numVersions = reader.readVarInt();
254
- if (numVersions === 0n) {
255
- throw new DecodeError("CONSTRAINT_VIOLATION", "supported_versions must not be empty", reader.offset);
256
- }
257
- const supportedVersions = [];
258
- for (let i = 0n; i < numVersions; i++) {
259
- supportedVersions.push(reader.readVarInt());
260
- }
261
- const parameters = reader.readParameters();
262
- return { type: "client_setup", supportedVersions, parameters };
263
- }
264
- function decodeServerSetup(reader) {
265
- const selectedVersion = reader.readVarInt();
266
- const parameters = reader.readParameters();
267
- return { type: "server_setup", selectedVersion, parameters };
268
- }
269
- function decodeSubscribe(reader) {
270
- const subscribeId = reader.readVarInt();
271
- const trackAlias = reader.readVarInt();
272
- const trackNamespace = reader.readTuple();
273
- const trackName = reader.readString();
274
- const subscriberPriority = reader.readUint8();
275
- const groupOrder = readGroupOrder(reader);
276
- const filterTypeWire = reader.readVarInt();
277
- const filterType = WIRE_TO_FILTER_TYPE.get(filterTypeWire);
278
- if (filterType === undefined) {
279
- throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid filter type: ${filterTypeWire}`, reader.offset);
280
- }
281
- const base = {
282
- type: "subscribe",
283
- subscribeId,
284
- trackAlias,
285
- trackNamespace,
286
- trackName,
287
- subscriberPriority,
288
- groupOrder,
289
- filterType,
290
- parameters: undefined,
291
- };
292
- if (filterType === "absolute_start") {
293
- const startGroup = reader.readVarInt();
294
- const startObject = reader.readVarInt();
295
- base.parameters = reader.readParameters();
296
- return { ...base, startGroup, startObject };
297
- }
298
- if (filterType === "absolute_range") {
299
- const startGroup = reader.readVarInt();
300
- const startObject = reader.readVarInt();
301
- const endGroup = reader.readVarInt();
302
- const endObject = reader.readVarInt();
303
- base.parameters = reader.readParameters();
304
- return { ...base, startGroup, startObject, endGroup, endObject };
305
- }
306
- base.parameters = reader.readParameters();
307
- return base;
308
- }
309
- function decodeSubscribeOk(reader) {
310
- const subscribeId = reader.readVarInt();
311
- const expires = reader.readVarInt();
312
- const groupOrder = readGroupOrder(reader);
313
- const contentExistsWire = reader.readUint8();
314
- const contentExists = contentExistsWire !== 0;
315
- if (contentExists) {
316
- const largestGroupId = reader.readVarInt();
317
- const largestObjectId = reader.readVarInt();
318
- const parameters = reader.readParameters();
319
- return {
320
- type: "subscribe_ok",
321
- subscribeId,
322
- expires,
323
- groupOrder,
324
- contentExists,
325
- largestGroupId,
326
- largestObjectId,
327
- parameters,
328
- };
329
- }
330
- const parameters = reader.readParameters();
331
- return {
332
- type: "subscribe_ok",
333
- subscribeId,
334
- expires,
335
- groupOrder,
336
- contentExists,
337
- parameters,
338
- };
339
- }
340
- function decodeSubscribeError(reader) {
341
- const subscribeId = reader.readVarInt();
342
- const errorCode = reader.readVarInt();
343
- const reasonPhrase = reader.readString();
344
- const trackAlias = reader.readVarInt();
345
- return { type: "subscribe_error", subscribeId, errorCode, reasonPhrase, trackAlias };
346
- }
347
- function decodeSubscribeDone(reader) {
348
- const subscribeId = reader.readVarInt();
349
- const statusCode = reader.readVarInt();
350
- const reasonPhrase = reader.readString();
351
- const contentExistsWire = reader.readUint8();
352
- const contentExists = contentExistsWire !== 0;
353
- if (contentExists) {
354
- const finalGroupId = reader.readVarInt();
355
- const finalObjectId = reader.readVarInt();
356
- return {
357
- type: "subscribe_done",
358
- subscribeId,
359
- statusCode,
360
- reasonPhrase,
361
- contentExists,
362
- finalGroupId,
363
- finalObjectId,
364
- };
365
- }
366
- return { type: "subscribe_done", subscribeId, statusCode, reasonPhrase, contentExists };
367
- }
368
- function decodeSubscribeUpdate(reader) {
369
- const subscribeId = reader.readVarInt();
370
- const startGroup = reader.readVarInt();
371
- const startObject = reader.readVarInt();
372
- const endGroup = reader.readVarInt();
373
- const endObject = reader.readVarInt();
374
- const subscriberPriority = reader.readUint8();
375
- const parameters = reader.readParameters();
376
- return {
377
- type: "subscribe_update",
378
- subscribeId,
379
- startGroup,
380
- startObject,
381
- endGroup,
382
- endObject,
383
- subscriberPriority,
384
- parameters,
385
- };
386
- }
387
- function decodeUnsubscribe(reader) {
388
- const subscribeId = reader.readVarInt();
389
- return { type: "unsubscribe", subscribeId };
390
- }
391
- function decodeAnnounce(reader) {
392
- const trackNamespace = reader.readTuple();
393
- const parameters = reader.readParameters();
394
- return { type: "announce", trackNamespace, parameters };
395
- }
396
- function decodeAnnounceOk(reader) {
397
- const trackNamespace = reader.readTuple();
398
- return { type: "announce_ok", trackNamespace };
399
- }
400
- function decodeAnnounceError(reader) {
401
- const trackNamespace = reader.readTuple();
402
- const errorCode = reader.readVarInt();
403
- const reasonPhrase = reader.readString();
404
- return { type: "announce_error", trackNamespace, errorCode, reasonPhrase };
405
- }
406
- function decodeAnnounceCancel(reader) {
407
- const trackNamespace = reader.readTuple();
408
- const errorCode = reader.readVarInt();
409
- const reasonPhrase = reader.readString();
410
- return { type: "announce_cancel", trackNamespace, errorCode, reasonPhrase };
411
- }
412
- function decodeUnannounce(reader) {
413
- const trackNamespace = reader.readTuple();
414
- return { type: "unannounce", trackNamespace };
415
- }
416
- function decodeTrackStatusRequest(reader) {
417
- const trackNamespace = reader.readTuple();
418
- const trackName = reader.readString();
419
- return { type: "track_status_request", trackNamespace, trackName };
420
- }
421
- function decodeTrackStatus(reader) {
422
- const trackNamespace = reader.readTuple();
423
- const trackName = reader.readString();
424
- const statusCode = reader.readVarInt();
425
- const lastGroupId = reader.readVarInt();
426
- const lastObjectId = reader.readVarInt();
427
- return { type: "track_status", trackNamespace, trackName, statusCode, lastGroupId, lastObjectId };
428
- }
429
- function decodeGoAway(reader) {
430
- const newSessionUri = reader.readString();
431
- return { type: "goaway", newSessionUri };
432
- }
433
- function decodeSubscribeAnnounces(reader) {
434
- const trackNamespace = reader.readTuple();
435
- const parameters = reader.readParameters();
436
- return { type: "subscribe_announces", trackNamespace, parameters };
437
- }
438
- function decodeSubscribeAnnouncesOk(reader) {
439
- const trackNamespace = reader.readTuple();
440
- return { type: "subscribe_announces_ok", trackNamespace };
441
- }
442
- function decodeSubscribeAnnouncesError(reader) {
443
- const trackNamespace = reader.readTuple();
444
- const errorCode = reader.readVarInt();
445
- const reasonPhrase = reader.readString();
446
- return { type: "subscribe_announces_error", trackNamespace, errorCode, reasonPhrase };
447
- }
448
- function decodeUnsubscribeAnnounces(reader) {
449
- const trackNamespace = reader.readTuple();
450
- return { type: "unsubscribe_announces", trackNamespace };
451
- }
452
- function decodeMaxSubscribeId(reader) {
453
- const subscribeId = reader.readVarInt();
454
- return { type: "max_subscribe_id", subscribeId };
455
- }
456
- function decodeFetch(reader) {
457
- const subscribeId = reader.readVarInt();
458
- const trackNamespace = reader.readTuple();
459
- const trackName = reader.readString();
460
- const subscriberPriority = reader.readUint8();
461
- const groupOrder = readGroupOrder(reader);
462
- const startGroup = reader.readVarInt();
463
- const startObject = reader.readVarInt();
464
- const endGroup = reader.readVarInt();
465
- const endObject = reader.readVarInt();
466
- const parameters = reader.readParameters();
467
- return {
468
- type: "fetch",
469
- subscribeId,
470
- trackNamespace,
471
- trackName,
472
- subscriberPriority,
473
- groupOrder,
474
- startGroup,
475
- startObject,
476
- endGroup,
477
- endObject,
478
- parameters,
479
- };
480
- }
481
- function decodeFetchOk(reader) {
482
- const subscribeId = reader.readVarInt();
483
- const groupOrder = readGroupOrder(reader);
484
- const endOfTrackWire = reader.readUint8();
485
- const endOfTrack = endOfTrackWire !== 0;
486
- const largestGroupId = reader.readVarInt();
487
- const largestObjectId = reader.readVarInt();
488
- const parameters = reader.readParameters();
489
- return {
490
- type: "fetch_ok",
491
- subscribeId,
492
- groupOrder,
493
- endOfTrack,
494
- largestGroupId,
495
- largestObjectId,
496
- parameters,
497
- };
498
- }
499
- function decodeFetchError(reader) {
500
- const subscribeId = reader.readVarInt();
501
- const errorCode = reader.readVarInt();
502
- const reasonPhrase = reader.readString();
503
- return { type: "fetch_error", subscribeId, errorCode, reasonPhrase };
504
- }
505
- function decodeFetchCancel(reader) {
506
- const subscribeId = reader.readVarInt();
507
- return { type: "fetch_cancel", subscribeId };
508
- }
509
- function decodeObjectDatagram(reader) {
510
- const trackAlias = reader.readVarInt();
511
- const groupId = reader.readVarInt();
512
- const objectId = reader.readVarInt();
513
- const publisherPriority = reader.readUint8();
514
- const payloadLength = Number(reader.readVarInt());
515
- if (payloadLength === 0) {
516
- // Object Status follows when payload length is 0
517
- const objectStatus = reader.remaining > 0 ? Number(reader.readVarInt()) : 0;
518
- return {
519
- type: "object_datagram",
520
- trackAlias,
521
- groupId,
522
- objectId,
523
- publisherPriority,
524
- objectStatus,
525
- payload: new Uint8Array(0),
526
- };
527
- }
528
- const payload = reader.readBytes(payloadLength);
529
- return {
530
- type: "object_datagram",
531
- trackAlias,
532
- groupId,
533
- objectId,
534
- publisherPriority,
535
- payload,
536
- };
537
- }
538
- const controlDecoders = new Map([
539
- [MESSAGE_TYPE_IDS.client_setup, decodeClientSetup],
540
- [MESSAGE_TYPE_IDS.server_setup, decodeServerSetup],
541
- [MESSAGE_TYPE_IDS.subscribe, decodeSubscribe],
542
- [MESSAGE_TYPE_IDS.subscribe_ok, decodeSubscribeOk],
543
- [MESSAGE_TYPE_IDS.subscribe_error, decodeSubscribeError],
544
- [MESSAGE_TYPE_IDS.subscribe_done, decodeSubscribeDone],
545
- [MESSAGE_TYPE_IDS.subscribe_update, decodeSubscribeUpdate],
546
- [MESSAGE_TYPE_IDS.unsubscribe, decodeUnsubscribe],
547
- [MESSAGE_TYPE_IDS.announce, decodeAnnounce],
548
- [MESSAGE_TYPE_IDS.announce_ok, decodeAnnounceOk],
549
- [MESSAGE_TYPE_IDS.announce_error, decodeAnnounceError],
550
- [MESSAGE_TYPE_IDS.announce_cancel, decodeAnnounceCancel],
551
- [MESSAGE_TYPE_IDS.unannounce, decodeUnannounce],
552
- [MESSAGE_TYPE_IDS.track_status_request, decodeTrackStatusRequest],
553
- [MESSAGE_TYPE_IDS.track_status, decodeTrackStatus],
554
- [MESSAGE_TYPE_IDS.goaway, decodeGoAway],
555
- [MESSAGE_TYPE_IDS.subscribe_announces, decodeSubscribeAnnounces],
556
- [MESSAGE_TYPE_IDS.subscribe_announces_ok, decodeSubscribeAnnouncesOk],
557
- [MESSAGE_TYPE_IDS.subscribe_announces_error, decodeSubscribeAnnouncesError],
558
- [MESSAGE_TYPE_IDS.unsubscribe_announces, decodeUnsubscribeAnnounces],
559
- [MESSAGE_TYPE_IDS.max_subscribe_id, decodeMaxSubscribeId],
560
- [MESSAGE_TYPE_IDS.fetch, decodeFetch],
561
- [MESSAGE_TYPE_IDS.fetch_ok, decodeFetchOk],
562
- [MESSAGE_TYPE_IDS.fetch_error, decodeFetchError],
563
- [MESSAGE_TYPE_IDS.fetch_cancel, decodeFetchCancel],
564
- ]);
565
- // Data stream decoders keyed by wire ID (for disambiguation)
566
- const dataStreamDecoders = new Map([
567
- [MESSAGE_TYPE_IDS.object_datagram, decodeObjectDatagram],
568
- ]);
569
- // --- Message type to wire ID mapping ---
570
- const MESSAGE_TYPE_TO_WIRE = {
571
- client_setup: MESSAGE_TYPE_IDS.client_setup,
572
- server_setup: MESSAGE_TYPE_IDS.server_setup,
573
- subscribe: MESSAGE_TYPE_IDS.subscribe,
574
- subscribe_ok: MESSAGE_TYPE_IDS.subscribe_ok,
575
- subscribe_error: MESSAGE_TYPE_IDS.subscribe_error,
576
- subscribe_done: MESSAGE_TYPE_IDS.subscribe_done,
577
- subscribe_update: MESSAGE_TYPE_IDS.subscribe_update,
578
- unsubscribe: MESSAGE_TYPE_IDS.unsubscribe,
579
- announce: MESSAGE_TYPE_IDS.announce,
580
- announce_ok: MESSAGE_TYPE_IDS.announce_ok,
581
- announce_error: MESSAGE_TYPE_IDS.announce_error,
582
- announce_cancel: MESSAGE_TYPE_IDS.announce_cancel,
583
- unannounce: MESSAGE_TYPE_IDS.unannounce,
584
- track_status_request: MESSAGE_TYPE_IDS.track_status_request,
585
- track_status: MESSAGE_TYPE_IDS.track_status,
586
- goaway: MESSAGE_TYPE_IDS.goaway,
587
- subscribe_announces: MESSAGE_TYPE_IDS.subscribe_announces,
588
- subscribe_announces_ok: MESSAGE_TYPE_IDS.subscribe_announces_ok,
589
- subscribe_announces_error: MESSAGE_TYPE_IDS.subscribe_announces_error,
590
- unsubscribe_announces: MESSAGE_TYPE_IDS.unsubscribe_announces,
591
- max_subscribe_id: MESSAGE_TYPE_IDS.max_subscribe_id,
592
- fetch: MESSAGE_TYPE_IDS.fetch,
593
- fetch_ok: MESSAGE_TYPE_IDS.fetch_ok,
594
- fetch_error: MESSAGE_TYPE_IDS.fetch_error,
595
- fetch_cancel: MESSAGE_TYPE_IDS.fetch_cancel,
596
- };
597
- // --- Public codec API ---
598
- function encodeMessageImpl(message) {
599
- // Check if it's a data stream message (no type+length framing)
600
- const dataEncoder = dataStreamEncoders[message.type];
601
- if (dataEncoder) {
602
- const writer = new BufferWriter();
603
- dataEncoder(message, writer);
604
- return writer.finish();
605
- }
606
- // Control message: type + length + payload framing
607
- const controlEncoder = controlEncoders[message.type];
608
- if (!controlEncoder) {
609
- throw new Error(`Unknown message type: ${message.type}`);
610
- }
611
- // Encode payload first
612
- const payloadWriter = new BufferWriter();
613
- controlEncoder(message, payloadWriter);
614
- const payload = payloadWriter.finish();
615
- // Write type + length + payload
616
- const frameWriter = new BufferWriter();
617
- frameWriter.writeVarInt(MESSAGE_TYPE_TO_WIRE[message.type]);
618
- frameWriter.writeVarInt(payload.byteLength);
619
- frameWriter.writeBytes(payload);
620
- return frameWriter.finish();
621
- }
622
- function decodeMessageImpl(bytes) {
623
- try {
624
- const reader = new BufferReader(bytes, 0);
625
- const typeId = reader.readVarInt();
626
- // Check if this is a data stream type (no length framing)
627
- if (DATA_STREAM_TYPE_IDS.has(typeId)) {
628
- const decoder = dataStreamDecoders.get(typeId);
629
- if (!decoder) {
630
- return {
631
- ok: false,
632
- error: new DecodeError("UNKNOWN_MESSAGE_TYPE", `Unknown data stream type ID: 0x${typeId.toString(16)}`, 0),
633
- };
634
- }
635
- const message = decoder(reader);
636
- return { ok: true, value: message, bytesRead: reader.offset };
637
- }
638
- // Control message: read length, then decode payload from bounded sub-reader
639
- const payloadLength = Number(reader.readVarInt());
640
- const _headerBytes = reader.offset; // bytes consumed by type + length
641
- if (reader.remaining < payloadLength) {
642
- return {
643
- ok: false,
644
- error: new DecodeError("UNEXPECTED_END", `Not enough bytes for payload: need ${payloadLength}, have ${reader.remaining}`, reader.offset),
645
- };
646
- }
647
- const payloadBytes = reader.readBytes(payloadLength);
648
- const totalBytesRead = reader.offset;
649
- const decoder = controlDecoders.get(typeId);
650
- if (!decoder) {
651
- return {
652
- ok: false,
653
- error: new DecodeError("UNKNOWN_MESSAGE_TYPE", `Unknown message type ID: 0x${typeId.toString(16)}`, 0),
654
- };
655
- }
656
- const payloadReader = new BufferReader(payloadBytes, 0);
657
- const message = decoder(payloadReader);
658
- return { ok: true, value: message, bytesRead: totalBytesRead };
659
- }
660
- catch (e) {
661
- if (e instanceof DecodeError) {
662
- return { ok: false, error: e };
663
- }
664
- throw e;
665
- }
666
- }
667
- function createStreamDecoderImpl() {
668
- let buffer = new Uint8Array(0);
669
- return new TransformStream({
670
- transform(chunk, controller) {
671
- // Accumulate incoming data
672
- const newBuffer = new Uint8Array(buffer.length + chunk.length);
673
- newBuffer.set(buffer, 0);
674
- newBuffer.set(chunk, buffer.length);
675
- buffer = newBuffer;
676
- // Try to decode messages from the buffer
677
- while (buffer.length > 0) {
678
- const result = decodeMessageImpl(buffer);
679
- if (!result.ok) {
680
- if (result.error.code === "UNEXPECTED_END") {
681
- // Need more data -- wait for next chunk
682
- break;
683
- }
684
- // Fatal decode error
685
- controller.error(result.error);
686
- return;
687
- }
688
- controller.enqueue(result.value);
689
- // Advance the buffer past the consumed bytes
690
- buffer = buffer.slice(result.bytesRead);
691
- }
692
- },
693
- flush(controller) {
694
- // If there is remaining data in the buffer, it is a truncated message
695
- if (buffer.length > 0) {
696
- controller.error(new DecodeError("UNEXPECTED_END", "Stream ended with incomplete message data", 0));
697
- }
698
- },
699
- });
700
- }
701
- // ─── Data stream encode/decode (re-exported from data-streams.ts) ─────────────
702
- export { encodeSubgroupStream, encodeDatagram, encodeFetchStream, decodeSubgroupStream, decodeDatagram, decodeFetchStream, } from "./data-streams.js";
703
- import { encodeSubgroupStream, encodeDatagram, encodeFetchStream, decodeSubgroupStream, decodeDatagram, decodeFetchStream, } from "./data-streams.js";
704
- export function createDraft07Codec() {
705
- return {
706
- draft: "draft-ietf-moq-transport-07",
707
- encodeMessage: encodeMessageImpl,
708
- decodeMessage: decodeMessageImpl,
709
- encodeVarInt,
710
- decodeVarInt,
711
- createStreamDecoder: createStreamDecoderImpl,
712
- encodeSubgroupStream,
713
- decodeSubgroupStream,
714
- encodeDatagram,
715
- decodeDatagram,
716
- encodeFetchStream,
717
- decodeFetchStream,
718
- };
719
- }
720
- // Export data-stream decoder map for callers that need to disambiguate
721
- export { dataStreamDecoders };
722
- //# sourceMappingURL=codec.js.map