@moqtap/codec 0.2.1 → 0.2.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-LH4NTURO.js → chunk-2GODRVT5.js} +699 -589
- package/dist/{chunk-4RIXXEII.js → chunk-2ZT6CVSE.js} +274 -242
- package/dist/{chunk-XUUCOLWU.cjs → chunk-4N4INRE7.cjs} +332 -321
- package/dist/{chunk-PJRA2TQ5.js → chunk-73MWUKSJ.js} +274 -228
- package/dist/{chunk-NGVE2RZT.js → chunk-77MNXX3M.js} +549 -538
- package/dist/{chunk-A27S7HW7.js → chunk-7L43FE6P.js} +24 -3
- package/dist/{chunk-RVJAGE4S.cjs → chunk-ACQ4CUJP.cjs} +297 -265
- package/dist/{chunk-IBVM4DMJ.cjs → chunk-BGWGVINJ.cjs} +332 -321
- package/dist/{chunk-KFTCU2P6.js → chunk-C6KUWLQC.js} +0 -3
- package/dist/{chunk-CXDHOMHG.js → chunk-CEH7ESNC.js} +549 -538
- package/dist/{chunk-ZBKE2QRQ.js → chunk-E6P74GDT.js} +686 -599
- package/dist/{chunk-FUFTMAQD.cjs → chunk-FPISPJ5N.cjs} +785 -497
- package/dist/{chunk-7IVGHMKJ.cjs → chunk-FZDIEHQL.cjs} +300 -124
- package/dist/{chunk-ZSPO2GF2.cjs → chunk-GLBQDG4L.cjs} +971 -884
- package/dist/chunk-HDWJ2GDE.js +24 -0
- package/dist/{chunk-4YJANAXU.cjs → chunk-JGG7CMSZ.cjs} +469 -434
- package/dist/{chunk-IV2H5CFI.cjs → chunk-JTVCOMBI.cjs} +298 -266
- package/dist/chunk-KNDYS3DK.cjs +24 -0
- package/dist/{chunk-BPNL5YFQ.cjs → chunk-KZCYQ7ED.cjs} +5 -5
- package/dist/{chunk-U2B3B42P.js → chunk-MC7W6PMI.js} +709 -421
- package/dist/{chunk-MFAP7R6L.js → chunk-MRJWLGYH.js} +1 -1
- package/dist/{chunk-RWQ43Z4F.cjs → chunk-MZ7VU52O.cjs} +0 -3
- package/dist/{chunk-TMNGRIPL.js → chunk-N2KBF5Q2.js} +285 -109
- package/dist/{chunk-IV2HRJVT.js → chunk-PZBPH2D7.js} +274 -242
- package/dist/{chunk-FWISIR26.cjs → chunk-RUPCJTC3.cjs} +24 -3
- package/dist/{chunk-G26SJ6XS.cjs → chunk-S74DWJE2.cjs} +1001 -925
- package/dist/{chunk-NUX5BHWO.js → chunk-U3IPZYPX.js} +1113 -1037
- package/dist/{chunk-HSVYF6XX.cjs → chunk-VJUUZ4W2.cjs} +1106 -996
- package/dist/{chunk-ST24APEO.js → chunk-XSNX2IUJ.js} +574 -539
- package/dist/{chunk-K4OLITS2.cjs → chunk-YIG2C3LF.cjs} +295 -249
- package/dist/{drafts/draft15/codec.d.ts → codec-B2cH-f5V.d.cts} +11 -10
- package/dist/codec-B5K73Bdj.d.ts +30 -0
- package/dist/{codec-C_HMXNK_.d.ts → codec-BFeliJFc.d.ts} +4 -10
- package/dist/codec-BUMjz0J4.d.cts +30 -0
- package/dist/{codec-D0x8-SCw.d.cts → codec-Bap882Fh.d.cts} +3 -9
- package/dist/codec-BdVMRMOI.d.ts +34 -0
- package/dist/codec-Bq-tLtfP.d.ts +30 -0
- package/dist/codec-BwFgpeQu.d.ts +23 -0
- package/dist/{codec-95k8CAu5.d.cts → codec-C4n1PS09.d.cts} +3 -9
- package/dist/{codec-BECYPfY8.d.ts → codec-CPlK3Pi5.d.ts} +3 -9
- package/dist/{drafts/draft08/codec.d.ts → codec-CPvPq0sb.d.cts} +11 -9
- package/dist/codec-DNUIgLqc.d.cts +23 -0
- package/dist/codec-DRcsBCsb.d.ts +23 -0
- package/dist/{codec-CAevkgf5.d.cts → codec-DY4QH364.d.cts} +4 -10
- package/dist/codec-DZhZSIii.d.cts +30 -0
- package/dist/{drafts/draft14/codec.d.ts → codec-FvGCxIhr.d.ts} +11 -10
- package/dist/codec-HgBgHkFI.d.cts +23 -0
- package/dist/codec-KXHvXZVb.d.cts +35 -0
- package/dist/{codec-BC5jfvMb.d.ts → codec-R8GrCPt2.d.ts} +3 -9
- package/dist/{codec-BsPU1vNC.d.ts → codec-SKBeHQk7.d.ts} +3 -11
- package/dist/draft10-session.d.cts +1 -1
- package/dist/draft10-session.d.ts +1 -1
- package/dist/draft10.cjs +4 -3
- package/dist/draft10.d.cts +15 -5
- package/dist/draft10.d.ts +15 -5
- package/dist/draft10.js +3 -2
- package/dist/draft11-session.d.cts +1 -1
- package/dist/draft11-session.d.ts +1 -1
- package/dist/draft11.cjs +4 -3
- package/dist/draft11.d.cts +13 -5
- package/dist/draft11.d.ts +13 -5
- package/dist/draft11.js +3 -2
- package/dist/draft12-session.d.cts +1 -1
- package/dist/draft12-session.d.ts +1 -1
- package/dist/draft12.cjs +4 -3
- package/dist/draft12.d.cts +13 -5
- package/dist/draft12.d.ts +13 -5
- package/dist/draft12.js +3 -2
- package/dist/draft13-session.d.cts +1 -1
- package/dist/draft13-session.d.ts +1 -1
- package/dist/draft13.cjs +4 -3
- package/dist/draft13.d.cts +13 -5
- package/dist/draft13.d.ts +13 -5
- package/dist/draft13.js +3 -2
- package/dist/draft14-session.d.cts +1 -1
- package/dist/draft14-session.d.ts +1 -1
- package/dist/draft14.cjs +4 -3
- package/dist/draft14.d.cts +59 -5
- package/dist/draft14.d.ts +59 -5
- package/dist/draft14.js +3 -2
- package/dist/draft15-session.d.cts +1 -1
- package/dist/draft15-session.d.ts +1 -1
- package/dist/draft15.cjs +4 -3
- package/dist/draft15.d.cts +48 -5
- package/dist/draft15.d.ts +48 -5
- package/dist/draft15.js +3 -2
- package/dist/draft16-session.d.cts +1 -1
- package/dist/draft16-session.d.ts +1 -1
- package/dist/draft16.cjs +4 -3
- package/dist/draft16.d.cts +37 -5
- package/dist/draft16.d.ts +37 -5
- package/dist/draft16.js +3 -2
- package/dist/draft17-session.d.cts +1 -1
- package/dist/draft17-session.d.ts +1 -1
- package/dist/draft17.cjs +4 -3
- package/dist/draft17.d.cts +16 -5
- package/dist/draft17.d.ts +16 -5
- package/dist/draft17.js +3 -2
- package/dist/draft7-session.cjs +3 -3
- package/dist/draft7-session.js +2 -2
- package/dist/draft7.cjs +18 -6
- package/dist/draft7.d.cts +84 -8
- package/dist/draft7.d.ts +84 -8
- package/dist/draft7.js +15 -3
- package/dist/draft8-session.d.cts +1 -1
- package/dist/draft8-session.d.ts +1 -1
- package/dist/draft8.cjs +4 -3
- package/dist/draft8.d.cts +15 -5
- package/dist/draft8.d.ts +15 -5
- package/dist/draft8.js +3 -2
- package/dist/draft9-session.d.cts +1 -1
- package/dist/draft9-session.d.ts +1 -1
- package/dist/draft9.cjs +4 -3
- package/dist/draft9.d.cts +15 -5
- package/dist/draft9.d.ts +15 -5
- package/dist/draft9.js +3 -2
- package/dist/index.cjs +25 -24
- package/dist/index.d.cts +20 -20
- package/dist/index.d.ts +38 -46
- package/dist/index.js +111 -93
- package/dist/session.cjs +3 -3
- package/dist/session.d.ts +8 -4
- package/dist/session.js +26 -32
- package/dist/{types-ERexTpT8.d.cts → types-8gUGeMgs.d.cts} +4 -1
- package/dist/{types-ERexTpT8.d.ts → types-8gUGeMgs.d.ts} +4 -1
- package/dist/{types-Cw4WE9dh.d.ts → types-B0FT5Qs2.d.cts} +9 -1
- package/dist/{types-Cw4WE9dh.d.cts → types-B0FT5Qs2.d.ts} +9 -1
- package/dist/{types-DqCDFqgB.d.cts → types-B9A2g05r.d.cts} +4 -1
- package/dist/{types-DqCDFqgB.d.ts → types-B9A2g05r.d.ts} +4 -1
- package/dist/{types-Bg6QYNVt.d.cts → types-BeAVNU-F.d.cts} +7 -2
- package/dist/{types-Bg6QYNVt.d.ts → types-BeAVNU-F.d.ts} +7 -2
- package/dist/{types-C_1HrqBl.d.ts → types-CDa7F5ct.d.cts} +7 -2
- package/dist/{types-C_1HrqBl.d.cts → types-CDa7F5ct.d.ts} +7 -2
- package/dist/{types-r-CasCf1.d.cts → types-D1dI_oTX.d.cts} +8 -1
- package/dist/{types-r-CasCf1.d.ts → types-D1dI_oTX.d.ts} +8 -1
- package/dist/{types-BTFeKYCb.d.ts → types-DKpsfD3i.d.cts} +19 -4
- package/dist/{types-BTFeKYCb.d.cts → types-DKpsfD3i.d.ts} +19 -4
- package/dist/{types-4VxSL2Ho.d.ts → types-DxSFvL2b.d.cts} +7 -1
- package/dist/{types-4VxSL2Ho.d.cts → types-DxSFvL2b.d.ts} +7 -1
- package/dist/{types-B2afJZM-.d.ts → types-Pme7sua0.d.cts} +4 -1
- package/dist/{types-B2afJZM-.d.cts → types-Pme7sua0.d.ts} +4 -1
- package/dist/{types-D5gNQiDj.d.ts → types-gQsr0AAA.d.cts} +9 -1
- package/dist/{types-D5gNQiDj.d.cts → types-gQsr0AAA.d.ts} +9 -1
- package/package.json +2 -2
- package/src/core/buffer-reader.ts +130 -114
- package/src/core/buffer-writer.ts +100 -91
- package/src/core/hex.ts +7 -3
- package/src/drafts/draft07/codec.ts +14 -9
- package/src/drafts/draft07/data-streams.ts +240 -240
- package/src/drafts/draft07/varint.ts +51 -23
- package/src/drafts/draft08/codec.ts +19 -10
- package/src/drafts/draft08/data-streams.ts +359 -359
- package/src/drafts/draft09/codec.ts +19 -10
- package/src/drafts/draft09/data-streams.ts +332 -332
- package/src/drafts/draft10/codec.ts +19 -10
- package/src/drafts/draft10/data-streams.ts +332 -332
- package/src/drafts/draft11/codec.ts +33 -14
- package/src/drafts/draft11/data-streams.ts +269 -269
- package/src/drafts/draft12/codec.ts +27 -31
- package/src/drafts/draft12/data-streams.ts +275 -275
- package/src/drafts/draft13/codec.ts +27 -31
- package/src/drafts/draft13/data-streams.ts +275 -275
- package/src/drafts/draft14/codec.ts +19 -10
- package/src/drafts/draft14/data-streams.ts +813 -798
- package/src/drafts/draft15/codec.ts +21 -12
- package/src/drafts/draft15/data-streams.ts +794 -778
- package/src/drafts/draft16/codec.ts +21 -12
- package/src/drafts/draft16/data-streams.ts +789 -773
- package/src/drafts/draft17/codec.ts +21 -12
- package/src/drafts/draft17/data-streams.ts +758 -742
- package/dist/codec-AFuOxfsO.d.ts +0 -60
- package/dist/codec-B-UJ5Iow.d.cts +0 -75
- package/dist/codec-BvpuF-6u.d.cts +0 -39
- package/dist/codec-C8jZI5Cx.d.cts +0 -39
- package/dist/codec-CSUqCrRs.d.ts +0 -39
- package/dist/codec-CpuvYTSV.d.cts +0 -86
- package/dist/codec-D7ARhpG1.d.ts +0 -75
- package/dist/codec-DNAUGshO.d.cts +0 -60
- package/dist/codec-DPx_QNn0.d.ts +0 -31
- package/dist/codec-DRhCx_hw.d.ts +0 -86
- package/dist/codec-Db7YPe3l.d.ts +0 -31
- package/dist/codec-axkJpb7D.d.cts +0 -31
- package/dist/codec-ujAbFaep.d.cts +0 -31
- package/dist/core/buffer-reader.d.ts +0 -15
- package/dist/core/buffer-reader.d.ts.map +0 -1
- package/dist/core/buffer-reader.js +0 -98
- package/dist/core/buffer-reader.js.map +0 -1
- package/dist/core/buffer-writer.d.ts +0 -16
- package/dist/core/buffer-writer.d.ts.map +0 -1
- package/dist/core/buffer-writer.js +0 -86
- package/dist/core/buffer-writer.js.map +0 -1
- package/dist/core/errors.d.ts +0 -2
- package/dist/core/errors.d.ts.map +0 -1
- package/dist/core/errors.js +0 -2
- package/dist/core/errors.js.map +0 -1
- package/dist/core/hex.d.ts +0 -5
- package/dist/core/hex.d.ts.map +0 -1
- package/dist/core/hex.js +0 -17
- package/dist/core/hex.js.map +0 -1
- package/dist/core/session-types.d.ts +0 -99
- package/dist/core/session-types.d.ts.map +0 -1
- package/dist/core/session-types.js +0 -2
- package/dist/core/session-types.js.map +0 -1
- package/dist/core/types.d.ts +0 -235
- package/dist/core/types.d.ts.map +0 -1
- package/dist/core/types.js +0 -11
- package/dist/core/types.js.map +0 -1
- package/dist/drafts/draft07/announce-fsm.d.ts +0 -2
- package/dist/drafts/draft07/announce-fsm.d.ts.map +0 -1
- package/dist/drafts/draft07/announce-fsm.js +0 -2
- package/dist/drafts/draft07/announce-fsm.js.map +0 -1
- package/dist/drafts/draft07/codec.d.ts +0 -17
- package/dist/drafts/draft07/codec.d.ts.map +0 -1
- package/dist/drafts/draft07/codec.js +0 -722
- package/dist/drafts/draft07/codec.js.map +0 -1
- package/dist/drafts/draft07/data-streams.d.ts +0 -9
- package/dist/drafts/draft07/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft07/data-streams.js +0 -228
- package/dist/drafts/draft07/data-streams.js.map +0 -1
- package/dist/drafts/draft07/index.d.ts +0 -14
- package/dist/drafts/draft07/index.d.ts.map +0 -1
- package/dist/drafts/draft07/index.js +0 -18
- package/dist/drafts/draft07/index.js.map +0 -1
- package/dist/drafts/draft07/messages.d.ts +0 -32
- package/dist/drafts/draft07/messages.d.ts.map +0 -1
- package/dist/drafts/draft07/messages.js +0 -42
- package/dist/drafts/draft07/messages.js.map +0 -1
- package/dist/drafts/draft07/parameters.d.ts +0 -4
- package/dist/drafts/draft07/parameters.d.ts.map +0 -1
- package/dist/drafts/draft07/parameters.js +0 -10
- package/dist/drafts/draft07/parameters.js.map +0 -1
- package/dist/drafts/draft07/rules.d.ts +0 -8
- package/dist/drafts/draft07/rules.d.ts.map +0 -1
- package/dist/drafts/draft07/rules.js +0 -95
- package/dist/drafts/draft07/rules.js.map +0 -1
- package/dist/drafts/draft07/session-fsm.d.ts +0 -38
- package/dist/drafts/draft07/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft07/session-fsm.js +0 -354
- package/dist/drafts/draft07/session-fsm.js.map +0 -1
- package/dist/drafts/draft07/session.d.ts +0 -4
- package/dist/drafts/draft07/session.d.ts.map +0 -1
- package/dist/drafts/draft07/session.js +0 -5
- package/dist/drafts/draft07/session.js.map +0 -1
- package/dist/drafts/draft07/subscription-fsm.d.ts +0 -2
- package/dist/drafts/draft07/subscription-fsm.d.ts.map +0 -1
- package/dist/drafts/draft07/subscription-fsm.js +0 -2
- package/dist/drafts/draft07/subscription-fsm.js.map +0 -1
- package/dist/drafts/draft07/types.d.ts +0 -61
- package/dist/drafts/draft07/types.d.ts.map +0 -1
- package/dist/drafts/draft07/types.js +0 -4
- package/dist/drafts/draft07/types.js.map +0 -1
- package/dist/drafts/draft07/varint.d.ts +0 -4
- package/dist/drafts/draft07/varint.d.ts.map +0 -1
- package/dist/drafts/draft07/varint.js +0 -22
- package/dist/drafts/draft07/varint.js.map +0 -1
- package/dist/drafts/draft08/codec.d.ts.map +0 -1
- package/dist/drafts/draft08/codec.js +0 -729
- package/dist/drafts/draft08/codec.js.map +0 -1
- package/dist/drafts/draft08/data-streams.d.ts +0 -12
- package/dist/drafts/draft08/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft08/data-streams.js +0 -345
- package/dist/drafts/draft08/data-streams.js.map +0 -1
- package/dist/drafts/draft08/index.d.ts +0 -9
- package/dist/drafts/draft08/index.d.ts.map +0 -1
- package/dist/drafts/draft08/index.js +0 -7
- package/dist/drafts/draft08/index.js.map +0 -1
- package/dist/drafts/draft08/messages.d.ts +0 -34
- package/dist/drafts/draft08/messages.d.ts.map +0 -1
- package/dist/drafts/draft08/messages.js +0 -66
- package/dist/drafts/draft08/messages.js.map +0 -1
- package/dist/drafts/draft08/rules.d.ts +0 -8
- package/dist/drafts/draft08/rules.d.ts.map +0 -1
- package/dist/drafts/draft08/rules.js +0 -83
- package/dist/drafts/draft08/rules.js.map +0 -1
- package/dist/drafts/draft08/session-fsm.d.ts +0 -47
- package/dist/drafts/draft08/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft08/session-fsm.js +0 -483
- package/dist/drafts/draft08/session-fsm.js.map +0 -1
- package/dist/drafts/draft08/session.d.ts +0 -5
- package/dist/drafts/draft08/session.d.ts.map +0 -1
- package/dist/drafts/draft08/session.js +0 -5
- package/dist/drafts/draft08/session.js.map +0 -1
- package/dist/drafts/draft08/types.d.ts +0 -268
- package/dist/drafts/draft08/types.d.ts.map +0 -1
- package/dist/drafts/draft08/types.js +0 -4
- package/dist/drafts/draft08/types.js.map +0 -1
- package/dist/drafts/draft09/codec.d.ts +0 -21
- package/dist/drafts/draft09/codec.d.ts.map +0 -1
- package/dist/drafts/draft09/codec.js +0 -721
- package/dist/drafts/draft09/codec.js.map +0 -1
- package/dist/drafts/draft09/data-streams.d.ts +0 -12
- package/dist/drafts/draft09/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft09/data-streams.js +0 -307
- package/dist/drafts/draft09/data-streams.js.map +0 -1
- package/dist/drafts/draft09/index.d.ts +0 -9
- package/dist/drafts/draft09/index.d.ts.map +0 -1
- package/dist/drafts/draft09/index.js +0 -7
- package/dist/drafts/draft09/index.js.map +0 -1
- package/dist/drafts/draft09/messages.d.ts +0 -34
- package/dist/drafts/draft09/messages.d.ts.map +0 -1
- package/dist/drafts/draft09/messages.js +0 -66
- package/dist/drafts/draft09/messages.js.map +0 -1
- package/dist/drafts/draft09/rules.d.ts +0 -8
- package/dist/drafts/draft09/rules.d.ts.map +0 -1
- package/dist/drafts/draft09/rules.js +0 -83
- package/dist/drafts/draft09/rules.js.map +0 -1
- package/dist/drafts/draft09/session-fsm.d.ts +0 -47
- package/dist/drafts/draft09/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft09/session-fsm.js +0 -483
- package/dist/drafts/draft09/session-fsm.js.map +0 -1
- package/dist/drafts/draft09/session.d.ts +0 -5
- package/dist/drafts/draft09/session.d.ts.map +0 -1
- package/dist/drafts/draft09/session.js +0 -5
- package/dist/drafts/draft09/session.js.map +0 -1
- package/dist/drafts/draft09/types.d.ts +0 -268
- package/dist/drafts/draft09/types.d.ts.map +0 -1
- package/dist/drafts/draft09/types.js +0 -4
- package/dist/drafts/draft09/types.js.map +0 -1
- package/dist/drafts/draft10/codec.d.ts +0 -21
- package/dist/drafts/draft10/codec.d.ts.map +0 -1
- package/dist/drafts/draft10/codec.js +0 -721
- package/dist/drafts/draft10/codec.js.map +0 -1
- package/dist/drafts/draft10/data-streams.d.ts +0 -12
- package/dist/drafts/draft10/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft10/data-streams.js +0 -307
- package/dist/drafts/draft10/data-streams.js.map +0 -1
- package/dist/drafts/draft10/index.d.ts +0 -9
- package/dist/drafts/draft10/index.d.ts.map +0 -1
- package/dist/drafts/draft10/index.js +0 -7
- package/dist/drafts/draft10/index.js.map +0 -1
- package/dist/drafts/draft10/messages.d.ts +0 -34
- package/dist/drafts/draft10/messages.d.ts.map +0 -1
- package/dist/drafts/draft10/messages.js +0 -66
- package/dist/drafts/draft10/messages.js.map +0 -1
- package/dist/drafts/draft10/rules.d.ts +0 -8
- package/dist/drafts/draft10/rules.d.ts.map +0 -1
- package/dist/drafts/draft10/rules.js +0 -83
- package/dist/drafts/draft10/rules.js.map +0 -1
- package/dist/drafts/draft10/session-fsm.d.ts +0 -47
- package/dist/drafts/draft10/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft10/session-fsm.js +0 -483
- package/dist/drafts/draft10/session-fsm.js.map +0 -1
- package/dist/drafts/draft10/session.d.ts +0 -5
- package/dist/drafts/draft10/session.d.ts.map +0 -1
- package/dist/drafts/draft10/session.js +0 -5
- package/dist/drafts/draft10/session.js.map +0 -1
- package/dist/drafts/draft10/types.d.ts +0 -268
- package/dist/drafts/draft10/types.d.ts.map +0 -1
- package/dist/drafts/draft10/types.js +0 -4
- package/dist/drafts/draft10/types.js.map +0 -1
- package/dist/drafts/draft11/codec.d.ts +0 -25
- package/dist/drafts/draft11/codec.d.ts.map +0 -1
- package/dist/drafts/draft11/codec.js +0 -775
- package/dist/drafts/draft11/codec.js.map +0 -1
- package/dist/drafts/draft11/data-streams.d.ts +0 -10
- package/dist/drafts/draft11/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft11/data-streams.js +0 -253
- package/dist/drafts/draft11/data-streams.js.map +0 -1
- package/dist/drafts/draft11/index.d.ts +0 -9
- package/dist/drafts/draft11/index.d.ts.map +0 -1
- package/dist/drafts/draft11/index.js +0 -7
- package/dist/drafts/draft11/index.js.map +0 -1
- package/dist/drafts/draft11/messages.d.ts +0 -33
- package/dist/drafts/draft11/messages.d.ts.map +0 -1
- package/dist/drafts/draft11/messages.js +0 -65
- package/dist/drafts/draft11/messages.js.map +0 -1
- package/dist/drafts/draft11/rules.d.ts +0 -8
- package/dist/drafts/draft11/rules.d.ts.map +0 -1
- package/dist/drafts/draft11/rules.js +0 -88
- package/dist/drafts/draft11/rules.js.map +0 -1
- package/dist/drafts/draft11/session-fsm.d.ts +0 -52
- package/dist/drafts/draft11/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft11/session-fsm.js +0 -530
- package/dist/drafts/draft11/session-fsm.js.map +0 -1
- package/dist/drafts/draft11/session.d.ts +0 -5
- package/dist/drafts/draft11/session.d.ts.map +0 -1
- package/dist/drafts/draft11/session.js +0 -5
- package/dist/drafts/draft11/session.js.map +0 -1
- package/dist/drafts/draft11/types.d.ts +0 -266
- package/dist/drafts/draft11/types.d.ts.map +0 -1
- package/dist/drafts/draft11/types.js +0 -4
- package/dist/drafts/draft11/types.js.map +0 -1
- package/dist/drafts/draft12/codec.d.ts +0 -27
- package/dist/drafts/draft12/codec.d.ts.map +0 -1
- package/dist/drafts/draft12/codec.js +0 -918
- package/dist/drafts/draft12/codec.js.map +0 -1
- package/dist/drafts/draft12/data-streams.d.ts +0 -10
- package/dist/drafts/draft12/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft12/data-streams.js +0 -254
- package/dist/drafts/draft12/data-streams.js.map +0 -1
- package/dist/drafts/draft12/index.d.ts +0 -9
- package/dist/drafts/draft12/index.d.ts.map +0 -1
- package/dist/drafts/draft12/index.js +0 -7
- package/dist/drafts/draft12/index.js.map +0 -1
- package/dist/drafts/draft12/messages.d.ts +0 -37
- package/dist/drafts/draft12/messages.d.ts.map +0 -1
- package/dist/drafts/draft12/messages.js +0 -77
- package/dist/drafts/draft12/messages.js.map +0 -1
- package/dist/drafts/draft12/rules.d.ts +0 -8
- package/dist/drafts/draft12/rules.d.ts.map +0 -1
- package/dist/drafts/draft12/rules.js +0 -94
- package/dist/drafts/draft12/rules.js.map +0 -1
- package/dist/drafts/draft12/session-fsm.d.ts +0 -55
- package/dist/drafts/draft12/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft12/session-fsm.js +0 -569
- package/dist/drafts/draft12/session-fsm.js.map +0 -1
- package/dist/drafts/draft12/session.d.ts +0 -5
- package/dist/drafts/draft12/session.d.ts.map +0 -1
- package/dist/drafts/draft12/session.js +0 -5
- package/dist/drafts/draft12/session.js.map +0 -1
- package/dist/drafts/draft12/types.d.ts +0 -294
- package/dist/drafts/draft12/types.d.ts.map +0 -1
- package/dist/drafts/draft12/types.js +0 -4
- package/dist/drafts/draft12/types.js.map +0 -1
- package/dist/drafts/draft13/codec.d.ts +0 -27
- package/dist/drafts/draft13/codec.d.ts.map +0 -1
- package/dist/drafts/draft13/codec.js +0 -1000
- package/dist/drafts/draft13/codec.js.map +0 -1
- package/dist/drafts/draft13/data-streams.d.ts +0 -10
- package/dist/drafts/draft13/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft13/data-streams.js +0 -254
- package/dist/drafts/draft13/data-streams.js.map +0 -1
- package/dist/drafts/draft13/index.d.ts +0 -9
- package/dist/drafts/draft13/index.d.ts.map +0 -1
- package/dist/drafts/draft13/index.js +0 -7
- package/dist/drafts/draft13/index.js.map +0 -1
- package/dist/drafts/draft13/messages.d.ts +0 -38
- package/dist/drafts/draft13/messages.d.ts.map +0 -1
- package/dist/drafts/draft13/messages.js +0 -79
- package/dist/drafts/draft13/messages.js.map +0 -1
- package/dist/drafts/draft13/rules.d.ts +0 -8
- package/dist/drafts/draft13/rules.d.ts.map +0 -1
- package/dist/drafts/draft13/rules.js +0 -96
- package/dist/drafts/draft13/rules.js.map +0 -1
- package/dist/drafts/draft13/session-fsm.d.ts +0 -56
- package/dist/drafts/draft13/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft13/session-fsm.js +0 -581
- package/dist/drafts/draft13/session-fsm.js.map +0 -1
- package/dist/drafts/draft13/session.d.ts +0 -5
- package/dist/drafts/draft13/session.d.ts.map +0 -1
- package/dist/drafts/draft13/session.js +0 -5
- package/dist/drafts/draft13/session.js.map +0 -1
- package/dist/drafts/draft13/types.d.ts +0 -310
- package/dist/drafts/draft13/types.d.ts.map +0 -1
- package/dist/drafts/draft13/types.js +0 -4
- package/dist/drafts/draft13/types.js.map +0 -1
- package/dist/drafts/draft14/codec.d.ts.map +0 -1
- package/dist/drafts/draft14/codec.js +0 -752
- package/dist/drafts/draft14/codec.js.map +0 -1
- package/dist/drafts/draft14/data-streams.d.ts +0 -56
- package/dist/drafts/draft14/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft14/data-streams.js +0 -729
- package/dist/drafts/draft14/data-streams.js.map +0 -1
- package/dist/drafts/draft14/index.d.ts +0 -9
- package/dist/drafts/draft14/index.d.ts.map +0 -1
- package/dist/drafts/draft14/index.js +0 -7
- package/dist/drafts/draft14/index.js.map +0 -1
- package/dist/drafts/draft14/messages.d.ts +0 -36
- package/dist/drafts/draft14/messages.d.ts.map +0 -1
- package/dist/drafts/draft14/messages.js +0 -71
- package/dist/drafts/draft14/messages.js.map +0 -1
- package/dist/drafts/draft14/rules.d.ts +0 -8
- package/dist/drafts/draft14/rules.d.ts.map +0 -1
- package/dist/drafts/draft14/rules.js +0 -101
- package/dist/drafts/draft14/rules.js.map +0 -1
- package/dist/drafts/draft14/session-fsm.d.ts +0 -58
- package/dist/drafts/draft14/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft14/session-fsm.js +0 -648
- package/dist/drafts/draft14/session-fsm.js.map +0 -1
- package/dist/drafts/draft14/session.d.ts +0 -5
- package/dist/drafts/draft14/session.d.ts.map +0 -1
- package/dist/drafts/draft14/session.js +0 -5
- package/dist/drafts/draft14/session.js.map +0 -1
- package/dist/drafts/draft14/types.d.ts +0 -263
- package/dist/drafts/draft14/types.d.ts.map +0 -1
- package/dist/drafts/draft14/types.js +0 -4
- package/dist/drafts/draft14/types.js.map +0 -1
- package/dist/drafts/draft15/codec.d.ts.map +0 -1
- package/dist/drafts/draft15/codec.js +0 -742
- package/dist/drafts/draft15/codec.js.map +0 -1
- package/dist/drafts/draft15/data-streams.d.ts +0 -45
- package/dist/drafts/draft15/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft15/data-streams.js +0 -675
- package/dist/drafts/draft15/data-streams.js.map +0 -1
- package/dist/drafts/draft15/index.d.ts +0 -9
- package/dist/drafts/draft15/index.d.ts.map +0 -1
- package/dist/drafts/draft15/index.js +0 -7
- package/dist/drafts/draft15/index.js.map +0 -1
- package/dist/drafts/draft15/messages.d.ts +0 -31
- package/dist/drafts/draft15/messages.d.ts.map +0 -1
- package/dist/drafts/draft15/messages.js +0 -59
- package/dist/drafts/draft15/messages.js.map +0 -1
- package/dist/drafts/draft15/rules.d.ts +0 -8
- package/dist/drafts/draft15/rules.d.ts.map +0 -1
- package/dist/drafts/draft15/rules.js +0 -83
- package/dist/drafts/draft15/rules.js.map +0 -1
- package/dist/drafts/draft15/session-fsm.d.ts +0 -48
- package/dist/drafts/draft15/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft15/session-fsm.js +0 -479
- package/dist/drafts/draft15/session-fsm.js.map +0 -1
- package/dist/drafts/draft15/session.d.ts +0 -5
- package/dist/drafts/draft15/session.d.ts.map +0 -1
- package/dist/drafts/draft15/session.js +0 -5
- package/dist/drafts/draft15/session.js.map +0 -1
- package/dist/drafts/draft15/types.d.ts +0 -232
- package/dist/drafts/draft15/types.d.ts.map +0 -1
- package/dist/drafts/draft15/types.js +0 -4
- package/dist/drafts/draft15/types.js.map +0 -1
- package/dist/drafts/draft16/codec.d.ts +0 -29
- package/dist/drafts/draft16/codec.d.ts.map +0 -1
- package/dist/drafts/draft16/codec.js +0 -747
- package/dist/drafts/draft16/codec.js.map +0 -1
- package/dist/drafts/draft16/data-streams.d.ts +0 -34
- package/dist/drafts/draft16/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft16/data-streams.js +0 -667
- package/dist/drafts/draft16/data-streams.js.map +0 -1
- package/dist/drafts/draft16/index.d.ts +0 -9
- package/dist/drafts/draft16/index.d.ts.map +0 -1
- package/dist/drafts/draft16/index.js +0 -7
- package/dist/drafts/draft16/index.js.map +0 -1
- package/dist/drafts/draft16/messages.d.ts +0 -32
- package/dist/drafts/draft16/messages.d.ts.map +0 -1
- package/dist/drafts/draft16/messages.js +0 -62
- package/dist/drafts/draft16/messages.js.map +0 -1
- package/dist/drafts/draft16/rules.d.ts +0 -8
- package/dist/drafts/draft16/rules.d.ts.map +0 -1
- package/dist/drafts/draft16/rules.js +0 -84
- package/dist/drafts/draft16/rules.js.map +0 -1
- package/dist/drafts/draft16/session-fsm.d.ts +0 -48
- package/dist/drafts/draft16/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft16/session-fsm.js +0 -474
- package/dist/drafts/draft16/session-fsm.js.map +0 -1
- package/dist/drafts/draft16/session.d.ts +0 -5
- package/dist/drafts/draft16/session.d.ts.map +0 -1
- package/dist/drafts/draft16/session.js +0 -5
- package/dist/drafts/draft16/session.js.map +0 -1
- package/dist/drafts/draft16/types.d.ts +0 -238
- package/dist/drafts/draft16/types.d.ts.map +0 -1
- package/dist/drafts/draft16/types.js +0 -4
- package/dist/drafts/draft16/types.js.map +0 -1
- package/dist/drafts/draft17/codec.d.ts +0 -29
- package/dist/drafts/draft17/codec.d.ts.map +0 -1
- package/dist/drafts/draft17/codec.js +0 -799
- package/dist/drafts/draft17/codec.js.map +0 -1
- package/dist/drafts/draft17/data-streams.d.ts +0 -13
- package/dist/drafts/draft17/data-streams.d.ts.map +0 -1
- package/dist/drafts/draft17/data-streams.js +0 -633
- package/dist/drafts/draft17/data-streams.js.map +0 -1
- package/dist/drafts/draft17/index.d.ts +0 -8
- package/dist/drafts/draft17/index.d.ts.map +0 -1
- package/dist/drafts/draft17/index.js +0 -6
- package/dist/drafts/draft17/index.js.map +0 -1
- package/dist/drafts/draft17/messages.d.ts +0 -25
- package/dist/drafts/draft17/messages.d.ts.map +0 -1
- package/dist/drafts/draft17/messages.js +0 -48
- package/dist/drafts/draft17/messages.js.map +0 -1
- package/dist/drafts/draft17/rules.d.ts +0 -8
- package/dist/drafts/draft17/rules.d.ts.map +0 -1
- package/dist/drafts/draft17/rules.js +0 -71
- package/dist/drafts/draft17/rules.js.map +0 -1
- package/dist/drafts/draft17/session-fsm.d.ts +0 -45
- package/dist/drafts/draft17/session-fsm.d.ts.map +0 -1
- package/dist/drafts/draft17/session-fsm.js +0 -328
- package/dist/drafts/draft17/session-fsm.js.map +0 -1
- package/dist/drafts/draft17/session.d.ts +0 -5
- package/dist/drafts/draft17/session.d.ts.map +0 -1
- package/dist/drafts/draft17/session.js +0 -6
- package/dist/drafts/draft17/session.js.map +0 -1
- package/dist/drafts/draft17/types.d.ts +0 -219
- package/dist/drafts/draft17/types.d.ts.map +0 -1
- package/dist/drafts/draft17/types.js +0 -3
- package/dist/drafts/draft17/types.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/session.d.ts.map +0 -1
- package/dist/session.js.map +0 -1
|
@@ -1,1000 +0,0 @@
|
|
|
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_ANNOUNCE, MSG_ANNOUNCE_CANCEL, MSG_ANNOUNCE_ERROR, MSG_ANNOUNCE_OK, MSG_CLIENT_SETUP, MSG_FETCH, MSG_FETCH_CANCEL, MSG_FETCH_ERROR, MSG_FETCH_OK, MSG_GOAWAY, MSG_MAX_REQUEST_ID, MSG_PUBLISH, MSG_PUBLISH_ERROR, MSG_PUBLISH_OK, MSG_REQUESTS_BLOCKED, MSG_SERVER_SETUP, MSG_SUBSCRIBE, MSG_SUBSCRIBE_DONE, MSG_SUBSCRIBE_ERROR, MSG_SUBSCRIBE_NAMESPACE, MSG_SUBSCRIBE_NAMESPACE_ERROR, MSG_SUBSCRIBE_NAMESPACE_OK, MSG_SUBSCRIBE_OK, MSG_SUBSCRIBE_UPDATE, MSG_TRACK_STATUS, MSG_TRACK_STATUS_ERROR, MSG_TRACK_STATUS_OK, MSG_UNANNOUNCE, MSG_UNSUBSCRIBE, MSG_UNSUBSCRIBE_NAMESPACE, PARAM_AUTHORIZATION_TOKEN, PARAM_DELIVERY_TIMEOUT, SETUP_PARAM_MAX_REQUEST_ID, SETUP_PARAM_PATH, VARINT_FRAMED_MESSAGES, } from "./messages.js";
|
|
6
|
-
// ─── Setup Parameter Encoding/Decoding (even/odd convention) ────────────────────
|
|
7
|
-
function encodeSetupParams(params, w) {
|
|
8
|
-
let count = 0;
|
|
9
|
-
if (params.path !== undefined)
|
|
10
|
-
count++;
|
|
11
|
-
if (params.max_request_id !== undefined)
|
|
12
|
-
count++;
|
|
13
|
-
if (params.unknown)
|
|
14
|
-
count += params.unknown.length;
|
|
15
|
-
w.writeVarInt(count);
|
|
16
|
-
if (params.path !== undefined) {
|
|
17
|
-
w.writeVarInt(SETUP_PARAM_PATH);
|
|
18
|
-
const encoded = new TextEncoder().encode(params.path);
|
|
19
|
-
w.writeVarInt(encoded.byteLength);
|
|
20
|
-
w.writeBytes(encoded);
|
|
21
|
-
}
|
|
22
|
-
if (params.max_request_id !== undefined) {
|
|
23
|
-
w.writeVarInt(SETUP_PARAM_MAX_REQUEST_ID);
|
|
24
|
-
w.writeVarInt(params.max_request_id);
|
|
25
|
-
}
|
|
26
|
-
if (params.unknown) {
|
|
27
|
-
for (const u of params.unknown) {
|
|
28
|
-
const id = BigInt(u.id);
|
|
29
|
-
w.writeVarInt(id);
|
|
30
|
-
if (id % 2n === 0n) {
|
|
31
|
-
const raw = hexToBytes(u.raw_hex);
|
|
32
|
-
const tmpReader = new BufferReader(raw);
|
|
33
|
-
w.writeVarInt(tmpReader.readVarInt());
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
36
|
-
const raw = hexToBytes(u.raw_hex);
|
|
37
|
-
w.writeVarInt(raw.byteLength);
|
|
38
|
-
w.writeBytes(raw);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
function decodeSetupParams(r) {
|
|
44
|
-
const count = Number(r.readVarInt());
|
|
45
|
-
const result = {};
|
|
46
|
-
const unknown = [];
|
|
47
|
-
for (let i = 0; i < count; i++) {
|
|
48
|
-
const paramType = r.readVarInt();
|
|
49
|
-
if (paramType % 2n === 0n) {
|
|
50
|
-
const value = r.readVarInt();
|
|
51
|
-
if (paramType === SETUP_PARAM_MAX_REQUEST_ID) {
|
|
52
|
-
result.max_request_id = value;
|
|
53
|
-
}
|
|
54
|
-
else {
|
|
55
|
-
const tmpW = new BufferWriter(16);
|
|
56
|
-
tmpW.writeVarInt(value);
|
|
57
|
-
const raw = tmpW.finish();
|
|
58
|
-
unknown.push({
|
|
59
|
-
id: `0x${paramType.toString(16)}`,
|
|
60
|
-
length: raw.byteLength,
|
|
61
|
-
raw_hex: bytesToHex(raw),
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
else {
|
|
66
|
-
const length = Number(r.readVarInt());
|
|
67
|
-
const bytes = r.readBytes(length);
|
|
68
|
-
if (paramType === SETUP_PARAM_PATH) {
|
|
69
|
-
result.path = new TextDecoder().decode(bytes);
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
unknown.push({ id: `0x${paramType.toString(16)}`, length, raw_hex: bytesToHex(bytes) });
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
if (unknown.length > 0)
|
|
77
|
-
result.unknown = unknown;
|
|
78
|
-
return result;
|
|
79
|
-
}
|
|
80
|
-
// ─── Version-Specific Parameter Encoding/Decoding ───────────────────────────────
|
|
81
|
-
// Uses even/odd convention: even type → bare varint value, odd type → length-prefixed blob
|
|
82
|
-
function encodeParams(params, w) {
|
|
83
|
-
let count = params.unknown ? params.unknown.length : 0;
|
|
84
|
-
if (params.authorization_token !== undefined)
|
|
85
|
-
count++;
|
|
86
|
-
if (params.delivery_timeout !== undefined)
|
|
87
|
-
count++;
|
|
88
|
-
w.writeVarInt(count);
|
|
89
|
-
if (params.authorization_token !== undefined) {
|
|
90
|
-
// AUTHORIZATION_TOKEN = 0x01 (odd → length-prefixed)
|
|
91
|
-
w.writeVarInt(PARAM_AUTHORIZATION_TOKEN);
|
|
92
|
-
const at = params.authorization_token;
|
|
93
|
-
const tmpW = new BufferWriter(64);
|
|
94
|
-
tmpW.writeVarInt(at.alias_type);
|
|
95
|
-
tmpW.writeVarInt(at.token_type);
|
|
96
|
-
const tokenBytes = new TextEncoder().encode(at.token_value);
|
|
97
|
-
tmpW.writeBytes(tokenBytes);
|
|
98
|
-
const raw = tmpW.finish();
|
|
99
|
-
w.writeVarInt(raw.byteLength);
|
|
100
|
-
w.writeBytes(raw);
|
|
101
|
-
}
|
|
102
|
-
if (params.delivery_timeout !== undefined) {
|
|
103
|
-
// DELIVERY_TIMEOUT = 0x03 (odd → length-prefixed varint)
|
|
104
|
-
w.writeVarInt(PARAM_DELIVERY_TIMEOUT);
|
|
105
|
-
const tmpW = new BufferWriter(16);
|
|
106
|
-
tmpW.writeVarInt(params.delivery_timeout);
|
|
107
|
-
const raw = tmpW.finish();
|
|
108
|
-
w.writeVarInt(raw.byteLength);
|
|
109
|
-
w.writeBytes(raw);
|
|
110
|
-
}
|
|
111
|
-
if (params.unknown) {
|
|
112
|
-
for (const u of params.unknown) {
|
|
113
|
-
const id = BigInt(u.id);
|
|
114
|
-
w.writeVarInt(id);
|
|
115
|
-
if (id % 2n === 0n) {
|
|
116
|
-
// Even → bare varint
|
|
117
|
-
const raw = hexToBytes(u.raw_hex);
|
|
118
|
-
const tmpReader = new BufferReader(raw);
|
|
119
|
-
w.writeVarInt(tmpReader.readVarInt());
|
|
120
|
-
}
|
|
121
|
-
else {
|
|
122
|
-
// Odd → length-prefixed
|
|
123
|
-
const raw = hexToBytes(u.raw_hex);
|
|
124
|
-
w.writeVarInt(raw.byteLength);
|
|
125
|
-
w.writeBytes(raw);
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
function decodeParams(r) {
|
|
131
|
-
const count = Number(r.readVarInt());
|
|
132
|
-
const result = {};
|
|
133
|
-
const unknown = [];
|
|
134
|
-
for (let i = 0; i < count; i++) {
|
|
135
|
-
const paramType = r.readVarInt();
|
|
136
|
-
if (paramType % 2n === 0n) {
|
|
137
|
-
// Even type → bare varint value
|
|
138
|
-
const value = r.readVarInt();
|
|
139
|
-
const tmpW = new BufferWriter(16);
|
|
140
|
-
tmpW.writeVarInt(value);
|
|
141
|
-
const raw = tmpW.finish();
|
|
142
|
-
unknown.push({
|
|
143
|
-
id: `0x${paramType.toString(16)}`,
|
|
144
|
-
length: raw.byteLength,
|
|
145
|
-
raw_hex: bytesToHex(raw),
|
|
146
|
-
});
|
|
147
|
-
}
|
|
148
|
-
else {
|
|
149
|
-
// Odd type → length-prefixed blob
|
|
150
|
-
const length = Number(r.readVarInt());
|
|
151
|
-
const startOff = r.offset;
|
|
152
|
-
if (paramType === PARAM_AUTHORIZATION_TOKEN) {
|
|
153
|
-
const alias_type = r.readVarInt();
|
|
154
|
-
const token_type = r.readVarInt();
|
|
155
|
-
const tokenBytesLen = length - (r.offset - startOff);
|
|
156
|
-
const tokenBytes = r.readBytes(tokenBytesLen);
|
|
157
|
-
result.authorization_token = {
|
|
158
|
-
alias_type,
|
|
159
|
-
token_type,
|
|
160
|
-
token_value: new TextDecoder().decode(tokenBytes),
|
|
161
|
-
};
|
|
162
|
-
}
|
|
163
|
-
else if (paramType === PARAM_DELIVERY_TIMEOUT) {
|
|
164
|
-
const blob = r.readBytes(length);
|
|
165
|
-
const tmpReader = new BufferReader(blob);
|
|
166
|
-
result.delivery_timeout = tmpReader.readVarInt();
|
|
167
|
-
}
|
|
168
|
-
else {
|
|
169
|
-
const bytes = r.readBytes(length);
|
|
170
|
-
unknown.push({ id: `0x${paramType.toString(16)}`, length, raw_hex: bytesToHex(bytes) });
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
if (unknown.length > 0)
|
|
175
|
-
result.unknown = unknown;
|
|
176
|
-
return result;
|
|
177
|
-
}
|
|
178
|
-
// ─── Payload Encoders ──────────────────────────────────────────────────────────
|
|
179
|
-
function encodeClientSetupPayload(msg, w) {
|
|
180
|
-
w.writeVarInt(msg.supported_versions.length);
|
|
181
|
-
for (const v of msg.supported_versions)
|
|
182
|
-
w.writeVarInt(v);
|
|
183
|
-
encodeSetupParams(msg.parameters, w);
|
|
184
|
-
}
|
|
185
|
-
function encodeServerSetupPayload(msg, w) {
|
|
186
|
-
w.writeVarInt(msg.selected_version);
|
|
187
|
-
encodeSetupParams(msg.parameters, w);
|
|
188
|
-
}
|
|
189
|
-
function encodeSubscribePayload(msg, w) {
|
|
190
|
-
w.writeVarInt(msg.request_id);
|
|
191
|
-
w.writeTuple(msg.track_namespace);
|
|
192
|
-
w.writeString(msg.track_name);
|
|
193
|
-
w.writeUint8(msg.subscriber_priority);
|
|
194
|
-
w.writeVarInt(msg.group_order);
|
|
195
|
-
w.writeVarInt(msg.forward);
|
|
196
|
-
w.writeVarInt(msg.filter_type);
|
|
197
|
-
const ft = Number(msg.filter_type);
|
|
198
|
-
if (ft === 3 || ft === 4) {
|
|
199
|
-
w.writeVarInt(msg.start_group);
|
|
200
|
-
w.writeVarInt(msg.start_object);
|
|
201
|
-
}
|
|
202
|
-
if (ft === 4) {
|
|
203
|
-
w.writeVarInt(msg.end_group);
|
|
204
|
-
}
|
|
205
|
-
encodeParams(msg.parameters, w);
|
|
206
|
-
}
|
|
207
|
-
function encodeSubscribeOkPayload(msg, w) {
|
|
208
|
-
w.writeVarInt(msg.request_id);
|
|
209
|
-
w.writeVarInt(msg.track_alias);
|
|
210
|
-
w.writeVarInt(msg.expires);
|
|
211
|
-
w.writeVarInt(msg.group_order);
|
|
212
|
-
w.writeVarInt(msg.content_exists);
|
|
213
|
-
if (msg.content_exists === 1n && msg.largest_location) {
|
|
214
|
-
w.writeVarInt(msg.largest_location.group);
|
|
215
|
-
w.writeVarInt(msg.largest_location.object);
|
|
216
|
-
}
|
|
217
|
-
encodeParams(msg.parameters, w);
|
|
218
|
-
}
|
|
219
|
-
function encodeSubscribeErrorPayload(msg, w) {
|
|
220
|
-
w.writeVarInt(msg.request_id);
|
|
221
|
-
w.writeVarInt(msg.error_code);
|
|
222
|
-
w.writeString(msg.reason_phrase);
|
|
223
|
-
}
|
|
224
|
-
function encodeSubscribeUpdatePayload(msg, w) {
|
|
225
|
-
w.writeVarInt(msg.request_id);
|
|
226
|
-
w.writeVarInt(msg.start_group);
|
|
227
|
-
w.writeVarInt(msg.start_object);
|
|
228
|
-
w.writeVarInt(msg.end_group);
|
|
229
|
-
w.writeUint8(msg.subscriber_priority);
|
|
230
|
-
w.writeVarInt(msg.forward);
|
|
231
|
-
encodeParams(msg.parameters, w);
|
|
232
|
-
}
|
|
233
|
-
function encodeSubscribeDonePayload(msg, w) {
|
|
234
|
-
w.writeVarInt(msg.request_id);
|
|
235
|
-
w.writeVarInt(msg.status_code);
|
|
236
|
-
w.writeVarInt(msg.stream_count);
|
|
237
|
-
w.writeString(msg.reason_phrase);
|
|
238
|
-
}
|
|
239
|
-
function encodeUnsubscribePayload(msg, w) {
|
|
240
|
-
w.writeVarInt(msg.request_id);
|
|
241
|
-
}
|
|
242
|
-
function encodeAnnouncePayload(msg, w) {
|
|
243
|
-
w.writeVarInt(msg.request_id);
|
|
244
|
-
w.writeTuple(msg.track_namespace);
|
|
245
|
-
encodeParams(msg.parameters, w);
|
|
246
|
-
}
|
|
247
|
-
function encodeAnnounceOkPayload(msg, w) {
|
|
248
|
-
w.writeVarInt(msg.request_id);
|
|
249
|
-
}
|
|
250
|
-
function encodeAnnounceErrorPayload(msg, w) {
|
|
251
|
-
w.writeVarInt(msg.request_id);
|
|
252
|
-
w.writeVarInt(msg.error_code);
|
|
253
|
-
w.writeString(msg.reason_phrase);
|
|
254
|
-
}
|
|
255
|
-
function encodeUnannouncePayload(msg, w) {
|
|
256
|
-
w.writeTuple(msg.track_namespace);
|
|
257
|
-
}
|
|
258
|
-
function encodeAnnounceCancelPayload(msg, w) {
|
|
259
|
-
w.writeTuple(msg.track_namespace);
|
|
260
|
-
w.writeVarInt(msg.error_code);
|
|
261
|
-
w.writeString(msg.reason_phrase);
|
|
262
|
-
}
|
|
263
|
-
// Draft-13: subscribe_namespace (renamed from subscribe_announces, same wire format)
|
|
264
|
-
function encodeSubscribeNamespacePayload(msg, w) {
|
|
265
|
-
w.writeVarInt(msg.request_id);
|
|
266
|
-
w.writeTuple(msg.track_namespace_prefix);
|
|
267
|
-
encodeParams(msg.parameters, w);
|
|
268
|
-
}
|
|
269
|
-
function encodeSubscribeNamespaceOkPayload(msg, w) {
|
|
270
|
-
w.writeVarInt(msg.request_id);
|
|
271
|
-
}
|
|
272
|
-
function encodeSubscribeNamespaceErrorPayload(msg, w) {
|
|
273
|
-
w.writeVarInt(msg.request_id);
|
|
274
|
-
w.writeVarInt(msg.error_code);
|
|
275
|
-
w.writeString(msg.reason_phrase);
|
|
276
|
-
}
|
|
277
|
-
function encodeUnsubscribeNamespacePayload(msg, w) {
|
|
278
|
-
w.writeTuple(msg.track_namespace_prefix);
|
|
279
|
-
}
|
|
280
|
-
function encodePublishPayload(msg, w) {
|
|
281
|
-
w.writeVarInt(msg.request_id);
|
|
282
|
-
w.writeTuple(msg.track_namespace);
|
|
283
|
-
w.writeString(msg.track_name);
|
|
284
|
-
w.writeVarInt(msg.track_alias);
|
|
285
|
-
w.writeVarInt(msg.group_order);
|
|
286
|
-
w.writeVarInt(msg.content_exists);
|
|
287
|
-
if (msg.content_exists === 1n && msg.largest_location) {
|
|
288
|
-
w.writeVarInt(msg.largest_location.group);
|
|
289
|
-
w.writeVarInt(msg.largest_location.object);
|
|
290
|
-
}
|
|
291
|
-
w.writeVarInt(msg.forward);
|
|
292
|
-
encodeParams(msg.parameters, w);
|
|
293
|
-
}
|
|
294
|
-
function encodePublishOkPayload(msg, w) {
|
|
295
|
-
w.writeVarInt(msg.request_id);
|
|
296
|
-
w.writeVarInt(msg.forward);
|
|
297
|
-
w.writeUint8(msg.subscriber_priority);
|
|
298
|
-
w.writeVarInt(msg.group_order);
|
|
299
|
-
w.writeVarInt(msg.filter_type);
|
|
300
|
-
const ft = Number(msg.filter_type);
|
|
301
|
-
if (ft === 3 || ft === 4) {
|
|
302
|
-
w.writeVarInt(msg.start_group);
|
|
303
|
-
w.writeVarInt(msg.start_object);
|
|
304
|
-
}
|
|
305
|
-
if (ft === 4) {
|
|
306
|
-
w.writeVarInt(msg.end_group);
|
|
307
|
-
}
|
|
308
|
-
encodeParams(msg.parameters, w);
|
|
309
|
-
}
|
|
310
|
-
function encodePublishErrorPayload(msg, w) {
|
|
311
|
-
w.writeVarInt(msg.request_id);
|
|
312
|
-
w.writeVarInt(msg.error_code);
|
|
313
|
-
w.writeString(msg.reason_phrase);
|
|
314
|
-
}
|
|
315
|
-
function encodeFetchPayload(msg, w) {
|
|
316
|
-
w.writeVarInt(msg.request_id);
|
|
317
|
-
w.writeUint8(msg.subscriber_priority);
|
|
318
|
-
w.writeVarInt(msg.group_order);
|
|
319
|
-
w.writeVarInt(msg.fetch_type);
|
|
320
|
-
const ft = Number(msg.fetch_type);
|
|
321
|
-
if (ft === 1 && msg.standalone) {
|
|
322
|
-
w.writeTuple(msg.standalone.track_namespace);
|
|
323
|
-
w.writeString(msg.standalone.track_name);
|
|
324
|
-
w.writeVarInt(msg.standalone.start_group);
|
|
325
|
-
w.writeVarInt(msg.standalone.start_object);
|
|
326
|
-
w.writeVarInt(msg.standalone.end_group);
|
|
327
|
-
w.writeVarInt(msg.standalone.end_object);
|
|
328
|
-
}
|
|
329
|
-
else if ((ft === 2 || ft === 3) && msg.joining) {
|
|
330
|
-
w.writeVarInt(msg.joining.joining_subscribe_id);
|
|
331
|
-
w.writeVarInt(msg.joining.joining_start);
|
|
332
|
-
}
|
|
333
|
-
encodeParams(msg.parameters, w);
|
|
334
|
-
}
|
|
335
|
-
function encodeFetchOkPayload(msg, w) {
|
|
336
|
-
w.writeVarInt(msg.request_id);
|
|
337
|
-
w.writeVarInt(msg.group_order);
|
|
338
|
-
w.writeVarInt(msg.end_of_track);
|
|
339
|
-
w.writeVarInt(msg.end_location.group);
|
|
340
|
-
w.writeVarInt(msg.end_location.object);
|
|
341
|
-
encodeParams(msg.parameters, w);
|
|
342
|
-
}
|
|
343
|
-
function encodeFetchErrorPayload(msg, w) {
|
|
344
|
-
w.writeVarInt(msg.request_id);
|
|
345
|
-
w.writeVarInt(msg.error_code);
|
|
346
|
-
w.writeString(msg.reason_phrase);
|
|
347
|
-
}
|
|
348
|
-
function encodeFetchCancelPayload(msg, w) {
|
|
349
|
-
w.writeVarInt(msg.request_id);
|
|
350
|
-
}
|
|
351
|
-
// Draft-13: track_status is now SUBSCRIBE-like
|
|
352
|
-
function encodeTrackStatusPayload(msg, w) {
|
|
353
|
-
w.writeVarInt(msg.request_id);
|
|
354
|
-
w.writeTuple(msg.track_namespace);
|
|
355
|
-
w.writeString(msg.track_name);
|
|
356
|
-
w.writeUint8(msg.subscriber_priority);
|
|
357
|
-
w.writeVarInt(msg.group_order);
|
|
358
|
-
w.writeVarInt(msg.forward);
|
|
359
|
-
w.writeVarInt(msg.filter_type);
|
|
360
|
-
const ft = Number(msg.filter_type);
|
|
361
|
-
if (ft === 3 || ft === 4) {
|
|
362
|
-
w.writeVarInt(msg.start_group);
|
|
363
|
-
w.writeVarInt(msg.start_object);
|
|
364
|
-
}
|
|
365
|
-
if (ft === 4) {
|
|
366
|
-
w.writeVarInt(msg.end_group);
|
|
367
|
-
}
|
|
368
|
-
encodeParams(msg.parameters, w);
|
|
369
|
-
}
|
|
370
|
-
// Draft-13: track_status_ok is SUBSCRIBE_OK-like
|
|
371
|
-
function encodeTrackStatusOkPayload(msg, w) {
|
|
372
|
-
w.writeVarInt(msg.request_id);
|
|
373
|
-
w.writeVarInt(msg.track_alias);
|
|
374
|
-
w.writeVarInt(msg.expires);
|
|
375
|
-
w.writeVarInt(msg.group_order);
|
|
376
|
-
w.writeVarInt(msg.content_exists);
|
|
377
|
-
if (msg.content_exists === 1n && msg.largest_location) {
|
|
378
|
-
w.writeVarInt(msg.largest_location.group);
|
|
379
|
-
w.writeVarInt(msg.largest_location.object);
|
|
380
|
-
}
|
|
381
|
-
encodeParams(msg.parameters, w);
|
|
382
|
-
}
|
|
383
|
-
// Draft-13: track_status_error
|
|
384
|
-
function encodeTrackStatusErrorPayload(msg, w) {
|
|
385
|
-
w.writeVarInt(msg.request_id);
|
|
386
|
-
w.writeVarInt(msg.error_code);
|
|
387
|
-
w.writeString(msg.reason_phrase);
|
|
388
|
-
}
|
|
389
|
-
function encodeGoAwayPayload(msg, w) {
|
|
390
|
-
w.writeString(msg.new_session_uri);
|
|
391
|
-
}
|
|
392
|
-
function encodeMaxRequestIdPayload(msg, w) {
|
|
393
|
-
w.writeVarInt(msg.request_id);
|
|
394
|
-
}
|
|
395
|
-
function encodeRequestsBlockedPayload(msg, w) {
|
|
396
|
-
w.writeVarInt(msg.maximum_request_id);
|
|
397
|
-
}
|
|
398
|
-
// ─── Payload Decoders ──────────────────────────────────────────────────────────
|
|
399
|
-
function decodeClientSetupPayload(r) {
|
|
400
|
-
const numVersions = Number(r.readVarInt());
|
|
401
|
-
if (numVersions === 0) {
|
|
402
|
-
throw new DecodeError("CONSTRAINT_VIOLATION", "supported_versions must not be empty", r.offset);
|
|
403
|
-
}
|
|
404
|
-
const supported_versions = [];
|
|
405
|
-
for (let i = 0; i < numVersions; i++)
|
|
406
|
-
supported_versions.push(r.readVarInt());
|
|
407
|
-
const parameters = decodeSetupParams(r);
|
|
408
|
-
return { type: "client_setup", supported_versions, parameters };
|
|
409
|
-
}
|
|
410
|
-
function decodeServerSetupPayload(r) {
|
|
411
|
-
const selected_version = r.readVarInt();
|
|
412
|
-
const parameters = decodeSetupParams(r);
|
|
413
|
-
return { type: "server_setup", selected_version, parameters };
|
|
414
|
-
}
|
|
415
|
-
function decodeSubscribePayload(r) {
|
|
416
|
-
const request_id = r.readVarInt();
|
|
417
|
-
const track_namespace = r.readTuple();
|
|
418
|
-
const track_name = r.readString();
|
|
419
|
-
const subscriber_priority = r.readUint8();
|
|
420
|
-
const group_order = r.readVarInt();
|
|
421
|
-
const forward = r.readVarInt();
|
|
422
|
-
const filter_type = r.readVarInt();
|
|
423
|
-
const ft = Number(filter_type);
|
|
424
|
-
if (ft < 1 || ft > 4) {
|
|
425
|
-
throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid filter_type: ${ft}`, r.offset);
|
|
426
|
-
}
|
|
427
|
-
let start_group;
|
|
428
|
-
let start_object;
|
|
429
|
-
let end_group;
|
|
430
|
-
if (ft === 3 || ft === 4) {
|
|
431
|
-
start_group = r.readVarInt();
|
|
432
|
-
start_object = r.readVarInt();
|
|
433
|
-
}
|
|
434
|
-
if (ft === 4) {
|
|
435
|
-
end_group = r.readVarInt();
|
|
436
|
-
}
|
|
437
|
-
const parameters = decodeParams(r);
|
|
438
|
-
const msg = {
|
|
439
|
-
type: "subscribe",
|
|
440
|
-
request_id,
|
|
441
|
-
track_namespace,
|
|
442
|
-
track_name,
|
|
443
|
-
subscriber_priority,
|
|
444
|
-
group_order,
|
|
445
|
-
forward,
|
|
446
|
-
filter_type,
|
|
447
|
-
parameters,
|
|
448
|
-
};
|
|
449
|
-
if (start_group !== undefined)
|
|
450
|
-
msg.start_group = start_group;
|
|
451
|
-
if (start_object !== undefined)
|
|
452
|
-
msg.start_object = start_object;
|
|
453
|
-
if (end_group !== undefined)
|
|
454
|
-
msg.end_group = end_group;
|
|
455
|
-
return msg;
|
|
456
|
-
}
|
|
457
|
-
function decodeSubscribeOkPayload(r) {
|
|
458
|
-
const request_id = r.readVarInt();
|
|
459
|
-
const track_alias = r.readVarInt();
|
|
460
|
-
const expires = r.readVarInt();
|
|
461
|
-
const group_order = r.readVarInt();
|
|
462
|
-
const content_exists = r.readVarInt();
|
|
463
|
-
let largest_location;
|
|
464
|
-
if (content_exists === 1n) {
|
|
465
|
-
const group = r.readVarInt();
|
|
466
|
-
const object = r.readVarInt();
|
|
467
|
-
largest_location = { group, object };
|
|
468
|
-
}
|
|
469
|
-
const parameters = decodeParams(r);
|
|
470
|
-
const msg = {
|
|
471
|
-
type: "subscribe_ok",
|
|
472
|
-
request_id,
|
|
473
|
-
track_alias,
|
|
474
|
-
expires,
|
|
475
|
-
group_order,
|
|
476
|
-
content_exists,
|
|
477
|
-
parameters,
|
|
478
|
-
};
|
|
479
|
-
if (largest_location)
|
|
480
|
-
msg.largest_location = largest_location;
|
|
481
|
-
return msg;
|
|
482
|
-
}
|
|
483
|
-
function decodeSubscribeErrorPayload(r) {
|
|
484
|
-
const request_id = r.readVarInt();
|
|
485
|
-
const error_code = r.readVarInt();
|
|
486
|
-
const reason_phrase = r.readString();
|
|
487
|
-
return { type: "subscribe_error", request_id, error_code, reason_phrase };
|
|
488
|
-
}
|
|
489
|
-
function decodeSubscribeUpdatePayload(r) {
|
|
490
|
-
const request_id = r.readVarInt();
|
|
491
|
-
const start_group = r.readVarInt();
|
|
492
|
-
const start_object = r.readVarInt();
|
|
493
|
-
const end_group = r.readVarInt();
|
|
494
|
-
const subscriber_priority = r.readUint8();
|
|
495
|
-
const forward = r.readVarInt();
|
|
496
|
-
const parameters = decodeParams(r);
|
|
497
|
-
return {
|
|
498
|
-
type: "subscribe_update",
|
|
499
|
-
request_id,
|
|
500
|
-
start_group,
|
|
501
|
-
start_object,
|
|
502
|
-
end_group,
|
|
503
|
-
subscriber_priority,
|
|
504
|
-
forward,
|
|
505
|
-
parameters,
|
|
506
|
-
};
|
|
507
|
-
}
|
|
508
|
-
function decodeSubscribeDonePayload(r) {
|
|
509
|
-
const request_id = r.readVarInt();
|
|
510
|
-
const status_code = r.readVarInt();
|
|
511
|
-
const stream_count = r.readVarInt();
|
|
512
|
-
const reason_phrase = r.readString();
|
|
513
|
-
return { type: "subscribe_done", request_id, status_code, stream_count, reason_phrase };
|
|
514
|
-
}
|
|
515
|
-
function decodeUnsubscribePayload(r) {
|
|
516
|
-
const request_id = r.readVarInt();
|
|
517
|
-
return { type: "unsubscribe", request_id };
|
|
518
|
-
}
|
|
519
|
-
function decodeAnnouncePayload(r) {
|
|
520
|
-
const request_id = r.readVarInt();
|
|
521
|
-
const track_namespace = r.readTuple();
|
|
522
|
-
const parameters = decodeParams(r);
|
|
523
|
-
return { type: "announce", request_id, track_namespace, parameters };
|
|
524
|
-
}
|
|
525
|
-
function decodeAnnounceOkPayload(r) {
|
|
526
|
-
const request_id = r.readVarInt();
|
|
527
|
-
return { type: "announce_ok", request_id };
|
|
528
|
-
}
|
|
529
|
-
function decodeAnnounceErrorPayload(r) {
|
|
530
|
-
const request_id = r.readVarInt();
|
|
531
|
-
const error_code = r.readVarInt();
|
|
532
|
-
const reason_phrase = r.readString();
|
|
533
|
-
return { type: "announce_error", request_id, error_code, reason_phrase };
|
|
534
|
-
}
|
|
535
|
-
function decodeUnannouncePayload(r) {
|
|
536
|
-
const track_namespace = r.readTuple();
|
|
537
|
-
return { type: "unannounce", track_namespace };
|
|
538
|
-
}
|
|
539
|
-
function decodeAnnounceCancelPayload(r) {
|
|
540
|
-
const track_namespace = r.readTuple();
|
|
541
|
-
const error_code = r.readVarInt();
|
|
542
|
-
const reason_phrase = r.readString();
|
|
543
|
-
return { type: "announce_cancel", track_namespace, error_code, reason_phrase };
|
|
544
|
-
}
|
|
545
|
-
// Draft-13: subscribe_namespace (renamed from subscribe_announces)
|
|
546
|
-
function decodeSubscribeNamespacePayload(r) {
|
|
547
|
-
const request_id = r.readVarInt();
|
|
548
|
-
const track_namespace_prefix = r.readTuple();
|
|
549
|
-
const parameters = decodeParams(r);
|
|
550
|
-
return { type: "subscribe_namespace", request_id, track_namespace_prefix, parameters };
|
|
551
|
-
}
|
|
552
|
-
function decodeSubscribeNamespaceOkPayload(r) {
|
|
553
|
-
const request_id = r.readVarInt();
|
|
554
|
-
return { type: "subscribe_namespace_ok", request_id };
|
|
555
|
-
}
|
|
556
|
-
function decodeSubscribeNamespaceErrorPayload(r) {
|
|
557
|
-
const request_id = r.readVarInt();
|
|
558
|
-
const error_code = r.readVarInt();
|
|
559
|
-
const reason_phrase = r.readString();
|
|
560
|
-
return { type: "subscribe_namespace_error", request_id, error_code, reason_phrase };
|
|
561
|
-
}
|
|
562
|
-
function decodeUnsubscribeNamespacePayload(r) {
|
|
563
|
-
const track_namespace_prefix = r.readTuple();
|
|
564
|
-
return { type: "unsubscribe_namespace", track_namespace_prefix };
|
|
565
|
-
}
|
|
566
|
-
function decodePublishPayload(r) {
|
|
567
|
-
const request_id = r.readVarInt();
|
|
568
|
-
const track_namespace = r.readTuple();
|
|
569
|
-
const track_name = r.readString();
|
|
570
|
-
const track_alias = r.readVarInt();
|
|
571
|
-
const group_order = r.readVarInt();
|
|
572
|
-
const content_exists = r.readVarInt();
|
|
573
|
-
let largest_location;
|
|
574
|
-
if (content_exists === 1n) {
|
|
575
|
-
const group = r.readVarInt();
|
|
576
|
-
const object = r.readVarInt();
|
|
577
|
-
largest_location = { group, object };
|
|
578
|
-
}
|
|
579
|
-
const forward = r.readVarInt();
|
|
580
|
-
const parameters = decodeParams(r);
|
|
581
|
-
const msg = {
|
|
582
|
-
type: "publish",
|
|
583
|
-
request_id,
|
|
584
|
-
track_namespace,
|
|
585
|
-
track_name,
|
|
586
|
-
track_alias,
|
|
587
|
-
group_order,
|
|
588
|
-
content_exists,
|
|
589
|
-
forward,
|
|
590
|
-
parameters,
|
|
591
|
-
};
|
|
592
|
-
if (largest_location)
|
|
593
|
-
msg.largest_location = largest_location;
|
|
594
|
-
return msg;
|
|
595
|
-
}
|
|
596
|
-
function decodePublishOkPayload(r) {
|
|
597
|
-
const request_id = r.readVarInt();
|
|
598
|
-
const forward = r.readVarInt();
|
|
599
|
-
const subscriber_priority = r.readUint8();
|
|
600
|
-
const group_order = r.readVarInt();
|
|
601
|
-
const filter_type = r.readVarInt();
|
|
602
|
-
const ft = Number(filter_type);
|
|
603
|
-
let start_group;
|
|
604
|
-
let start_object;
|
|
605
|
-
let end_group;
|
|
606
|
-
if (ft === 3 || ft === 4) {
|
|
607
|
-
start_group = r.readVarInt();
|
|
608
|
-
start_object = r.readVarInt();
|
|
609
|
-
}
|
|
610
|
-
if (ft === 4) {
|
|
611
|
-
end_group = r.readVarInt();
|
|
612
|
-
}
|
|
613
|
-
const parameters = decodeParams(r);
|
|
614
|
-
const msg = {
|
|
615
|
-
type: "publish_ok",
|
|
616
|
-
request_id,
|
|
617
|
-
forward,
|
|
618
|
-
subscriber_priority,
|
|
619
|
-
group_order,
|
|
620
|
-
filter_type,
|
|
621
|
-
parameters,
|
|
622
|
-
};
|
|
623
|
-
if (start_group !== undefined)
|
|
624
|
-
msg.start_group = start_group;
|
|
625
|
-
if (start_object !== undefined)
|
|
626
|
-
msg.start_object = start_object;
|
|
627
|
-
if (end_group !== undefined)
|
|
628
|
-
msg.end_group = end_group;
|
|
629
|
-
return msg;
|
|
630
|
-
}
|
|
631
|
-
function decodePublishErrorPayload(r) {
|
|
632
|
-
const request_id = r.readVarInt();
|
|
633
|
-
const error_code = r.readVarInt();
|
|
634
|
-
const reason_phrase = r.readString();
|
|
635
|
-
return { type: "publish_error", request_id, error_code, reason_phrase };
|
|
636
|
-
}
|
|
637
|
-
function decodeFetchPayload(r) {
|
|
638
|
-
const request_id = r.readVarInt();
|
|
639
|
-
const subscriber_priority = r.readUint8();
|
|
640
|
-
const group_order = r.readVarInt();
|
|
641
|
-
const fetch_type = r.readVarInt();
|
|
642
|
-
const ft = Number(fetch_type);
|
|
643
|
-
if (ft < 1 || ft > 3) {
|
|
644
|
-
throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid fetch_type: ${ft}`, r.offset);
|
|
645
|
-
}
|
|
646
|
-
let standalone;
|
|
647
|
-
let joining;
|
|
648
|
-
if (ft === 1) {
|
|
649
|
-
const track_namespace = r.readTuple();
|
|
650
|
-
const track_name = r.readString();
|
|
651
|
-
const start_group = r.readVarInt();
|
|
652
|
-
const start_object = r.readVarInt();
|
|
653
|
-
const end_group = r.readVarInt();
|
|
654
|
-
const end_object = r.readVarInt();
|
|
655
|
-
standalone = { track_namespace, track_name, start_group, start_object, end_group, end_object };
|
|
656
|
-
}
|
|
657
|
-
else {
|
|
658
|
-
const joining_subscribe_id = r.readVarInt();
|
|
659
|
-
const joining_start = r.readVarInt();
|
|
660
|
-
joining = { joining_subscribe_id, joining_start };
|
|
661
|
-
}
|
|
662
|
-
const parameters = decodeParams(r);
|
|
663
|
-
return {
|
|
664
|
-
type: "fetch",
|
|
665
|
-
request_id,
|
|
666
|
-
subscriber_priority,
|
|
667
|
-
group_order,
|
|
668
|
-
fetch_type,
|
|
669
|
-
standalone,
|
|
670
|
-
joining,
|
|
671
|
-
parameters,
|
|
672
|
-
};
|
|
673
|
-
}
|
|
674
|
-
function decodeFetchOkPayload(r) {
|
|
675
|
-
const request_id = r.readVarInt();
|
|
676
|
-
const group_order = r.readVarInt();
|
|
677
|
-
const end_of_track = r.readVarInt();
|
|
678
|
-
const group = r.readVarInt();
|
|
679
|
-
const object = r.readVarInt();
|
|
680
|
-
const parameters = decodeParams(r);
|
|
681
|
-
return {
|
|
682
|
-
type: "fetch_ok",
|
|
683
|
-
request_id,
|
|
684
|
-
group_order,
|
|
685
|
-
end_of_track,
|
|
686
|
-
end_location: { group, object },
|
|
687
|
-
parameters,
|
|
688
|
-
};
|
|
689
|
-
}
|
|
690
|
-
function decodeFetchErrorPayload(r) {
|
|
691
|
-
const request_id = r.readVarInt();
|
|
692
|
-
const error_code = r.readVarInt();
|
|
693
|
-
const reason_phrase = r.readString();
|
|
694
|
-
return { type: "fetch_error", request_id, error_code, reason_phrase };
|
|
695
|
-
}
|
|
696
|
-
function decodeFetchCancelPayload(r) {
|
|
697
|
-
const request_id = r.readVarInt();
|
|
698
|
-
return { type: "fetch_cancel", request_id };
|
|
699
|
-
}
|
|
700
|
-
// Draft-13: track_status is SUBSCRIBE-like
|
|
701
|
-
function decodeTrackStatusPayload(r) {
|
|
702
|
-
const request_id = r.readVarInt();
|
|
703
|
-
const track_namespace = r.readTuple();
|
|
704
|
-
const track_name = r.readString();
|
|
705
|
-
const subscriber_priority = r.readUint8();
|
|
706
|
-
const group_order = r.readVarInt();
|
|
707
|
-
const forward = r.readVarInt();
|
|
708
|
-
const filter_type = r.readVarInt();
|
|
709
|
-
const ft = Number(filter_type);
|
|
710
|
-
if (ft < 1 || ft > 4) {
|
|
711
|
-
throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid filter_type: ${ft}`, r.offset);
|
|
712
|
-
}
|
|
713
|
-
let start_group;
|
|
714
|
-
let start_object;
|
|
715
|
-
let end_group;
|
|
716
|
-
if (ft === 3 || ft === 4) {
|
|
717
|
-
start_group = r.readVarInt();
|
|
718
|
-
start_object = r.readVarInt();
|
|
719
|
-
}
|
|
720
|
-
if (ft === 4) {
|
|
721
|
-
end_group = r.readVarInt();
|
|
722
|
-
}
|
|
723
|
-
const parameters = decodeParams(r);
|
|
724
|
-
const msg = {
|
|
725
|
-
type: "track_status",
|
|
726
|
-
request_id,
|
|
727
|
-
track_namespace,
|
|
728
|
-
track_name,
|
|
729
|
-
subscriber_priority,
|
|
730
|
-
group_order,
|
|
731
|
-
forward,
|
|
732
|
-
filter_type,
|
|
733
|
-
parameters,
|
|
734
|
-
};
|
|
735
|
-
if (start_group !== undefined)
|
|
736
|
-
msg.start_group = start_group;
|
|
737
|
-
if (start_object !== undefined)
|
|
738
|
-
msg.start_object = start_object;
|
|
739
|
-
if (end_group !== undefined)
|
|
740
|
-
msg.end_group = end_group;
|
|
741
|
-
return msg;
|
|
742
|
-
}
|
|
743
|
-
// Draft-13: track_status_ok is SUBSCRIBE_OK-like
|
|
744
|
-
function decodeTrackStatusOkPayload(r) {
|
|
745
|
-
const request_id = r.readVarInt();
|
|
746
|
-
const track_alias = r.readVarInt();
|
|
747
|
-
const expires = r.readVarInt();
|
|
748
|
-
const group_order = r.readVarInt();
|
|
749
|
-
const content_exists = r.readVarInt();
|
|
750
|
-
let largest_location;
|
|
751
|
-
if (content_exists === 1n) {
|
|
752
|
-
const group = r.readVarInt();
|
|
753
|
-
const object = r.readVarInt();
|
|
754
|
-
largest_location = { group, object };
|
|
755
|
-
}
|
|
756
|
-
const parameters = decodeParams(r);
|
|
757
|
-
const msg = {
|
|
758
|
-
type: "track_status_ok",
|
|
759
|
-
request_id,
|
|
760
|
-
track_alias,
|
|
761
|
-
expires,
|
|
762
|
-
group_order,
|
|
763
|
-
content_exists,
|
|
764
|
-
parameters,
|
|
765
|
-
};
|
|
766
|
-
if (largest_location)
|
|
767
|
-
msg.largest_location = largest_location;
|
|
768
|
-
return msg;
|
|
769
|
-
}
|
|
770
|
-
// Draft-13: track_status_error
|
|
771
|
-
function decodeTrackStatusErrorPayload(r) {
|
|
772
|
-
const request_id = r.readVarInt();
|
|
773
|
-
const error_code = r.readVarInt();
|
|
774
|
-
const reason_phrase = r.readString();
|
|
775
|
-
return { type: "track_status_error", request_id, error_code, reason_phrase };
|
|
776
|
-
}
|
|
777
|
-
function decodeGoAwayPayload(r) {
|
|
778
|
-
const new_session_uri = r.readString();
|
|
779
|
-
return { type: "goaway", new_session_uri };
|
|
780
|
-
}
|
|
781
|
-
function decodeMaxRequestIdPayload(r) {
|
|
782
|
-
const request_id = r.readVarInt();
|
|
783
|
-
return { type: "max_request_id", request_id };
|
|
784
|
-
}
|
|
785
|
-
function decodeRequestsBlockedPayload(r) {
|
|
786
|
-
const maximum_request_id = r.readVarInt();
|
|
787
|
-
return { type: "requests_blocked", maximum_request_id };
|
|
788
|
-
}
|
|
789
|
-
// ─── Payload dispatch tables ───────────────────────────────────────────────────
|
|
790
|
-
const payloadDecoders = new Map([
|
|
791
|
-
[MSG_CLIENT_SETUP, decodeClientSetupPayload],
|
|
792
|
-
[MSG_SERVER_SETUP, decodeServerSetupPayload],
|
|
793
|
-
[MSG_SUBSCRIBE, decodeSubscribePayload],
|
|
794
|
-
[MSG_SUBSCRIBE_OK, decodeSubscribeOkPayload],
|
|
795
|
-
[MSG_SUBSCRIBE_ERROR, decodeSubscribeErrorPayload],
|
|
796
|
-
[MSG_SUBSCRIBE_UPDATE, decodeSubscribeUpdatePayload],
|
|
797
|
-
[MSG_SUBSCRIBE_DONE, decodeSubscribeDonePayload],
|
|
798
|
-
[MSG_UNSUBSCRIBE, decodeUnsubscribePayload],
|
|
799
|
-
[MSG_ANNOUNCE, decodeAnnouncePayload],
|
|
800
|
-
[MSG_ANNOUNCE_OK, decodeAnnounceOkPayload],
|
|
801
|
-
[MSG_ANNOUNCE_ERROR, decodeAnnounceErrorPayload],
|
|
802
|
-
[MSG_UNANNOUNCE, decodeUnannouncePayload],
|
|
803
|
-
[MSG_ANNOUNCE_CANCEL, decodeAnnounceCancelPayload],
|
|
804
|
-
[MSG_SUBSCRIBE_NAMESPACE, decodeSubscribeNamespacePayload],
|
|
805
|
-
[MSG_SUBSCRIBE_NAMESPACE_OK, decodeSubscribeNamespaceOkPayload],
|
|
806
|
-
[MSG_SUBSCRIBE_NAMESPACE_ERROR, decodeSubscribeNamespaceErrorPayload],
|
|
807
|
-
[MSG_UNSUBSCRIBE_NAMESPACE, decodeUnsubscribeNamespacePayload],
|
|
808
|
-
[MSG_PUBLISH, decodePublishPayload],
|
|
809
|
-
[MSG_PUBLISH_OK, decodePublishOkPayload],
|
|
810
|
-
[MSG_PUBLISH_ERROR, decodePublishErrorPayload],
|
|
811
|
-
[MSG_FETCH, decodeFetchPayload],
|
|
812
|
-
[MSG_FETCH_OK, decodeFetchOkPayload],
|
|
813
|
-
[MSG_FETCH_ERROR, decodeFetchErrorPayload],
|
|
814
|
-
[MSG_FETCH_CANCEL, decodeFetchCancelPayload],
|
|
815
|
-
[MSG_TRACK_STATUS, decodeTrackStatusPayload],
|
|
816
|
-
[MSG_TRACK_STATUS_OK, decodeTrackStatusOkPayload],
|
|
817
|
-
[MSG_TRACK_STATUS_ERROR, decodeTrackStatusErrorPayload],
|
|
818
|
-
[MSG_GOAWAY, decodeGoAwayPayload],
|
|
819
|
-
[MSG_MAX_REQUEST_ID, decodeMaxRequestIdPayload],
|
|
820
|
-
[MSG_REQUESTS_BLOCKED, decodeRequestsBlockedPayload],
|
|
821
|
-
]);
|
|
822
|
-
// ─── Public API ────────────────────────────────────────────────────────────────
|
|
823
|
-
/**
|
|
824
|
-
* Encode a draft-13 control message.
|
|
825
|
-
* Most messages use type(varint) + length(uint16 BE) + payload.
|
|
826
|
-
* PUBLISH family uses type(varint) + length(varint) + payload.
|
|
827
|
-
*/
|
|
828
|
-
export function encodeMessage(message) {
|
|
829
|
-
const typeId = MESSAGE_ID_MAP.get(message.type);
|
|
830
|
-
if (typeId === undefined)
|
|
831
|
-
throw new Error(`Unknown message type: ${message.type}`);
|
|
832
|
-
const payloadWriter = new BufferWriter();
|
|
833
|
-
encodePayload(message, payloadWriter);
|
|
834
|
-
const payload = payloadWriter.finish();
|
|
835
|
-
const writer = new BufferWriter();
|
|
836
|
-
writer.writeVarInt(typeId);
|
|
837
|
-
if (VARINT_FRAMED_MESSAGES.has(typeId)) {
|
|
838
|
-
// PUBLISH family: varint length framing
|
|
839
|
-
writer.writeVarInt(payload.byteLength);
|
|
840
|
-
}
|
|
841
|
-
else {
|
|
842
|
-
// All other messages: uint16 BE length framing
|
|
843
|
-
if (payload.byteLength > 0xffff) {
|
|
844
|
-
throw new Error(`Payload too large for 16-bit length: ${payload.byteLength}`);
|
|
845
|
-
}
|
|
846
|
-
writer.writeUint8((payload.byteLength >> 8) & 0xff);
|
|
847
|
-
writer.writeUint8(payload.byteLength & 0xff);
|
|
848
|
-
}
|
|
849
|
-
writer.writeBytes(payload);
|
|
850
|
-
return writer.finish();
|
|
851
|
-
}
|
|
852
|
-
function encodePayload(msg, w) {
|
|
853
|
-
switch (msg.type) {
|
|
854
|
-
case "client_setup":
|
|
855
|
-
return encodeClientSetupPayload(msg, w);
|
|
856
|
-
case "server_setup":
|
|
857
|
-
return encodeServerSetupPayload(msg, w);
|
|
858
|
-
case "subscribe":
|
|
859
|
-
return encodeSubscribePayload(msg, w);
|
|
860
|
-
case "subscribe_ok":
|
|
861
|
-
return encodeSubscribeOkPayload(msg, w);
|
|
862
|
-
case "subscribe_error":
|
|
863
|
-
return encodeSubscribeErrorPayload(msg, w);
|
|
864
|
-
case "subscribe_update":
|
|
865
|
-
return encodeSubscribeUpdatePayload(msg, w);
|
|
866
|
-
case "subscribe_done":
|
|
867
|
-
return encodeSubscribeDonePayload(msg, w);
|
|
868
|
-
case "unsubscribe":
|
|
869
|
-
return encodeUnsubscribePayload(msg, w);
|
|
870
|
-
case "announce":
|
|
871
|
-
return encodeAnnouncePayload(msg, w);
|
|
872
|
-
case "announce_ok":
|
|
873
|
-
return encodeAnnounceOkPayload(msg, w);
|
|
874
|
-
case "announce_error":
|
|
875
|
-
return encodeAnnounceErrorPayload(msg, w);
|
|
876
|
-
case "unannounce":
|
|
877
|
-
return encodeUnannouncePayload(msg, w);
|
|
878
|
-
case "announce_cancel":
|
|
879
|
-
return encodeAnnounceCancelPayload(msg, w);
|
|
880
|
-
case "subscribe_namespace":
|
|
881
|
-
return encodeSubscribeNamespacePayload(msg, w);
|
|
882
|
-
case "subscribe_namespace_ok":
|
|
883
|
-
return encodeSubscribeNamespaceOkPayload(msg, w);
|
|
884
|
-
case "subscribe_namespace_error":
|
|
885
|
-
return encodeSubscribeNamespaceErrorPayload(msg, w);
|
|
886
|
-
case "unsubscribe_namespace":
|
|
887
|
-
return encodeUnsubscribeNamespacePayload(msg, w);
|
|
888
|
-
case "publish":
|
|
889
|
-
return encodePublishPayload(msg, w);
|
|
890
|
-
case "publish_ok":
|
|
891
|
-
return encodePublishOkPayload(msg, w);
|
|
892
|
-
case "publish_error":
|
|
893
|
-
return encodePublishErrorPayload(msg, w);
|
|
894
|
-
case "fetch":
|
|
895
|
-
return encodeFetchPayload(msg, w);
|
|
896
|
-
case "fetch_ok":
|
|
897
|
-
return encodeFetchOkPayload(msg, w);
|
|
898
|
-
case "fetch_error":
|
|
899
|
-
return encodeFetchErrorPayload(msg, w);
|
|
900
|
-
case "fetch_cancel":
|
|
901
|
-
return encodeFetchCancelPayload(msg, w);
|
|
902
|
-
case "track_status":
|
|
903
|
-
return encodeTrackStatusPayload(msg, w);
|
|
904
|
-
case "track_status_ok":
|
|
905
|
-
return encodeTrackStatusOkPayload(msg, w);
|
|
906
|
-
case "track_status_error":
|
|
907
|
-
return encodeTrackStatusErrorPayload(msg, w);
|
|
908
|
-
case "goaway":
|
|
909
|
-
return encodeGoAwayPayload(msg, w);
|
|
910
|
-
case "max_request_id":
|
|
911
|
-
return encodeMaxRequestIdPayload(msg, w);
|
|
912
|
-
case "requests_blocked":
|
|
913
|
-
return encodeRequestsBlockedPayload(msg, w);
|
|
914
|
-
default: {
|
|
915
|
-
const _exhaustive = msg;
|
|
916
|
-
throw new Error(`Unhandled message type: ${_exhaustive.type}`);
|
|
917
|
-
}
|
|
918
|
-
}
|
|
919
|
-
}
|
|
920
|
-
/**
|
|
921
|
-
* Decode a draft-13 control message from bytes.
|
|
922
|
-
*/
|
|
923
|
-
export function decodeMessage(bytes) {
|
|
924
|
-
try {
|
|
925
|
-
const reader = new BufferReader(bytes);
|
|
926
|
-
const typeId = reader.readVarInt();
|
|
927
|
-
let payloadLength;
|
|
928
|
-
if (VARINT_FRAMED_MESSAGES.has(typeId)) {
|
|
929
|
-
// PUBLISH family: varint length framing
|
|
930
|
-
payloadLength = Number(reader.readVarInt());
|
|
931
|
-
}
|
|
932
|
-
else {
|
|
933
|
-
// All other messages: uint16 BE length framing
|
|
934
|
-
const lenHi = reader.readUint8();
|
|
935
|
-
const lenLo = reader.readUint8();
|
|
936
|
-
payloadLength = (lenHi << 8) | lenLo;
|
|
937
|
-
}
|
|
938
|
-
const payloadBytes = reader.readBytes(payloadLength);
|
|
939
|
-
const payloadReader = new BufferReader(payloadBytes);
|
|
940
|
-
const decoder = payloadDecoders.get(typeId);
|
|
941
|
-
if (!decoder) {
|
|
942
|
-
return {
|
|
943
|
-
ok: false,
|
|
944
|
-
error: new DecodeError("UNKNOWN_MESSAGE_TYPE", `Unknown message type ID: 0x${typeId.toString(16)}`, 0),
|
|
945
|
-
};
|
|
946
|
-
}
|
|
947
|
-
const message = decoder(payloadReader);
|
|
948
|
-
return { ok: true, value: message, bytesRead: reader.offset };
|
|
949
|
-
}
|
|
950
|
-
catch (e) {
|
|
951
|
-
if (e instanceof DecodeError)
|
|
952
|
-
return { ok: false, error: e };
|
|
953
|
-
throw e;
|
|
954
|
-
}
|
|
955
|
-
}
|
|
956
|
-
// ─── Data Stream Encoding/Decoding ─────────────────────────────────────────────
|
|
957
|
-
export { encodeSubgroupStream, encodeDatagram, encodeFetchStream, decodeSubgroupStream, decodeDatagram, decodeFetchStream, decodeDataStream } from "./data-streams.js";
|
|
958
|
-
import { encodeSubgroupStream, encodeDatagram, encodeFetchStream, decodeSubgroupStream, decodeDatagram, decodeFetchStream, decodeDataStream } from "./data-streams.js";
|
|
959
|
-
export function createStreamDecoder() {
|
|
960
|
-
let buffer = new Uint8Array(0);
|
|
961
|
-
return new TransformStream({
|
|
962
|
-
transform(chunk, controller) {
|
|
963
|
-
const newBuffer = new Uint8Array(buffer.length + chunk.length);
|
|
964
|
-
newBuffer.set(buffer, 0);
|
|
965
|
-
newBuffer.set(chunk, buffer.length);
|
|
966
|
-
buffer = newBuffer;
|
|
967
|
-
while (buffer.length > 0) {
|
|
968
|
-
const result = decodeMessage(buffer);
|
|
969
|
-
if (!result.ok) {
|
|
970
|
-
if (result.error.code === "UNEXPECTED_END")
|
|
971
|
-
break;
|
|
972
|
-
controller.error(result.error);
|
|
973
|
-
return;
|
|
974
|
-
}
|
|
975
|
-
controller.enqueue(result.value);
|
|
976
|
-
buffer = buffer.slice(result.bytesRead);
|
|
977
|
-
}
|
|
978
|
-
},
|
|
979
|
-
flush(controller) {
|
|
980
|
-
if (buffer.length > 0)
|
|
981
|
-
controller.error(new DecodeError("UNEXPECTED_END", "Stream ended with incomplete data", 0));
|
|
982
|
-
},
|
|
983
|
-
});
|
|
984
|
-
}
|
|
985
|
-
export function createDraft13Codec() {
|
|
986
|
-
return {
|
|
987
|
-
draft: "draft-ietf-moq-transport-13",
|
|
988
|
-
encodeMessage,
|
|
989
|
-
decodeMessage,
|
|
990
|
-
encodeSubgroupStream,
|
|
991
|
-
encodeDatagram,
|
|
992
|
-
encodeFetchStream,
|
|
993
|
-
decodeSubgroupStream,
|
|
994
|
-
decodeDatagram,
|
|
995
|
-
decodeFetchStream,
|
|
996
|
-
decodeDataStream,
|
|
997
|
-
createStreamDecoder,
|
|
998
|
-
};
|
|
999
|
-
}
|
|
1000
|
-
//# sourceMappingURL=codec.js.map
|