@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,962 @@
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_FETCH,
9
+ MSG_FETCH_OK,
10
+ MSG_GOAWAY,
11
+ MSG_NAMESPACE,
12
+ MSG_NAMESPACE_DONE,
13
+ MSG_PUBLISH,
14
+ MSG_PUBLISH_BLOCKED,
15
+ MSG_PUBLISH_DONE,
16
+ MSG_PUBLISH_NAMESPACE,
17
+ MSG_PUBLISH_OK,
18
+ MSG_REQUEST_ERROR,
19
+ MSG_REQUEST_OK,
20
+ MSG_REQUEST_UPDATE,
21
+ MSG_SETUP,
22
+ MSG_SUBSCRIBE,
23
+ MSG_SUBSCRIBE_NAMESPACE,
24
+ MSG_SUBSCRIBE_OK,
25
+ MSG_TRACK_STATUS,
26
+ SETUP_OPT_AUTHORITY,
27
+ SETUP_OPT_MAX_AUTH_TOKEN_CACHE_SIZE,
28
+ SETUP_OPT_MOQT_IMPLEMENTATION,
29
+ SETUP_OPT_PATH,
30
+ } from "./messages.js";
31
+ import type {
32
+ DatagramObject,
33
+ DataStreamEvent,
34
+ Draft17DataStream,
35
+ Draft17Fetch,
36
+ Draft17Message,
37
+ Draft17Params,
38
+ Draft17SetupOptions,
39
+ Draft17TrackProperties,
40
+ FetchObjectPayload,
41
+ FetchStream,
42
+ FetchStreamHeader,
43
+ JoiningFetch,
44
+ ObjectPayload,
45
+ StandaloneFetch,
46
+ SubgroupStream,
47
+ SubgroupStreamHeader,
48
+ UnknownParam,
49
+ } from "./types.js";
50
+ // ─── Setup Options Encoding/Decoding (KVP, no count prefix) ─────────────────
51
+
52
+ function encodeSetupOptions(opts: Draft17SetupOptions, writer: BufferWriter): void {
53
+ // Collect all options sorted by type ID
54
+ const entries: Array<{ type: bigint; encode: (w: BufferWriter) => void }> = [];
55
+
56
+ if (opts.path !== undefined) {
57
+ entries.push({
58
+ type: SETUP_OPT_PATH,
59
+ encode: (w) => {
60
+ const encoded = new TextEncoder().encode(opts.path!);
61
+ w.writeVarInt(BigInt(encoded.byteLength));
62
+ w.writeBytes(encoded);
63
+ },
64
+ });
65
+ }
66
+ if (opts.max_auth_token_cache_size !== undefined) {
67
+ entries.push({
68
+ type: SETUP_OPT_MAX_AUTH_TOKEN_CACHE_SIZE,
69
+ encode: (w) => w.writeVarInt(opts.max_auth_token_cache_size!),
70
+ });
71
+ }
72
+ if (opts.authority !== undefined) {
73
+ entries.push({
74
+ type: SETUP_OPT_AUTHORITY,
75
+ encode: (w) => {
76
+ const encoded = new TextEncoder().encode(opts.authority!);
77
+ w.writeVarInt(BigInt(encoded.byteLength));
78
+ w.writeBytes(encoded);
79
+ },
80
+ });
81
+ }
82
+ if (opts.moqt_implementation !== undefined) {
83
+ entries.push({
84
+ type: SETUP_OPT_MOQT_IMPLEMENTATION,
85
+ encode: (w) => {
86
+ const encoded = new TextEncoder().encode(opts.moqt_implementation!);
87
+ w.writeVarInt(BigInt(encoded.byteLength));
88
+ w.writeBytes(encoded);
89
+ },
90
+ });
91
+ }
92
+ if (opts.unknown) {
93
+ for (const u of opts.unknown) {
94
+ const id = BigInt(u.id);
95
+ entries.push({
96
+ type: id,
97
+ encode: (w) => {
98
+ if (id % 2n === 0n) {
99
+ const raw = hexToBytes(u.raw_hex);
100
+ const tmpReader = new BufferReader(raw);
101
+ w.writeVarInt(tmpReader.readVarInt());
102
+ } else {
103
+ const raw = hexToBytes(u.raw_hex);
104
+ w.writeVarInt(BigInt(raw.byteLength));
105
+ w.writeBytes(raw);
106
+ }
107
+ },
108
+ });
109
+ }
110
+ }
111
+
112
+ // Sort by type (ascending) and write with delta encoding
113
+ entries.sort((a, b) => (a.type < b.type ? -1 : a.type > b.type ? 1 : 0));
114
+ let prevType = 0n;
115
+ for (const entry of entries) {
116
+ writer.writeVarInt(entry.type - prevType);
117
+ entry.encode(writer);
118
+ prevType = entry.type;
119
+ }
120
+ }
121
+
122
+ function decodeSetupOptions(reader: BufferReader, payloadEnd: number): Draft17SetupOptions {
123
+ const result: Draft17SetupOptions = {};
124
+ const unknown: UnknownParam[] = [];
125
+ let prevType = 0n;
126
+
127
+ while (reader.offset < payloadEnd) {
128
+ const delta = reader.readVarInt();
129
+ const optType = prevType + delta;
130
+ prevType = optType;
131
+
132
+ if (optType % 2n === 0n) {
133
+ // Even: single varint value
134
+ const value = reader.readVarInt();
135
+ if (optType === SETUP_OPT_MAX_AUTH_TOKEN_CACHE_SIZE) {
136
+ result.max_auth_token_cache_size = value;
137
+ } else {
138
+ const tmpWriter = new BufferWriter(16);
139
+ tmpWriter.writeVarInt(value);
140
+ const raw = tmpWriter.finish();
141
+ unknown.push({
142
+ id: `0x${optType.toString(16)}`,
143
+ length: raw.byteLength,
144
+ raw_hex: bytesToHex(raw),
145
+ });
146
+ }
147
+ } else {
148
+ // Odd: length-prefixed bytes
149
+ const length = Number(reader.readVarInt());
150
+ const bytes = reader.readBytes(length);
151
+ if (optType === SETUP_OPT_PATH) {
152
+ result.path = new TextDecoder().decode(bytes);
153
+ } else if (optType === SETUP_OPT_AUTHORITY) {
154
+ result.authority = new TextDecoder().decode(bytes);
155
+ } else if (optType === SETUP_OPT_MOQT_IMPLEMENTATION) {
156
+ result.moqt_implementation = new TextDecoder().decode(bytes);
157
+ } else {
158
+ unknown.push({ id: `0x${optType.toString(16)}`, length, raw_hex: bytesToHex(bytes) });
159
+ }
160
+ }
161
+ }
162
+
163
+ if (unknown.length > 0) result.unknown = unknown;
164
+ return result;
165
+ }
166
+
167
+ // ─── Message Parameter Encoding/Decoding (delta types, count prefix) ─────────
168
+
169
+ const PARAM_EXPIRES = 0x08n;
170
+ const PARAM_LARGEST_OBJECT = 0x09n;
171
+ const PARAM_SUBSCRIBER_PRIORITY = 0x20n;
172
+ const PARAM_SUBSCRIPTION_FILTER = 0x21n;
173
+ const PARAM_GROUP_ORDER = 0x22n;
174
+
175
+ function encodeParams(params: Draft17Params, writer: BufferWriter): void {
176
+ // Collect and sort params by type
177
+ const entries: Array<{ type: bigint; encode: (w: BufferWriter) => void }> = [];
178
+
179
+ if (params.expires !== undefined) {
180
+ entries.push({ type: PARAM_EXPIRES, encode: (w) => w.writeVarInt(params.expires!) });
181
+ }
182
+ if (params.largest_object !== undefined) {
183
+ entries.push({
184
+ type: PARAM_LARGEST_OBJECT,
185
+ encode: (w) => {
186
+ w.writeVarInt(params.largest_object!.group);
187
+ w.writeVarInt(params.largest_object!.object);
188
+ },
189
+ });
190
+ }
191
+ if (params.subscriber_priority !== undefined) {
192
+ entries.push({
193
+ type: PARAM_SUBSCRIBER_PRIORITY,
194
+ encode: (w) => w.writeUint8(Number(params.subscriber_priority!)),
195
+ });
196
+ }
197
+ if (params.subscription_filter !== undefined) {
198
+ entries.push({
199
+ type: PARAM_SUBSCRIPTION_FILTER,
200
+ encode: (w) => {
201
+ const f = params.subscription_filter!;
202
+ const tmpW = new BufferWriter(32);
203
+ tmpW.writeVarInt(f.filter_type);
204
+ if (f.filter_type === 3n || f.filter_type === 4n) {
205
+ tmpW.writeVarInt(f.start_group!);
206
+ tmpW.writeVarInt(f.start_object!);
207
+ }
208
+ if (f.filter_type === 4n) {
209
+ tmpW.writeVarInt(f.end_group!);
210
+ }
211
+ const raw = tmpW.finish();
212
+ w.writeVarInt(BigInt(raw.byteLength));
213
+ w.writeBytes(raw);
214
+ },
215
+ });
216
+ }
217
+ if (params.group_order !== undefined) {
218
+ entries.push({
219
+ type: PARAM_GROUP_ORDER,
220
+ encode: (w) => w.writeUint8(Number(params.group_order!)),
221
+ });
222
+ }
223
+
224
+ // Unknown params
225
+ if (params.unknown) {
226
+ for (const u of params.unknown) {
227
+ const id = BigInt(u.id);
228
+ entries.push({
229
+ type: id,
230
+ encode: (w) => {
231
+ const raw = hexToBytes(u.raw_hex);
232
+ // For unknown params, we store raw bytes and re-emit them
233
+ w.writeBytes(raw);
234
+ },
235
+ });
236
+ }
237
+ }
238
+
239
+ entries.sort((a, b) => (a.type < b.type ? -1 : a.type > b.type ? 1 : 0));
240
+
241
+ writer.writeVarInt(BigInt(entries.length));
242
+ let prevType = 0n;
243
+ for (const entry of entries) {
244
+ writer.writeVarInt(entry.type - prevType);
245
+ entry.encode(writer);
246
+ prevType = entry.type;
247
+ }
248
+ }
249
+
250
+ function decodeParams(reader: BufferReader): Draft17Params {
251
+ const count = Number(reader.readVarInt());
252
+ const result: Draft17Params = {};
253
+ const unknown: UnknownParam[] = [];
254
+ let prevType = 0n;
255
+
256
+ for (let i = 0; i < count; i++) {
257
+ const delta = reader.readVarInt();
258
+ const paramType = prevType + delta;
259
+ prevType = paramType;
260
+
261
+ if (paramType === PARAM_EXPIRES) {
262
+ result.expires = reader.readVarInt();
263
+ } else if (paramType === PARAM_LARGEST_OBJECT) {
264
+ // Location: 2 bare varints (not length-prefixed)
265
+ const group = reader.readVarInt();
266
+ const object = reader.readVarInt();
267
+ result.largest_object = { group, object };
268
+ } else if (paramType === PARAM_SUBSCRIBER_PRIORITY) {
269
+ // uint8: single raw byte
270
+ result.subscriber_priority = BigInt(reader.readUint8());
271
+ } else if (paramType === PARAM_SUBSCRIPTION_FILTER) {
272
+ // Length-prefixed
273
+ const length = Number(reader.readVarInt());
274
+ const startOff = reader.offset;
275
+ const filter_type = reader.readVarInt();
276
+ const filter: {
277
+ filter_type: bigint;
278
+ start_group?: bigint;
279
+ start_object?: bigint;
280
+ end_group?: bigint;
281
+ } = { filter_type };
282
+ if (filter_type === 3n || filter_type === 4n) {
283
+ filter.start_group = reader.readVarInt();
284
+ filter.start_object = reader.readVarInt();
285
+ }
286
+ if (filter_type === 4n) {
287
+ filter.end_group = reader.readVarInt();
288
+ }
289
+ const consumed = reader.offset - startOff;
290
+ if (consumed < length) reader.readBytes(length - consumed);
291
+ result.subscription_filter = filter;
292
+ } else if (paramType === PARAM_GROUP_ORDER) {
293
+ // uint8: single raw byte
294
+ result.group_order = BigInt(reader.readUint8());
295
+ } else {
296
+ // Unknown parameter — we don't know the encoding, protocol violation per spec
297
+ // But for robustness, attempt even/odd heuristic
298
+ if (paramType % 2n === 0n) {
299
+ const value = reader.readVarInt();
300
+ const tmpWriter = new BufferWriter(16);
301
+ tmpWriter.writeVarInt(value);
302
+ const raw = tmpWriter.finish();
303
+ unknown.push({
304
+ id: `0x${paramType.toString(16)}`,
305
+ length: raw.byteLength,
306
+ raw_hex: bytesToHex(raw),
307
+ });
308
+ } else {
309
+ const length = Number(reader.readVarInt());
310
+ const bytes = reader.readBytes(length);
311
+ unknown.push({ id: `0x${paramType.toString(16)}`, length, raw_hex: bytesToHex(bytes) });
312
+ }
313
+ }
314
+ }
315
+
316
+ if (unknown.length > 0) result.unknown = unknown;
317
+ return result;
318
+ }
319
+
320
+ // ─── Track Properties Encoding/Decoding (KVP, no count prefix) ──────────────
321
+
322
+ function encodeTrackProperties(props: Draft17TrackProperties, writer: BufferWriter): void {
323
+ if (!props.unknown || props.unknown.length === 0) return;
324
+
325
+ const entries = props.unknown.map((u) => ({ type: BigInt(u.id), raw: u }));
326
+ entries.sort((a, b) => (a.type < b.type ? -1 : a.type > b.type ? 1 : 0));
327
+
328
+ let prevType = 0n;
329
+ for (const entry of entries) {
330
+ writer.writeVarInt(entry.type - prevType);
331
+ if (entry.type % 2n === 0n) {
332
+ const raw = hexToBytes(entry.raw.raw_hex);
333
+ const tmpReader = new BufferReader(raw);
334
+ writer.writeVarInt(tmpReader.readVarInt());
335
+ } else {
336
+ const raw = hexToBytes(entry.raw.raw_hex);
337
+ writer.writeVarInt(BigInt(raw.byteLength));
338
+ writer.writeBytes(raw);
339
+ }
340
+ prevType = entry.type;
341
+ }
342
+ }
343
+
344
+ function decodeTrackProperties(reader: BufferReader, payloadEnd: number): Draft17TrackProperties {
345
+ const result: Draft17TrackProperties = {};
346
+ const unknown: UnknownParam[] = [];
347
+ let prevType = 0n;
348
+
349
+ while (reader.offset < payloadEnd) {
350
+ const delta = reader.readVarInt();
351
+ const propType = prevType + delta;
352
+ prevType = propType;
353
+
354
+ if (propType % 2n === 0n) {
355
+ const value = reader.readVarInt();
356
+ const tmpWriter = new BufferWriter(16);
357
+ tmpWriter.writeVarInt(value);
358
+ const raw = tmpWriter.finish();
359
+ unknown.push({
360
+ id: `0x${propType.toString(16)}`,
361
+ length: raw.byteLength,
362
+ raw_hex: bytesToHex(raw),
363
+ });
364
+ } else {
365
+ const length = Number(reader.readVarInt());
366
+ const bytes = reader.readBytes(length);
367
+ unknown.push({ id: `0x${propType.toString(16)}`, length, raw_hex: bytesToHex(bytes) });
368
+ }
369
+ }
370
+
371
+ if (unknown.length > 0) result.unknown = unknown;
372
+ return result;
373
+ }
374
+
375
+ // ─── Payload Encoders ──────────────────────────────────────────────────────────
376
+
377
+ function encodeSetupPayload(msg: Draft17Message & { type: "setup" }, w: BufferWriter): void {
378
+ encodeSetupOptions(msg.options, w);
379
+ }
380
+
381
+ function encodeSubscribePayload(
382
+ msg: Draft17Message & { type: "subscribe" },
383
+ w: BufferWriter,
384
+ ): void {
385
+ w.writeVarInt(msg.request_id);
386
+ w.writeVarInt(msg.required_request_id_delta);
387
+ w.writeTuple(msg.track_namespace);
388
+ w.writeString(msg.track_name);
389
+ encodeParams(msg.parameters, w);
390
+ }
391
+
392
+ function encodeSubscribeOkPayload(
393
+ msg: Draft17Message & { type: "subscribe_ok" },
394
+ w: BufferWriter,
395
+ ): void {
396
+ w.writeVarInt(msg.track_alias);
397
+ encodeParams(msg.parameters, w);
398
+ encodeTrackProperties(msg.track_properties, w);
399
+ }
400
+
401
+ function encodeRequestUpdatePayload(
402
+ msg: Draft17Message & { type: "request_update" },
403
+ w: BufferWriter,
404
+ ): void {
405
+ w.writeVarInt(msg.request_id);
406
+ w.writeVarInt(msg.required_request_id_delta);
407
+ encodeParams(msg.parameters, w);
408
+ }
409
+
410
+ function encodePublishPayload(msg: Draft17Message & { type: "publish" }, w: BufferWriter): void {
411
+ w.writeVarInt(msg.request_id);
412
+ w.writeVarInt(msg.required_request_id_delta);
413
+ w.writeTuple(msg.track_namespace);
414
+ w.writeString(msg.track_name);
415
+ w.writeVarInt(msg.track_alias);
416
+ encodeParams(msg.parameters, w);
417
+ encodeTrackProperties(msg.track_properties, w);
418
+ }
419
+
420
+ function encodePublishOkPayload(
421
+ msg: Draft17Message & { type: "publish_ok" },
422
+ w: BufferWriter,
423
+ ): void {
424
+ encodeParams(msg.parameters, w);
425
+ }
426
+
427
+ function encodePublishDonePayload(
428
+ msg: Draft17Message & { type: "publish_done" },
429
+ w: BufferWriter,
430
+ ): void {
431
+ w.writeVarInt(msg.status_code);
432
+ w.writeVarInt(msg.stream_count);
433
+ w.writeString(msg.reason_phrase);
434
+ }
435
+
436
+ function encodePublishNamespacePayload(
437
+ msg: Draft17Message & { type: "publish_namespace" },
438
+ w: BufferWriter,
439
+ ): void {
440
+ w.writeVarInt(msg.request_id);
441
+ w.writeVarInt(msg.required_request_id_delta);
442
+ w.writeTuple(msg.track_namespace);
443
+ encodeParams(msg.parameters, w);
444
+ }
445
+
446
+ function encodeNamespacePayload(
447
+ msg: Draft17Message & { type: "namespace" },
448
+ w: BufferWriter,
449
+ ): void {
450
+ w.writeTuple(msg.namespace_suffix);
451
+ }
452
+
453
+ function encodeNamespaceDonePayload(
454
+ msg: Draft17Message & { type: "namespace_done" },
455
+ w: BufferWriter,
456
+ ): void {
457
+ w.writeTuple(msg.namespace_suffix);
458
+ }
459
+
460
+ function encodeSubscribeNamespacePayload(
461
+ msg: Draft17Message & { type: "subscribe_namespace" },
462
+ w: BufferWriter,
463
+ ): void {
464
+ w.writeVarInt(msg.request_id);
465
+ w.writeVarInt(msg.required_request_id_delta);
466
+ w.writeTuple(msg.namespace_prefix);
467
+ w.writeVarInt(msg.subscribe_options);
468
+ encodeParams(msg.parameters, w);
469
+ }
470
+
471
+ function encodePublishBlockedPayload(
472
+ msg: Draft17Message & { type: "publish_blocked" },
473
+ w: BufferWriter,
474
+ ): void {
475
+ w.writeTuple(msg.namespace_suffix);
476
+ w.writeString(msg.track_name);
477
+ }
478
+
479
+ function encodeFetchPayload(msg: Draft17Message & { type: "fetch" }, w: BufferWriter): void {
480
+ w.writeVarInt(msg.request_id);
481
+ w.writeVarInt(msg.required_request_id_delta);
482
+ w.writeVarInt(msg.fetch_type);
483
+ const ft = Number(msg.fetch_type);
484
+ if (ft === 1 && msg.standalone) {
485
+ w.writeTuple(msg.standalone.track_namespace);
486
+ w.writeString(msg.standalone.track_name);
487
+ w.writeVarInt(msg.standalone.start_group);
488
+ w.writeVarInt(msg.standalone.start_object);
489
+ w.writeVarInt(msg.standalone.end_group);
490
+ w.writeVarInt(msg.standalone.end_object);
491
+ } else if ((ft === 2 || ft === 3) && msg.joining) {
492
+ w.writeVarInt(msg.joining.joining_request_id);
493
+ w.writeVarInt(msg.joining.joining_start);
494
+ }
495
+ encodeParams(msg.parameters, w);
496
+ }
497
+
498
+ function encodeFetchOkPayload(msg: Draft17Message & { type: "fetch_ok" }, w: BufferWriter): void {
499
+ w.writeUint8(msg.end_of_track);
500
+ w.writeVarInt(msg.end_group);
501
+ w.writeVarInt(msg.end_object);
502
+ encodeParams(msg.parameters, w);
503
+ encodeTrackProperties(msg.track_properties, w);
504
+ }
505
+
506
+ function encodeTrackStatusPayload(
507
+ msg: Draft17Message & { type: "track_status" },
508
+ w: BufferWriter,
509
+ ): void {
510
+ w.writeVarInt(msg.request_id);
511
+ w.writeVarInt(msg.required_request_id_delta);
512
+ w.writeTuple(msg.track_namespace);
513
+ w.writeString(msg.track_name);
514
+ encodeParams(msg.parameters, w);
515
+ }
516
+
517
+ function encodeRequestOkPayload(
518
+ msg: Draft17Message & { type: "request_ok" },
519
+ w: BufferWriter,
520
+ ): void {
521
+ encodeParams(msg.parameters, w);
522
+ }
523
+
524
+ function encodeRequestErrorPayload(
525
+ msg: Draft17Message & { type: "request_error" },
526
+ w: BufferWriter,
527
+ ): void {
528
+ w.writeVarInt(msg.error_code);
529
+ w.writeVarInt(msg.retry_interval);
530
+ w.writeString(msg.reason_phrase);
531
+ }
532
+
533
+ function encodeGoAwayPayload(msg: Draft17Message & { type: "goaway" }, w: BufferWriter): void {
534
+ w.writeString(msg.new_session_uri);
535
+ w.writeVarInt(msg.timeout);
536
+ }
537
+
538
+ // ─── Payload Decoders ──────────────────────────────────────────────────────────
539
+
540
+ function decodeSetupPayload(r: BufferReader, payloadEnd: number): Draft17Message {
541
+ const options = decodeSetupOptions(r, payloadEnd);
542
+ return { type: "setup", options };
543
+ }
544
+
545
+ function decodeSubscribePayload(r: BufferReader): Draft17Message {
546
+ const request_id = r.readVarInt();
547
+ const required_request_id_delta = r.readVarInt();
548
+ const track_namespace = r.readTuple();
549
+ const track_name = r.readString();
550
+ const parameters = decodeParams(r);
551
+ return {
552
+ type: "subscribe",
553
+ request_id,
554
+ required_request_id_delta,
555
+ track_namespace,
556
+ track_name,
557
+ parameters,
558
+ };
559
+ }
560
+
561
+ function decodeSubscribeOkPayload(r: BufferReader, payloadEnd: number): Draft17Message {
562
+ const track_alias = r.readVarInt();
563
+ const parameters = decodeParams(r);
564
+ const track_properties = decodeTrackProperties(r, payloadEnd);
565
+ return { type: "subscribe_ok", track_alias, parameters, track_properties };
566
+ }
567
+
568
+ function decodeRequestUpdatePayload(r: BufferReader): Draft17Message {
569
+ const request_id = r.readVarInt();
570
+ const required_request_id_delta = r.readVarInt();
571
+ const parameters = decodeParams(r);
572
+ return { type: "request_update", request_id, required_request_id_delta, parameters };
573
+ }
574
+
575
+ function decodePublishPayload(r: BufferReader, payloadEnd: number): Draft17Message {
576
+ const request_id = r.readVarInt();
577
+ const required_request_id_delta = r.readVarInt();
578
+ const track_namespace = r.readTuple();
579
+ const track_name = r.readString();
580
+ const track_alias = r.readVarInt();
581
+ const parameters = decodeParams(r);
582
+ const track_properties = decodeTrackProperties(r, payloadEnd);
583
+ return {
584
+ type: "publish",
585
+ request_id,
586
+ required_request_id_delta,
587
+ track_namespace,
588
+ track_name,
589
+ track_alias,
590
+ parameters,
591
+ track_properties,
592
+ };
593
+ }
594
+
595
+ function decodePublishOkPayload(r: BufferReader): Draft17Message {
596
+ const parameters = decodeParams(r);
597
+ return { type: "publish_ok", parameters };
598
+ }
599
+
600
+ function decodePublishDonePayload(r: BufferReader): Draft17Message {
601
+ const status_code = r.readVarInt();
602
+ const stream_count = r.readVarInt();
603
+ const reason_phrase = r.readString();
604
+ return { type: "publish_done", status_code, stream_count, reason_phrase };
605
+ }
606
+
607
+ function decodePublishNamespacePayload(r: BufferReader): Draft17Message {
608
+ const request_id = r.readVarInt();
609
+ const required_request_id_delta = r.readVarInt();
610
+ const track_namespace = r.readTuple();
611
+ const parameters = decodeParams(r);
612
+ return {
613
+ type: "publish_namespace",
614
+ request_id,
615
+ required_request_id_delta,
616
+ track_namespace,
617
+ parameters,
618
+ };
619
+ }
620
+
621
+ function decodeNamespacePayload(r: BufferReader): Draft17Message {
622
+ const namespace_suffix = r.readTuple();
623
+ return { type: "namespace", namespace_suffix };
624
+ }
625
+
626
+ function decodeNamespaceDonePayload(r: BufferReader): Draft17Message {
627
+ const namespace_suffix = r.readTuple();
628
+ return { type: "namespace_done", namespace_suffix };
629
+ }
630
+
631
+ function decodeSubscribeNamespacePayload(r: BufferReader): Draft17Message {
632
+ const request_id = r.readVarInt();
633
+ const required_request_id_delta = r.readVarInt();
634
+ const namespace_prefix = r.readTuple();
635
+ const subscribe_options = r.readVarInt();
636
+ const parameters = decodeParams(r);
637
+ return {
638
+ type: "subscribe_namespace",
639
+ request_id,
640
+ required_request_id_delta,
641
+ namespace_prefix,
642
+ subscribe_options,
643
+ parameters,
644
+ };
645
+ }
646
+
647
+ function decodePublishBlockedPayload(r: BufferReader): Draft17Message {
648
+ const namespace_suffix = r.readTuple();
649
+ const track_name = r.readString();
650
+ return { type: "publish_blocked", namespace_suffix, track_name };
651
+ }
652
+
653
+ function decodeFetchPayload(r: BufferReader): Draft17Message {
654
+ const request_id = r.readVarInt();
655
+ const required_request_id_delta = r.readVarInt();
656
+ const fetch_type = r.readVarInt();
657
+ const ft = Number(fetch_type);
658
+
659
+ if (ft < 1 || ft > 3) {
660
+ throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid fetch_type: ${ft}`, r.offset);
661
+ }
662
+
663
+ let standalone: StandaloneFetch | undefined;
664
+ let joining: JoiningFetch | undefined;
665
+
666
+ if (ft === 1) {
667
+ const track_namespace = r.readTuple();
668
+ const track_name = r.readString();
669
+ const start_group = r.readVarInt();
670
+ const start_object = r.readVarInt();
671
+ const end_group = r.readVarInt();
672
+ const end_object = r.readVarInt();
673
+ standalone = { track_namespace, track_name, start_group, start_object, end_group, end_object };
674
+ } else {
675
+ const joining_request_id = r.readVarInt();
676
+ const joining_start = r.readVarInt();
677
+ joining = { joining_request_id, joining_start };
678
+ }
679
+
680
+ const parameters = decodeParams(r);
681
+
682
+ return {
683
+ type: "fetch",
684
+ request_id,
685
+ required_request_id_delta,
686
+ fetch_type,
687
+ standalone,
688
+ joining,
689
+ parameters,
690
+ } as Draft17Fetch;
691
+ }
692
+
693
+ function decodeFetchOkPayload(r: BufferReader, payloadEnd: number): Draft17Message {
694
+ const end_of_track = r.readUint8();
695
+ const end_group = r.readVarInt();
696
+ const end_object = r.readVarInt();
697
+ const parameters = decodeParams(r);
698
+ const track_properties = decodeTrackProperties(r, payloadEnd);
699
+ return { type: "fetch_ok", end_of_track, end_group, end_object, parameters, track_properties };
700
+ }
701
+
702
+ function decodeTrackStatusPayload(r: BufferReader): Draft17Message {
703
+ const request_id = r.readVarInt();
704
+ const required_request_id_delta = r.readVarInt();
705
+ const track_namespace = r.readTuple();
706
+ const track_name = r.readString();
707
+ const parameters = decodeParams(r);
708
+ return {
709
+ type: "track_status",
710
+ request_id,
711
+ required_request_id_delta,
712
+ track_namespace,
713
+ track_name,
714
+ parameters,
715
+ };
716
+ }
717
+
718
+ function decodeRequestOkPayload(r: BufferReader): Draft17Message {
719
+ const parameters = decodeParams(r);
720
+ return { type: "request_ok", parameters };
721
+ }
722
+
723
+ function decodeRequestErrorPayload(r: BufferReader): Draft17Message {
724
+ const error_code = r.readVarInt();
725
+ const retry_interval = r.readVarInt();
726
+ const reason_phrase = r.readString();
727
+ return { type: "request_error", error_code, retry_interval, reason_phrase };
728
+ }
729
+
730
+ function decodeGoAwayPayload(r: BufferReader): Draft17Message {
731
+ const new_session_uri = r.readString();
732
+ const timeout = r.readVarInt();
733
+ return { type: "goaway", new_session_uri, timeout };
734
+ }
735
+
736
+ // ─── Public API ────────────────────────────────────────────────────────────────
737
+
738
+ /**
739
+ * Encode a draft-17 control message with type(varint) + length(uint16 BE) + payload.
740
+ */
741
+ export function encodeMessage(message: Draft17Message): Uint8Array {
742
+ const typeId = MESSAGE_ID_MAP.get(message.type);
743
+ if (typeId === undefined) {
744
+ throw new Error(`Unknown message type: ${message.type}`);
745
+ }
746
+
747
+ const payloadWriter = new BufferWriter();
748
+ encodePayload(message, payloadWriter);
749
+ const payload = payloadWriter.finish();
750
+
751
+ if (payload.byteLength > 0xffff) {
752
+ throw new Error(`Payload too large for 16-bit length: ${payload.byteLength}`);
753
+ }
754
+
755
+ const writer = new BufferWriter();
756
+ writer.writeVarInt(typeId);
757
+ writer.writeUint8((payload.byteLength >> 8) & 0xff);
758
+ writer.writeUint8(payload.byteLength & 0xff);
759
+ writer.writeBytes(payload);
760
+
761
+ return writer.finish();
762
+ }
763
+
764
+ function encodePayload(msg: Draft17Message, w: BufferWriter): void {
765
+ switch (msg.type) {
766
+ case "setup":
767
+ return encodeSetupPayload(msg, w);
768
+ case "subscribe":
769
+ return encodeSubscribePayload(msg, w);
770
+ case "subscribe_ok":
771
+ return encodeSubscribeOkPayload(msg, w);
772
+ case "request_update":
773
+ return encodeRequestUpdatePayload(msg, w);
774
+ case "publish":
775
+ return encodePublishPayload(msg, w);
776
+ case "publish_ok":
777
+ return encodePublishOkPayload(msg, w);
778
+ case "publish_done":
779
+ return encodePublishDonePayload(msg, w);
780
+ case "publish_namespace":
781
+ return encodePublishNamespacePayload(msg, w);
782
+ case "namespace":
783
+ return encodeNamespacePayload(msg, w);
784
+ case "namespace_done":
785
+ return encodeNamespaceDonePayload(msg, w);
786
+ case "subscribe_namespace":
787
+ return encodeSubscribeNamespacePayload(msg, w);
788
+ case "publish_blocked":
789
+ return encodePublishBlockedPayload(msg, w);
790
+ case "fetch":
791
+ return encodeFetchPayload(msg, w);
792
+ case "fetch_ok":
793
+ return encodeFetchOkPayload(msg, w);
794
+ case "track_status":
795
+ return encodeTrackStatusPayload(msg, w);
796
+ case "request_ok":
797
+ return encodeRequestOkPayload(msg, w);
798
+ case "request_error":
799
+ return encodeRequestErrorPayload(msg, w);
800
+ case "goaway":
801
+ return encodeGoAwayPayload(msg, w);
802
+ default: {
803
+ const _exhaustive: never = msg;
804
+ throw new Error(`Unhandled message type: ${(_exhaustive as Draft17Message).type}`);
805
+ }
806
+ }
807
+ }
808
+
809
+ /**
810
+ * Decode a draft-17 control message from bytes (type + uint16 length + payload).
811
+ */
812
+ export function decodeMessage(bytes: Uint8Array): DecodeResult<Draft17Message> {
813
+ try {
814
+ const reader = new BufferReader(bytes);
815
+ const typeId = reader.readVarInt();
816
+
817
+ const lenHi = reader.readUint8();
818
+ const lenLo = reader.readUint8();
819
+ const payloadLength = (lenHi << 8) | lenLo;
820
+
821
+ const payloadStart = reader.offset;
822
+ const _payloadEnd = payloadStart + payloadLength;
823
+ const payloadBytes = reader.readBytes(payloadLength);
824
+ const payloadReader = new BufferReader(payloadBytes);
825
+
826
+ let message: Draft17Message;
827
+
828
+ if (typeId === MSG_SETUP) {
829
+ message = decodeSetupPayload(payloadReader, payloadLength);
830
+ } else if (typeId === MSG_SUBSCRIBE) {
831
+ message = decodeSubscribePayload(payloadReader);
832
+ } else if (typeId === MSG_SUBSCRIBE_OK) {
833
+ message = decodeSubscribeOkPayload(payloadReader, payloadLength);
834
+ } else if (typeId === MSG_REQUEST_UPDATE) {
835
+ message = decodeRequestUpdatePayload(payloadReader);
836
+ } else if (typeId === MSG_PUBLISH) {
837
+ message = decodePublishPayload(payloadReader, payloadLength);
838
+ } else if (typeId === MSG_PUBLISH_OK) {
839
+ message = decodePublishOkPayload(payloadReader);
840
+ } else if (typeId === MSG_PUBLISH_DONE) {
841
+ message = decodePublishDonePayload(payloadReader);
842
+ } else if (typeId === MSG_PUBLISH_NAMESPACE) {
843
+ message = decodePublishNamespacePayload(payloadReader);
844
+ } else if (typeId === MSG_NAMESPACE) {
845
+ message = decodeNamespacePayload(payloadReader);
846
+ } else if (typeId === MSG_NAMESPACE_DONE) {
847
+ message = decodeNamespaceDonePayload(payloadReader);
848
+ } else if (typeId === MSG_SUBSCRIBE_NAMESPACE) {
849
+ message = decodeSubscribeNamespacePayload(payloadReader);
850
+ } else if (typeId === MSG_PUBLISH_BLOCKED) {
851
+ message = decodePublishBlockedPayload(payloadReader);
852
+ } else if (typeId === MSG_FETCH) {
853
+ message = decodeFetchPayload(payloadReader);
854
+ } else if (typeId === MSG_FETCH_OK) {
855
+ message = decodeFetchOkPayload(payloadReader, payloadLength);
856
+ } else if (typeId === MSG_TRACK_STATUS) {
857
+ message = decodeTrackStatusPayload(payloadReader);
858
+ } else if (typeId === MSG_REQUEST_OK) {
859
+ message = decodeRequestOkPayload(payloadReader);
860
+ } else if (typeId === MSG_REQUEST_ERROR) {
861
+ message = decodeRequestErrorPayload(payloadReader);
862
+ } else if (typeId === MSG_GOAWAY) {
863
+ message = decodeGoAwayPayload(payloadReader);
864
+ } else {
865
+ return {
866
+ ok: false,
867
+ error: new DecodeError(
868
+ "UNKNOWN_MESSAGE_TYPE",
869
+ `Unknown message type ID: 0x${typeId.toString(16)}`,
870
+ 0,
871
+ ),
872
+ };
873
+ }
874
+
875
+ return { ok: true, value: message, bytesRead: reader.offset };
876
+ } catch (e) {
877
+ if (e instanceof DecodeError) {
878
+ return { ok: false, error: e };
879
+ }
880
+ throw e;
881
+ }
882
+ }
883
+
884
+ // ─── Data Stream Encoding/Decoding (re-exported from data-streams.ts) ───────
885
+
886
+ import { encodeSubgroupStream, decodeSubgroupStream, encodeDatagram, decodeDatagram, encodeFetchStream, decodeFetchStream, decodeDataStream, createSubgroupStreamDecoder, createFetchStreamDecoder, createDataStreamDecoder } from "./data-streams.js";
887
+ export { encodeSubgroupStream, decodeSubgroupStream, encodeDatagram, decodeDatagram, encodeFetchStream, decodeFetchStream, decodeDataStream, createSubgroupStreamDecoder, createFetchStreamDecoder, createDataStreamDecoder };
888
+
889
+ // ─── Stream Decoders ───────────────────────────────────────────────────────────
890
+
891
+ export function createStreamDecoder(): TransformStream<Uint8Array, Draft17Message> {
892
+ let buffer = new Uint8Array(0);
893
+
894
+ return new TransformStream<Uint8Array, Draft17Message>({
895
+ transform(chunk, controller) {
896
+ const newBuffer = new Uint8Array(buffer.length + chunk.length);
897
+ newBuffer.set(buffer, 0);
898
+ newBuffer.set(chunk, buffer.length);
899
+ buffer = newBuffer;
900
+
901
+ while (buffer.length > 0) {
902
+ const result = decodeMessage(buffer);
903
+ if (!result.ok) {
904
+ if (result.error.code === "UNEXPECTED_END") {
905
+ break;
906
+ }
907
+ controller.error(result.error);
908
+ return;
909
+ }
910
+ controller.enqueue(result.value);
911
+ buffer = buffer.slice(result.bytesRead);
912
+ }
913
+ },
914
+
915
+ flush(controller) {
916
+ if (buffer.length > 0) {
917
+ controller.error(
918
+ new DecodeError("UNEXPECTED_END", "Stream ended with incomplete message data", 0),
919
+ );
920
+ }
921
+ },
922
+ });
923
+ }
924
+
925
+ // ─── Codec Factory ─────────────────────────────────────────────────────────────
926
+
927
+ export interface Draft17Codec extends BaseCodec<Draft17Message> {
928
+ readonly draft: "draft-ietf-moq-transport-17";
929
+ encodeSubgroupStream(stream: SubgroupStream): Uint8Array;
930
+ encodeDatagram(dg: DatagramObject): Uint8Array;
931
+ encodeFetchStream(stream: FetchStream): Uint8Array;
932
+ decodeSubgroupStream(bytes: Uint8Array): DecodeResult<SubgroupStream>;
933
+ decodeDatagram(bytes: Uint8Array): DecodeResult<DatagramObject>;
934
+ decodeFetchStream(bytes: Uint8Array): DecodeResult<FetchStream>;
935
+ decodeDataStream(
936
+ streamType: "subgroup" | "datagram" | "fetch",
937
+ bytes: Uint8Array,
938
+ ): DecodeResult<Draft17DataStream>;
939
+ createStreamDecoder(): TransformStream<Uint8Array, Draft17Message>;
940
+ createSubgroupStreamDecoder(): TransformStream<Uint8Array, SubgroupStreamHeader | ObjectPayload>;
941
+ createFetchStreamDecoder(): TransformStream<Uint8Array, FetchStreamHeader | ObjectPayload>;
942
+ createDataStreamDecoder(): TransformStream<Uint8Array, DataStreamEvent>;
943
+ }
944
+
945
+ export function createDraft17Codec(): Draft17Codec {
946
+ return {
947
+ draft: "draft-ietf-moq-transport-17",
948
+ encodeMessage,
949
+ decodeMessage,
950
+ encodeSubgroupStream,
951
+ encodeDatagram,
952
+ encodeFetchStream,
953
+ decodeSubgroupStream,
954
+ decodeDatagram,
955
+ decodeFetchStream,
956
+ decodeDataStream,
957
+ createStreamDecoder,
958
+ createSubgroupStreamDecoder,
959
+ createFetchStreamDecoder,
960
+ createDataStreamDecoder,
961
+ };
962
+ }