@moqtap/codec 0.2.0 → 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 (439) hide show
  1. package/dist/core/buffer-reader.d.ts +15 -0
  2. package/dist/core/buffer-reader.d.ts.map +1 -0
  3. package/dist/core/buffer-reader.js +98 -0
  4. package/dist/core/buffer-reader.js.map +1 -0
  5. package/dist/core/buffer-writer.d.ts +16 -0
  6. package/dist/core/buffer-writer.d.ts.map +1 -0
  7. package/dist/core/buffer-writer.js +86 -0
  8. package/dist/core/buffer-writer.js.map +1 -0
  9. package/dist/core/errors.d.ts +2 -0
  10. package/dist/core/errors.d.ts.map +1 -0
  11. package/dist/core/errors.js +2 -0
  12. package/dist/core/errors.js.map +1 -0
  13. package/dist/core/hex.d.ts +5 -0
  14. package/dist/core/hex.d.ts.map +1 -0
  15. package/dist/core/hex.js +17 -0
  16. package/dist/core/hex.js.map +1 -0
  17. package/dist/core/session-types.d.ts +99 -0
  18. package/dist/core/session-types.d.ts.map +1 -0
  19. package/dist/core/session-types.js +2 -0
  20. package/dist/core/session-types.js.map +1 -0
  21. package/dist/core/types.d.ts +235 -0
  22. package/dist/core/types.d.ts.map +1 -0
  23. package/dist/core/types.js +11 -0
  24. package/dist/core/types.js.map +1 -0
  25. package/dist/drafts/draft07/announce-fsm.d.ts +2 -0
  26. package/dist/drafts/draft07/announce-fsm.d.ts.map +1 -0
  27. package/dist/drafts/draft07/announce-fsm.js +2 -0
  28. package/dist/drafts/draft07/announce-fsm.js.map +1 -0
  29. package/dist/drafts/draft07/codec.d.ts +17 -0
  30. package/dist/drafts/draft07/codec.d.ts.map +1 -0
  31. package/dist/drafts/draft07/codec.js +722 -0
  32. package/dist/drafts/draft07/codec.js.map +1 -0
  33. package/dist/drafts/draft07/data-streams.d.ts +9 -0
  34. package/dist/drafts/draft07/data-streams.d.ts.map +1 -0
  35. package/dist/drafts/draft07/data-streams.js +228 -0
  36. package/dist/drafts/draft07/data-streams.js.map +1 -0
  37. package/dist/drafts/draft07/index.d.ts +14 -0
  38. package/dist/drafts/draft07/index.d.ts.map +1 -0
  39. package/dist/drafts/draft07/index.js +18 -0
  40. package/dist/drafts/draft07/index.js.map +1 -0
  41. package/dist/drafts/draft07/messages.d.ts +32 -0
  42. package/dist/drafts/draft07/messages.d.ts.map +1 -0
  43. package/dist/drafts/draft07/messages.js +42 -0
  44. package/dist/drafts/draft07/messages.js.map +1 -0
  45. package/dist/drafts/draft07/parameters.d.ts +4 -0
  46. package/dist/drafts/draft07/parameters.d.ts.map +1 -0
  47. package/dist/drafts/draft07/parameters.js +10 -0
  48. package/dist/drafts/draft07/parameters.js.map +1 -0
  49. package/dist/drafts/draft07/rules.d.ts +8 -0
  50. package/dist/drafts/draft07/rules.d.ts.map +1 -0
  51. package/dist/drafts/draft07/rules.js +95 -0
  52. package/dist/drafts/draft07/rules.js.map +1 -0
  53. package/dist/drafts/draft07/session-fsm.d.ts +38 -0
  54. package/dist/drafts/draft07/session-fsm.d.ts.map +1 -0
  55. package/dist/drafts/draft07/session-fsm.js +354 -0
  56. package/dist/drafts/draft07/session-fsm.js.map +1 -0
  57. package/dist/drafts/draft07/session.d.ts +4 -0
  58. package/dist/drafts/draft07/session.d.ts.map +1 -0
  59. package/dist/drafts/draft07/session.js +5 -0
  60. package/dist/drafts/draft07/session.js.map +1 -0
  61. package/dist/drafts/draft07/subscription-fsm.d.ts +2 -0
  62. package/dist/drafts/draft07/subscription-fsm.d.ts.map +1 -0
  63. package/dist/drafts/draft07/subscription-fsm.js +2 -0
  64. package/dist/drafts/draft07/subscription-fsm.js.map +1 -0
  65. package/dist/drafts/draft07/types.d.ts +61 -0
  66. package/dist/drafts/draft07/types.d.ts.map +1 -0
  67. package/dist/drafts/draft07/types.js +4 -0
  68. package/dist/drafts/draft07/types.js.map +1 -0
  69. package/dist/drafts/draft07/varint.d.ts +4 -0
  70. package/dist/drafts/draft07/varint.d.ts.map +1 -0
  71. package/dist/drafts/draft07/varint.js +22 -0
  72. package/dist/drafts/draft07/varint.js.map +1 -0
  73. package/dist/drafts/draft08/codec.d.ts +29 -0
  74. package/dist/drafts/draft08/codec.d.ts.map +1 -0
  75. package/dist/drafts/draft08/codec.js +729 -0
  76. package/dist/drafts/draft08/codec.js.map +1 -0
  77. package/dist/drafts/draft08/data-streams.d.ts +12 -0
  78. package/dist/drafts/draft08/data-streams.d.ts.map +1 -0
  79. package/dist/drafts/draft08/data-streams.js +345 -0
  80. package/dist/drafts/draft08/data-streams.js.map +1 -0
  81. package/dist/drafts/draft08/index.d.ts +9 -0
  82. package/dist/drafts/draft08/index.d.ts.map +1 -0
  83. package/dist/drafts/draft08/index.js +7 -0
  84. package/dist/drafts/draft08/index.js.map +1 -0
  85. package/dist/drafts/draft08/messages.d.ts +34 -0
  86. package/dist/drafts/draft08/messages.d.ts.map +1 -0
  87. package/dist/drafts/draft08/messages.js +66 -0
  88. package/dist/drafts/draft08/messages.js.map +1 -0
  89. package/dist/drafts/draft08/rules.d.ts +8 -0
  90. package/dist/drafts/draft08/rules.d.ts.map +1 -0
  91. package/dist/drafts/draft08/rules.js +83 -0
  92. package/dist/drafts/draft08/rules.js.map +1 -0
  93. package/dist/drafts/draft08/session-fsm.d.ts +47 -0
  94. package/dist/drafts/draft08/session-fsm.d.ts.map +1 -0
  95. package/dist/drafts/draft08/session-fsm.js +483 -0
  96. package/dist/drafts/draft08/session-fsm.js.map +1 -0
  97. package/dist/drafts/draft08/session.d.ts +5 -0
  98. package/dist/drafts/draft08/session.d.ts.map +1 -0
  99. package/dist/drafts/draft08/session.js +5 -0
  100. package/dist/drafts/draft08/session.js.map +1 -0
  101. package/dist/drafts/draft08/types.d.ts +268 -0
  102. package/dist/drafts/draft08/types.d.ts.map +1 -0
  103. package/dist/drafts/draft08/types.js +4 -0
  104. package/dist/drafts/draft08/types.js.map +1 -0
  105. package/dist/drafts/draft09/codec.d.ts +21 -0
  106. package/dist/drafts/draft09/codec.d.ts.map +1 -0
  107. package/dist/drafts/draft09/codec.js +721 -0
  108. package/dist/drafts/draft09/codec.js.map +1 -0
  109. package/dist/drafts/draft09/data-streams.d.ts +12 -0
  110. package/dist/drafts/draft09/data-streams.d.ts.map +1 -0
  111. package/dist/drafts/draft09/data-streams.js +307 -0
  112. package/dist/drafts/draft09/data-streams.js.map +1 -0
  113. package/dist/drafts/draft09/index.d.ts +9 -0
  114. package/dist/drafts/draft09/index.d.ts.map +1 -0
  115. package/dist/drafts/draft09/index.js +7 -0
  116. package/dist/drafts/draft09/index.js.map +1 -0
  117. package/dist/drafts/draft09/messages.d.ts +34 -0
  118. package/dist/drafts/draft09/messages.d.ts.map +1 -0
  119. package/dist/drafts/draft09/messages.js +66 -0
  120. package/dist/drafts/draft09/messages.js.map +1 -0
  121. package/dist/drafts/draft09/rules.d.ts +8 -0
  122. package/dist/drafts/draft09/rules.d.ts.map +1 -0
  123. package/dist/drafts/draft09/rules.js +83 -0
  124. package/dist/drafts/draft09/rules.js.map +1 -0
  125. package/dist/drafts/draft09/session-fsm.d.ts +47 -0
  126. package/dist/drafts/draft09/session-fsm.d.ts.map +1 -0
  127. package/dist/drafts/draft09/session-fsm.js +483 -0
  128. package/dist/drafts/draft09/session-fsm.js.map +1 -0
  129. package/dist/drafts/draft09/session.d.ts +5 -0
  130. package/dist/drafts/draft09/session.d.ts.map +1 -0
  131. package/dist/drafts/draft09/session.js +5 -0
  132. package/dist/drafts/draft09/session.js.map +1 -0
  133. package/dist/drafts/draft09/types.d.ts +268 -0
  134. package/dist/drafts/draft09/types.d.ts.map +1 -0
  135. package/dist/drafts/draft09/types.js +4 -0
  136. package/dist/drafts/draft09/types.js.map +1 -0
  137. package/dist/drafts/draft10/codec.d.ts +21 -0
  138. package/dist/drafts/draft10/codec.d.ts.map +1 -0
  139. package/dist/drafts/draft10/codec.js +721 -0
  140. package/dist/drafts/draft10/codec.js.map +1 -0
  141. package/dist/drafts/draft10/data-streams.d.ts +12 -0
  142. package/dist/drafts/draft10/data-streams.d.ts.map +1 -0
  143. package/dist/drafts/draft10/data-streams.js +307 -0
  144. package/dist/drafts/draft10/data-streams.js.map +1 -0
  145. package/dist/drafts/draft10/index.d.ts +9 -0
  146. package/dist/drafts/draft10/index.d.ts.map +1 -0
  147. package/dist/drafts/draft10/index.js +7 -0
  148. package/dist/drafts/draft10/index.js.map +1 -0
  149. package/dist/drafts/draft10/messages.d.ts +34 -0
  150. package/dist/drafts/draft10/messages.d.ts.map +1 -0
  151. package/dist/drafts/draft10/messages.js +66 -0
  152. package/dist/drafts/draft10/messages.js.map +1 -0
  153. package/dist/drafts/draft10/rules.d.ts +8 -0
  154. package/dist/drafts/draft10/rules.d.ts.map +1 -0
  155. package/dist/drafts/draft10/rules.js +83 -0
  156. package/dist/drafts/draft10/rules.js.map +1 -0
  157. package/dist/drafts/draft10/session-fsm.d.ts +47 -0
  158. package/dist/drafts/draft10/session-fsm.d.ts.map +1 -0
  159. package/dist/drafts/draft10/session-fsm.js +483 -0
  160. package/dist/drafts/draft10/session-fsm.js.map +1 -0
  161. package/dist/drafts/draft10/session.d.ts +5 -0
  162. package/dist/drafts/draft10/session.d.ts.map +1 -0
  163. package/dist/drafts/draft10/session.js +5 -0
  164. package/dist/drafts/draft10/session.js.map +1 -0
  165. package/dist/drafts/draft10/types.d.ts +268 -0
  166. package/dist/drafts/draft10/types.d.ts.map +1 -0
  167. package/dist/drafts/draft10/types.js +4 -0
  168. package/dist/drafts/draft10/types.js.map +1 -0
  169. package/dist/drafts/draft11/codec.d.ts +25 -0
  170. package/dist/drafts/draft11/codec.d.ts.map +1 -0
  171. package/dist/drafts/draft11/codec.js +775 -0
  172. package/dist/drafts/draft11/codec.js.map +1 -0
  173. package/dist/drafts/draft11/data-streams.d.ts +10 -0
  174. package/dist/drafts/draft11/data-streams.d.ts.map +1 -0
  175. package/dist/drafts/draft11/data-streams.js +253 -0
  176. package/dist/drafts/draft11/data-streams.js.map +1 -0
  177. package/dist/drafts/draft11/index.d.ts +9 -0
  178. package/dist/drafts/draft11/index.d.ts.map +1 -0
  179. package/dist/drafts/draft11/index.js +7 -0
  180. package/dist/drafts/draft11/index.js.map +1 -0
  181. package/dist/drafts/draft11/messages.d.ts +33 -0
  182. package/dist/drafts/draft11/messages.d.ts.map +1 -0
  183. package/dist/drafts/draft11/messages.js +65 -0
  184. package/dist/drafts/draft11/messages.js.map +1 -0
  185. package/dist/drafts/draft11/rules.d.ts +8 -0
  186. package/dist/drafts/draft11/rules.d.ts.map +1 -0
  187. package/dist/drafts/draft11/rules.js +88 -0
  188. package/dist/drafts/draft11/rules.js.map +1 -0
  189. package/dist/drafts/draft11/session-fsm.d.ts +52 -0
  190. package/dist/drafts/draft11/session-fsm.d.ts.map +1 -0
  191. package/dist/drafts/draft11/session-fsm.js +530 -0
  192. package/dist/drafts/draft11/session-fsm.js.map +1 -0
  193. package/dist/drafts/draft11/session.d.ts +5 -0
  194. package/dist/drafts/draft11/session.d.ts.map +1 -0
  195. package/dist/drafts/draft11/session.js +5 -0
  196. package/dist/drafts/draft11/session.js.map +1 -0
  197. package/dist/drafts/draft11/types.d.ts +266 -0
  198. package/dist/drafts/draft11/types.d.ts.map +1 -0
  199. package/dist/drafts/draft11/types.js +4 -0
  200. package/dist/drafts/draft11/types.js.map +1 -0
  201. package/dist/drafts/draft12/codec.d.ts +27 -0
  202. package/dist/drafts/draft12/codec.d.ts.map +1 -0
  203. package/dist/drafts/draft12/codec.js +918 -0
  204. package/dist/drafts/draft12/codec.js.map +1 -0
  205. package/dist/drafts/draft12/data-streams.d.ts +10 -0
  206. package/dist/drafts/draft12/data-streams.d.ts.map +1 -0
  207. package/dist/drafts/draft12/data-streams.js +254 -0
  208. package/dist/drafts/draft12/data-streams.js.map +1 -0
  209. package/dist/drafts/draft12/index.d.ts +9 -0
  210. package/dist/drafts/draft12/index.d.ts.map +1 -0
  211. package/dist/drafts/draft12/index.js +7 -0
  212. package/dist/drafts/draft12/index.js.map +1 -0
  213. package/dist/drafts/draft12/messages.d.ts +37 -0
  214. package/dist/drafts/draft12/messages.d.ts.map +1 -0
  215. package/dist/drafts/draft12/messages.js +77 -0
  216. package/dist/drafts/draft12/messages.js.map +1 -0
  217. package/dist/drafts/draft12/rules.d.ts +8 -0
  218. package/dist/drafts/draft12/rules.d.ts.map +1 -0
  219. package/dist/drafts/draft12/rules.js +94 -0
  220. package/dist/drafts/draft12/rules.js.map +1 -0
  221. package/dist/drafts/draft12/session-fsm.d.ts +55 -0
  222. package/dist/drafts/draft12/session-fsm.d.ts.map +1 -0
  223. package/dist/drafts/draft12/session-fsm.js +569 -0
  224. package/dist/drafts/draft12/session-fsm.js.map +1 -0
  225. package/dist/drafts/draft12/session.d.ts +5 -0
  226. package/dist/drafts/draft12/session.d.ts.map +1 -0
  227. package/dist/drafts/draft12/session.js +5 -0
  228. package/dist/drafts/draft12/session.js.map +1 -0
  229. package/dist/drafts/draft12/types.d.ts +294 -0
  230. package/dist/drafts/draft12/types.d.ts.map +1 -0
  231. package/dist/drafts/draft12/types.js +4 -0
  232. package/dist/drafts/draft12/types.js.map +1 -0
  233. package/dist/drafts/draft13/codec.d.ts +27 -0
  234. package/dist/drafts/draft13/codec.d.ts.map +1 -0
  235. package/dist/drafts/draft13/codec.js +1000 -0
  236. package/dist/drafts/draft13/codec.js.map +1 -0
  237. package/dist/drafts/draft13/data-streams.d.ts +10 -0
  238. package/dist/drafts/draft13/data-streams.d.ts.map +1 -0
  239. package/dist/drafts/draft13/data-streams.js +254 -0
  240. package/dist/drafts/draft13/data-streams.js.map +1 -0
  241. package/dist/drafts/draft13/index.d.ts +9 -0
  242. package/dist/drafts/draft13/index.d.ts.map +1 -0
  243. package/dist/drafts/draft13/index.js +7 -0
  244. package/dist/drafts/draft13/index.js.map +1 -0
  245. package/dist/drafts/draft13/messages.d.ts +38 -0
  246. package/dist/drafts/draft13/messages.d.ts.map +1 -0
  247. package/dist/drafts/draft13/messages.js +79 -0
  248. package/dist/drafts/draft13/messages.js.map +1 -0
  249. package/dist/drafts/draft13/rules.d.ts +8 -0
  250. package/dist/drafts/draft13/rules.d.ts.map +1 -0
  251. package/dist/drafts/draft13/rules.js +96 -0
  252. package/dist/drafts/draft13/rules.js.map +1 -0
  253. package/dist/drafts/draft13/session-fsm.d.ts +56 -0
  254. package/dist/drafts/draft13/session-fsm.d.ts.map +1 -0
  255. package/dist/drafts/draft13/session-fsm.js +581 -0
  256. package/dist/drafts/draft13/session-fsm.js.map +1 -0
  257. package/dist/drafts/draft13/session.d.ts +5 -0
  258. package/dist/drafts/draft13/session.d.ts.map +1 -0
  259. package/dist/drafts/draft13/session.js +5 -0
  260. package/dist/drafts/draft13/session.js.map +1 -0
  261. package/dist/drafts/draft13/types.d.ts +310 -0
  262. package/dist/drafts/draft13/types.d.ts.map +1 -0
  263. package/dist/drafts/draft13/types.js +4 -0
  264. package/dist/drafts/draft13/types.js.map +1 -0
  265. package/dist/drafts/draft14/codec.d.ts +34 -0
  266. package/dist/drafts/draft14/codec.d.ts.map +1 -0
  267. package/dist/drafts/draft14/codec.js +752 -0
  268. package/dist/drafts/draft14/codec.js.map +1 -0
  269. package/dist/drafts/draft14/data-streams.d.ts +56 -0
  270. package/dist/drafts/draft14/data-streams.d.ts.map +1 -0
  271. package/dist/drafts/draft14/data-streams.js +729 -0
  272. package/dist/drafts/draft14/data-streams.js.map +1 -0
  273. package/dist/drafts/draft14/index.d.ts +9 -0
  274. package/dist/drafts/draft14/index.d.ts.map +1 -0
  275. package/dist/drafts/draft14/index.js +7 -0
  276. package/dist/drafts/draft14/index.js.map +1 -0
  277. package/dist/drafts/draft14/messages.d.ts +36 -0
  278. package/dist/drafts/draft14/messages.d.ts.map +1 -0
  279. package/dist/drafts/draft14/messages.js +71 -0
  280. package/dist/drafts/draft14/messages.js.map +1 -0
  281. package/dist/drafts/draft14/rules.d.ts +8 -0
  282. package/dist/drafts/draft14/rules.d.ts.map +1 -0
  283. package/dist/drafts/draft14/rules.js +101 -0
  284. package/dist/drafts/draft14/rules.js.map +1 -0
  285. package/dist/drafts/draft14/session-fsm.d.ts +58 -0
  286. package/dist/drafts/draft14/session-fsm.d.ts.map +1 -0
  287. package/dist/drafts/draft14/session-fsm.js +648 -0
  288. package/dist/drafts/draft14/session-fsm.js.map +1 -0
  289. package/dist/drafts/draft14/session.d.ts +5 -0
  290. package/dist/drafts/draft14/session.d.ts.map +1 -0
  291. package/dist/drafts/draft14/session.js +5 -0
  292. package/dist/drafts/draft14/session.js.map +1 -0
  293. package/dist/drafts/draft14/types.d.ts +263 -0
  294. package/dist/drafts/draft14/types.d.ts.map +1 -0
  295. package/dist/drafts/draft14/types.js +4 -0
  296. package/dist/drafts/draft14/types.js.map +1 -0
  297. package/dist/drafts/draft15/codec.d.ts +33 -0
  298. package/dist/drafts/draft15/codec.d.ts.map +1 -0
  299. package/dist/drafts/draft15/codec.js +742 -0
  300. package/dist/drafts/draft15/codec.js.map +1 -0
  301. package/dist/drafts/draft15/data-streams.d.ts +45 -0
  302. package/dist/drafts/draft15/data-streams.d.ts.map +1 -0
  303. package/dist/drafts/draft15/data-streams.js +675 -0
  304. package/dist/drafts/draft15/data-streams.js.map +1 -0
  305. package/dist/drafts/draft15/index.d.ts +9 -0
  306. package/dist/drafts/draft15/index.d.ts.map +1 -0
  307. package/dist/drafts/draft15/index.js +7 -0
  308. package/dist/drafts/draft15/index.js.map +1 -0
  309. package/dist/drafts/draft15/messages.d.ts +31 -0
  310. package/dist/drafts/draft15/messages.d.ts.map +1 -0
  311. package/dist/drafts/draft15/messages.js +59 -0
  312. package/dist/drafts/draft15/messages.js.map +1 -0
  313. package/dist/drafts/draft15/rules.d.ts +8 -0
  314. package/dist/drafts/draft15/rules.d.ts.map +1 -0
  315. package/dist/drafts/draft15/rules.js +83 -0
  316. package/dist/drafts/draft15/rules.js.map +1 -0
  317. package/dist/drafts/draft15/session-fsm.d.ts +48 -0
  318. package/dist/drafts/draft15/session-fsm.d.ts.map +1 -0
  319. package/dist/drafts/draft15/session-fsm.js +479 -0
  320. package/dist/drafts/draft15/session-fsm.js.map +1 -0
  321. package/dist/drafts/draft15/session.d.ts +5 -0
  322. package/dist/drafts/draft15/session.d.ts.map +1 -0
  323. package/dist/drafts/draft15/session.js +5 -0
  324. package/dist/drafts/draft15/session.js.map +1 -0
  325. package/dist/drafts/draft15/types.d.ts +232 -0
  326. package/dist/drafts/draft15/types.d.ts.map +1 -0
  327. package/dist/drafts/draft15/types.js +4 -0
  328. package/dist/drafts/draft15/types.js.map +1 -0
  329. package/dist/drafts/draft16/codec.d.ts +29 -0
  330. package/dist/drafts/draft16/codec.d.ts.map +1 -0
  331. package/dist/drafts/draft16/codec.js +747 -0
  332. package/dist/drafts/draft16/codec.js.map +1 -0
  333. package/dist/drafts/draft16/data-streams.d.ts +34 -0
  334. package/dist/drafts/draft16/data-streams.d.ts.map +1 -0
  335. package/dist/drafts/draft16/data-streams.js +667 -0
  336. package/dist/drafts/draft16/data-streams.js.map +1 -0
  337. package/dist/drafts/draft16/index.d.ts +9 -0
  338. package/dist/drafts/draft16/index.d.ts.map +1 -0
  339. package/dist/drafts/draft16/index.js +7 -0
  340. package/dist/drafts/draft16/index.js.map +1 -0
  341. package/dist/drafts/draft16/messages.d.ts +32 -0
  342. package/dist/drafts/draft16/messages.d.ts.map +1 -0
  343. package/dist/drafts/draft16/messages.js +62 -0
  344. package/dist/drafts/draft16/messages.js.map +1 -0
  345. package/dist/drafts/draft16/rules.d.ts +8 -0
  346. package/dist/drafts/draft16/rules.d.ts.map +1 -0
  347. package/dist/drafts/draft16/rules.js +84 -0
  348. package/dist/drafts/draft16/rules.js.map +1 -0
  349. package/dist/drafts/draft16/session-fsm.d.ts +48 -0
  350. package/dist/drafts/draft16/session-fsm.d.ts.map +1 -0
  351. package/dist/drafts/draft16/session-fsm.js +474 -0
  352. package/dist/drafts/draft16/session-fsm.js.map +1 -0
  353. package/dist/drafts/draft16/session.d.ts +5 -0
  354. package/dist/drafts/draft16/session.d.ts.map +1 -0
  355. package/dist/drafts/draft16/session.js +5 -0
  356. package/dist/drafts/draft16/session.js.map +1 -0
  357. package/dist/drafts/draft16/types.d.ts +238 -0
  358. package/dist/drafts/draft16/types.d.ts.map +1 -0
  359. package/dist/drafts/draft16/types.js +4 -0
  360. package/dist/drafts/draft16/types.js.map +1 -0
  361. package/dist/drafts/draft17/codec.d.ts +29 -0
  362. package/dist/drafts/draft17/codec.d.ts.map +1 -0
  363. package/dist/drafts/draft17/codec.js +799 -0
  364. package/dist/drafts/draft17/codec.js.map +1 -0
  365. package/dist/drafts/draft17/data-streams.d.ts +13 -0
  366. package/dist/drafts/draft17/data-streams.d.ts.map +1 -0
  367. package/dist/drafts/draft17/data-streams.js +633 -0
  368. package/dist/drafts/draft17/data-streams.js.map +1 -0
  369. package/dist/drafts/draft17/index.d.ts +8 -0
  370. package/dist/drafts/draft17/index.d.ts.map +1 -0
  371. package/dist/drafts/draft17/index.js +6 -0
  372. package/dist/drafts/draft17/index.js.map +1 -0
  373. package/dist/drafts/draft17/messages.d.ts +25 -0
  374. package/dist/drafts/draft17/messages.d.ts.map +1 -0
  375. package/dist/drafts/draft17/messages.js +48 -0
  376. package/dist/drafts/draft17/messages.js.map +1 -0
  377. package/dist/drafts/draft17/rules.d.ts +8 -0
  378. package/dist/drafts/draft17/rules.d.ts.map +1 -0
  379. package/dist/drafts/draft17/rules.js +71 -0
  380. package/dist/drafts/draft17/rules.js.map +1 -0
  381. package/dist/drafts/draft17/session-fsm.d.ts +45 -0
  382. package/dist/drafts/draft17/session-fsm.d.ts.map +1 -0
  383. package/dist/drafts/draft17/session-fsm.js +328 -0
  384. package/dist/drafts/draft17/session-fsm.js.map +1 -0
  385. package/dist/drafts/draft17/session.d.ts +5 -0
  386. package/dist/drafts/draft17/session.d.ts.map +1 -0
  387. package/dist/drafts/draft17/session.js +6 -0
  388. package/dist/drafts/draft17/session.js.map +1 -0
  389. package/dist/drafts/draft17/types.d.ts +219 -0
  390. package/dist/drafts/draft17/types.d.ts.map +1 -0
  391. package/dist/drafts/draft17/types.js +3 -0
  392. package/dist/drafts/draft17/types.js.map +1 -0
  393. package/dist/index.d.ts +46 -38
  394. package/dist/index.d.ts.map +1 -0
  395. package/dist/index.js +93 -110
  396. package/dist/index.js.map +1 -0
  397. package/dist/session.d.ts +4 -8
  398. package/dist/session.d.ts.map +1 -0
  399. package/dist/session.js +32 -26
  400. package/dist/session.js.map +1 -0
  401. package/package.json +192 -192
  402. package/src/core/buffer-reader.ts +1 -1
  403. package/src/core/hex.ts +17 -0
  404. package/src/drafts/draft07/codec.ts +933 -991
  405. package/src/drafts/draft07/data-streams.ts +240 -0
  406. package/src/drafts/draft07/index.ts +89 -69
  407. package/src/drafts/draft07/messages.ts +42 -44
  408. package/src/drafts/draft07/rules.ts +101 -104
  409. package/src/drafts/draft07/types.ts +72 -0
  410. package/src/drafts/draft08/codec.ts +944 -1254
  411. package/src/drafts/draft08/data-streams.ts +359 -0
  412. package/src/drafts/draft08/types.ts +384 -377
  413. package/src/drafts/draft09/codec.ts +936 -1235
  414. package/src/drafts/draft09/data-streams.ts +332 -0
  415. package/src/drafts/draft09/types.ts +384 -376
  416. package/src/drafts/draft10/codec.ts +936 -1235
  417. package/src/drafts/draft10/data-streams.ts +332 -0
  418. package/src/drafts/draft10/types.ts +384 -376
  419. package/src/drafts/draft11/codec.ts +969 -1198
  420. package/src/drafts/draft11/data-streams.ts +269 -0
  421. package/src/drafts/draft11/types.ts +381 -375
  422. package/src/drafts/draft12/codec.ts +1126 -1354
  423. package/src/drafts/draft12/data-streams.ts +275 -0
  424. package/src/drafts/draft12/types.ts +419 -414
  425. package/src/drafts/draft13/codec.ts +1210 -1438
  426. package/src/drafts/draft13/data-streams.ts +275 -0
  427. package/src/drafts/draft13/types.ts +438 -433
  428. package/src/drafts/draft14/codec.ts +1034 -1480
  429. package/src/drafts/draft14/data-streams.ts +798 -0
  430. package/src/drafts/draft14/types.ts +381 -365
  431. package/src/drafts/draft15/codec.ts +969 -1661
  432. package/src/drafts/draft15/data-streams.ts +778 -0
  433. package/src/drafts/draft15/types.ts +339 -336
  434. package/src/drafts/draft16/codec.ts +957 -1623
  435. package/src/drafts/draft16/data-streams.ts +773 -0
  436. package/src/drafts/draft16/types.ts +357 -354
  437. package/src/drafts/draft17/codec.ts +962 -1621
  438. package/src/drafts/draft17/data-streams.ts +742 -0
  439. package/src/drafts/draft17/types.ts +313 -310
@@ -0,0 +1,747 @@
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 { DecodeError } from "../../core/types.js";
5
+ import { MESSAGE_ID_MAP, MSG_CLIENT_SETUP, MSG_FETCH, MSG_FETCH_CANCEL, MSG_FETCH_OK, MSG_GOAWAY, MSG_MAX_REQUEST_ID, MSG_NAMESPACE, MSG_NAMESPACE_DONE, MSG_PUBLISH, MSG_PUBLISH_DONE, MSG_PUBLISH_NAMESPACE, MSG_PUBLISH_NAMESPACE_CANCEL, MSG_PUBLISH_NAMESPACE_DONE, MSG_PUBLISH_OK, MSG_REQUEST_ERROR, MSG_REQUEST_OK, MSG_REQUEST_UPDATE, MSG_REQUESTS_BLOCKED, MSG_SERVER_SETUP, MSG_SUBSCRIBE, MSG_SUBSCRIBE_NAMESPACE, MSG_SUBSCRIBE_OK, MSG_TRACK_STATUS, MSG_UNSUBSCRIBE, SETUP_PARAM_AUTHORITY, SETUP_PARAM_MAX_AUTH_TOKEN_CACHE_SIZE, SETUP_PARAM_MAX_REQUEST_ID, SETUP_PARAM_MOQT_IMPLEMENTATION, SETUP_PARAM_PATH, } from "./messages.js";
6
+ // ─── Setup Parameter Encoding/Decoding ──────────────────────────────────────────
7
+ function encodeSetupParams(params, writer) {
8
+ let count = 0;
9
+ if (params.path !== undefined)
10
+ count++;
11
+ if (params.max_request_id !== undefined)
12
+ count++;
13
+ if (params.max_auth_token_cache_size !== undefined)
14
+ count++;
15
+ if (params.authority !== undefined)
16
+ count++;
17
+ if (params.moqt_implementation !== undefined)
18
+ count++;
19
+ if (params.unknown)
20
+ count += params.unknown.length;
21
+ writer.writeVarInt(count);
22
+ // PATH (0x01) - odd, length-prefixed bytes
23
+ if (params.path !== undefined) {
24
+ writer.writeVarInt(SETUP_PARAM_PATH);
25
+ const encoded = new TextEncoder().encode(params.path);
26
+ writer.writeVarInt(encoded.byteLength);
27
+ writer.writeBytes(encoded);
28
+ }
29
+ // MAX_REQUEST_ID (0x02) - even, varint value
30
+ if (params.max_request_id !== undefined) {
31
+ writer.writeVarInt(SETUP_PARAM_MAX_REQUEST_ID);
32
+ writer.writeVarInt(params.max_request_id);
33
+ }
34
+ // MAX_AUTH_TOKEN_CACHE_SIZE (0x04) - even, varint value
35
+ if (params.max_auth_token_cache_size !== undefined) {
36
+ writer.writeVarInt(SETUP_PARAM_MAX_AUTH_TOKEN_CACHE_SIZE);
37
+ writer.writeVarInt(params.max_auth_token_cache_size);
38
+ }
39
+ // AUTHORITY (0x05) - odd, length-prefixed bytes
40
+ if (params.authority !== undefined) {
41
+ writer.writeVarInt(SETUP_PARAM_AUTHORITY);
42
+ const encoded = new TextEncoder().encode(params.authority);
43
+ writer.writeVarInt(encoded.byteLength);
44
+ writer.writeBytes(encoded);
45
+ }
46
+ // MOQT_IMPLEMENTATION (0x07) - odd, length-prefixed bytes
47
+ if (params.moqt_implementation !== undefined) {
48
+ writer.writeVarInt(SETUP_PARAM_MOQT_IMPLEMENTATION);
49
+ const encoded = new TextEncoder().encode(params.moqt_implementation);
50
+ writer.writeVarInt(encoded.byteLength);
51
+ writer.writeBytes(encoded);
52
+ }
53
+ // Unknown params
54
+ if (params.unknown) {
55
+ for (const u of params.unknown) {
56
+ const id = BigInt(u.id);
57
+ writer.writeVarInt(id);
58
+ if (id % 2n === 0n) {
59
+ const raw = hexToBytes(u.raw_hex);
60
+ const tmpReader = new BufferReader(raw);
61
+ const value = tmpReader.readVarInt();
62
+ writer.writeVarInt(value);
63
+ }
64
+ else {
65
+ const raw = hexToBytes(u.raw_hex);
66
+ writer.writeVarInt(raw.byteLength);
67
+ writer.writeBytes(raw);
68
+ }
69
+ }
70
+ }
71
+ }
72
+ function decodeSetupParams(reader) {
73
+ const count = Number(reader.readVarInt());
74
+ const result = {};
75
+ const unknown = [];
76
+ for (let i = 0; i < count; i++) {
77
+ const paramType = reader.readVarInt();
78
+ if (paramType % 2n === 0n) {
79
+ const value = reader.readVarInt();
80
+ if (paramType === SETUP_PARAM_MAX_REQUEST_ID) {
81
+ result.max_request_id = value;
82
+ }
83
+ else if (paramType === SETUP_PARAM_MAX_AUTH_TOKEN_CACHE_SIZE) {
84
+ result.max_auth_token_cache_size = value;
85
+ }
86
+ else {
87
+ const tmpWriter = new BufferWriter(16);
88
+ tmpWriter.writeVarInt(value);
89
+ const raw = tmpWriter.finish();
90
+ unknown.push({
91
+ id: `0x${paramType.toString(16)}`,
92
+ length: raw.byteLength,
93
+ raw_hex: bytesToHex(raw),
94
+ });
95
+ }
96
+ }
97
+ else {
98
+ const length = Number(reader.readVarInt());
99
+ const bytes = reader.readBytes(length);
100
+ if (paramType === SETUP_PARAM_PATH) {
101
+ result.path = new TextDecoder().decode(bytes);
102
+ }
103
+ else if (paramType === SETUP_PARAM_AUTHORITY) {
104
+ result.authority = new TextDecoder().decode(bytes);
105
+ }
106
+ else if (paramType === SETUP_PARAM_MOQT_IMPLEMENTATION) {
107
+ result.moqt_implementation = new TextDecoder().decode(bytes);
108
+ }
109
+ else {
110
+ unknown.push({
111
+ id: `0x${paramType.toString(16)}`,
112
+ length,
113
+ raw_hex: bytesToHex(bytes),
114
+ });
115
+ }
116
+ }
117
+ }
118
+ if (unknown.length > 0) {
119
+ result.unknown = unknown;
120
+ }
121
+ return result;
122
+ }
123
+ // ─── Version-Specific Parameter Encoding/Decoding ───────────────────────────────
124
+ const PARAM_EXPIRES = 0x08n;
125
+ const PARAM_LARGEST_OBJECT = 0x09n;
126
+ const PARAM_SUBSCRIBER_PRIORITY = 0x20n;
127
+ const PARAM_SUBSCRIPTION_FILTER = 0x21n;
128
+ const PARAM_GROUP_ORDER = 0x22n;
129
+ function encodeParams(params, writer) {
130
+ let count = params.unknown ? params.unknown.length : 0;
131
+ if (params.expires !== undefined)
132
+ count++;
133
+ if (params.largest_object !== undefined)
134
+ count++;
135
+ if (params.subscriber_priority !== undefined)
136
+ count++;
137
+ if (params.subscription_filter !== undefined)
138
+ count++;
139
+ if (params.group_order !== undefined)
140
+ count++;
141
+ writer.writeVarInt(count);
142
+ if (params.expires !== undefined) {
143
+ writer.writeVarInt(PARAM_EXPIRES);
144
+ writer.writeVarInt(params.expires);
145
+ }
146
+ if (params.largest_object !== undefined) {
147
+ writer.writeVarInt(PARAM_LARGEST_OBJECT);
148
+ const tmpW = new BufferWriter(16);
149
+ tmpW.writeVarInt(params.largest_object.group);
150
+ tmpW.writeVarInt(params.largest_object.object);
151
+ const raw = tmpW.finish();
152
+ writer.writeVarInt(raw.byteLength);
153
+ writer.writeBytes(raw);
154
+ }
155
+ if (params.subscriber_priority !== undefined) {
156
+ writer.writeVarInt(PARAM_SUBSCRIBER_PRIORITY);
157
+ writer.writeVarInt(params.subscriber_priority);
158
+ }
159
+ if (params.subscription_filter !== undefined) {
160
+ writer.writeVarInt(PARAM_SUBSCRIPTION_FILTER);
161
+ const tmpW = new BufferWriter(32);
162
+ const f = params.subscription_filter;
163
+ tmpW.writeVarInt(f.filter_type);
164
+ if (f.filter_type === 3n || f.filter_type === 4n) {
165
+ tmpW.writeVarInt(f.start_group);
166
+ tmpW.writeVarInt(f.start_object);
167
+ }
168
+ if (f.filter_type === 4n) {
169
+ tmpW.writeVarInt(f.end_group);
170
+ }
171
+ const raw = tmpW.finish();
172
+ writer.writeVarInt(raw.byteLength);
173
+ writer.writeBytes(raw);
174
+ }
175
+ if (params.group_order !== undefined) {
176
+ writer.writeVarInt(PARAM_GROUP_ORDER);
177
+ writer.writeVarInt(params.group_order);
178
+ }
179
+ if (params.unknown) {
180
+ for (const u of params.unknown) {
181
+ const id = BigInt(u.id);
182
+ writer.writeVarInt(id);
183
+ if (id % 2n === 0n) {
184
+ const raw = hexToBytes(u.raw_hex);
185
+ const tmpReader = new BufferReader(raw);
186
+ const value = tmpReader.readVarInt();
187
+ writer.writeVarInt(value);
188
+ }
189
+ else {
190
+ const raw = hexToBytes(u.raw_hex);
191
+ writer.writeVarInt(raw.byteLength);
192
+ writer.writeBytes(raw);
193
+ }
194
+ }
195
+ }
196
+ }
197
+ function decodeParams(reader) {
198
+ const count = Number(reader.readVarInt());
199
+ const result = {};
200
+ const unknown = [];
201
+ for (let i = 0; i < count; i++) {
202
+ const paramType = reader.readVarInt();
203
+ if (paramType === PARAM_EXPIRES) {
204
+ result.expires = reader.readVarInt();
205
+ }
206
+ else if (paramType === PARAM_SUBSCRIBER_PRIORITY) {
207
+ result.subscriber_priority = reader.readVarInt();
208
+ }
209
+ else if (paramType === PARAM_GROUP_ORDER) {
210
+ result.group_order = reader.readVarInt();
211
+ }
212
+ else if (paramType === PARAM_LARGEST_OBJECT) {
213
+ const length = Number(reader.readVarInt());
214
+ const startOff = reader.offset;
215
+ const group = reader.readVarInt();
216
+ const object = reader.readVarInt();
217
+ const consumed = reader.offset - startOff;
218
+ if (consumed < length)
219
+ reader.readBytes(length - consumed);
220
+ result.largest_object = { group, object };
221
+ }
222
+ else if (paramType === PARAM_SUBSCRIPTION_FILTER) {
223
+ const length = Number(reader.readVarInt());
224
+ const startOff = reader.offset;
225
+ const filter_type = reader.readVarInt();
226
+ const filter = { filter_type };
227
+ if (filter_type === 3n || filter_type === 4n) {
228
+ filter.start_group = reader.readVarInt();
229
+ filter.start_object = reader.readVarInt();
230
+ }
231
+ if (filter_type === 4n) {
232
+ filter.end_group = reader.readVarInt();
233
+ }
234
+ const consumed = reader.offset - startOff;
235
+ if (consumed < length)
236
+ reader.readBytes(length - consumed);
237
+ result.subscription_filter = filter;
238
+ }
239
+ else if (paramType % 2n === 0n) {
240
+ const value = reader.readVarInt();
241
+ const tmpWriter = new BufferWriter(16);
242
+ tmpWriter.writeVarInt(value);
243
+ const raw = tmpWriter.finish();
244
+ unknown.push({
245
+ id: `0x${paramType.toString(16)}`,
246
+ length: raw.byteLength,
247
+ raw_hex: bytesToHex(raw),
248
+ });
249
+ }
250
+ else {
251
+ const length = Number(reader.readVarInt());
252
+ const bytes = reader.readBytes(length);
253
+ unknown.push({
254
+ id: `0x${paramType.toString(16)}`,
255
+ length,
256
+ raw_hex: bytesToHex(bytes),
257
+ });
258
+ }
259
+ }
260
+ if (unknown.length > 0) {
261
+ result.unknown = unknown;
262
+ }
263
+ return result;
264
+ }
265
+ // ─── Payload Encoders ──────────────────────────────────────────────────────────
266
+ function encodeClientSetupPayload(msg, w) {
267
+ encodeSetupParams(msg.parameters, w);
268
+ }
269
+ function encodeServerSetupPayload(msg, w) {
270
+ encodeSetupParams(msg.parameters, w);
271
+ }
272
+ function encodeSubscribePayload(msg, w) {
273
+ w.writeVarInt(msg.request_id);
274
+ w.writeTuple(msg.track_namespace);
275
+ w.writeString(msg.track_name);
276
+ encodeParams(msg.parameters, w);
277
+ }
278
+ function encodeSubscribeOkPayload(msg, w) {
279
+ w.writeVarInt(msg.request_id);
280
+ w.writeVarInt(msg.track_alias);
281
+ encodeParams(msg.parameters, w);
282
+ }
283
+ function encodeRequestUpdatePayload(msg, w) {
284
+ w.writeVarInt(msg.request_id);
285
+ w.writeVarInt(msg.existing_request_id);
286
+ encodeParams(msg.parameters, w);
287
+ }
288
+ function encodeUnsubscribePayload(msg, w) {
289
+ w.writeVarInt(msg.request_id);
290
+ }
291
+ function encodePublishPayload(msg, w) {
292
+ w.writeVarInt(msg.request_id);
293
+ w.writeTuple(msg.track_namespace);
294
+ w.writeString(msg.track_name);
295
+ w.writeVarInt(msg.track_alias);
296
+ encodeParams(msg.parameters, w);
297
+ }
298
+ function encodePublishOkPayload(msg, w) {
299
+ w.writeVarInt(msg.request_id);
300
+ encodeParams(msg.parameters, w);
301
+ }
302
+ function encodePublishDonePayload(msg, w) {
303
+ w.writeVarInt(msg.request_id);
304
+ w.writeVarInt(msg.status_code);
305
+ w.writeVarInt(msg.stream_count);
306
+ w.writeString(msg.reason_phrase);
307
+ }
308
+ function encodePublishNamespacePayload(msg, w) {
309
+ w.writeVarInt(msg.request_id);
310
+ w.writeTuple(msg.track_namespace);
311
+ encodeParams(msg.parameters, w);
312
+ }
313
+ // Draft-16: simplified to just request_id
314
+ function encodePublishNamespaceDonePayload(msg, w) {
315
+ w.writeVarInt(msg.request_id);
316
+ }
317
+ // Draft-16: changed to request_id + error_code + reason_phrase
318
+ function encodePublishNamespaceCancelPayload(msg, w) {
319
+ w.writeVarInt(msg.request_id);
320
+ w.writeVarInt(msg.error_code);
321
+ w.writeString(msg.reason_phrase);
322
+ }
323
+ // Draft-16: added subscribe_options
324
+ function encodeSubscribeNamespacePayload(msg, w) {
325
+ w.writeVarInt(msg.request_id);
326
+ w.writeTuple(msg.namespace_prefix);
327
+ w.writeVarInt(msg.subscribe_options);
328
+ encodeParams(msg.parameters, w);
329
+ }
330
+ // New in draft-16
331
+ function encodeNamespacePayload(msg, w) {
332
+ w.writeTuple(msg.namespace_suffix);
333
+ }
334
+ // New in draft-16
335
+ function encodeNamespaceDonePayload(msg, w) {
336
+ w.writeTuple(msg.namespace_suffix);
337
+ }
338
+ function encodeFetchPayload(msg, w) {
339
+ w.writeVarInt(msg.request_id);
340
+ w.writeVarInt(msg.fetch_type);
341
+ const ft = Number(msg.fetch_type);
342
+ if (ft === 1 && msg.standalone) {
343
+ w.writeTuple(msg.standalone.track_namespace);
344
+ w.writeString(msg.standalone.track_name);
345
+ w.writeVarInt(msg.standalone.start_group);
346
+ w.writeVarInt(msg.standalone.start_object);
347
+ w.writeVarInt(msg.standalone.end_group);
348
+ w.writeVarInt(msg.standalone.end_object);
349
+ }
350
+ else if ((ft === 2 || ft === 3) && msg.joining) {
351
+ w.writeVarInt(msg.joining.joining_request_id);
352
+ w.writeVarInt(msg.joining.joining_start);
353
+ }
354
+ encodeParams(msg.parameters, w);
355
+ }
356
+ function encodeFetchOkPayload(msg, w) {
357
+ w.writeVarInt(msg.request_id);
358
+ w.writeUint8(msg.end_of_track);
359
+ w.writeVarInt(msg.end_group);
360
+ w.writeVarInt(msg.end_object);
361
+ encodeParams(msg.parameters, w);
362
+ }
363
+ function encodeFetchCancelPayload(msg, w) {
364
+ w.writeVarInt(msg.request_id);
365
+ }
366
+ function encodeTrackStatusPayload(msg, w) {
367
+ w.writeVarInt(msg.request_id);
368
+ w.writeTuple(msg.track_namespace);
369
+ w.writeString(msg.track_name);
370
+ encodeParams(msg.parameters, w);
371
+ }
372
+ function encodeRequestOkPayload(msg, w) {
373
+ w.writeVarInt(msg.request_id);
374
+ encodeParams(msg.parameters, w);
375
+ }
376
+ // Draft-16: added retry_interval
377
+ function encodeRequestErrorPayload(msg, w) {
378
+ w.writeVarInt(msg.request_id);
379
+ w.writeVarInt(msg.error_code);
380
+ w.writeVarInt(msg.retry_interval);
381
+ w.writeString(msg.reason_phrase);
382
+ }
383
+ function encodeGoAwayPayload(msg, w) {
384
+ w.writeString(msg.new_session_uri);
385
+ }
386
+ function encodeMaxRequestIdPayload(msg, w) {
387
+ w.writeVarInt(msg.max_request_id);
388
+ }
389
+ function encodeRequestsBlockedPayload(msg, w) {
390
+ w.writeVarInt(msg.maximum_request_id);
391
+ }
392
+ // ─── Payload Decoders ──────────────────────────────────────────────────────────
393
+ function decodeClientSetupPayload(r) {
394
+ const parameters = decodeSetupParams(r);
395
+ return { type: "client_setup", parameters };
396
+ }
397
+ function decodeServerSetupPayload(r) {
398
+ const parameters = decodeSetupParams(r);
399
+ return { type: "server_setup", parameters };
400
+ }
401
+ function decodeSubscribePayload(r) {
402
+ const request_id = r.readVarInt();
403
+ const track_namespace = r.readTuple();
404
+ const track_name = r.readString();
405
+ const parameters = decodeParams(r);
406
+ return { type: "subscribe", request_id, track_namespace, track_name, parameters };
407
+ }
408
+ function decodeSubscribeOkPayload(r) {
409
+ const request_id = r.readVarInt();
410
+ const track_alias = r.readVarInt();
411
+ const parameters = decodeParams(r);
412
+ return { type: "subscribe_ok", request_id, track_alias, parameters };
413
+ }
414
+ function decodeRequestUpdatePayload(r) {
415
+ const request_id = r.readVarInt();
416
+ const existing_request_id = r.readVarInt();
417
+ const parameters = decodeParams(r);
418
+ return { type: "request_update", request_id, existing_request_id, parameters };
419
+ }
420
+ function decodeUnsubscribePayload(r) {
421
+ const request_id = r.readVarInt();
422
+ return { type: "unsubscribe", request_id };
423
+ }
424
+ function decodePublishPayload(r) {
425
+ const request_id = r.readVarInt();
426
+ const track_namespace = r.readTuple();
427
+ const track_name = r.readString();
428
+ const track_alias = r.readVarInt();
429
+ const parameters = decodeParams(r);
430
+ return { type: "publish", request_id, track_namespace, track_name, track_alias, parameters };
431
+ }
432
+ function decodePublishOkPayload(r) {
433
+ const request_id = r.readVarInt();
434
+ const parameters = decodeParams(r);
435
+ return { type: "publish_ok", request_id, parameters };
436
+ }
437
+ function decodePublishDonePayload(r) {
438
+ const request_id = r.readVarInt();
439
+ const status_code = r.readVarInt();
440
+ const stream_count = r.readVarInt();
441
+ const reason_phrase = r.readString();
442
+ return { type: "publish_done", request_id, status_code, stream_count, reason_phrase };
443
+ }
444
+ function decodePublishNamespacePayload(r) {
445
+ const request_id = r.readVarInt();
446
+ const track_namespace = r.readTuple();
447
+ const parameters = decodeParams(r);
448
+ return { type: "publish_namespace", request_id, track_namespace, parameters };
449
+ }
450
+ // Draft-16: simplified to just request_id
451
+ function decodePublishNamespaceDonePayload(r) {
452
+ const request_id = r.readVarInt();
453
+ return { type: "publish_namespace_done", request_id };
454
+ }
455
+ // Draft-16: changed to request_id + error_code + reason_phrase
456
+ function decodePublishNamespaceCancelPayload(r) {
457
+ const request_id = r.readVarInt();
458
+ const error_code = r.readVarInt();
459
+ const reason_phrase = r.readString();
460
+ return { type: "publish_namespace_cancel", request_id, error_code, reason_phrase };
461
+ }
462
+ // Draft-16: added subscribe_options
463
+ function decodeSubscribeNamespacePayload(r) {
464
+ const request_id = r.readVarInt();
465
+ const namespace_prefix = r.readTuple();
466
+ const subscribe_options = r.readVarInt();
467
+ const parameters = decodeParams(r);
468
+ return {
469
+ type: "subscribe_namespace",
470
+ request_id,
471
+ namespace_prefix,
472
+ subscribe_options,
473
+ parameters,
474
+ };
475
+ }
476
+ // New in draft-16
477
+ function decodeNamespacePayload(r) {
478
+ const namespace_suffix = r.readTuple();
479
+ return { type: "namespace", namespace_suffix };
480
+ }
481
+ // New in draft-16
482
+ function decodeNamespaceDonePayload(r) {
483
+ const namespace_suffix = r.readTuple();
484
+ return { type: "namespace_done", namespace_suffix };
485
+ }
486
+ function decodeFetchPayload(r) {
487
+ const request_id = r.readVarInt();
488
+ const fetch_type = r.readVarInt();
489
+ const ft = Number(fetch_type);
490
+ if (ft < 1 || ft > 3) {
491
+ throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid fetch_type: ${ft}`, r.offset);
492
+ }
493
+ let standalone;
494
+ let joining;
495
+ if (ft === 1) {
496
+ const track_namespace = r.readTuple();
497
+ const track_name = r.readString();
498
+ const start_group = r.readVarInt();
499
+ const start_object = r.readVarInt();
500
+ const end_group = r.readVarInt();
501
+ const end_object = r.readVarInt();
502
+ standalone = { track_namespace, track_name, start_group, start_object, end_group, end_object };
503
+ }
504
+ else {
505
+ const joining_request_id = r.readVarInt();
506
+ const joining_start = r.readVarInt();
507
+ joining = { joining_request_id, joining_start };
508
+ }
509
+ const parameters = decodeParams(r);
510
+ return {
511
+ type: "fetch",
512
+ request_id,
513
+ fetch_type,
514
+ standalone,
515
+ joining,
516
+ parameters,
517
+ };
518
+ }
519
+ function decodeFetchOkPayload(r) {
520
+ const request_id = r.readVarInt();
521
+ const end_of_track = r.readUint8();
522
+ const end_group = r.readVarInt();
523
+ const end_object = r.readVarInt();
524
+ const parameters = decodeParams(r);
525
+ return { type: "fetch_ok", request_id, end_of_track, end_group, end_object, parameters };
526
+ }
527
+ function decodeFetchCancelPayload(r) {
528
+ const request_id = r.readVarInt();
529
+ return { type: "fetch_cancel", request_id };
530
+ }
531
+ function decodeTrackStatusPayload(r) {
532
+ const request_id = r.readVarInt();
533
+ const track_namespace = r.readTuple();
534
+ const track_name = r.readString();
535
+ const parameters = decodeParams(r);
536
+ return { type: "track_status", request_id, track_namespace, track_name, parameters };
537
+ }
538
+ function decodeRequestOkPayload(r) {
539
+ const request_id = r.readVarInt();
540
+ const parameters = decodeParams(r);
541
+ return { type: "request_ok", request_id, parameters };
542
+ }
543
+ // Draft-16: added retry_interval
544
+ function decodeRequestErrorPayload(r) {
545
+ const request_id = r.readVarInt();
546
+ const error_code = r.readVarInt();
547
+ const retry_interval = r.readVarInt();
548
+ const reason_phrase = r.readString();
549
+ return { type: "request_error", request_id, error_code, retry_interval, reason_phrase };
550
+ }
551
+ function decodeGoAwayPayload(r) {
552
+ const new_session_uri = r.readString();
553
+ return { type: "goaway", new_session_uri };
554
+ }
555
+ function decodeMaxRequestIdPayload(r) {
556
+ const max_request_id = r.readVarInt();
557
+ return { type: "max_request_id", max_request_id };
558
+ }
559
+ function decodeRequestsBlockedPayload(r) {
560
+ const maximum_request_id = r.readVarInt();
561
+ return { type: "requests_blocked", maximum_request_id };
562
+ }
563
+ // ─── Payload dispatch tables ───────────────────────────────────────────────────
564
+ const payloadDecoders = new Map([
565
+ [MSG_CLIENT_SETUP, decodeClientSetupPayload],
566
+ [MSG_SERVER_SETUP, decodeServerSetupPayload],
567
+ [MSG_SUBSCRIBE, decodeSubscribePayload],
568
+ [MSG_SUBSCRIBE_OK, decodeSubscribeOkPayload],
569
+ [MSG_REQUEST_UPDATE, decodeRequestUpdatePayload],
570
+ [MSG_UNSUBSCRIBE, decodeUnsubscribePayload],
571
+ [MSG_PUBLISH, decodePublishPayload],
572
+ [MSG_PUBLISH_OK, decodePublishOkPayload],
573
+ [MSG_PUBLISH_DONE, decodePublishDonePayload],
574
+ [MSG_PUBLISH_NAMESPACE, decodePublishNamespacePayload],
575
+ [MSG_PUBLISH_NAMESPACE_DONE, decodePublishNamespaceDonePayload],
576
+ [MSG_PUBLISH_NAMESPACE_CANCEL, decodePublishNamespaceCancelPayload],
577
+ [MSG_SUBSCRIBE_NAMESPACE, decodeSubscribeNamespacePayload],
578
+ [MSG_NAMESPACE, decodeNamespacePayload],
579
+ [MSG_NAMESPACE_DONE, decodeNamespaceDonePayload],
580
+ [MSG_FETCH, decodeFetchPayload],
581
+ [MSG_FETCH_OK, decodeFetchOkPayload],
582
+ [MSG_FETCH_CANCEL, decodeFetchCancelPayload],
583
+ [MSG_TRACK_STATUS, decodeTrackStatusPayload],
584
+ [MSG_REQUEST_OK, decodeRequestOkPayload],
585
+ [MSG_REQUEST_ERROR, decodeRequestErrorPayload],
586
+ [MSG_GOAWAY, decodeGoAwayPayload],
587
+ [MSG_MAX_REQUEST_ID, decodeMaxRequestIdPayload],
588
+ [MSG_REQUESTS_BLOCKED, decodeRequestsBlockedPayload],
589
+ ]);
590
+ // ─── Public API ────────────────────────────────────────────────────────────────
591
+ /**
592
+ * Encode a draft-16 control message with type(varint) + length(uint16 BE) + payload.
593
+ */
594
+ export function encodeMessage(message) {
595
+ const typeId = MESSAGE_ID_MAP.get(message.type);
596
+ if (typeId === undefined) {
597
+ throw new Error(`Unknown message type: ${message.type}`);
598
+ }
599
+ const payloadWriter = new BufferWriter();
600
+ encodePayload(message, payloadWriter);
601
+ const payload = payloadWriter.finish();
602
+ if (payload.byteLength > 0xffff) {
603
+ throw new Error(`Payload too large for 16-bit length: ${payload.byteLength}`);
604
+ }
605
+ const writer = new BufferWriter();
606
+ writer.writeVarInt(typeId);
607
+ writer.writeUint8((payload.byteLength >> 8) & 0xff);
608
+ writer.writeUint8(payload.byteLength & 0xff);
609
+ writer.writeBytes(payload);
610
+ return writer.finish();
611
+ }
612
+ function encodePayload(msg, w) {
613
+ switch (msg.type) {
614
+ case "client_setup":
615
+ return encodeClientSetupPayload(msg, w);
616
+ case "server_setup":
617
+ return encodeServerSetupPayload(msg, w);
618
+ case "subscribe":
619
+ return encodeSubscribePayload(msg, w);
620
+ case "subscribe_ok":
621
+ return encodeSubscribeOkPayload(msg, w);
622
+ case "request_update":
623
+ return encodeRequestUpdatePayload(msg, w);
624
+ case "unsubscribe":
625
+ return encodeUnsubscribePayload(msg, w);
626
+ case "publish":
627
+ return encodePublishPayload(msg, w);
628
+ case "publish_ok":
629
+ return encodePublishOkPayload(msg, w);
630
+ case "publish_done":
631
+ return encodePublishDonePayload(msg, w);
632
+ case "publish_namespace":
633
+ return encodePublishNamespacePayload(msg, w);
634
+ case "publish_namespace_done":
635
+ return encodePublishNamespaceDonePayload(msg, w);
636
+ case "publish_namespace_cancel":
637
+ return encodePublishNamespaceCancelPayload(msg, w);
638
+ case "subscribe_namespace":
639
+ return encodeSubscribeNamespacePayload(msg, w);
640
+ case "namespace":
641
+ return encodeNamespacePayload(msg, w);
642
+ case "namespace_done":
643
+ return encodeNamespaceDonePayload(msg, w);
644
+ case "fetch":
645
+ return encodeFetchPayload(msg, w);
646
+ case "fetch_ok":
647
+ return encodeFetchOkPayload(msg, w);
648
+ case "fetch_cancel":
649
+ return encodeFetchCancelPayload(msg, w);
650
+ case "track_status":
651
+ return encodeTrackStatusPayload(msg, w);
652
+ case "request_ok":
653
+ return encodeRequestOkPayload(msg, w);
654
+ case "request_error":
655
+ return encodeRequestErrorPayload(msg, w);
656
+ case "goaway":
657
+ return encodeGoAwayPayload(msg, w);
658
+ case "max_request_id":
659
+ return encodeMaxRequestIdPayload(msg, w);
660
+ case "requests_blocked":
661
+ return encodeRequestsBlockedPayload(msg, w);
662
+ default: {
663
+ const _exhaustive = msg;
664
+ throw new Error(`Unhandled message type: ${_exhaustive.type}`);
665
+ }
666
+ }
667
+ }
668
+ /**
669
+ * Decode a draft-16 control message from bytes (type + uint16 length + payload).
670
+ */
671
+ export function decodeMessage(bytes) {
672
+ try {
673
+ const reader = new BufferReader(bytes);
674
+ const typeId = reader.readVarInt();
675
+ const lenHi = reader.readUint8();
676
+ const lenLo = reader.readUint8();
677
+ const payloadLength = (lenHi << 8) | lenLo;
678
+ const payloadBytes = reader.readBytes(payloadLength);
679
+ const payloadReader = new BufferReader(payloadBytes);
680
+ const decoder = payloadDecoders.get(typeId);
681
+ if (!decoder) {
682
+ return {
683
+ ok: false,
684
+ error: new DecodeError("UNKNOWN_MESSAGE_TYPE", `Unknown message type ID: 0x${typeId.toString(16)}`, 0),
685
+ };
686
+ }
687
+ const message = decoder(payloadReader);
688
+ return { ok: true, value: message, bytesRead: reader.offset };
689
+ }
690
+ catch (e) {
691
+ if (e instanceof DecodeError) {
692
+ return { ok: false, error: e };
693
+ }
694
+ throw e;
695
+ }
696
+ }
697
+ // ─── Data Stream Encoding/Decoding (re-exported from data-streams.ts) ───────
698
+ import { encodeSubgroupStream, decodeSubgroupStream, encodeDatagram, decodeDatagram, encodeFetchStream, decodeFetchStream, decodeDataStream, createSubgroupStreamDecoder, createFetchStreamDecoder, createDataStreamDecoder } from "./data-streams.js";
699
+ export { encodeSubgroupStream, decodeSubgroupStream, encodeDatagram, decodeDatagram, encodeFetchStream, decodeFetchStream, decodeDataStream, createSubgroupStreamDecoder, createFetchStreamDecoder, createDataStreamDecoder };
700
+ // ─── Stream Decoders ───────────────────────────────────────────────────────────
701
+ export function createStreamDecoder() {
702
+ let buffer = new Uint8Array(0);
703
+ return new TransformStream({
704
+ transform(chunk, controller) {
705
+ const newBuffer = new Uint8Array(buffer.length + chunk.length);
706
+ newBuffer.set(buffer, 0);
707
+ newBuffer.set(chunk, buffer.length);
708
+ buffer = newBuffer;
709
+ while (buffer.length > 0) {
710
+ const result = decodeMessage(buffer);
711
+ if (!result.ok) {
712
+ if (result.error.code === "UNEXPECTED_END") {
713
+ break;
714
+ }
715
+ controller.error(result.error);
716
+ return;
717
+ }
718
+ controller.enqueue(result.value);
719
+ buffer = buffer.slice(result.bytesRead);
720
+ }
721
+ },
722
+ flush(controller) {
723
+ if (buffer.length > 0) {
724
+ controller.error(new DecodeError("UNEXPECTED_END", "Stream ended with incomplete message data", 0));
725
+ }
726
+ },
727
+ });
728
+ }
729
+ export function createDraft16Codec() {
730
+ return {
731
+ draft: "draft-ietf-moq-transport-16",
732
+ encodeMessage,
733
+ decodeMessage,
734
+ encodeSubgroupStream,
735
+ encodeDatagram,
736
+ encodeFetchStream,
737
+ decodeSubgroupStream,
738
+ decodeDatagram,
739
+ decodeFetchStream,
740
+ decodeDataStream,
741
+ createStreamDecoder,
742
+ createSubgroupStreamDecoder,
743
+ createFetchStreamDecoder,
744
+ createDataStreamDecoder,
745
+ };
746
+ }
747
+ //# sourceMappingURL=codec.js.map