@moqtap/codec 0.1.1 → 0.2.1

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 (666) hide show
  1. package/README.md +99 -95
  2. package/dist/chunk-4RIXXEII.js +1275 -0
  3. package/dist/chunk-4XYGE53S.cjs +698 -0
  4. package/dist/chunk-4YJANAXU.cjs +1109 -0
  5. package/dist/chunk-6AEHWULA.cjs +641 -0
  6. package/dist/chunk-7DUBLRXC.js +680 -0
  7. package/dist/{chunk-YBZD3DU5.cjs → chunk-7IVGHMKJ.cjs} +44 -42
  8. package/dist/chunk-BISI45MN.cjs +680 -0
  9. package/dist/{chunk-NLYTRGXA.cjs → chunk-BPNL5YFQ.cjs} +5 -5
  10. package/dist/chunk-CXDHOMHG.js +1097 -0
  11. package/dist/chunk-DUBCL3WF.cjs +749 -0
  12. package/dist/chunk-DWK5ZQZ4.js +642 -0
  13. package/dist/chunk-E6E3NQYU.js +680 -0
  14. package/dist/chunk-EFM5T7OM.js +698 -0
  15. package/dist/chunk-ENURAVHI.cjs +680 -0
  16. package/dist/{chunk-Z66WDWHI.js → chunk-FXZ2MYKJ.js} +127 -1
  17. package/dist/chunk-G26SJ6XS.cjs +1341 -0
  18. package/dist/chunk-G7GI7LJA.js +737 -0
  19. package/dist/chunk-GXEW4COZ.cjs +737 -0
  20. package/dist/chunk-HSVYF6XX.cjs +1361 -0
  21. package/dist/chunk-IBVM4DMJ.cjs +1097 -0
  22. package/dist/chunk-IV2H5CFI.cjs +1275 -0
  23. package/dist/chunk-IV2HRJVT.js +1198 -0
  24. package/dist/chunk-JSQM2MG3.js +680 -0
  25. package/dist/chunk-K4OLITS2.cjs +1055 -0
  26. package/dist/{chunk-UOBWHJA5.js → chunk-KFTCU2P6.js} +2 -3
  27. package/dist/chunk-LH4NTURO.js +1361 -0
  28. package/dist/{chunk-YTXLWKOR.js → chunk-MFAP7R6L.js} +1 -1
  29. package/dist/chunk-NGVE2RZT.js +1097 -0
  30. package/dist/chunk-NUX5BHWO.js +1341 -0
  31. package/dist/chunk-PJRA2TQ5.js +1055 -0
  32. package/dist/chunk-RVJAGE4S.cjs +1198 -0
  33. package/dist/{chunk-QYG6KGOV.cjs → chunk-RWQ43Z4F.cjs} +2 -3
  34. package/dist/chunk-RZHAPEXO.js +749 -0
  35. package/dist/chunk-ST24APEO.js +1109 -0
  36. package/dist/chunk-SYHW3FLI.cjs +642 -0
  37. package/dist/chunk-TLYNOOQP.cjs +432 -0
  38. package/dist/{chunk-IXHOBNXA.js → chunk-TMNGRIPL.js} +43 -41
  39. package/dist/chunk-UNS34PTA.cjs +680 -0
  40. package/dist/chunk-UR6JKS56.js +432 -0
  41. package/dist/{chunk-NPWHHWXT.cjs → chunk-UYXTY6ZQ.cjs} +127 -1
  42. package/dist/chunk-XUUCOLWU.cjs +1097 -0
  43. package/dist/chunk-YG5KJESI.js +641 -0
  44. package/dist/chunk-ZBKE2QRQ.js +1401 -0
  45. package/dist/chunk-ZSPO2GF2.cjs +1401 -0
  46. package/dist/codec-95k8CAu5.d.cts +35 -0
  47. package/dist/codec-AFuOxfsO.d.ts +60 -0
  48. package/dist/codec-B-UJ5Iow.d.cts +75 -0
  49. package/dist/codec-BC5jfvMb.d.ts +35 -0
  50. package/dist/codec-BECYPfY8.d.ts +35 -0
  51. package/dist/codec-BsPU1vNC.d.ts +39 -0
  52. package/dist/codec-BvpuF-6u.d.cts +39 -0
  53. package/dist/codec-C8jZI5Cx.d.cts +39 -0
  54. package/dist/codec-CAevkgf5.d.cts +33 -0
  55. package/dist/codec-CSUqCrRs.d.ts +39 -0
  56. package/dist/codec-C_HMXNK_.d.ts +33 -0
  57. package/dist/{codec-Bvr7rFtj.d.cts → codec-CpuvYTSV.d.cts} +1 -1
  58. package/dist/codec-D0x8-SCw.d.cts +35 -0
  59. package/dist/codec-D7ARhpG1.d.ts +75 -0
  60. package/dist/codec-DNAUGshO.d.cts +60 -0
  61. package/dist/codec-DPx_QNn0.d.ts +31 -0
  62. package/dist/{codec-B2mc2g3i.d.ts → codec-DRhCx_hw.d.ts} +1 -1
  63. package/dist/codec-Db7YPe3l.d.ts +31 -0
  64. package/dist/codec-axkJpb7D.d.cts +31 -0
  65. package/dist/codec-ujAbFaep.d.cts +31 -0
  66. package/dist/core/buffer-reader.d.ts +15 -0
  67. package/dist/core/buffer-reader.d.ts.map +1 -0
  68. package/dist/core/buffer-reader.js +98 -0
  69. package/dist/core/buffer-reader.js.map +1 -0
  70. package/dist/core/buffer-writer.d.ts +16 -0
  71. package/dist/core/buffer-writer.d.ts.map +1 -0
  72. package/dist/core/buffer-writer.js +86 -0
  73. package/dist/core/buffer-writer.js.map +1 -0
  74. package/dist/core/errors.d.ts +2 -0
  75. package/dist/core/errors.d.ts.map +1 -0
  76. package/dist/core/errors.js +2 -0
  77. package/dist/core/errors.js.map +1 -0
  78. package/dist/core/hex.d.ts +5 -0
  79. package/dist/core/hex.d.ts.map +1 -0
  80. package/dist/core/hex.js +17 -0
  81. package/dist/core/hex.js.map +1 -0
  82. package/dist/core/session-types.d.ts +99 -0
  83. package/dist/core/session-types.d.ts.map +1 -0
  84. package/dist/core/session-types.js +2 -0
  85. package/dist/core/session-types.js.map +1 -0
  86. package/dist/core/types.d.ts +235 -0
  87. package/dist/core/types.d.ts.map +1 -0
  88. package/dist/core/types.js +11 -0
  89. package/dist/core/types.js.map +1 -0
  90. package/dist/draft10-session.cjs +6 -0
  91. package/dist/draft10-session.d.cts +8 -0
  92. package/dist/draft10-session.d.ts +8 -0
  93. package/dist/draft10-session.js +6 -0
  94. package/dist/draft10.cjs +115 -0
  95. package/dist/draft10.d.cts +95 -0
  96. package/dist/draft10.d.ts +95 -0
  97. package/dist/draft10.js +115 -0
  98. package/dist/draft11-session.cjs +6 -0
  99. package/dist/draft11-session.d.cts +8 -0
  100. package/dist/draft11-session.d.ts +8 -0
  101. package/dist/draft11-session.js +6 -0
  102. package/dist/draft11.cjs +109 -0
  103. package/dist/draft11.d.cts +99 -0
  104. package/dist/draft11.d.ts +99 -0
  105. package/dist/draft11.js +109 -0
  106. package/dist/draft12-session.cjs +6 -0
  107. package/dist/draft12-session.d.cts +8 -0
  108. package/dist/draft12-session.d.ts +8 -0
  109. package/dist/draft12-session.js +6 -0
  110. package/dist/draft12.cjs +117 -0
  111. package/dist/draft12.d.cts +106 -0
  112. package/dist/draft12.d.ts +106 -0
  113. package/dist/draft12.js +117 -0
  114. package/dist/draft13-session.cjs +6 -0
  115. package/dist/draft13-session.d.cts +8 -0
  116. package/dist/draft13-session.d.ts +8 -0
  117. package/dist/draft13-session.js +6 -0
  118. package/dist/draft13.cjs +119 -0
  119. package/dist/draft13.d.cts +108 -0
  120. package/dist/draft13.d.ts +108 -0
  121. package/dist/draft13.js +119 -0
  122. package/dist/draft14-session.cjs +2 -2
  123. package/dist/draft14-session.d.cts +3 -3
  124. package/dist/draft14-session.d.ts +3 -3
  125. package/dist/draft14-session.js +1 -1
  126. package/dist/draft14.cjs +3 -3
  127. package/dist/draft14.d.cts +16 -4
  128. package/dist/draft14.d.ts +16 -4
  129. package/dist/draft14.js +2 -2
  130. package/dist/draft15-session.cjs +6 -0
  131. package/dist/draft15-session.d.cts +8 -0
  132. package/dist/draft15-session.d.ts +8 -0
  133. package/dist/draft15-session.js +6 -0
  134. package/dist/draft15.cjs +111 -0
  135. package/dist/draft15.d.cts +93 -0
  136. package/dist/draft15.d.ts +93 -0
  137. package/dist/draft15.js +111 -0
  138. package/dist/draft16-session.cjs +6 -0
  139. package/dist/draft16-session.d.cts +8 -0
  140. package/dist/draft16-session.d.ts +8 -0
  141. package/dist/draft16-session.js +6 -0
  142. package/dist/draft16.cjs +113 -0
  143. package/dist/draft16.d.cts +94 -0
  144. package/dist/draft16.d.ts +94 -0
  145. package/dist/draft16.js +113 -0
  146. package/dist/draft17-session.cjs +8 -0
  147. package/dist/draft17-session.d.cts +51 -0
  148. package/dist/draft17-session.d.ts +51 -0
  149. package/dist/draft17-session.js +8 -0
  150. package/dist/draft17.cjs +99 -0
  151. package/dist/draft17.d.cts +40 -0
  152. package/dist/draft17.d.ts +40 -0
  153. package/dist/draft17.js +99 -0
  154. package/dist/draft7-session.cjs +3 -3
  155. package/dist/draft7-session.d.cts +3 -3
  156. package/dist/draft7-session.d.ts +3 -3
  157. package/dist/draft7-session.js +2 -2
  158. package/dist/draft7.cjs +4 -4
  159. package/dist/draft7.d.cts +2 -2
  160. package/dist/draft7.d.ts +2 -2
  161. package/dist/draft7.js +2 -2
  162. package/dist/draft8-session.cjs +6 -0
  163. package/dist/draft8-session.d.cts +8 -0
  164. package/dist/draft8-session.d.ts +8 -0
  165. package/dist/draft8-session.js +6 -0
  166. package/dist/draft8.cjs +115 -0
  167. package/dist/draft8.d.cts +95 -0
  168. package/dist/draft8.d.ts +95 -0
  169. package/dist/draft8.js +115 -0
  170. package/dist/draft9-session.cjs +6 -0
  171. package/dist/draft9-session.d.cts +8 -0
  172. package/dist/draft9-session.d.ts +8 -0
  173. package/dist/draft9-session.js +6 -0
  174. package/dist/draft9.cjs +115 -0
  175. package/dist/draft9.d.cts +95 -0
  176. package/dist/draft9.d.ts +95 -0
  177. package/dist/draft9.js +115 -0
  178. package/dist/drafts/draft07/announce-fsm.d.ts +2 -0
  179. package/dist/drafts/draft07/announce-fsm.d.ts.map +1 -0
  180. package/dist/drafts/draft07/announce-fsm.js +2 -0
  181. package/dist/drafts/draft07/announce-fsm.js.map +1 -0
  182. package/dist/drafts/draft07/codec.d.ts +17 -0
  183. package/dist/drafts/draft07/codec.d.ts.map +1 -0
  184. package/dist/drafts/draft07/codec.js +722 -0
  185. package/dist/drafts/draft07/codec.js.map +1 -0
  186. package/dist/drafts/draft07/data-streams.d.ts +9 -0
  187. package/dist/drafts/draft07/data-streams.d.ts.map +1 -0
  188. package/dist/drafts/draft07/data-streams.js +228 -0
  189. package/dist/drafts/draft07/data-streams.js.map +1 -0
  190. package/dist/drafts/draft07/index.d.ts +14 -0
  191. package/dist/drafts/draft07/index.d.ts.map +1 -0
  192. package/dist/drafts/draft07/index.js +18 -0
  193. package/dist/drafts/draft07/index.js.map +1 -0
  194. package/dist/drafts/draft07/messages.d.ts +32 -0
  195. package/dist/drafts/draft07/messages.d.ts.map +1 -0
  196. package/dist/drafts/draft07/messages.js +42 -0
  197. package/dist/drafts/draft07/messages.js.map +1 -0
  198. package/dist/drafts/draft07/parameters.d.ts +4 -0
  199. package/dist/drafts/draft07/parameters.d.ts.map +1 -0
  200. package/dist/drafts/draft07/parameters.js +10 -0
  201. package/dist/drafts/draft07/parameters.js.map +1 -0
  202. package/dist/drafts/draft07/rules.d.ts +8 -0
  203. package/dist/drafts/draft07/rules.d.ts.map +1 -0
  204. package/dist/drafts/draft07/rules.js +95 -0
  205. package/dist/drafts/draft07/rules.js.map +1 -0
  206. package/dist/drafts/draft07/session-fsm.d.ts +38 -0
  207. package/dist/drafts/draft07/session-fsm.d.ts.map +1 -0
  208. package/dist/drafts/draft07/session-fsm.js +354 -0
  209. package/dist/drafts/draft07/session-fsm.js.map +1 -0
  210. package/dist/drafts/draft07/session.d.ts +4 -0
  211. package/dist/drafts/draft07/session.d.ts.map +1 -0
  212. package/dist/drafts/draft07/session.js +5 -0
  213. package/dist/drafts/draft07/session.js.map +1 -0
  214. package/dist/drafts/draft07/subscription-fsm.d.ts +2 -0
  215. package/dist/drafts/draft07/subscription-fsm.d.ts.map +1 -0
  216. package/dist/drafts/draft07/subscription-fsm.js +2 -0
  217. package/dist/drafts/draft07/subscription-fsm.js.map +1 -0
  218. package/dist/drafts/draft07/types.d.ts +61 -0
  219. package/dist/drafts/draft07/types.d.ts.map +1 -0
  220. package/dist/drafts/draft07/types.js +4 -0
  221. package/dist/drafts/draft07/types.js.map +1 -0
  222. package/dist/drafts/draft07/varint.d.ts +4 -0
  223. package/dist/drafts/draft07/varint.d.ts.map +1 -0
  224. package/dist/drafts/draft07/varint.js +22 -0
  225. package/dist/drafts/draft07/varint.js.map +1 -0
  226. package/dist/drafts/draft08/codec.d.ts +29 -0
  227. package/dist/drafts/draft08/codec.d.ts.map +1 -0
  228. package/dist/drafts/draft08/codec.js +729 -0
  229. package/dist/drafts/draft08/codec.js.map +1 -0
  230. package/dist/drafts/draft08/data-streams.d.ts +12 -0
  231. package/dist/drafts/draft08/data-streams.d.ts.map +1 -0
  232. package/dist/drafts/draft08/data-streams.js +345 -0
  233. package/dist/drafts/draft08/data-streams.js.map +1 -0
  234. package/dist/drafts/draft08/index.d.ts +9 -0
  235. package/dist/drafts/draft08/index.d.ts.map +1 -0
  236. package/dist/drafts/draft08/index.js +7 -0
  237. package/dist/drafts/draft08/index.js.map +1 -0
  238. package/dist/drafts/draft08/messages.d.ts +34 -0
  239. package/dist/drafts/draft08/messages.d.ts.map +1 -0
  240. package/dist/drafts/draft08/messages.js +66 -0
  241. package/dist/drafts/draft08/messages.js.map +1 -0
  242. package/dist/drafts/draft08/rules.d.ts +8 -0
  243. package/dist/drafts/draft08/rules.d.ts.map +1 -0
  244. package/dist/drafts/draft08/rules.js +83 -0
  245. package/dist/drafts/draft08/rules.js.map +1 -0
  246. package/dist/drafts/draft08/session-fsm.d.ts +47 -0
  247. package/dist/drafts/draft08/session-fsm.d.ts.map +1 -0
  248. package/dist/drafts/draft08/session-fsm.js +483 -0
  249. package/dist/drafts/draft08/session-fsm.js.map +1 -0
  250. package/dist/drafts/draft08/session.d.ts +5 -0
  251. package/dist/drafts/draft08/session.d.ts.map +1 -0
  252. package/dist/drafts/draft08/session.js +5 -0
  253. package/dist/drafts/draft08/session.js.map +1 -0
  254. package/dist/drafts/draft08/types.d.ts +268 -0
  255. package/dist/drafts/draft08/types.d.ts.map +1 -0
  256. package/dist/drafts/draft08/types.js +4 -0
  257. package/dist/drafts/draft08/types.js.map +1 -0
  258. package/dist/drafts/draft09/codec.d.ts +21 -0
  259. package/dist/drafts/draft09/codec.d.ts.map +1 -0
  260. package/dist/drafts/draft09/codec.js +721 -0
  261. package/dist/drafts/draft09/codec.js.map +1 -0
  262. package/dist/drafts/draft09/data-streams.d.ts +12 -0
  263. package/dist/drafts/draft09/data-streams.d.ts.map +1 -0
  264. package/dist/drafts/draft09/data-streams.js +307 -0
  265. package/dist/drafts/draft09/data-streams.js.map +1 -0
  266. package/dist/drafts/draft09/index.d.ts +9 -0
  267. package/dist/drafts/draft09/index.d.ts.map +1 -0
  268. package/dist/drafts/draft09/index.js +7 -0
  269. package/dist/drafts/draft09/index.js.map +1 -0
  270. package/dist/drafts/draft09/messages.d.ts +34 -0
  271. package/dist/drafts/draft09/messages.d.ts.map +1 -0
  272. package/dist/drafts/draft09/messages.js +66 -0
  273. package/dist/drafts/draft09/messages.js.map +1 -0
  274. package/dist/drafts/draft09/rules.d.ts +8 -0
  275. package/dist/drafts/draft09/rules.d.ts.map +1 -0
  276. package/dist/drafts/draft09/rules.js +83 -0
  277. package/dist/drafts/draft09/rules.js.map +1 -0
  278. package/dist/drafts/draft09/session-fsm.d.ts +47 -0
  279. package/dist/drafts/draft09/session-fsm.d.ts.map +1 -0
  280. package/dist/drafts/draft09/session-fsm.js +483 -0
  281. package/dist/drafts/draft09/session-fsm.js.map +1 -0
  282. package/dist/drafts/draft09/session.d.ts +5 -0
  283. package/dist/drafts/draft09/session.d.ts.map +1 -0
  284. package/dist/drafts/draft09/session.js +5 -0
  285. package/dist/drafts/draft09/session.js.map +1 -0
  286. package/dist/drafts/draft09/types.d.ts +268 -0
  287. package/dist/drafts/draft09/types.d.ts.map +1 -0
  288. package/dist/drafts/draft09/types.js +4 -0
  289. package/dist/drafts/draft09/types.js.map +1 -0
  290. package/dist/drafts/draft10/codec.d.ts +21 -0
  291. package/dist/drafts/draft10/codec.d.ts.map +1 -0
  292. package/dist/drafts/draft10/codec.js +721 -0
  293. package/dist/drafts/draft10/codec.js.map +1 -0
  294. package/dist/drafts/draft10/data-streams.d.ts +12 -0
  295. package/dist/drafts/draft10/data-streams.d.ts.map +1 -0
  296. package/dist/drafts/draft10/data-streams.js +307 -0
  297. package/dist/drafts/draft10/data-streams.js.map +1 -0
  298. package/dist/drafts/draft10/index.d.ts +9 -0
  299. package/dist/drafts/draft10/index.d.ts.map +1 -0
  300. package/dist/drafts/draft10/index.js +7 -0
  301. package/dist/drafts/draft10/index.js.map +1 -0
  302. package/dist/drafts/draft10/messages.d.ts +34 -0
  303. package/dist/drafts/draft10/messages.d.ts.map +1 -0
  304. package/dist/drafts/draft10/messages.js +66 -0
  305. package/dist/drafts/draft10/messages.js.map +1 -0
  306. package/dist/drafts/draft10/rules.d.ts +8 -0
  307. package/dist/drafts/draft10/rules.d.ts.map +1 -0
  308. package/dist/drafts/draft10/rules.js +83 -0
  309. package/dist/drafts/draft10/rules.js.map +1 -0
  310. package/dist/drafts/draft10/session-fsm.d.ts +47 -0
  311. package/dist/drafts/draft10/session-fsm.d.ts.map +1 -0
  312. package/dist/drafts/draft10/session-fsm.js +483 -0
  313. package/dist/drafts/draft10/session-fsm.js.map +1 -0
  314. package/dist/drafts/draft10/session.d.ts +5 -0
  315. package/dist/drafts/draft10/session.d.ts.map +1 -0
  316. package/dist/drafts/draft10/session.js +5 -0
  317. package/dist/drafts/draft10/session.js.map +1 -0
  318. package/dist/drafts/draft10/types.d.ts +268 -0
  319. package/dist/drafts/draft10/types.d.ts.map +1 -0
  320. package/dist/drafts/draft10/types.js +4 -0
  321. package/dist/drafts/draft10/types.js.map +1 -0
  322. package/dist/drafts/draft11/codec.d.ts +25 -0
  323. package/dist/drafts/draft11/codec.d.ts.map +1 -0
  324. package/dist/drafts/draft11/codec.js +775 -0
  325. package/dist/drafts/draft11/codec.js.map +1 -0
  326. package/dist/drafts/draft11/data-streams.d.ts +10 -0
  327. package/dist/drafts/draft11/data-streams.d.ts.map +1 -0
  328. package/dist/drafts/draft11/data-streams.js +253 -0
  329. package/dist/drafts/draft11/data-streams.js.map +1 -0
  330. package/dist/drafts/draft11/index.d.ts +9 -0
  331. package/dist/drafts/draft11/index.d.ts.map +1 -0
  332. package/dist/drafts/draft11/index.js +7 -0
  333. package/dist/drafts/draft11/index.js.map +1 -0
  334. package/dist/drafts/draft11/messages.d.ts +33 -0
  335. package/dist/drafts/draft11/messages.d.ts.map +1 -0
  336. package/dist/drafts/draft11/messages.js +65 -0
  337. package/dist/drafts/draft11/messages.js.map +1 -0
  338. package/dist/drafts/draft11/rules.d.ts +8 -0
  339. package/dist/drafts/draft11/rules.d.ts.map +1 -0
  340. package/dist/drafts/draft11/rules.js +88 -0
  341. package/dist/drafts/draft11/rules.js.map +1 -0
  342. package/dist/drafts/draft11/session-fsm.d.ts +52 -0
  343. package/dist/drafts/draft11/session-fsm.d.ts.map +1 -0
  344. package/dist/drafts/draft11/session-fsm.js +530 -0
  345. package/dist/drafts/draft11/session-fsm.js.map +1 -0
  346. package/dist/drafts/draft11/session.d.ts +5 -0
  347. package/dist/drafts/draft11/session.d.ts.map +1 -0
  348. package/dist/drafts/draft11/session.js +5 -0
  349. package/dist/drafts/draft11/session.js.map +1 -0
  350. package/dist/drafts/draft11/types.d.ts +266 -0
  351. package/dist/drafts/draft11/types.d.ts.map +1 -0
  352. package/dist/drafts/draft11/types.js +4 -0
  353. package/dist/drafts/draft11/types.js.map +1 -0
  354. package/dist/drafts/draft12/codec.d.ts +27 -0
  355. package/dist/drafts/draft12/codec.d.ts.map +1 -0
  356. package/dist/drafts/draft12/codec.js +918 -0
  357. package/dist/drafts/draft12/codec.js.map +1 -0
  358. package/dist/drafts/draft12/data-streams.d.ts +10 -0
  359. package/dist/drafts/draft12/data-streams.d.ts.map +1 -0
  360. package/dist/drafts/draft12/data-streams.js +254 -0
  361. package/dist/drafts/draft12/data-streams.js.map +1 -0
  362. package/dist/drafts/draft12/index.d.ts +9 -0
  363. package/dist/drafts/draft12/index.d.ts.map +1 -0
  364. package/dist/drafts/draft12/index.js +7 -0
  365. package/dist/drafts/draft12/index.js.map +1 -0
  366. package/dist/drafts/draft12/messages.d.ts +37 -0
  367. package/dist/drafts/draft12/messages.d.ts.map +1 -0
  368. package/dist/drafts/draft12/messages.js +77 -0
  369. package/dist/drafts/draft12/messages.js.map +1 -0
  370. package/dist/drafts/draft12/rules.d.ts +8 -0
  371. package/dist/drafts/draft12/rules.d.ts.map +1 -0
  372. package/dist/drafts/draft12/rules.js +94 -0
  373. package/dist/drafts/draft12/rules.js.map +1 -0
  374. package/dist/drafts/draft12/session-fsm.d.ts +55 -0
  375. package/dist/drafts/draft12/session-fsm.d.ts.map +1 -0
  376. package/dist/drafts/draft12/session-fsm.js +569 -0
  377. package/dist/drafts/draft12/session-fsm.js.map +1 -0
  378. package/dist/drafts/draft12/session.d.ts +5 -0
  379. package/dist/drafts/draft12/session.d.ts.map +1 -0
  380. package/dist/drafts/draft12/session.js +5 -0
  381. package/dist/drafts/draft12/session.js.map +1 -0
  382. package/dist/drafts/draft12/types.d.ts +294 -0
  383. package/dist/drafts/draft12/types.d.ts.map +1 -0
  384. package/dist/drafts/draft12/types.js +4 -0
  385. package/dist/drafts/draft12/types.js.map +1 -0
  386. package/dist/drafts/draft13/codec.d.ts +27 -0
  387. package/dist/drafts/draft13/codec.d.ts.map +1 -0
  388. package/dist/drafts/draft13/codec.js +1000 -0
  389. package/dist/drafts/draft13/codec.js.map +1 -0
  390. package/dist/drafts/draft13/data-streams.d.ts +10 -0
  391. package/dist/drafts/draft13/data-streams.d.ts.map +1 -0
  392. package/dist/drafts/draft13/data-streams.js +254 -0
  393. package/dist/drafts/draft13/data-streams.js.map +1 -0
  394. package/dist/drafts/draft13/index.d.ts +9 -0
  395. package/dist/drafts/draft13/index.d.ts.map +1 -0
  396. package/dist/drafts/draft13/index.js +7 -0
  397. package/dist/drafts/draft13/index.js.map +1 -0
  398. package/dist/drafts/draft13/messages.d.ts +38 -0
  399. package/dist/drafts/draft13/messages.d.ts.map +1 -0
  400. package/dist/drafts/draft13/messages.js +79 -0
  401. package/dist/drafts/draft13/messages.js.map +1 -0
  402. package/dist/drafts/draft13/rules.d.ts +8 -0
  403. package/dist/drafts/draft13/rules.d.ts.map +1 -0
  404. package/dist/drafts/draft13/rules.js +96 -0
  405. package/dist/drafts/draft13/rules.js.map +1 -0
  406. package/dist/drafts/draft13/session-fsm.d.ts +56 -0
  407. package/dist/drafts/draft13/session-fsm.d.ts.map +1 -0
  408. package/dist/drafts/draft13/session-fsm.js +581 -0
  409. package/dist/drafts/draft13/session-fsm.js.map +1 -0
  410. package/dist/drafts/draft13/session.d.ts +5 -0
  411. package/dist/drafts/draft13/session.d.ts.map +1 -0
  412. package/dist/drafts/draft13/session.js +5 -0
  413. package/dist/drafts/draft13/session.js.map +1 -0
  414. package/dist/drafts/draft13/types.d.ts +310 -0
  415. package/dist/drafts/draft13/types.d.ts.map +1 -0
  416. package/dist/drafts/draft13/types.js +4 -0
  417. package/dist/drafts/draft13/types.js.map +1 -0
  418. package/dist/drafts/draft14/codec.d.ts +34 -0
  419. package/dist/drafts/draft14/codec.d.ts.map +1 -0
  420. package/dist/drafts/draft14/codec.js +752 -0
  421. package/dist/drafts/draft14/codec.js.map +1 -0
  422. package/dist/drafts/draft14/data-streams.d.ts +56 -0
  423. package/dist/drafts/draft14/data-streams.d.ts.map +1 -0
  424. package/dist/drafts/draft14/data-streams.js +729 -0
  425. package/dist/drafts/draft14/data-streams.js.map +1 -0
  426. package/dist/drafts/draft14/index.d.ts +9 -0
  427. package/dist/drafts/draft14/index.d.ts.map +1 -0
  428. package/dist/drafts/draft14/index.js +7 -0
  429. package/dist/drafts/draft14/index.js.map +1 -0
  430. package/dist/drafts/draft14/messages.d.ts +36 -0
  431. package/dist/drafts/draft14/messages.d.ts.map +1 -0
  432. package/dist/drafts/draft14/messages.js +71 -0
  433. package/dist/drafts/draft14/messages.js.map +1 -0
  434. package/dist/drafts/draft14/rules.d.ts +8 -0
  435. package/dist/drafts/draft14/rules.d.ts.map +1 -0
  436. package/dist/drafts/draft14/rules.js +101 -0
  437. package/dist/drafts/draft14/rules.js.map +1 -0
  438. package/dist/drafts/draft14/session-fsm.d.ts +58 -0
  439. package/dist/drafts/draft14/session-fsm.d.ts.map +1 -0
  440. package/dist/drafts/draft14/session-fsm.js +648 -0
  441. package/dist/drafts/draft14/session-fsm.js.map +1 -0
  442. package/dist/drafts/draft14/session.d.ts +5 -0
  443. package/dist/drafts/draft14/session.d.ts.map +1 -0
  444. package/dist/drafts/draft14/session.js +5 -0
  445. package/dist/drafts/draft14/session.js.map +1 -0
  446. package/dist/drafts/draft14/types.d.ts +263 -0
  447. package/dist/drafts/draft14/types.d.ts.map +1 -0
  448. package/dist/drafts/draft14/types.js +4 -0
  449. package/dist/drafts/draft14/types.js.map +1 -0
  450. package/dist/drafts/draft15/codec.d.ts +33 -0
  451. package/dist/drafts/draft15/codec.d.ts.map +1 -0
  452. package/dist/drafts/draft15/codec.js +742 -0
  453. package/dist/drafts/draft15/codec.js.map +1 -0
  454. package/dist/drafts/draft15/data-streams.d.ts +45 -0
  455. package/dist/drafts/draft15/data-streams.d.ts.map +1 -0
  456. package/dist/drafts/draft15/data-streams.js +675 -0
  457. package/dist/drafts/draft15/data-streams.js.map +1 -0
  458. package/dist/drafts/draft15/index.d.ts +9 -0
  459. package/dist/drafts/draft15/index.d.ts.map +1 -0
  460. package/dist/drafts/draft15/index.js +7 -0
  461. package/dist/drafts/draft15/index.js.map +1 -0
  462. package/dist/drafts/draft15/messages.d.ts +31 -0
  463. package/dist/drafts/draft15/messages.d.ts.map +1 -0
  464. package/dist/drafts/draft15/messages.js +59 -0
  465. package/dist/drafts/draft15/messages.js.map +1 -0
  466. package/dist/drafts/draft15/rules.d.ts +8 -0
  467. package/dist/drafts/draft15/rules.d.ts.map +1 -0
  468. package/dist/drafts/draft15/rules.js +83 -0
  469. package/dist/drafts/draft15/rules.js.map +1 -0
  470. package/dist/drafts/draft15/session-fsm.d.ts +48 -0
  471. package/dist/drafts/draft15/session-fsm.d.ts.map +1 -0
  472. package/dist/drafts/draft15/session-fsm.js +479 -0
  473. package/dist/drafts/draft15/session-fsm.js.map +1 -0
  474. package/dist/drafts/draft15/session.d.ts +5 -0
  475. package/dist/drafts/draft15/session.d.ts.map +1 -0
  476. package/dist/drafts/draft15/session.js +5 -0
  477. package/dist/drafts/draft15/session.js.map +1 -0
  478. package/dist/drafts/draft15/types.d.ts +232 -0
  479. package/dist/drafts/draft15/types.d.ts.map +1 -0
  480. package/dist/drafts/draft15/types.js +4 -0
  481. package/dist/drafts/draft15/types.js.map +1 -0
  482. package/dist/drafts/draft16/codec.d.ts +29 -0
  483. package/dist/drafts/draft16/codec.d.ts.map +1 -0
  484. package/dist/drafts/draft16/codec.js +747 -0
  485. package/dist/drafts/draft16/codec.js.map +1 -0
  486. package/dist/drafts/draft16/data-streams.d.ts +34 -0
  487. package/dist/drafts/draft16/data-streams.d.ts.map +1 -0
  488. package/dist/drafts/draft16/data-streams.js +667 -0
  489. package/dist/drafts/draft16/data-streams.js.map +1 -0
  490. package/dist/drafts/draft16/index.d.ts +9 -0
  491. package/dist/drafts/draft16/index.d.ts.map +1 -0
  492. package/dist/drafts/draft16/index.js +7 -0
  493. package/dist/drafts/draft16/index.js.map +1 -0
  494. package/dist/drafts/draft16/messages.d.ts +32 -0
  495. package/dist/drafts/draft16/messages.d.ts.map +1 -0
  496. package/dist/drafts/draft16/messages.js +62 -0
  497. package/dist/drafts/draft16/messages.js.map +1 -0
  498. package/dist/drafts/draft16/rules.d.ts +8 -0
  499. package/dist/drafts/draft16/rules.d.ts.map +1 -0
  500. package/dist/drafts/draft16/rules.js +84 -0
  501. package/dist/drafts/draft16/rules.js.map +1 -0
  502. package/dist/drafts/draft16/session-fsm.d.ts +48 -0
  503. package/dist/drafts/draft16/session-fsm.d.ts.map +1 -0
  504. package/dist/drafts/draft16/session-fsm.js +474 -0
  505. package/dist/drafts/draft16/session-fsm.js.map +1 -0
  506. package/dist/drafts/draft16/session.d.ts +5 -0
  507. package/dist/drafts/draft16/session.d.ts.map +1 -0
  508. package/dist/drafts/draft16/session.js +5 -0
  509. package/dist/drafts/draft16/session.js.map +1 -0
  510. package/dist/drafts/draft16/types.d.ts +238 -0
  511. package/dist/drafts/draft16/types.d.ts.map +1 -0
  512. package/dist/drafts/draft16/types.js +4 -0
  513. package/dist/drafts/draft16/types.js.map +1 -0
  514. package/dist/drafts/draft17/codec.d.ts +29 -0
  515. package/dist/drafts/draft17/codec.d.ts.map +1 -0
  516. package/dist/drafts/draft17/codec.js +799 -0
  517. package/dist/drafts/draft17/codec.js.map +1 -0
  518. package/dist/drafts/draft17/data-streams.d.ts +13 -0
  519. package/dist/drafts/draft17/data-streams.d.ts.map +1 -0
  520. package/dist/drafts/draft17/data-streams.js +633 -0
  521. package/dist/drafts/draft17/data-streams.js.map +1 -0
  522. package/dist/drafts/draft17/index.d.ts +8 -0
  523. package/dist/drafts/draft17/index.d.ts.map +1 -0
  524. package/dist/drafts/draft17/index.js +6 -0
  525. package/dist/drafts/draft17/index.js.map +1 -0
  526. package/dist/drafts/draft17/messages.d.ts +25 -0
  527. package/dist/drafts/draft17/messages.d.ts.map +1 -0
  528. package/dist/drafts/draft17/messages.js +48 -0
  529. package/dist/drafts/draft17/messages.js.map +1 -0
  530. package/dist/drafts/draft17/rules.d.ts +8 -0
  531. package/dist/drafts/draft17/rules.d.ts.map +1 -0
  532. package/dist/drafts/draft17/rules.js +71 -0
  533. package/dist/drafts/draft17/rules.js.map +1 -0
  534. package/dist/drafts/draft17/session-fsm.d.ts +45 -0
  535. package/dist/drafts/draft17/session-fsm.d.ts.map +1 -0
  536. package/dist/drafts/draft17/session-fsm.js +328 -0
  537. package/dist/drafts/draft17/session-fsm.js.map +1 -0
  538. package/dist/drafts/draft17/session.d.ts +5 -0
  539. package/dist/drafts/draft17/session.d.ts.map +1 -0
  540. package/dist/drafts/draft17/session.js +6 -0
  541. package/dist/drafts/draft17/session.js.map +1 -0
  542. package/dist/drafts/draft17/types.d.ts +219 -0
  543. package/dist/drafts/draft17/types.d.ts.map +1 -0
  544. package/dist/drafts/draft17/types.js +3 -0
  545. package/dist/drafts/draft17/types.js.map +1 -0
  546. package/dist/index.cjs +76 -4
  547. package/dist/index.d.cts +68 -5
  548. package/dist/index.d.ts +82 -11
  549. package/dist/index.d.ts.map +1 -0
  550. package/dist/index.js +93 -38
  551. package/dist/index.js.map +1 -0
  552. package/dist/{session-types-DFjMk4HH.d.ts → session-types-CJIFbTPd.d.ts} +1 -1
  553. package/dist/{session-types-DW1RSZX_.d.cts → session-types-Cbq8IGCP.d.cts} +1 -1
  554. package/dist/session.cjs +5 -5
  555. package/dist/session.d.cts +3 -3
  556. package/dist/session.d.ts +4 -8
  557. package/dist/session.d.ts.map +1 -0
  558. package/dist/session.js +32 -26
  559. package/dist/session.js.map +1 -0
  560. package/dist/types-4VxSL2Ho.d.cts +261 -0
  561. package/dist/types-4VxSL2Ho.d.ts +261 -0
  562. package/dist/types-B2afJZM-.d.cts +236 -0
  563. package/dist/types-B2afJZM-.d.ts +236 -0
  564. package/dist/types-Bg6QYNVt.d.cts +290 -0
  565. package/dist/types-Bg6QYNVt.d.ts +290 -0
  566. package/dist/types-C_1HrqBl.d.cts +306 -0
  567. package/dist/types-C_1HrqBl.d.ts +306 -0
  568. package/dist/types-Cw4WE9dh.d.cts +261 -0
  569. package/dist/types-Cw4WE9dh.d.ts +261 -0
  570. package/dist/types-D5gNQiDj.d.cts +261 -0
  571. package/dist/types-D5gNQiDj.d.ts +261 -0
  572. package/dist/types-DqCDFqgB.d.cts +230 -0
  573. package/dist/types-DqCDFqgB.d.ts +230 -0
  574. package/dist/types-ERexTpT8.d.cts +217 -0
  575. package/dist/types-ERexTpT8.d.ts +217 -0
  576. package/dist/{types-DPYE49t0.d.cts → types-QNXoxC9Y.d.cts} +2 -7
  577. package/dist/{types-DPYE49t0.d.ts → types-QNXoxC9Y.d.ts} +2 -7
  578. package/dist/types-r-CasCf1.d.cts +262 -0
  579. package/dist/types-r-CasCf1.d.ts +262 -0
  580. package/package.json +192 -84
  581. package/src/core/buffer-reader.ts +1 -1
  582. package/src/core/hex.ts +17 -0
  583. package/src/core/types.ts +24 -7
  584. package/src/drafts/draft07/codec.ts +933 -983
  585. package/src/drafts/draft07/data-streams.ts +240 -0
  586. package/src/drafts/draft07/index.ts +89 -69
  587. package/src/drafts/draft07/messages.ts +42 -44
  588. package/src/drafts/draft07/rules.ts +101 -106
  589. package/src/drafts/draft07/types.ts +72 -0
  590. package/src/drafts/draft08/codec.ts +944 -0
  591. package/src/drafts/draft08/data-streams.ts +359 -0
  592. package/src/drafts/draft08/index.ts +125 -0
  593. package/src/drafts/draft08/messages.ts +72 -0
  594. package/src/drafts/draft08/rules.ts +91 -0
  595. package/src/drafts/draft08/session-fsm.ts +718 -0
  596. package/src/drafts/draft08/session.ts +26 -0
  597. package/src/drafts/draft08/types.ts +384 -0
  598. package/src/drafts/draft09/codec.ts +936 -0
  599. package/src/drafts/draft09/data-streams.ts +332 -0
  600. package/src/drafts/draft09/index.ts +125 -0
  601. package/src/drafts/draft09/messages.ts +72 -0
  602. package/src/drafts/draft09/rules.ts +91 -0
  603. package/src/drafts/draft09/session-fsm.ts +718 -0
  604. package/src/drafts/draft09/session.ts +26 -0
  605. package/src/drafts/draft09/types.ts +384 -0
  606. package/src/drafts/draft10/codec.ts +936 -0
  607. package/src/drafts/draft10/data-streams.ts +332 -0
  608. package/src/drafts/draft10/index.ts +125 -0
  609. package/src/drafts/draft10/messages.ts +72 -0
  610. package/src/drafts/draft10/rules.ts +91 -0
  611. package/src/drafts/draft10/session-fsm.ts +718 -0
  612. package/src/drafts/draft10/session.ts +26 -0
  613. package/src/drafts/draft10/types.ts +384 -0
  614. package/src/drafts/draft11/codec.ts +969 -0
  615. package/src/drafts/draft11/data-streams.ts +269 -0
  616. package/src/drafts/draft11/index.ts +123 -0
  617. package/src/drafts/draft11/messages.ts +71 -0
  618. package/src/drafts/draft11/rules.ts +100 -0
  619. package/src/drafts/draft11/session-fsm.ts +758 -0
  620. package/src/drafts/draft11/session.ts +26 -0
  621. package/src/drafts/draft11/types.ts +381 -0
  622. package/src/drafts/draft12/codec.ts +1126 -0
  623. package/src/drafts/draft12/data-streams.ts +275 -0
  624. package/src/drafts/draft12/index.ts +130 -0
  625. package/src/drafts/draft12/messages.ts +84 -0
  626. package/src/drafts/draft12/rules.ts +106 -0
  627. package/src/drafts/draft12/session-fsm.ts +805 -0
  628. package/src/drafts/draft12/session.ts +26 -0
  629. package/src/drafts/draft12/types.ts +419 -0
  630. package/src/drafts/draft13/codec.ts +1210 -0
  631. package/src/drafts/draft13/data-streams.ts +275 -0
  632. package/src/drafts/draft13/index.ts +132 -0
  633. package/src/drafts/draft13/messages.ts +86 -0
  634. package/src/drafts/draft13/rules.ts +108 -0
  635. package/src/drafts/draft13/session-fsm.ts +819 -0
  636. package/src/drafts/draft13/session.ts +26 -0
  637. package/src/drafts/draft13/types.ts +438 -0
  638. package/src/drafts/draft14/codec.ts +1034 -1480
  639. package/src/drafts/draft14/data-streams.ts +798 -0
  640. package/src/drafts/draft14/session-fsm.ts +182 -1
  641. package/src/drafts/draft14/types.ts +381 -365
  642. package/src/drafts/draft15/codec.ts +969 -0
  643. package/src/drafts/draft15/data-streams.ts +778 -0
  644. package/src/drafts/draft15/index.ts +121 -0
  645. package/src/drafts/draft15/messages.ts +64 -0
  646. package/src/drafts/draft15/rules.ts +95 -0
  647. package/src/drafts/draft15/session-fsm.ts +687 -0
  648. package/src/drafts/draft15/session.ts +26 -0
  649. package/src/drafts/draft15/types.ts +339 -0
  650. package/src/drafts/draft16/codec.ts +957 -0
  651. package/src/drafts/draft16/data-streams.ts +773 -0
  652. package/src/drafts/draft16/index.ts +123 -0
  653. package/src/drafts/draft16/messages.ts +67 -0
  654. package/src/drafts/draft16/rules.ts +96 -0
  655. package/src/drafts/draft16/session-fsm.ts +682 -0
  656. package/src/drafts/draft16/session.ts +26 -0
  657. package/src/drafts/draft16/types.ts +357 -0
  658. package/src/drafts/draft17/codec.ts +962 -0
  659. package/src/drafts/draft17/data-streams.ts +742 -0
  660. package/src/drafts/draft17/index.ts +105 -0
  661. package/src/drafts/draft17/messages.ts +53 -0
  662. package/src/drafts/draft17/rules.ts +85 -0
  663. package/src/drafts/draft17/session-fsm.ts +437 -0
  664. package/src/drafts/draft17/session.ts +15 -0
  665. package/src/drafts/draft17/types.ts +313 -0
  666. package/src/index.ts +217 -2
@@ -0,0 +1,969 @@
1
+ import { bytesToHex, hexToBytes } from "../../core/hex.js";
2
+ import { BufferReader } from "../../core/buffer-reader.js";
3
+ import { BufferWriter } from "../../core/buffer-writer.js";
4
+ import type { BaseCodec, DecodeResult } from "../../core/types.js";
5
+ import { DecodeError } from "../../core/types.js";
6
+ import {
7
+ MESSAGE_ID_MAP,
8
+ MSG_CLIENT_SETUP,
9
+ MSG_FETCH,
10
+ MSG_FETCH_CANCEL,
11
+ MSG_FETCH_OK,
12
+ MSG_GOAWAY,
13
+ MSG_MAX_REQUEST_ID,
14
+ MSG_PUBLISH,
15
+ MSG_PUBLISH_DONE,
16
+ MSG_PUBLISH_NAMESPACE,
17
+ MSG_PUBLISH_NAMESPACE_CANCEL,
18
+ MSG_PUBLISH_NAMESPACE_DONE,
19
+ MSG_PUBLISH_OK,
20
+ MSG_REQUEST_ERROR,
21
+ MSG_REQUEST_OK,
22
+ MSG_REQUESTS_BLOCKED,
23
+ MSG_SERVER_SETUP,
24
+ MSG_SUBSCRIBE,
25
+ MSG_SUBSCRIBE_NAMESPACE,
26
+ MSG_SUBSCRIBE_OK,
27
+ MSG_SUBSCRIBE_UPDATE,
28
+ MSG_TRACK_STATUS,
29
+ MSG_UNSUBSCRIBE,
30
+ MSG_UNSUBSCRIBE_NAMESPACE,
31
+ SETUP_PARAM_AUTHORITY,
32
+ SETUP_PARAM_MAX_AUTH_TOKEN_CACHE_SIZE,
33
+ SETUP_PARAM_MAX_REQUEST_ID,
34
+ SETUP_PARAM_MOQT_IMPLEMENTATION,
35
+ SETUP_PARAM_PATH,
36
+ } from "./messages.js";
37
+ import type {
38
+ DatagramObject,
39
+ DataStreamEvent,
40
+ Draft15DataStream,
41
+ Draft15Fetch,
42
+ Draft15Message,
43
+ Draft15Params,
44
+ Draft15SetupParams,
45
+ FetchObjectPayload,
46
+ FetchStream,
47
+ FetchStreamHeader,
48
+ JoiningFetch,
49
+ ObjectPayload,
50
+ StandaloneFetch,
51
+ SubgroupStream,
52
+ SubgroupStreamHeader,
53
+ UnknownParam,
54
+ } from "./types.js";
55
+ // ─── Setup Parameter Encoding/Decoding ──────────────────────────────────────────
56
+
57
+ function encodeSetupParams(params: Draft15SetupParams, writer: BufferWriter): void {
58
+ let count = 0;
59
+ if (params.path !== undefined) count++;
60
+ if (params.max_request_id !== undefined) count++;
61
+ if (params.max_auth_token_cache_size !== undefined) count++;
62
+ if (params.authority !== undefined) count++;
63
+ if (params.moqt_implementation !== undefined) count++;
64
+ if (params.unknown) count += params.unknown.length;
65
+
66
+ writer.writeVarInt(count);
67
+
68
+ // PATH (0x01) - odd, length-prefixed bytes
69
+ if (params.path !== undefined) {
70
+ writer.writeVarInt(SETUP_PARAM_PATH);
71
+ const encoded = new TextEncoder().encode(params.path);
72
+ writer.writeVarInt(encoded.byteLength);
73
+ writer.writeBytes(encoded);
74
+ }
75
+
76
+ // MAX_REQUEST_ID (0x02) - even, varint value
77
+ if (params.max_request_id !== undefined) {
78
+ writer.writeVarInt(SETUP_PARAM_MAX_REQUEST_ID);
79
+ writer.writeVarInt(params.max_request_id);
80
+ }
81
+
82
+ // MAX_AUTH_TOKEN_CACHE_SIZE (0x04) - even, varint value
83
+ if (params.max_auth_token_cache_size !== undefined) {
84
+ writer.writeVarInt(SETUP_PARAM_MAX_AUTH_TOKEN_CACHE_SIZE);
85
+ writer.writeVarInt(params.max_auth_token_cache_size);
86
+ }
87
+
88
+ // AUTHORITY (0x05) - odd, length-prefixed bytes
89
+ if (params.authority !== undefined) {
90
+ writer.writeVarInt(SETUP_PARAM_AUTHORITY);
91
+ const encoded = new TextEncoder().encode(params.authority);
92
+ writer.writeVarInt(encoded.byteLength);
93
+ writer.writeBytes(encoded);
94
+ }
95
+
96
+ // MOQT_IMPLEMENTATION (0x07) - odd, length-prefixed bytes
97
+ if (params.moqt_implementation !== undefined) {
98
+ writer.writeVarInt(SETUP_PARAM_MOQT_IMPLEMENTATION);
99
+ const encoded = new TextEncoder().encode(params.moqt_implementation);
100
+ writer.writeVarInt(encoded.byteLength);
101
+ writer.writeBytes(encoded);
102
+ }
103
+
104
+ // Unknown params
105
+ if (params.unknown) {
106
+ for (const u of params.unknown) {
107
+ const id = BigInt(u.id);
108
+ writer.writeVarInt(id);
109
+ if (id % 2n === 0n) {
110
+ // Even: value is a varint — raw_hex contains the varint bytes
111
+ const raw = hexToBytes(u.raw_hex);
112
+ const tmpReader = new BufferReader(raw);
113
+ const value = tmpReader.readVarInt();
114
+ writer.writeVarInt(value);
115
+ } else {
116
+ // Odd: length-prefixed bytes
117
+ const raw = hexToBytes(u.raw_hex);
118
+ writer.writeVarInt(raw.byteLength);
119
+ writer.writeBytes(raw);
120
+ }
121
+ }
122
+ }
123
+ }
124
+
125
+ function decodeSetupParams(reader: BufferReader): Draft15SetupParams {
126
+ const count = Number(reader.readVarInt());
127
+ const result: Draft15SetupParams = {};
128
+ const unknown: UnknownParam[] = [];
129
+
130
+ for (let i = 0; i < count; i++) {
131
+ const paramType = reader.readVarInt();
132
+
133
+ if (paramType % 2n === 0n) {
134
+ // Even: value is a varint directly
135
+ const value = reader.readVarInt();
136
+ if (paramType === SETUP_PARAM_MAX_REQUEST_ID) {
137
+ result.max_request_id = value;
138
+ } else if (paramType === SETUP_PARAM_MAX_AUTH_TOKEN_CACHE_SIZE) {
139
+ result.max_auth_token_cache_size = value;
140
+ } else {
141
+ const tmpWriter = new BufferWriter(16);
142
+ tmpWriter.writeVarInt(value);
143
+ const raw = tmpWriter.finish();
144
+ unknown.push({
145
+ id: `0x${paramType.toString(16)}`,
146
+ length: raw.byteLength,
147
+ raw_hex: bytesToHex(raw),
148
+ });
149
+ }
150
+ } else {
151
+ // Odd: value is length-prefixed bytes
152
+ const length = Number(reader.readVarInt());
153
+ const bytes = reader.readBytes(length);
154
+ if (paramType === SETUP_PARAM_PATH) {
155
+ result.path = new TextDecoder().decode(bytes);
156
+ } else if (paramType === SETUP_PARAM_AUTHORITY) {
157
+ result.authority = new TextDecoder().decode(bytes);
158
+ } else if (paramType === SETUP_PARAM_MOQT_IMPLEMENTATION) {
159
+ result.moqt_implementation = new TextDecoder().decode(bytes);
160
+ } else {
161
+ unknown.push({
162
+ id: `0x${paramType.toString(16)}`,
163
+ length,
164
+ raw_hex: bytesToHex(bytes),
165
+ });
166
+ }
167
+ }
168
+ }
169
+
170
+ if (unknown.length > 0) {
171
+ result.unknown = unknown;
172
+ }
173
+
174
+ return result;
175
+ }
176
+
177
+ // ─── Version-Specific Parameter Encoding/Decoding ───────────────────────────────
178
+
179
+ // Well-known version-specific parameter IDs
180
+ const PARAM_EXPIRES = 0x08n; // even: varint
181
+ const PARAM_LARGEST_OBJECT = 0x09n; // odd: length-prefixed (group varint + object varint)
182
+ const PARAM_SUBSCRIBER_PRIORITY = 0x20n; // even: varint
183
+ const PARAM_SUBSCRIPTION_FILTER = 0x21n; // odd: length-prefixed
184
+ const PARAM_GROUP_ORDER = 0x22n; // even: varint
185
+
186
+ function encodeParams(params: Draft15Params, writer: BufferWriter): void {
187
+ // Count known + unknown params
188
+ let count = params.unknown ? params.unknown.length : 0;
189
+ if (params.expires !== undefined) count++;
190
+ if (params.largest_object !== undefined) count++;
191
+ if (params.subscriber_priority !== undefined) count++;
192
+ if (params.subscription_filter !== undefined) count++;
193
+ if (params.group_order !== undefined) count++;
194
+ writer.writeVarInt(count);
195
+
196
+ // Encode known params (sorted by ID for canonical encoding)
197
+ if (params.expires !== undefined) {
198
+ writer.writeVarInt(PARAM_EXPIRES);
199
+ writer.writeVarInt(params.expires);
200
+ }
201
+ if (params.largest_object !== undefined) {
202
+ writer.writeVarInt(PARAM_LARGEST_OBJECT);
203
+ const tmpW = new BufferWriter(16);
204
+ tmpW.writeVarInt(params.largest_object.group);
205
+ tmpW.writeVarInt(params.largest_object.object);
206
+ const raw = tmpW.finish();
207
+ writer.writeVarInt(raw.byteLength);
208
+ writer.writeBytes(raw);
209
+ }
210
+ if (params.subscriber_priority !== undefined) {
211
+ writer.writeVarInt(PARAM_SUBSCRIBER_PRIORITY);
212
+ writer.writeVarInt(params.subscriber_priority);
213
+ }
214
+ if (params.subscription_filter !== undefined) {
215
+ writer.writeVarInt(PARAM_SUBSCRIPTION_FILTER);
216
+ const tmpW = new BufferWriter(32);
217
+ const f = params.subscription_filter;
218
+ tmpW.writeVarInt(f.filter_type);
219
+ if (f.filter_type === 3n || f.filter_type === 4n) {
220
+ tmpW.writeVarInt(f.start_group!);
221
+ tmpW.writeVarInt(f.start_object!);
222
+ }
223
+ if (f.filter_type === 4n) {
224
+ tmpW.writeVarInt(f.end_group!);
225
+ }
226
+ const raw = tmpW.finish();
227
+ writer.writeVarInt(raw.byteLength);
228
+ writer.writeBytes(raw);
229
+ }
230
+ if (params.group_order !== undefined) {
231
+ writer.writeVarInt(PARAM_GROUP_ORDER);
232
+ writer.writeVarInt(params.group_order);
233
+ }
234
+
235
+ // Encode unknown params
236
+ if (params.unknown) {
237
+ for (const u of params.unknown) {
238
+ const id = BigInt(u.id);
239
+ writer.writeVarInt(id);
240
+ if (id % 2n === 0n) {
241
+ const raw = hexToBytes(u.raw_hex);
242
+ const tmpReader = new BufferReader(raw);
243
+ const value = tmpReader.readVarInt();
244
+ writer.writeVarInt(value);
245
+ } else {
246
+ const raw = hexToBytes(u.raw_hex);
247
+ writer.writeVarInt(raw.byteLength);
248
+ writer.writeBytes(raw);
249
+ }
250
+ }
251
+ }
252
+ }
253
+
254
+ function decodeParams(reader: BufferReader): Draft15Params {
255
+ const count = Number(reader.readVarInt());
256
+ const result: Draft15Params = {};
257
+ const unknown: UnknownParam[] = [];
258
+
259
+ for (let i = 0; i < count; i++) {
260
+ const paramType = reader.readVarInt();
261
+
262
+ if (paramType === PARAM_EXPIRES) {
263
+ result.expires = reader.readVarInt();
264
+ } else if (paramType === PARAM_SUBSCRIBER_PRIORITY) {
265
+ result.subscriber_priority = reader.readVarInt();
266
+ } else if (paramType === PARAM_GROUP_ORDER) {
267
+ result.group_order = reader.readVarInt();
268
+ } else if (paramType === PARAM_LARGEST_OBJECT) {
269
+ const length = Number(reader.readVarInt());
270
+ const startOff = reader.offset;
271
+ const group = reader.readVarInt();
272
+ const object = reader.readVarInt();
273
+ // Skip any remaining bytes in the length-prefixed block
274
+ const consumed = reader.offset - startOff;
275
+ if (consumed < length) reader.readBytes(length - consumed);
276
+ result.largest_object = { group, object };
277
+ } else if (paramType === PARAM_SUBSCRIPTION_FILTER) {
278
+ const length = Number(reader.readVarInt());
279
+ const startOff = reader.offset;
280
+ const filter_type = reader.readVarInt();
281
+ const filter: {
282
+ filter_type: bigint;
283
+ start_group?: bigint;
284
+ start_object?: bigint;
285
+ end_group?: bigint;
286
+ } = { filter_type };
287
+ if (filter_type === 3n || filter_type === 4n) {
288
+ filter.start_group = reader.readVarInt();
289
+ filter.start_object = reader.readVarInt();
290
+ }
291
+ if (filter_type === 4n) {
292
+ filter.end_group = reader.readVarInt();
293
+ }
294
+ // Skip any remaining bytes
295
+ const consumed = reader.offset - startOff;
296
+ if (consumed < length) reader.readBytes(length - consumed);
297
+ result.subscription_filter = filter;
298
+ } else if (paramType % 2n === 0n) {
299
+ // Unknown even: varint value
300
+ const value = reader.readVarInt();
301
+ const tmpWriter = new BufferWriter(16);
302
+ tmpWriter.writeVarInt(value);
303
+ const raw = tmpWriter.finish();
304
+ unknown.push({
305
+ id: `0x${paramType.toString(16)}`,
306
+ length: raw.byteLength,
307
+ raw_hex: bytesToHex(raw),
308
+ });
309
+ } else {
310
+ // Unknown odd: length-prefixed bytes
311
+ const length = Number(reader.readVarInt());
312
+ const bytes = reader.readBytes(length);
313
+ unknown.push({
314
+ id: `0x${paramType.toString(16)}`,
315
+ length,
316
+ raw_hex: bytesToHex(bytes),
317
+ });
318
+ }
319
+ }
320
+
321
+ if (unknown.length > 0) {
322
+ result.unknown = unknown;
323
+ }
324
+
325
+ return result;
326
+ }
327
+
328
+ // ─── Payload Encoders ──────────────────────────────────────────────────────────
329
+
330
+ function encodeClientSetupPayload(
331
+ msg: Draft15Message & { type: "client_setup" },
332
+ w: BufferWriter,
333
+ ): void {
334
+ encodeSetupParams(msg.parameters, w);
335
+ }
336
+
337
+ function encodeServerSetupPayload(
338
+ msg: Draft15Message & { type: "server_setup" },
339
+ w: BufferWriter,
340
+ ): void {
341
+ encodeSetupParams(msg.parameters, w);
342
+ }
343
+
344
+ function encodeSubscribePayload(
345
+ msg: Draft15Message & { type: "subscribe" },
346
+ w: BufferWriter,
347
+ ): void {
348
+ w.writeVarInt(msg.request_id);
349
+ w.writeTuple(msg.track_namespace);
350
+ w.writeString(msg.track_name);
351
+ encodeParams(msg.parameters, w);
352
+ }
353
+
354
+ function encodeSubscribeOkPayload(
355
+ msg: Draft15Message & { type: "subscribe_ok" },
356
+ w: BufferWriter,
357
+ ): void {
358
+ w.writeVarInt(msg.request_id);
359
+ w.writeVarInt(msg.track_alias);
360
+ encodeParams(msg.parameters, w);
361
+ }
362
+
363
+ function encodeSubscribeUpdatePayload(
364
+ msg: Draft15Message & { type: "subscribe_update" },
365
+ w: BufferWriter,
366
+ ): void {
367
+ w.writeVarInt(msg.request_id);
368
+ w.writeVarInt(msg.subscription_request_id);
369
+ encodeParams(msg.parameters, w);
370
+ }
371
+
372
+ function encodeUnsubscribePayload(
373
+ msg: Draft15Message & { type: "unsubscribe" },
374
+ w: BufferWriter,
375
+ ): void {
376
+ w.writeVarInt(msg.request_id);
377
+ }
378
+
379
+ function encodePublishPayload(msg: Draft15Message & { type: "publish" }, w: BufferWriter): void {
380
+ w.writeVarInt(msg.request_id);
381
+ w.writeTuple(msg.track_namespace);
382
+ w.writeString(msg.track_name);
383
+ w.writeVarInt(msg.track_alias);
384
+ encodeParams(msg.parameters, w);
385
+ }
386
+
387
+ function encodePublishOkPayload(
388
+ msg: Draft15Message & { type: "publish_ok" },
389
+ w: BufferWriter,
390
+ ): void {
391
+ w.writeVarInt(msg.request_id);
392
+ encodeParams(msg.parameters, w);
393
+ }
394
+
395
+ function encodePublishDonePayload(
396
+ msg: Draft15Message & { type: "publish_done" },
397
+ w: BufferWriter,
398
+ ): void {
399
+ w.writeVarInt(msg.request_id);
400
+ w.writeVarInt(msg.status_code);
401
+ w.writeVarInt(msg.stream_count);
402
+ w.writeString(msg.reason_phrase);
403
+ }
404
+
405
+ function encodePublishNamespacePayload(
406
+ msg: Draft15Message & { type: "publish_namespace" },
407
+ w: BufferWriter,
408
+ ): void {
409
+ w.writeVarInt(msg.request_id);
410
+ w.writeTuple(msg.track_namespace);
411
+ encodeParams(msg.parameters, w);
412
+ }
413
+
414
+ function encodePublishNamespaceDonePayload(
415
+ msg: Draft15Message & { type: "publish_namespace_done" },
416
+ w: BufferWriter,
417
+ ): void {
418
+ w.writeTuple(msg.track_namespace);
419
+ }
420
+
421
+ function encodePublishNamespaceCancelPayload(
422
+ msg: Draft15Message & { type: "publish_namespace_cancel" },
423
+ w: BufferWriter,
424
+ ): void {
425
+ w.writeTuple(msg.track_namespace);
426
+ w.writeVarInt(msg.error_code);
427
+ w.writeString(msg.reason_phrase);
428
+ }
429
+
430
+ function encodeSubscribeNamespacePayload(
431
+ msg: Draft15Message & { type: "subscribe_namespace" },
432
+ w: BufferWriter,
433
+ ): void {
434
+ w.writeVarInt(msg.request_id);
435
+ w.writeTuple(msg.namespace_prefix);
436
+ encodeParams(msg.parameters, w);
437
+ }
438
+
439
+ function encodeUnsubscribeNamespacePayload(
440
+ msg: Draft15Message & { type: "unsubscribe_namespace" },
441
+ w: BufferWriter,
442
+ ): void {
443
+ w.writeVarInt(msg.request_id);
444
+ }
445
+
446
+ function encodeFetchPayload(msg: Draft15Message & { type: "fetch" }, w: BufferWriter): void {
447
+ w.writeVarInt(msg.request_id);
448
+ w.writeVarInt(msg.fetch_type);
449
+ const ft = Number(msg.fetch_type);
450
+ if (ft === 1 && msg.standalone) {
451
+ // Standalone Fetch
452
+ w.writeTuple(msg.standalone.track_namespace);
453
+ w.writeString(msg.standalone.track_name);
454
+ // Start Location
455
+ w.writeVarInt(msg.standalone.start_group);
456
+ w.writeVarInt(msg.standalone.start_object);
457
+ // End Location
458
+ w.writeVarInt(msg.standalone.end_group);
459
+ w.writeVarInt(msg.standalone.end_object);
460
+ } else if ((ft === 2 || ft === 3) && msg.joining) {
461
+ // Joining Fetch (relative=2, absolute=3)
462
+ w.writeVarInt(msg.joining.joining_request_id);
463
+ w.writeVarInt(msg.joining.joining_start);
464
+ }
465
+ encodeParams(msg.parameters, w);
466
+ }
467
+
468
+ function encodeFetchOkPayload(msg: Draft15Message & { type: "fetch_ok" }, w: BufferWriter): void {
469
+ w.writeVarInt(msg.request_id);
470
+ w.writeUint8(msg.end_of_track);
471
+ // End Location
472
+ w.writeVarInt(msg.end_group);
473
+ w.writeVarInt(msg.end_object);
474
+ encodeParams(msg.parameters, w);
475
+ }
476
+
477
+ function encodeFetchCancelPayload(
478
+ msg: Draft15Message & { type: "fetch_cancel" },
479
+ w: BufferWriter,
480
+ ): void {
481
+ w.writeVarInt(msg.request_id);
482
+ }
483
+
484
+ function encodeTrackStatusPayload(
485
+ msg: Draft15Message & { type: "track_status" },
486
+ w: BufferWriter,
487
+ ): void {
488
+ w.writeVarInt(msg.request_id);
489
+ w.writeTuple(msg.track_namespace);
490
+ w.writeString(msg.track_name);
491
+ encodeParams(msg.parameters, w);
492
+ }
493
+
494
+ function encodeRequestOkPayload(
495
+ msg: Draft15Message & { type: "request_ok" },
496
+ w: BufferWriter,
497
+ ): void {
498
+ w.writeVarInt(msg.request_id);
499
+ encodeParams(msg.parameters, w);
500
+ }
501
+
502
+ function encodeRequestErrorPayload(
503
+ msg: Draft15Message & { type: "request_error" },
504
+ w: BufferWriter,
505
+ ): void {
506
+ w.writeVarInt(msg.request_id);
507
+ w.writeVarInt(msg.error_code);
508
+ w.writeString(msg.reason_phrase);
509
+ }
510
+
511
+ function encodeGoAwayPayload(msg: Draft15Message & { type: "goaway" }, w: BufferWriter): void {
512
+ w.writeString(msg.new_session_uri);
513
+ }
514
+
515
+ function encodeMaxRequestIdPayload(
516
+ msg: Draft15Message & { type: "max_request_id" },
517
+ w: BufferWriter,
518
+ ): void {
519
+ w.writeVarInt(msg.max_request_id);
520
+ }
521
+
522
+ function encodeRequestsBlockedPayload(
523
+ msg: Draft15Message & { type: "requests_blocked" },
524
+ w: BufferWriter,
525
+ ): void {
526
+ w.writeVarInt(msg.maximum_request_id);
527
+ }
528
+
529
+ // ─── Payload Decoders ──────────────────────────────────────────────────────────
530
+
531
+ function decodeClientSetupPayload(r: BufferReader): Draft15Message {
532
+ const parameters = decodeSetupParams(r);
533
+ return { type: "client_setup", parameters };
534
+ }
535
+
536
+ function decodeServerSetupPayload(r: BufferReader): Draft15Message {
537
+ const parameters = decodeSetupParams(r);
538
+ return { type: "server_setup", parameters };
539
+ }
540
+
541
+ function decodeSubscribePayload(r: BufferReader): Draft15Message {
542
+ const request_id = r.readVarInt();
543
+ const track_namespace = r.readTuple();
544
+ const track_name = r.readString();
545
+ const parameters = decodeParams(r);
546
+ return { type: "subscribe", request_id, track_namespace, track_name, parameters };
547
+ }
548
+
549
+ function decodeSubscribeOkPayload(r: BufferReader): Draft15Message {
550
+ const request_id = r.readVarInt();
551
+ const track_alias = r.readVarInt();
552
+ const parameters = decodeParams(r);
553
+ return { type: "subscribe_ok", request_id, track_alias, parameters };
554
+ }
555
+
556
+ function decodeSubscribeUpdatePayload(r: BufferReader): Draft15Message {
557
+ const request_id = r.readVarInt();
558
+ const subscription_request_id = r.readVarInt();
559
+ const parameters = decodeParams(r);
560
+ return { type: "subscribe_update", request_id, subscription_request_id, parameters };
561
+ }
562
+
563
+ function decodeUnsubscribePayload(r: BufferReader): Draft15Message {
564
+ const request_id = r.readVarInt();
565
+ return { type: "unsubscribe", request_id };
566
+ }
567
+
568
+ function decodePublishPayload(r: BufferReader): Draft15Message {
569
+ const request_id = r.readVarInt();
570
+ const track_namespace = r.readTuple();
571
+ const track_name = r.readString();
572
+ const track_alias = r.readVarInt();
573
+ const parameters = decodeParams(r);
574
+ return { type: "publish", request_id, track_namespace, track_name, track_alias, parameters };
575
+ }
576
+
577
+ function decodePublishOkPayload(r: BufferReader): Draft15Message {
578
+ const request_id = r.readVarInt();
579
+ const parameters = decodeParams(r);
580
+ return { type: "publish_ok", request_id, parameters };
581
+ }
582
+
583
+ function decodePublishDonePayload(r: BufferReader): Draft15Message {
584
+ const request_id = r.readVarInt();
585
+ const status_code = r.readVarInt();
586
+ const stream_count = r.readVarInt();
587
+ const reason_phrase = r.readString();
588
+ return { type: "publish_done", request_id, status_code, stream_count, reason_phrase };
589
+ }
590
+
591
+ function decodePublishNamespacePayload(r: BufferReader): Draft15Message {
592
+ const request_id = r.readVarInt();
593
+ const track_namespace = r.readTuple();
594
+ const parameters = decodeParams(r);
595
+ return { type: "publish_namespace", request_id, track_namespace, parameters };
596
+ }
597
+
598
+ function decodePublishNamespaceDonePayload(r: BufferReader): Draft15Message {
599
+ const track_namespace = r.readTuple();
600
+ return { type: "publish_namespace_done", track_namespace };
601
+ }
602
+
603
+ function decodePublishNamespaceCancelPayload(r: BufferReader): Draft15Message {
604
+ const track_namespace = r.readTuple();
605
+ const error_code = r.readVarInt();
606
+ const reason_phrase = r.readString();
607
+ return { type: "publish_namespace_cancel", track_namespace, error_code, reason_phrase };
608
+ }
609
+
610
+ function decodeSubscribeNamespacePayload(r: BufferReader): Draft15Message {
611
+ const request_id = r.readVarInt();
612
+ const namespace_prefix = r.readTuple();
613
+ const parameters = decodeParams(r);
614
+ return { type: "subscribe_namespace", request_id, namespace_prefix, parameters };
615
+ }
616
+
617
+ function decodeUnsubscribeNamespacePayload(r: BufferReader): Draft15Message {
618
+ const request_id = r.readVarInt();
619
+ return { type: "unsubscribe_namespace", request_id };
620
+ }
621
+
622
+ function decodeFetchPayload(r: BufferReader): Draft15Message {
623
+ const request_id = r.readVarInt();
624
+ const fetch_type = r.readVarInt();
625
+ const ft = Number(fetch_type);
626
+
627
+ if (ft < 1 || ft > 3) {
628
+ throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid fetch_type: ${ft}`, r.offset);
629
+ }
630
+
631
+ let standalone: StandaloneFetch | undefined;
632
+ let joining: JoiningFetch | undefined;
633
+
634
+ if (ft === 1) {
635
+ // Standalone Fetch
636
+ const track_namespace = r.readTuple();
637
+ const track_name = r.readString();
638
+ const start_group = r.readVarInt();
639
+ const start_object = r.readVarInt();
640
+ const end_group = r.readVarInt();
641
+ const end_object = r.readVarInt();
642
+ standalone = { track_namespace, track_name, start_group, start_object, end_group, end_object };
643
+ } else {
644
+ // Joining Fetch (relative=2, absolute=3)
645
+ const joining_request_id = r.readVarInt();
646
+ const joining_start = r.readVarInt();
647
+ joining = { joining_request_id, joining_start };
648
+ }
649
+
650
+ const parameters = decodeParams(r);
651
+
652
+ return {
653
+ type: "fetch",
654
+ request_id,
655
+ fetch_type,
656
+ standalone,
657
+ joining,
658
+ parameters,
659
+ } as Draft15Fetch;
660
+ }
661
+
662
+ function decodeFetchOkPayload(r: BufferReader): Draft15Message {
663
+ const request_id = r.readVarInt();
664
+ const end_of_track = r.readUint8();
665
+ const end_group = r.readVarInt();
666
+ const end_object = r.readVarInt();
667
+ const parameters = decodeParams(r);
668
+ return { type: "fetch_ok", request_id, end_of_track, end_group, end_object, parameters };
669
+ }
670
+
671
+ function decodeFetchCancelPayload(r: BufferReader): Draft15Message {
672
+ const request_id = r.readVarInt();
673
+ return { type: "fetch_cancel", request_id };
674
+ }
675
+
676
+ function decodeTrackStatusPayload(r: BufferReader): Draft15Message {
677
+ const request_id = r.readVarInt();
678
+ const track_namespace = r.readTuple();
679
+ const track_name = r.readString();
680
+ const parameters = decodeParams(r);
681
+ return { type: "track_status", request_id, track_namespace, track_name, parameters };
682
+ }
683
+
684
+ function decodeRequestOkPayload(r: BufferReader): Draft15Message {
685
+ const request_id = r.readVarInt();
686
+ const parameters = decodeParams(r);
687
+ return { type: "request_ok", request_id, parameters };
688
+ }
689
+
690
+ function decodeRequestErrorPayload(r: BufferReader): Draft15Message {
691
+ const request_id = r.readVarInt();
692
+ const error_code = r.readVarInt();
693
+ const reason_phrase = r.readString();
694
+ return { type: "request_error", request_id, error_code, reason_phrase };
695
+ }
696
+
697
+ function decodeGoAwayPayload(r: BufferReader): Draft15Message {
698
+ const new_session_uri = r.readString();
699
+ return { type: "goaway", new_session_uri };
700
+ }
701
+
702
+ function decodeMaxRequestIdPayload(r: BufferReader): Draft15Message {
703
+ const max_request_id = r.readVarInt();
704
+ return { type: "max_request_id", max_request_id };
705
+ }
706
+
707
+ function decodeRequestsBlockedPayload(r: BufferReader): Draft15Message {
708
+ const maximum_request_id = r.readVarInt();
709
+ return { type: "requests_blocked", maximum_request_id };
710
+ }
711
+
712
+ // ─── Payload dispatch tables ───────────────────────────────────────────────────
713
+
714
+ const payloadDecoders: ReadonlyMap<bigint, (r: BufferReader) => Draft15Message> = new Map([
715
+ [MSG_CLIENT_SETUP, decodeClientSetupPayload],
716
+ [MSG_SERVER_SETUP, decodeServerSetupPayload],
717
+ [MSG_SUBSCRIBE, decodeSubscribePayload],
718
+ [MSG_SUBSCRIBE_OK, decodeSubscribeOkPayload],
719
+ [MSG_SUBSCRIBE_UPDATE, decodeSubscribeUpdatePayload],
720
+ [MSG_UNSUBSCRIBE, decodeUnsubscribePayload],
721
+ [MSG_PUBLISH, decodePublishPayload],
722
+ [MSG_PUBLISH_OK, decodePublishOkPayload],
723
+ [MSG_PUBLISH_DONE, decodePublishDonePayload],
724
+ [MSG_PUBLISH_NAMESPACE, decodePublishNamespacePayload],
725
+ [MSG_PUBLISH_NAMESPACE_DONE, decodePublishNamespaceDonePayload],
726
+ [MSG_PUBLISH_NAMESPACE_CANCEL, decodePublishNamespaceCancelPayload],
727
+ [MSG_SUBSCRIBE_NAMESPACE, decodeSubscribeNamespacePayload],
728
+ [MSG_UNSUBSCRIBE_NAMESPACE, decodeUnsubscribeNamespacePayload],
729
+ [MSG_FETCH, decodeFetchPayload],
730
+ [MSG_FETCH_OK, decodeFetchOkPayload],
731
+ [MSG_FETCH_CANCEL, decodeFetchCancelPayload],
732
+ [MSG_TRACK_STATUS, decodeTrackStatusPayload],
733
+ [MSG_REQUEST_OK, decodeRequestOkPayload],
734
+ [MSG_REQUEST_ERROR, decodeRequestErrorPayload],
735
+ [MSG_GOAWAY, decodeGoAwayPayload],
736
+ [MSG_MAX_REQUEST_ID, decodeMaxRequestIdPayload],
737
+ [MSG_REQUESTS_BLOCKED, decodeRequestsBlockedPayload],
738
+ ]);
739
+
740
+ // ─── Public API ────────────────────────────────────────────────────────────────
741
+
742
+ /**
743
+ * Encode a draft-15 control message with type(varint) + length(uint16 BE) + payload.
744
+ */
745
+ export function encodeMessage(message: Draft15Message): Uint8Array {
746
+ const typeId = MESSAGE_ID_MAP.get(message.type);
747
+ if (typeId === undefined) {
748
+ throw new Error(`Unknown message type: ${message.type}`);
749
+ }
750
+
751
+ // Encode payload into a separate buffer
752
+ const payloadWriter = new BufferWriter();
753
+ encodePayload(message, payloadWriter);
754
+ const payload = payloadWriter.finish();
755
+
756
+ if (payload.byteLength > 0xffff) {
757
+ throw new Error(`Payload too large for 16-bit length: ${payload.byteLength}`);
758
+ }
759
+
760
+ // Write framed message: type(varint) + length(uint16 BE) + payload
761
+ const writer = new BufferWriter();
762
+ writer.writeVarInt(typeId);
763
+ writer.writeUint8((payload.byteLength >> 8) & 0xff);
764
+ writer.writeUint8(payload.byteLength & 0xff);
765
+ writer.writeBytes(payload);
766
+
767
+ return writer.finish();
768
+ }
769
+
770
+ function encodePayload(msg: Draft15Message, w: BufferWriter): void {
771
+ switch (msg.type) {
772
+ case "client_setup":
773
+ return encodeClientSetupPayload(msg, w);
774
+ case "server_setup":
775
+ return encodeServerSetupPayload(msg, w);
776
+ case "subscribe":
777
+ return encodeSubscribePayload(msg, w);
778
+ case "subscribe_ok":
779
+ return encodeSubscribeOkPayload(msg, w);
780
+ case "subscribe_update":
781
+ return encodeSubscribeUpdatePayload(msg, w);
782
+ case "unsubscribe":
783
+ return encodeUnsubscribePayload(msg, w);
784
+ case "publish":
785
+ return encodePublishPayload(msg, w);
786
+ case "publish_ok":
787
+ return encodePublishOkPayload(msg, w);
788
+ case "publish_done":
789
+ return encodePublishDonePayload(msg, w);
790
+ case "publish_namespace":
791
+ return encodePublishNamespacePayload(msg, w);
792
+ case "publish_namespace_done":
793
+ return encodePublishNamespaceDonePayload(msg, w);
794
+ case "publish_namespace_cancel":
795
+ return encodePublishNamespaceCancelPayload(msg, w);
796
+ case "subscribe_namespace":
797
+ return encodeSubscribeNamespacePayload(msg, w);
798
+ case "unsubscribe_namespace":
799
+ return encodeUnsubscribeNamespacePayload(msg, w);
800
+ case "fetch":
801
+ return encodeFetchPayload(msg, w);
802
+ case "fetch_ok":
803
+ return encodeFetchOkPayload(msg, w);
804
+ case "fetch_cancel":
805
+ return encodeFetchCancelPayload(msg, w);
806
+ case "track_status":
807
+ return encodeTrackStatusPayload(msg, w);
808
+ case "request_ok":
809
+ return encodeRequestOkPayload(msg, w);
810
+ case "request_error":
811
+ return encodeRequestErrorPayload(msg, w);
812
+ case "goaway":
813
+ return encodeGoAwayPayload(msg, w);
814
+ case "max_request_id":
815
+ return encodeMaxRequestIdPayload(msg, w);
816
+ case "requests_blocked":
817
+ return encodeRequestsBlockedPayload(msg, w);
818
+ default: {
819
+ const _exhaustive: never = msg;
820
+ throw new Error(`Unhandled message type: ${(_exhaustive as Draft15Message).type}`);
821
+ }
822
+ }
823
+ }
824
+
825
+ /**
826
+ * Decode a draft-15 control message from bytes (type + uint16 length + payload).
827
+ */
828
+ export function decodeMessage(bytes: Uint8Array): DecodeResult<Draft15Message> {
829
+ try {
830
+ const reader = new BufferReader(bytes);
831
+ const typeId = reader.readVarInt();
832
+
833
+ // Read 16-bit big-endian payload length
834
+ const lenHi = reader.readUint8();
835
+ const lenLo = reader.readUint8();
836
+ const payloadLength = (lenHi << 8) | lenLo;
837
+
838
+ // Read exactly payloadLength bytes
839
+ const payloadBytes = reader.readBytes(payloadLength);
840
+ const payloadReader = new BufferReader(payloadBytes);
841
+
842
+ const decoder = payloadDecoders.get(typeId);
843
+ if (!decoder) {
844
+ return {
845
+ ok: false,
846
+ error: new DecodeError(
847
+ "UNKNOWN_MESSAGE_TYPE",
848
+ `Unknown message type ID: 0x${typeId.toString(16)}`,
849
+ 0,
850
+ ),
851
+ };
852
+ }
853
+
854
+ const message = decoder(payloadReader);
855
+ return { ok: true, value: message, bytesRead: reader.offset };
856
+ } catch (e) {
857
+ if (e instanceof DecodeError) {
858
+ return { ok: false, error: e };
859
+ }
860
+ throw e;
861
+ }
862
+ }
863
+
864
+ // ─── Data Stream Re-exports ───────────────────────────────────────────────────
865
+
866
+ import {
867
+ encodeSubgroupStream,
868
+ decodeSubgroupStream,
869
+ encodeDatagram,
870
+ decodeDatagram,
871
+ encodeFetchStream,
872
+ decodeFetchStream,
873
+ decodeDataStream,
874
+ createSubgroupStreamDecoder,
875
+ createFetchStreamDecoder,
876
+ createDataStreamDecoder,
877
+ } from "./data-streams.js";
878
+
879
+ export {
880
+ encodeSubgroupStream,
881
+ decodeSubgroupStream,
882
+ encodeDatagram,
883
+ decodeDatagram,
884
+ encodeFetchStream,
885
+ decodeFetchStream,
886
+ decodeDataStream,
887
+ createSubgroupStreamDecoder,
888
+ createFetchStreamDecoder,
889
+ createDataStreamDecoder,
890
+ };
891
+
892
+ // ─── Stream Decoders ───────────────────────────────────────────────────────────
893
+
894
+ /**
895
+ * Create a TransformStream that decodes a continuous byte stream into
896
+ * individual Draft15Message objects.
897
+ */
898
+ export function createStreamDecoder(): TransformStream<Uint8Array, Draft15Message> {
899
+ let buffer = new Uint8Array(0);
900
+
901
+ return new TransformStream<Uint8Array, Draft15Message>({
902
+ transform(chunk, controller) {
903
+ const newBuffer = new Uint8Array(buffer.length + chunk.length);
904
+ newBuffer.set(buffer, 0);
905
+ newBuffer.set(chunk, buffer.length);
906
+ buffer = newBuffer;
907
+
908
+ while (buffer.length > 0) {
909
+ const result = decodeMessage(buffer);
910
+ if (!result.ok) {
911
+ if (result.error.code === "UNEXPECTED_END") {
912
+ break;
913
+ }
914
+ controller.error(result.error);
915
+ return;
916
+ }
917
+ controller.enqueue(result.value);
918
+ buffer = buffer.slice(result.bytesRead);
919
+ }
920
+ },
921
+
922
+ flush(controller) {
923
+ if (buffer.length > 0) {
924
+ controller.error(
925
+ new DecodeError("UNEXPECTED_END", "Stream ended with incomplete message data", 0),
926
+ );
927
+ }
928
+ },
929
+ });
930
+ }
931
+
932
+ // ─── Codec Factory ─────────────────────────────────────────────────────────────
933
+
934
+ export interface Draft15Codec extends BaseCodec<Draft15Message> {
935
+ readonly draft: "draft-ietf-moq-transport-15";
936
+ encodeSubgroupStream(stream: SubgroupStream): Uint8Array;
937
+ encodeDatagram(dg: DatagramObject): Uint8Array;
938
+ encodeFetchStream(stream: FetchStream): Uint8Array;
939
+ decodeSubgroupStream(bytes: Uint8Array): DecodeResult<SubgroupStream>;
940
+ decodeDatagram(bytes: Uint8Array): DecodeResult<DatagramObject>;
941
+ decodeFetchStream(bytes: Uint8Array): DecodeResult<FetchStream>;
942
+ decodeDataStream(
943
+ streamType: "subgroup" | "datagram" | "fetch",
944
+ bytes: Uint8Array,
945
+ ): DecodeResult<Draft15DataStream>;
946
+ createStreamDecoder(): TransformStream<Uint8Array, Draft15Message>;
947
+ createSubgroupStreamDecoder(): TransformStream<Uint8Array, SubgroupStreamHeader | ObjectPayload>;
948
+ createFetchStreamDecoder(): TransformStream<Uint8Array, FetchStreamHeader | ObjectPayload>;
949
+ createDataStreamDecoder(): TransformStream<Uint8Array, DataStreamEvent>;
950
+ }
951
+
952
+ export function createDraft15Codec(): Draft15Codec {
953
+ return {
954
+ draft: "draft-ietf-moq-transport-15",
955
+ encodeMessage,
956
+ decodeMessage,
957
+ encodeSubgroupStream,
958
+ encodeDatagram,
959
+ encodeFetchStream,
960
+ decodeSubgroupStream,
961
+ decodeDatagram,
962
+ decodeFetchStream,
963
+ decodeDataStream,
964
+ createStreamDecoder,
965
+ createSubgroupStreamDecoder,
966
+ createFetchStreamDecoder,
967
+ createDataStreamDecoder,
968
+ };
969
+ }