@moqtap/codec 0.1.1 → 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +99 -95
- package/dist/chunk-4RIXXEII.js +1275 -0
- package/dist/chunk-4XYGE53S.cjs +698 -0
- package/dist/chunk-4YJANAXU.cjs +1109 -0
- package/dist/chunk-6AEHWULA.cjs +641 -0
- package/dist/chunk-7DUBLRXC.js +680 -0
- package/dist/{chunk-YBZD3DU5.cjs → chunk-7IVGHMKJ.cjs} +44 -42
- package/dist/chunk-BISI45MN.cjs +680 -0
- package/dist/{chunk-NLYTRGXA.cjs → chunk-BPNL5YFQ.cjs} +5 -5
- package/dist/chunk-CXDHOMHG.js +1097 -0
- package/dist/chunk-DUBCL3WF.cjs +749 -0
- package/dist/chunk-DWK5ZQZ4.js +642 -0
- package/dist/chunk-E6E3NQYU.js +680 -0
- package/dist/chunk-EFM5T7OM.js +698 -0
- package/dist/chunk-ENURAVHI.cjs +680 -0
- package/dist/{chunk-Z66WDWHI.js → chunk-FXZ2MYKJ.js} +127 -1
- package/dist/chunk-G26SJ6XS.cjs +1341 -0
- package/dist/chunk-G7GI7LJA.js +737 -0
- package/dist/chunk-GXEW4COZ.cjs +737 -0
- package/dist/chunk-HSVYF6XX.cjs +1361 -0
- package/dist/chunk-IBVM4DMJ.cjs +1097 -0
- package/dist/chunk-IV2H5CFI.cjs +1275 -0
- package/dist/chunk-IV2HRJVT.js +1198 -0
- package/dist/chunk-JSQM2MG3.js +680 -0
- package/dist/chunk-K4OLITS2.cjs +1055 -0
- package/dist/{chunk-UOBWHJA5.js → chunk-KFTCU2P6.js} +2 -3
- package/dist/chunk-LH4NTURO.js +1361 -0
- package/dist/{chunk-YTXLWKOR.js → chunk-MFAP7R6L.js} +1 -1
- package/dist/chunk-NGVE2RZT.js +1097 -0
- package/dist/chunk-NUX5BHWO.js +1341 -0
- package/dist/chunk-PJRA2TQ5.js +1055 -0
- package/dist/chunk-RVJAGE4S.cjs +1198 -0
- package/dist/{chunk-QYG6KGOV.cjs → chunk-RWQ43Z4F.cjs} +2 -3
- package/dist/chunk-RZHAPEXO.js +749 -0
- package/dist/chunk-ST24APEO.js +1109 -0
- package/dist/chunk-SYHW3FLI.cjs +642 -0
- package/dist/chunk-TLYNOOQP.cjs +432 -0
- package/dist/{chunk-IXHOBNXA.js → chunk-TMNGRIPL.js} +43 -41
- package/dist/chunk-UNS34PTA.cjs +680 -0
- package/dist/chunk-UR6JKS56.js +432 -0
- package/dist/{chunk-NPWHHWXT.cjs → chunk-UYXTY6ZQ.cjs} +127 -1
- package/dist/chunk-XUUCOLWU.cjs +1097 -0
- package/dist/chunk-YG5KJESI.js +641 -0
- package/dist/chunk-ZBKE2QRQ.js +1401 -0
- package/dist/chunk-ZSPO2GF2.cjs +1401 -0
- package/dist/codec-95k8CAu5.d.cts +35 -0
- package/dist/codec-AFuOxfsO.d.ts +60 -0
- package/dist/codec-B-UJ5Iow.d.cts +75 -0
- package/dist/codec-BC5jfvMb.d.ts +35 -0
- package/dist/codec-BECYPfY8.d.ts +35 -0
- package/dist/codec-BsPU1vNC.d.ts +39 -0
- package/dist/codec-BvpuF-6u.d.cts +39 -0
- package/dist/codec-C8jZI5Cx.d.cts +39 -0
- package/dist/codec-CAevkgf5.d.cts +33 -0
- package/dist/codec-CSUqCrRs.d.ts +39 -0
- package/dist/codec-C_HMXNK_.d.ts +33 -0
- package/dist/{codec-Bvr7rFtj.d.cts → codec-CpuvYTSV.d.cts} +1 -1
- package/dist/codec-D0x8-SCw.d.cts +35 -0
- package/dist/codec-D7ARhpG1.d.ts +75 -0
- package/dist/codec-DNAUGshO.d.cts +60 -0
- package/dist/codec-DPx_QNn0.d.ts +31 -0
- package/dist/{codec-B2mc2g3i.d.ts → codec-DRhCx_hw.d.ts} +1 -1
- package/dist/codec-Db7YPe3l.d.ts +31 -0
- package/dist/codec-axkJpb7D.d.cts +31 -0
- package/dist/codec-ujAbFaep.d.cts +31 -0
- package/dist/core/buffer-reader.d.ts +15 -0
- package/dist/core/buffer-reader.d.ts.map +1 -0
- package/dist/core/buffer-reader.js +98 -0
- package/dist/core/buffer-reader.js.map +1 -0
- package/dist/core/buffer-writer.d.ts +16 -0
- package/dist/core/buffer-writer.d.ts.map +1 -0
- package/dist/core/buffer-writer.js +86 -0
- package/dist/core/buffer-writer.js.map +1 -0
- package/dist/core/errors.d.ts +2 -0
- package/dist/core/errors.d.ts.map +1 -0
- package/dist/core/errors.js +2 -0
- package/dist/core/errors.js.map +1 -0
- package/dist/core/hex.d.ts +5 -0
- package/dist/core/hex.d.ts.map +1 -0
- package/dist/core/hex.js +17 -0
- package/dist/core/hex.js.map +1 -0
- package/dist/core/session-types.d.ts +99 -0
- package/dist/core/session-types.d.ts.map +1 -0
- package/dist/core/session-types.js +2 -0
- package/dist/core/session-types.js.map +1 -0
- package/dist/core/types.d.ts +235 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +11 -0
- package/dist/core/types.js.map +1 -0
- package/dist/draft10-session.cjs +6 -0
- package/dist/draft10-session.d.cts +8 -0
- package/dist/draft10-session.d.ts +8 -0
- package/dist/draft10-session.js +6 -0
- package/dist/draft10.cjs +115 -0
- package/dist/draft10.d.cts +95 -0
- package/dist/draft10.d.ts +95 -0
- package/dist/draft10.js +115 -0
- package/dist/draft11-session.cjs +6 -0
- package/dist/draft11-session.d.cts +8 -0
- package/dist/draft11-session.d.ts +8 -0
- package/dist/draft11-session.js +6 -0
- package/dist/draft11.cjs +109 -0
- package/dist/draft11.d.cts +99 -0
- package/dist/draft11.d.ts +99 -0
- package/dist/draft11.js +109 -0
- package/dist/draft12-session.cjs +6 -0
- package/dist/draft12-session.d.cts +8 -0
- package/dist/draft12-session.d.ts +8 -0
- package/dist/draft12-session.js +6 -0
- package/dist/draft12.cjs +117 -0
- package/dist/draft12.d.cts +106 -0
- package/dist/draft12.d.ts +106 -0
- package/dist/draft12.js +117 -0
- package/dist/draft13-session.cjs +6 -0
- package/dist/draft13-session.d.cts +8 -0
- package/dist/draft13-session.d.ts +8 -0
- package/dist/draft13-session.js +6 -0
- package/dist/draft13.cjs +119 -0
- package/dist/draft13.d.cts +108 -0
- package/dist/draft13.d.ts +108 -0
- package/dist/draft13.js +119 -0
- package/dist/draft14-session.cjs +2 -2
- package/dist/draft14-session.d.cts +3 -3
- package/dist/draft14-session.d.ts +3 -3
- package/dist/draft14-session.js +1 -1
- package/dist/draft14.cjs +3 -3
- package/dist/draft14.d.cts +16 -4
- package/dist/draft14.d.ts +16 -4
- package/dist/draft14.js +2 -2
- package/dist/draft15-session.cjs +6 -0
- package/dist/draft15-session.d.cts +8 -0
- package/dist/draft15-session.d.ts +8 -0
- package/dist/draft15-session.js +6 -0
- package/dist/draft15.cjs +111 -0
- package/dist/draft15.d.cts +93 -0
- package/dist/draft15.d.ts +93 -0
- package/dist/draft15.js +111 -0
- package/dist/draft16-session.cjs +6 -0
- package/dist/draft16-session.d.cts +8 -0
- package/dist/draft16-session.d.ts +8 -0
- package/dist/draft16-session.js +6 -0
- package/dist/draft16.cjs +113 -0
- package/dist/draft16.d.cts +94 -0
- package/dist/draft16.d.ts +94 -0
- package/dist/draft16.js +113 -0
- package/dist/draft17-session.cjs +8 -0
- package/dist/draft17-session.d.cts +51 -0
- package/dist/draft17-session.d.ts +51 -0
- package/dist/draft17-session.js +8 -0
- package/dist/draft17.cjs +99 -0
- package/dist/draft17.d.cts +40 -0
- package/dist/draft17.d.ts +40 -0
- package/dist/draft17.js +99 -0
- package/dist/draft7-session.cjs +3 -3
- package/dist/draft7-session.d.cts +3 -3
- package/dist/draft7-session.d.ts +3 -3
- package/dist/draft7-session.js +2 -2
- package/dist/draft7.cjs +4 -4
- package/dist/draft7.d.cts +2 -2
- package/dist/draft7.d.ts +2 -2
- package/dist/draft7.js +2 -2
- package/dist/draft8-session.cjs +6 -0
- package/dist/draft8-session.d.cts +8 -0
- package/dist/draft8-session.d.ts +8 -0
- package/dist/draft8-session.js +6 -0
- package/dist/draft8.cjs +115 -0
- package/dist/draft8.d.cts +95 -0
- package/dist/draft8.d.ts +95 -0
- package/dist/draft8.js +115 -0
- package/dist/draft9-session.cjs +6 -0
- package/dist/draft9-session.d.cts +8 -0
- package/dist/draft9-session.d.ts +8 -0
- package/dist/draft9-session.js +6 -0
- package/dist/draft9.cjs +115 -0
- package/dist/draft9.d.cts +95 -0
- package/dist/draft9.d.ts +95 -0
- package/dist/draft9.js +115 -0
- package/dist/drafts/draft07/announce-fsm.d.ts +2 -0
- package/dist/drafts/draft07/announce-fsm.d.ts.map +1 -0
- package/dist/drafts/draft07/announce-fsm.js +2 -0
- package/dist/drafts/draft07/announce-fsm.js.map +1 -0
- package/dist/drafts/draft07/codec.d.ts +17 -0
- package/dist/drafts/draft07/codec.d.ts.map +1 -0
- package/dist/drafts/draft07/codec.js +722 -0
- package/dist/drafts/draft07/codec.js.map +1 -0
- package/dist/drafts/draft07/data-streams.d.ts +9 -0
- package/dist/drafts/draft07/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft07/data-streams.js +228 -0
- package/dist/drafts/draft07/data-streams.js.map +1 -0
- package/dist/drafts/draft07/index.d.ts +14 -0
- package/dist/drafts/draft07/index.d.ts.map +1 -0
- package/dist/drafts/draft07/index.js +18 -0
- package/dist/drafts/draft07/index.js.map +1 -0
- package/dist/drafts/draft07/messages.d.ts +32 -0
- package/dist/drafts/draft07/messages.d.ts.map +1 -0
- package/dist/drafts/draft07/messages.js +42 -0
- package/dist/drafts/draft07/messages.js.map +1 -0
- package/dist/drafts/draft07/parameters.d.ts +4 -0
- package/dist/drafts/draft07/parameters.d.ts.map +1 -0
- package/dist/drafts/draft07/parameters.js +10 -0
- package/dist/drafts/draft07/parameters.js.map +1 -0
- package/dist/drafts/draft07/rules.d.ts +8 -0
- package/dist/drafts/draft07/rules.d.ts.map +1 -0
- package/dist/drafts/draft07/rules.js +95 -0
- package/dist/drafts/draft07/rules.js.map +1 -0
- package/dist/drafts/draft07/session-fsm.d.ts +38 -0
- package/dist/drafts/draft07/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft07/session-fsm.js +354 -0
- package/dist/drafts/draft07/session-fsm.js.map +1 -0
- package/dist/drafts/draft07/session.d.ts +4 -0
- package/dist/drafts/draft07/session.d.ts.map +1 -0
- package/dist/drafts/draft07/session.js +5 -0
- package/dist/drafts/draft07/session.js.map +1 -0
- package/dist/drafts/draft07/subscription-fsm.d.ts +2 -0
- package/dist/drafts/draft07/subscription-fsm.d.ts.map +1 -0
- package/dist/drafts/draft07/subscription-fsm.js +2 -0
- package/dist/drafts/draft07/subscription-fsm.js.map +1 -0
- package/dist/drafts/draft07/types.d.ts +61 -0
- package/dist/drafts/draft07/types.d.ts.map +1 -0
- package/dist/drafts/draft07/types.js +4 -0
- package/dist/drafts/draft07/types.js.map +1 -0
- package/dist/drafts/draft07/varint.d.ts +4 -0
- package/dist/drafts/draft07/varint.d.ts.map +1 -0
- package/dist/drafts/draft07/varint.js +22 -0
- package/dist/drafts/draft07/varint.js.map +1 -0
- package/dist/drafts/draft08/codec.d.ts +29 -0
- package/dist/drafts/draft08/codec.d.ts.map +1 -0
- package/dist/drafts/draft08/codec.js +729 -0
- package/dist/drafts/draft08/codec.js.map +1 -0
- package/dist/drafts/draft08/data-streams.d.ts +12 -0
- package/dist/drafts/draft08/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft08/data-streams.js +345 -0
- package/dist/drafts/draft08/data-streams.js.map +1 -0
- package/dist/drafts/draft08/index.d.ts +9 -0
- package/dist/drafts/draft08/index.d.ts.map +1 -0
- package/dist/drafts/draft08/index.js +7 -0
- package/dist/drafts/draft08/index.js.map +1 -0
- package/dist/drafts/draft08/messages.d.ts +34 -0
- package/dist/drafts/draft08/messages.d.ts.map +1 -0
- package/dist/drafts/draft08/messages.js +66 -0
- package/dist/drafts/draft08/messages.js.map +1 -0
- package/dist/drafts/draft08/rules.d.ts +8 -0
- package/dist/drafts/draft08/rules.d.ts.map +1 -0
- package/dist/drafts/draft08/rules.js +83 -0
- package/dist/drafts/draft08/rules.js.map +1 -0
- package/dist/drafts/draft08/session-fsm.d.ts +47 -0
- package/dist/drafts/draft08/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft08/session-fsm.js +483 -0
- package/dist/drafts/draft08/session-fsm.js.map +1 -0
- package/dist/drafts/draft08/session.d.ts +5 -0
- package/dist/drafts/draft08/session.d.ts.map +1 -0
- package/dist/drafts/draft08/session.js +5 -0
- package/dist/drafts/draft08/session.js.map +1 -0
- package/dist/drafts/draft08/types.d.ts +268 -0
- package/dist/drafts/draft08/types.d.ts.map +1 -0
- package/dist/drafts/draft08/types.js +4 -0
- package/dist/drafts/draft08/types.js.map +1 -0
- package/dist/drafts/draft09/codec.d.ts +21 -0
- package/dist/drafts/draft09/codec.d.ts.map +1 -0
- package/dist/drafts/draft09/codec.js +721 -0
- package/dist/drafts/draft09/codec.js.map +1 -0
- package/dist/drafts/draft09/data-streams.d.ts +12 -0
- package/dist/drafts/draft09/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft09/data-streams.js +307 -0
- package/dist/drafts/draft09/data-streams.js.map +1 -0
- package/dist/drafts/draft09/index.d.ts +9 -0
- package/dist/drafts/draft09/index.d.ts.map +1 -0
- package/dist/drafts/draft09/index.js +7 -0
- package/dist/drafts/draft09/index.js.map +1 -0
- package/dist/drafts/draft09/messages.d.ts +34 -0
- package/dist/drafts/draft09/messages.d.ts.map +1 -0
- package/dist/drafts/draft09/messages.js +66 -0
- package/dist/drafts/draft09/messages.js.map +1 -0
- package/dist/drafts/draft09/rules.d.ts +8 -0
- package/dist/drafts/draft09/rules.d.ts.map +1 -0
- package/dist/drafts/draft09/rules.js +83 -0
- package/dist/drafts/draft09/rules.js.map +1 -0
- package/dist/drafts/draft09/session-fsm.d.ts +47 -0
- package/dist/drafts/draft09/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft09/session-fsm.js +483 -0
- package/dist/drafts/draft09/session-fsm.js.map +1 -0
- package/dist/drafts/draft09/session.d.ts +5 -0
- package/dist/drafts/draft09/session.d.ts.map +1 -0
- package/dist/drafts/draft09/session.js +5 -0
- package/dist/drafts/draft09/session.js.map +1 -0
- package/dist/drafts/draft09/types.d.ts +268 -0
- package/dist/drafts/draft09/types.d.ts.map +1 -0
- package/dist/drafts/draft09/types.js +4 -0
- package/dist/drafts/draft09/types.js.map +1 -0
- package/dist/drafts/draft10/codec.d.ts +21 -0
- package/dist/drafts/draft10/codec.d.ts.map +1 -0
- package/dist/drafts/draft10/codec.js +721 -0
- package/dist/drafts/draft10/codec.js.map +1 -0
- package/dist/drafts/draft10/data-streams.d.ts +12 -0
- package/dist/drafts/draft10/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft10/data-streams.js +307 -0
- package/dist/drafts/draft10/data-streams.js.map +1 -0
- package/dist/drafts/draft10/index.d.ts +9 -0
- package/dist/drafts/draft10/index.d.ts.map +1 -0
- package/dist/drafts/draft10/index.js +7 -0
- package/dist/drafts/draft10/index.js.map +1 -0
- package/dist/drafts/draft10/messages.d.ts +34 -0
- package/dist/drafts/draft10/messages.d.ts.map +1 -0
- package/dist/drafts/draft10/messages.js +66 -0
- package/dist/drafts/draft10/messages.js.map +1 -0
- package/dist/drafts/draft10/rules.d.ts +8 -0
- package/dist/drafts/draft10/rules.d.ts.map +1 -0
- package/dist/drafts/draft10/rules.js +83 -0
- package/dist/drafts/draft10/rules.js.map +1 -0
- package/dist/drafts/draft10/session-fsm.d.ts +47 -0
- package/dist/drafts/draft10/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft10/session-fsm.js +483 -0
- package/dist/drafts/draft10/session-fsm.js.map +1 -0
- package/dist/drafts/draft10/session.d.ts +5 -0
- package/dist/drafts/draft10/session.d.ts.map +1 -0
- package/dist/drafts/draft10/session.js +5 -0
- package/dist/drafts/draft10/session.js.map +1 -0
- package/dist/drafts/draft10/types.d.ts +268 -0
- package/dist/drafts/draft10/types.d.ts.map +1 -0
- package/dist/drafts/draft10/types.js +4 -0
- package/dist/drafts/draft10/types.js.map +1 -0
- package/dist/drafts/draft11/codec.d.ts +25 -0
- package/dist/drafts/draft11/codec.d.ts.map +1 -0
- package/dist/drafts/draft11/codec.js +775 -0
- package/dist/drafts/draft11/codec.js.map +1 -0
- package/dist/drafts/draft11/data-streams.d.ts +10 -0
- package/dist/drafts/draft11/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft11/data-streams.js +253 -0
- package/dist/drafts/draft11/data-streams.js.map +1 -0
- package/dist/drafts/draft11/index.d.ts +9 -0
- package/dist/drafts/draft11/index.d.ts.map +1 -0
- package/dist/drafts/draft11/index.js +7 -0
- package/dist/drafts/draft11/index.js.map +1 -0
- package/dist/drafts/draft11/messages.d.ts +33 -0
- package/dist/drafts/draft11/messages.d.ts.map +1 -0
- package/dist/drafts/draft11/messages.js +65 -0
- package/dist/drafts/draft11/messages.js.map +1 -0
- package/dist/drafts/draft11/rules.d.ts +8 -0
- package/dist/drafts/draft11/rules.d.ts.map +1 -0
- package/dist/drafts/draft11/rules.js +88 -0
- package/dist/drafts/draft11/rules.js.map +1 -0
- package/dist/drafts/draft11/session-fsm.d.ts +52 -0
- package/dist/drafts/draft11/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft11/session-fsm.js +530 -0
- package/dist/drafts/draft11/session-fsm.js.map +1 -0
- package/dist/drafts/draft11/session.d.ts +5 -0
- package/dist/drafts/draft11/session.d.ts.map +1 -0
- package/dist/drafts/draft11/session.js +5 -0
- package/dist/drafts/draft11/session.js.map +1 -0
- package/dist/drafts/draft11/types.d.ts +266 -0
- package/dist/drafts/draft11/types.d.ts.map +1 -0
- package/dist/drafts/draft11/types.js +4 -0
- package/dist/drafts/draft11/types.js.map +1 -0
- package/dist/drafts/draft12/codec.d.ts +27 -0
- package/dist/drafts/draft12/codec.d.ts.map +1 -0
- package/dist/drafts/draft12/codec.js +918 -0
- package/dist/drafts/draft12/codec.js.map +1 -0
- package/dist/drafts/draft12/data-streams.d.ts +10 -0
- package/dist/drafts/draft12/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft12/data-streams.js +254 -0
- package/dist/drafts/draft12/data-streams.js.map +1 -0
- package/dist/drafts/draft12/index.d.ts +9 -0
- package/dist/drafts/draft12/index.d.ts.map +1 -0
- package/dist/drafts/draft12/index.js +7 -0
- package/dist/drafts/draft12/index.js.map +1 -0
- package/dist/drafts/draft12/messages.d.ts +37 -0
- package/dist/drafts/draft12/messages.d.ts.map +1 -0
- package/dist/drafts/draft12/messages.js +77 -0
- package/dist/drafts/draft12/messages.js.map +1 -0
- package/dist/drafts/draft12/rules.d.ts +8 -0
- package/dist/drafts/draft12/rules.d.ts.map +1 -0
- package/dist/drafts/draft12/rules.js +94 -0
- package/dist/drafts/draft12/rules.js.map +1 -0
- package/dist/drafts/draft12/session-fsm.d.ts +55 -0
- package/dist/drafts/draft12/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft12/session-fsm.js +569 -0
- package/dist/drafts/draft12/session-fsm.js.map +1 -0
- package/dist/drafts/draft12/session.d.ts +5 -0
- package/dist/drafts/draft12/session.d.ts.map +1 -0
- package/dist/drafts/draft12/session.js +5 -0
- package/dist/drafts/draft12/session.js.map +1 -0
- package/dist/drafts/draft12/types.d.ts +294 -0
- package/dist/drafts/draft12/types.d.ts.map +1 -0
- package/dist/drafts/draft12/types.js +4 -0
- package/dist/drafts/draft12/types.js.map +1 -0
- package/dist/drafts/draft13/codec.d.ts +27 -0
- package/dist/drafts/draft13/codec.d.ts.map +1 -0
- package/dist/drafts/draft13/codec.js +1000 -0
- package/dist/drafts/draft13/codec.js.map +1 -0
- package/dist/drafts/draft13/data-streams.d.ts +10 -0
- package/dist/drafts/draft13/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft13/data-streams.js +254 -0
- package/dist/drafts/draft13/data-streams.js.map +1 -0
- package/dist/drafts/draft13/index.d.ts +9 -0
- package/dist/drafts/draft13/index.d.ts.map +1 -0
- package/dist/drafts/draft13/index.js +7 -0
- package/dist/drafts/draft13/index.js.map +1 -0
- package/dist/drafts/draft13/messages.d.ts +38 -0
- package/dist/drafts/draft13/messages.d.ts.map +1 -0
- package/dist/drafts/draft13/messages.js +79 -0
- package/dist/drafts/draft13/messages.js.map +1 -0
- package/dist/drafts/draft13/rules.d.ts +8 -0
- package/dist/drafts/draft13/rules.d.ts.map +1 -0
- package/dist/drafts/draft13/rules.js +96 -0
- package/dist/drafts/draft13/rules.js.map +1 -0
- package/dist/drafts/draft13/session-fsm.d.ts +56 -0
- package/dist/drafts/draft13/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft13/session-fsm.js +581 -0
- package/dist/drafts/draft13/session-fsm.js.map +1 -0
- package/dist/drafts/draft13/session.d.ts +5 -0
- package/dist/drafts/draft13/session.d.ts.map +1 -0
- package/dist/drafts/draft13/session.js +5 -0
- package/dist/drafts/draft13/session.js.map +1 -0
- package/dist/drafts/draft13/types.d.ts +310 -0
- package/dist/drafts/draft13/types.d.ts.map +1 -0
- package/dist/drafts/draft13/types.js +4 -0
- package/dist/drafts/draft13/types.js.map +1 -0
- package/dist/drafts/draft14/codec.d.ts +34 -0
- package/dist/drafts/draft14/codec.d.ts.map +1 -0
- package/dist/drafts/draft14/codec.js +752 -0
- package/dist/drafts/draft14/codec.js.map +1 -0
- package/dist/drafts/draft14/data-streams.d.ts +56 -0
- package/dist/drafts/draft14/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft14/data-streams.js +729 -0
- package/dist/drafts/draft14/data-streams.js.map +1 -0
- package/dist/drafts/draft14/index.d.ts +9 -0
- package/dist/drafts/draft14/index.d.ts.map +1 -0
- package/dist/drafts/draft14/index.js +7 -0
- package/dist/drafts/draft14/index.js.map +1 -0
- package/dist/drafts/draft14/messages.d.ts +36 -0
- package/dist/drafts/draft14/messages.d.ts.map +1 -0
- package/dist/drafts/draft14/messages.js +71 -0
- package/dist/drafts/draft14/messages.js.map +1 -0
- package/dist/drafts/draft14/rules.d.ts +8 -0
- package/dist/drafts/draft14/rules.d.ts.map +1 -0
- package/dist/drafts/draft14/rules.js +101 -0
- package/dist/drafts/draft14/rules.js.map +1 -0
- package/dist/drafts/draft14/session-fsm.d.ts +58 -0
- package/dist/drafts/draft14/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft14/session-fsm.js +648 -0
- package/dist/drafts/draft14/session-fsm.js.map +1 -0
- package/dist/drafts/draft14/session.d.ts +5 -0
- package/dist/drafts/draft14/session.d.ts.map +1 -0
- package/dist/drafts/draft14/session.js +5 -0
- package/dist/drafts/draft14/session.js.map +1 -0
- package/dist/drafts/draft14/types.d.ts +263 -0
- package/dist/drafts/draft14/types.d.ts.map +1 -0
- package/dist/drafts/draft14/types.js +4 -0
- package/dist/drafts/draft14/types.js.map +1 -0
- package/dist/drafts/draft15/codec.d.ts +33 -0
- package/dist/drafts/draft15/codec.d.ts.map +1 -0
- package/dist/drafts/draft15/codec.js +742 -0
- package/dist/drafts/draft15/codec.js.map +1 -0
- package/dist/drafts/draft15/data-streams.d.ts +45 -0
- package/dist/drafts/draft15/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft15/data-streams.js +675 -0
- package/dist/drafts/draft15/data-streams.js.map +1 -0
- package/dist/drafts/draft15/index.d.ts +9 -0
- package/dist/drafts/draft15/index.d.ts.map +1 -0
- package/dist/drafts/draft15/index.js +7 -0
- package/dist/drafts/draft15/index.js.map +1 -0
- package/dist/drafts/draft15/messages.d.ts +31 -0
- package/dist/drafts/draft15/messages.d.ts.map +1 -0
- package/dist/drafts/draft15/messages.js +59 -0
- package/dist/drafts/draft15/messages.js.map +1 -0
- package/dist/drafts/draft15/rules.d.ts +8 -0
- package/dist/drafts/draft15/rules.d.ts.map +1 -0
- package/dist/drafts/draft15/rules.js +83 -0
- package/dist/drafts/draft15/rules.js.map +1 -0
- package/dist/drafts/draft15/session-fsm.d.ts +48 -0
- package/dist/drafts/draft15/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft15/session-fsm.js +479 -0
- package/dist/drafts/draft15/session-fsm.js.map +1 -0
- package/dist/drafts/draft15/session.d.ts +5 -0
- package/dist/drafts/draft15/session.d.ts.map +1 -0
- package/dist/drafts/draft15/session.js +5 -0
- package/dist/drafts/draft15/session.js.map +1 -0
- package/dist/drafts/draft15/types.d.ts +232 -0
- package/dist/drafts/draft15/types.d.ts.map +1 -0
- package/dist/drafts/draft15/types.js +4 -0
- package/dist/drafts/draft15/types.js.map +1 -0
- package/dist/drafts/draft16/codec.d.ts +29 -0
- package/dist/drafts/draft16/codec.d.ts.map +1 -0
- package/dist/drafts/draft16/codec.js +747 -0
- package/dist/drafts/draft16/codec.js.map +1 -0
- package/dist/drafts/draft16/data-streams.d.ts +34 -0
- package/dist/drafts/draft16/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft16/data-streams.js +667 -0
- package/dist/drafts/draft16/data-streams.js.map +1 -0
- package/dist/drafts/draft16/index.d.ts +9 -0
- package/dist/drafts/draft16/index.d.ts.map +1 -0
- package/dist/drafts/draft16/index.js +7 -0
- package/dist/drafts/draft16/index.js.map +1 -0
- package/dist/drafts/draft16/messages.d.ts +32 -0
- package/dist/drafts/draft16/messages.d.ts.map +1 -0
- package/dist/drafts/draft16/messages.js +62 -0
- package/dist/drafts/draft16/messages.js.map +1 -0
- package/dist/drafts/draft16/rules.d.ts +8 -0
- package/dist/drafts/draft16/rules.d.ts.map +1 -0
- package/dist/drafts/draft16/rules.js +84 -0
- package/dist/drafts/draft16/rules.js.map +1 -0
- package/dist/drafts/draft16/session-fsm.d.ts +48 -0
- package/dist/drafts/draft16/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft16/session-fsm.js +474 -0
- package/dist/drafts/draft16/session-fsm.js.map +1 -0
- package/dist/drafts/draft16/session.d.ts +5 -0
- package/dist/drafts/draft16/session.d.ts.map +1 -0
- package/dist/drafts/draft16/session.js +5 -0
- package/dist/drafts/draft16/session.js.map +1 -0
- package/dist/drafts/draft16/types.d.ts +238 -0
- package/dist/drafts/draft16/types.d.ts.map +1 -0
- package/dist/drafts/draft16/types.js +4 -0
- package/dist/drafts/draft16/types.js.map +1 -0
- package/dist/drafts/draft17/codec.d.ts +29 -0
- package/dist/drafts/draft17/codec.d.ts.map +1 -0
- package/dist/drafts/draft17/codec.js +799 -0
- package/dist/drafts/draft17/codec.js.map +1 -0
- package/dist/drafts/draft17/data-streams.d.ts +13 -0
- package/dist/drafts/draft17/data-streams.d.ts.map +1 -0
- package/dist/drafts/draft17/data-streams.js +633 -0
- package/dist/drafts/draft17/data-streams.js.map +1 -0
- package/dist/drafts/draft17/index.d.ts +8 -0
- package/dist/drafts/draft17/index.d.ts.map +1 -0
- package/dist/drafts/draft17/index.js +6 -0
- package/dist/drafts/draft17/index.js.map +1 -0
- package/dist/drafts/draft17/messages.d.ts +25 -0
- package/dist/drafts/draft17/messages.d.ts.map +1 -0
- package/dist/drafts/draft17/messages.js +48 -0
- package/dist/drafts/draft17/messages.js.map +1 -0
- package/dist/drafts/draft17/rules.d.ts +8 -0
- package/dist/drafts/draft17/rules.d.ts.map +1 -0
- package/dist/drafts/draft17/rules.js +71 -0
- package/dist/drafts/draft17/rules.js.map +1 -0
- package/dist/drafts/draft17/session-fsm.d.ts +45 -0
- package/dist/drafts/draft17/session-fsm.d.ts.map +1 -0
- package/dist/drafts/draft17/session-fsm.js +328 -0
- package/dist/drafts/draft17/session-fsm.js.map +1 -0
- package/dist/drafts/draft17/session.d.ts +5 -0
- package/dist/drafts/draft17/session.d.ts.map +1 -0
- package/dist/drafts/draft17/session.js +6 -0
- package/dist/drafts/draft17/session.js.map +1 -0
- package/dist/drafts/draft17/types.d.ts +219 -0
- package/dist/drafts/draft17/types.d.ts.map +1 -0
- package/dist/drafts/draft17/types.js +3 -0
- package/dist/drafts/draft17/types.js.map +1 -0
- package/dist/index.cjs +76 -4
- package/dist/index.d.cts +68 -5
- package/dist/index.d.ts +82 -11
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +93 -38
- package/dist/index.js.map +1 -0
- package/dist/{session-types-DFjMk4HH.d.ts → session-types-CJIFbTPd.d.ts} +1 -1
- package/dist/{session-types-DW1RSZX_.d.cts → session-types-Cbq8IGCP.d.cts} +1 -1
- package/dist/session.cjs +5 -5
- package/dist/session.d.cts +3 -3
- package/dist/session.d.ts +4 -8
- package/dist/session.d.ts.map +1 -0
- package/dist/session.js +32 -26
- package/dist/session.js.map +1 -0
- package/dist/types-4VxSL2Ho.d.cts +261 -0
- package/dist/types-4VxSL2Ho.d.ts +261 -0
- package/dist/types-B2afJZM-.d.cts +236 -0
- package/dist/types-B2afJZM-.d.ts +236 -0
- package/dist/types-Bg6QYNVt.d.cts +290 -0
- package/dist/types-Bg6QYNVt.d.ts +290 -0
- package/dist/types-C_1HrqBl.d.cts +306 -0
- package/dist/types-C_1HrqBl.d.ts +306 -0
- package/dist/types-Cw4WE9dh.d.cts +261 -0
- package/dist/types-Cw4WE9dh.d.ts +261 -0
- package/dist/types-D5gNQiDj.d.cts +261 -0
- package/dist/types-D5gNQiDj.d.ts +261 -0
- package/dist/types-DqCDFqgB.d.cts +230 -0
- package/dist/types-DqCDFqgB.d.ts +230 -0
- package/dist/types-ERexTpT8.d.cts +217 -0
- package/dist/types-ERexTpT8.d.ts +217 -0
- package/dist/{types-DPYE49t0.d.cts → types-QNXoxC9Y.d.cts} +2 -7
- package/dist/{types-DPYE49t0.d.ts → types-QNXoxC9Y.d.ts} +2 -7
- package/dist/types-r-CasCf1.d.cts +262 -0
- package/dist/types-r-CasCf1.d.ts +262 -0
- package/package.json +192 -84
- package/src/core/buffer-reader.ts +1 -1
- package/src/core/hex.ts +17 -0
- package/src/core/types.ts +24 -7
- package/src/drafts/draft07/codec.ts +933 -983
- package/src/drafts/draft07/data-streams.ts +240 -0
- package/src/drafts/draft07/index.ts +89 -69
- package/src/drafts/draft07/messages.ts +42 -44
- package/src/drafts/draft07/rules.ts +101 -106
- package/src/drafts/draft07/types.ts +72 -0
- package/src/drafts/draft08/codec.ts +944 -0
- package/src/drafts/draft08/data-streams.ts +359 -0
- package/src/drafts/draft08/index.ts +125 -0
- package/src/drafts/draft08/messages.ts +72 -0
- package/src/drafts/draft08/rules.ts +91 -0
- package/src/drafts/draft08/session-fsm.ts +718 -0
- package/src/drafts/draft08/session.ts +26 -0
- package/src/drafts/draft08/types.ts +384 -0
- package/src/drafts/draft09/codec.ts +936 -0
- package/src/drafts/draft09/data-streams.ts +332 -0
- package/src/drafts/draft09/index.ts +125 -0
- package/src/drafts/draft09/messages.ts +72 -0
- package/src/drafts/draft09/rules.ts +91 -0
- package/src/drafts/draft09/session-fsm.ts +718 -0
- package/src/drafts/draft09/session.ts +26 -0
- package/src/drafts/draft09/types.ts +384 -0
- package/src/drafts/draft10/codec.ts +936 -0
- package/src/drafts/draft10/data-streams.ts +332 -0
- package/src/drafts/draft10/index.ts +125 -0
- package/src/drafts/draft10/messages.ts +72 -0
- package/src/drafts/draft10/rules.ts +91 -0
- package/src/drafts/draft10/session-fsm.ts +718 -0
- package/src/drafts/draft10/session.ts +26 -0
- package/src/drafts/draft10/types.ts +384 -0
- package/src/drafts/draft11/codec.ts +969 -0
- package/src/drafts/draft11/data-streams.ts +269 -0
- package/src/drafts/draft11/index.ts +123 -0
- package/src/drafts/draft11/messages.ts +71 -0
- package/src/drafts/draft11/rules.ts +100 -0
- package/src/drafts/draft11/session-fsm.ts +758 -0
- package/src/drafts/draft11/session.ts +26 -0
- package/src/drafts/draft11/types.ts +381 -0
- package/src/drafts/draft12/codec.ts +1126 -0
- package/src/drafts/draft12/data-streams.ts +275 -0
- package/src/drafts/draft12/index.ts +130 -0
- package/src/drafts/draft12/messages.ts +84 -0
- package/src/drafts/draft12/rules.ts +106 -0
- package/src/drafts/draft12/session-fsm.ts +805 -0
- package/src/drafts/draft12/session.ts +26 -0
- package/src/drafts/draft12/types.ts +419 -0
- package/src/drafts/draft13/codec.ts +1210 -0
- package/src/drafts/draft13/data-streams.ts +275 -0
- package/src/drafts/draft13/index.ts +132 -0
- package/src/drafts/draft13/messages.ts +86 -0
- package/src/drafts/draft13/rules.ts +108 -0
- package/src/drafts/draft13/session-fsm.ts +819 -0
- package/src/drafts/draft13/session.ts +26 -0
- package/src/drafts/draft13/types.ts +438 -0
- package/src/drafts/draft14/codec.ts +1034 -1480
- package/src/drafts/draft14/data-streams.ts +798 -0
- package/src/drafts/draft14/session-fsm.ts +182 -1
- package/src/drafts/draft14/types.ts +381 -365
- package/src/drafts/draft15/codec.ts +969 -0
- package/src/drafts/draft15/data-streams.ts +778 -0
- package/src/drafts/draft15/index.ts +121 -0
- package/src/drafts/draft15/messages.ts +64 -0
- package/src/drafts/draft15/rules.ts +95 -0
- package/src/drafts/draft15/session-fsm.ts +687 -0
- package/src/drafts/draft15/session.ts +26 -0
- package/src/drafts/draft15/types.ts +339 -0
- package/src/drafts/draft16/codec.ts +957 -0
- package/src/drafts/draft16/data-streams.ts +773 -0
- package/src/drafts/draft16/index.ts +123 -0
- package/src/drafts/draft16/messages.ts +67 -0
- package/src/drafts/draft16/rules.ts +96 -0
- package/src/drafts/draft16/session-fsm.ts +682 -0
- package/src/drafts/draft16/session.ts +26 -0
- package/src/drafts/draft16/types.ts +357 -0
- package/src/drafts/draft17/codec.ts +962 -0
- package/src/drafts/draft17/data-streams.ts +742 -0
- package/src/drafts/draft17/index.ts +105 -0
- package/src/drafts/draft17/messages.ts +53 -0
- package/src/drafts/draft17/rules.ts +85 -0
- package/src/drafts/draft17/session-fsm.ts +437 -0
- package/src/drafts/draft17/session.ts +15 -0
- package/src/drafts/draft17/types.ts +313 -0
- package/src/index.ts +217 -2
|
@@ -0,0 +1,752 @@
|
|
|
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_ERROR, MSG_FETCH_OK, MSG_GOAWAY, MSG_MAX_REQUEST_ID, MSG_PUBLISH, MSG_PUBLISH_DONE, MSG_PUBLISH_ERROR, MSG_PUBLISH_NAMESPACE, MSG_PUBLISH_NAMESPACE_CANCEL, MSG_PUBLISH_NAMESPACE_DONE, MSG_PUBLISH_NAMESPACE_ERROR, MSG_PUBLISH_NAMESPACE_OK, MSG_PUBLISH_OK, MSG_REQUESTS_BLOCKED, MSG_SERVER_SETUP, MSG_SUBSCRIBE, 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_UNSUBSCRIBE, MSG_UNSUBSCRIBE_NAMESPACE, PARAM_MAX_REQUEST_ID, PARAM_PATH, PARAM_ROLE, } from "./messages.js";
|
|
6
|
+
// ─── Parameter Encoding/Decoding ───────────────────────────────────────────────
|
|
7
|
+
function encodeParams(params, writer) {
|
|
8
|
+
// Count total params
|
|
9
|
+
let count = 0;
|
|
10
|
+
if (params.role !== undefined)
|
|
11
|
+
count++;
|
|
12
|
+
if (params.path !== undefined)
|
|
13
|
+
count++;
|
|
14
|
+
if (params.max_request_id !== undefined)
|
|
15
|
+
count++;
|
|
16
|
+
if (params.unknown)
|
|
17
|
+
count += params.unknown.length;
|
|
18
|
+
writer.writeVarInt(count);
|
|
19
|
+
// ROLE (0x00) - even, varint value
|
|
20
|
+
if (params.role !== undefined) {
|
|
21
|
+
writer.writeVarInt(PARAM_ROLE);
|
|
22
|
+
writer.writeVarInt(params.role);
|
|
23
|
+
}
|
|
24
|
+
// PATH (0x01) - odd, length-prefixed bytes
|
|
25
|
+
if (params.path !== undefined) {
|
|
26
|
+
writer.writeVarInt(PARAM_PATH);
|
|
27
|
+
const encoded = new TextEncoder().encode(params.path);
|
|
28
|
+
writer.writeVarInt(encoded.byteLength);
|
|
29
|
+
writer.writeBytes(encoded);
|
|
30
|
+
}
|
|
31
|
+
// MAX_REQUEST_ID (0x02) - even, varint value
|
|
32
|
+
if (params.max_request_id !== undefined) {
|
|
33
|
+
writer.writeVarInt(PARAM_MAX_REQUEST_ID);
|
|
34
|
+
writer.writeVarInt(params.max_request_id);
|
|
35
|
+
}
|
|
36
|
+
// Unknown params
|
|
37
|
+
if (params.unknown) {
|
|
38
|
+
for (const u of params.unknown) {
|
|
39
|
+
const id = BigInt(u.id);
|
|
40
|
+
writer.writeVarInt(id);
|
|
41
|
+
const raw = hexToBytes(u.raw_hex);
|
|
42
|
+
writer.writeVarInt(raw.byteLength);
|
|
43
|
+
writer.writeBytes(raw);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
function decodeParams(reader) {
|
|
48
|
+
const count = Number(reader.readVarInt());
|
|
49
|
+
const result = {};
|
|
50
|
+
const unknown = [];
|
|
51
|
+
for (let i = 0; i < count; i++) {
|
|
52
|
+
const paramType = reader.readVarInt();
|
|
53
|
+
if (paramType % 2n === 0n) {
|
|
54
|
+
// Even: value is a varint directly
|
|
55
|
+
const value = reader.readVarInt();
|
|
56
|
+
if (paramType === PARAM_ROLE) {
|
|
57
|
+
result.role = value;
|
|
58
|
+
}
|
|
59
|
+
else if (paramType === PARAM_MAX_REQUEST_ID) {
|
|
60
|
+
result.max_request_id = value;
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
// Unknown even param — encode the varint value as raw bytes
|
|
64
|
+
const tmpWriter = new BufferWriter(16);
|
|
65
|
+
tmpWriter.writeVarInt(value);
|
|
66
|
+
const raw = tmpWriter.finish();
|
|
67
|
+
unknown.push({
|
|
68
|
+
id: `0x${paramType.toString(16)}`,
|
|
69
|
+
length: raw.byteLength,
|
|
70
|
+
raw_hex: bytesToHex(raw),
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
// Odd: value is length-prefixed bytes
|
|
76
|
+
const length = Number(reader.readVarInt());
|
|
77
|
+
const bytes = reader.readBytes(length);
|
|
78
|
+
if (paramType === PARAM_PATH) {
|
|
79
|
+
result.path = new TextDecoder().decode(bytes);
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
unknown.push({
|
|
83
|
+
id: `0x${paramType.toString(16)}`,
|
|
84
|
+
length,
|
|
85
|
+
raw_hex: bytesToHex(bytes),
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
if (unknown.length > 0) {
|
|
91
|
+
result.unknown = unknown;
|
|
92
|
+
}
|
|
93
|
+
return result;
|
|
94
|
+
}
|
|
95
|
+
// ─── Payload Encoders ──────────────────────────────────────────────────────────
|
|
96
|
+
function encodeClientSetupPayload(msg, w) {
|
|
97
|
+
w.writeVarInt(msg.supported_versions.length);
|
|
98
|
+
for (const v of msg.supported_versions) {
|
|
99
|
+
w.writeVarInt(v);
|
|
100
|
+
}
|
|
101
|
+
encodeParams(msg.parameters, w);
|
|
102
|
+
}
|
|
103
|
+
function encodeServerSetupPayload(msg, w) {
|
|
104
|
+
w.writeVarInt(msg.selected_version);
|
|
105
|
+
encodeParams(msg.parameters, w);
|
|
106
|
+
}
|
|
107
|
+
function encodeSubscribePayload(msg, w) {
|
|
108
|
+
w.writeVarInt(msg.request_id);
|
|
109
|
+
w.writeTuple(msg.track_namespace);
|
|
110
|
+
w.writeString(msg.track_name);
|
|
111
|
+
w.writeUint8(Number(msg.subscriber_priority));
|
|
112
|
+
w.writeVarInt(msg.group_order);
|
|
113
|
+
w.writeVarInt(msg.forward);
|
|
114
|
+
w.writeVarInt(msg.filter_type);
|
|
115
|
+
const ft = Number(msg.filter_type);
|
|
116
|
+
if (ft >= 3) {
|
|
117
|
+
w.writeVarInt(msg.start_group);
|
|
118
|
+
w.writeVarInt(msg.start_object);
|
|
119
|
+
}
|
|
120
|
+
if (ft === 4) {
|
|
121
|
+
w.writeVarInt(msg.end_group);
|
|
122
|
+
}
|
|
123
|
+
encodeParams(msg.parameters, w);
|
|
124
|
+
}
|
|
125
|
+
function encodeSubscribeOkPayload(msg, w) {
|
|
126
|
+
w.writeVarInt(msg.request_id);
|
|
127
|
+
w.writeVarInt(msg.track_alias);
|
|
128
|
+
w.writeVarInt(msg.expires);
|
|
129
|
+
w.writeVarInt(msg.group_order);
|
|
130
|
+
w.writeVarInt(msg.content_exists);
|
|
131
|
+
if (Number(msg.content_exists) === 1) {
|
|
132
|
+
w.writeVarInt(msg.largest_group);
|
|
133
|
+
w.writeVarInt(msg.largest_object);
|
|
134
|
+
}
|
|
135
|
+
encodeParams(msg.parameters, w);
|
|
136
|
+
}
|
|
137
|
+
function encodeSubscribeUpdatePayload(msg, w) {
|
|
138
|
+
w.writeVarInt(msg.request_id);
|
|
139
|
+
w.writeVarInt(msg.start_group);
|
|
140
|
+
w.writeVarInt(msg.start_object);
|
|
141
|
+
w.writeVarInt(msg.end_group);
|
|
142
|
+
w.writeUint8(Number(msg.subscriber_priority));
|
|
143
|
+
w.writeVarInt(msg.forward);
|
|
144
|
+
encodeParams(msg.parameters, w);
|
|
145
|
+
}
|
|
146
|
+
function encodeSubscribeErrorPayload(msg, w) {
|
|
147
|
+
w.writeVarInt(msg.request_id);
|
|
148
|
+
w.writeVarInt(msg.error_code);
|
|
149
|
+
w.writeString(msg.reason_phrase);
|
|
150
|
+
}
|
|
151
|
+
function encodeUnsubscribePayload(msg, w) {
|
|
152
|
+
w.writeVarInt(msg.request_id);
|
|
153
|
+
}
|
|
154
|
+
function encodePublishPayload(msg, w) {
|
|
155
|
+
w.writeVarInt(msg.request_id);
|
|
156
|
+
w.writeTuple(msg.track_namespace);
|
|
157
|
+
w.writeString(msg.track_name);
|
|
158
|
+
w.writeVarInt(msg.forward);
|
|
159
|
+
encodeParams(msg.parameters, w);
|
|
160
|
+
}
|
|
161
|
+
function encodePublishOkPayload(msg, w) {
|
|
162
|
+
w.writeVarInt(msg.request_id);
|
|
163
|
+
w.writeVarInt(msg.track_alias);
|
|
164
|
+
w.writeVarInt(msg.forward);
|
|
165
|
+
encodeParams(msg.parameters, w);
|
|
166
|
+
}
|
|
167
|
+
function encodePublishErrorPayload(msg, w) {
|
|
168
|
+
w.writeVarInt(msg.request_id);
|
|
169
|
+
w.writeVarInt(msg.error_code);
|
|
170
|
+
w.writeString(msg.reason_phrase);
|
|
171
|
+
}
|
|
172
|
+
function encodePublishDonePayload(msg, w) {
|
|
173
|
+
w.writeVarInt(msg.request_id);
|
|
174
|
+
w.writeVarInt(msg.status_code);
|
|
175
|
+
w.writeString(msg.reason_phrase);
|
|
176
|
+
}
|
|
177
|
+
function encodePublishNamespacePayload(msg, w) {
|
|
178
|
+
w.writeVarInt(msg.request_id);
|
|
179
|
+
w.writeTuple(msg.track_namespace);
|
|
180
|
+
encodeParams(msg.parameters, w);
|
|
181
|
+
}
|
|
182
|
+
function encodePublishNamespaceOkPayload(msg, w) {
|
|
183
|
+
w.writeVarInt(msg.request_id);
|
|
184
|
+
encodeParams(msg.parameters, w);
|
|
185
|
+
}
|
|
186
|
+
function encodePublishNamespaceErrorPayload(msg, w) {
|
|
187
|
+
w.writeVarInt(msg.request_id);
|
|
188
|
+
w.writeVarInt(msg.error_code);
|
|
189
|
+
w.writeString(msg.reason_phrase);
|
|
190
|
+
}
|
|
191
|
+
function encodePublishNamespaceDonePayload(msg, w) {
|
|
192
|
+
w.writeVarInt(msg.request_id);
|
|
193
|
+
w.writeVarInt(msg.status_code);
|
|
194
|
+
w.writeString(msg.reason_phrase);
|
|
195
|
+
}
|
|
196
|
+
function encodePublishNamespaceCancelPayload(msg, w) {
|
|
197
|
+
w.writeVarInt(msg.request_id);
|
|
198
|
+
}
|
|
199
|
+
function encodeSubscribeNamespacePayload(msg, w) {
|
|
200
|
+
w.writeVarInt(msg.request_id);
|
|
201
|
+
w.writeTuple(msg.namespace_prefix);
|
|
202
|
+
encodeParams(msg.parameters, w);
|
|
203
|
+
}
|
|
204
|
+
function encodeSubscribeNamespaceOkPayload(msg, w) {
|
|
205
|
+
w.writeVarInt(msg.request_id);
|
|
206
|
+
encodeParams(msg.parameters, w);
|
|
207
|
+
}
|
|
208
|
+
function encodeSubscribeNamespaceErrorPayload(msg, w) {
|
|
209
|
+
w.writeVarInt(msg.request_id);
|
|
210
|
+
w.writeVarInt(msg.error_code);
|
|
211
|
+
w.writeString(msg.reason_phrase);
|
|
212
|
+
}
|
|
213
|
+
function encodeUnsubscribeNamespacePayload(msg, w) {
|
|
214
|
+
w.writeVarInt(msg.request_id);
|
|
215
|
+
}
|
|
216
|
+
function encodeFetchPayload(msg, w) {
|
|
217
|
+
w.writeVarInt(msg.request_id);
|
|
218
|
+
w.writeTuple(msg.track_namespace);
|
|
219
|
+
w.writeString(msg.track_name);
|
|
220
|
+
w.writeVarInt(msg.start_group);
|
|
221
|
+
w.writeVarInt(msg.start_object);
|
|
222
|
+
w.writeVarInt(msg.end_group);
|
|
223
|
+
encodeParams(msg.parameters, w);
|
|
224
|
+
}
|
|
225
|
+
function encodeFetchOkPayload(msg, w) {
|
|
226
|
+
w.writeVarInt(msg.request_id);
|
|
227
|
+
w.writeVarInt(msg.track_alias);
|
|
228
|
+
w.writeVarInt(msg.end_of_track);
|
|
229
|
+
encodeParams(msg.parameters, w);
|
|
230
|
+
}
|
|
231
|
+
function encodeFetchErrorPayload(msg, w) {
|
|
232
|
+
w.writeVarInt(msg.request_id);
|
|
233
|
+
w.writeVarInt(msg.error_code);
|
|
234
|
+
w.writeString(msg.reason_phrase);
|
|
235
|
+
}
|
|
236
|
+
function encodeFetchCancelPayload(msg, w) {
|
|
237
|
+
w.writeVarInt(msg.request_id);
|
|
238
|
+
}
|
|
239
|
+
function encodeTrackStatusPayload(msg, w) {
|
|
240
|
+
w.writeVarInt(msg.request_id);
|
|
241
|
+
w.writeTuple(msg.track_namespace);
|
|
242
|
+
w.writeString(msg.track_name);
|
|
243
|
+
encodeParams(msg.parameters, w);
|
|
244
|
+
}
|
|
245
|
+
function encodeTrackStatusOkPayload(msg, w) {
|
|
246
|
+
w.writeVarInt(msg.request_id);
|
|
247
|
+
w.writeVarInt(msg.status_code);
|
|
248
|
+
const sc = Number(msg.status_code);
|
|
249
|
+
if (sc === 0 || sc === 3) {
|
|
250
|
+
w.writeVarInt(msg.largest_group);
|
|
251
|
+
w.writeVarInt(msg.largest_object);
|
|
252
|
+
}
|
|
253
|
+
encodeParams(msg.parameters, w);
|
|
254
|
+
}
|
|
255
|
+
function encodeTrackStatusErrorPayload(msg, w) {
|
|
256
|
+
w.writeVarInt(msg.request_id);
|
|
257
|
+
w.writeVarInt(msg.error_code);
|
|
258
|
+
w.writeString(msg.reason_phrase);
|
|
259
|
+
}
|
|
260
|
+
function encodeGoAwayPayload(msg, w) {
|
|
261
|
+
w.writeString(msg.new_session_uri);
|
|
262
|
+
}
|
|
263
|
+
function encodeMaxRequestIdPayload(msg, w) {
|
|
264
|
+
w.writeVarInt(msg.request_id);
|
|
265
|
+
}
|
|
266
|
+
function encodeRequestsBlockedPayload(msg, w) {
|
|
267
|
+
w.writeVarInt(msg.request_id);
|
|
268
|
+
}
|
|
269
|
+
// ─── Payload Decoders ──────────────────────────────────────────────────────────
|
|
270
|
+
function decodeClientSetupPayload(r) {
|
|
271
|
+
const numVersions = Number(r.readVarInt());
|
|
272
|
+
if (numVersions === 0) {
|
|
273
|
+
throw new DecodeError("CONSTRAINT_VIOLATION", "CLIENT_SETUP must offer at least one version", r.offset);
|
|
274
|
+
}
|
|
275
|
+
const supported_versions = [];
|
|
276
|
+
for (let i = 0; i < numVersions; i++) {
|
|
277
|
+
supported_versions.push(r.readVarInt());
|
|
278
|
+
}
|
|
279
|
+
const parameters = decodeParams(r);
|
|
280
|
+
return { type: "client_setup", supported_versions, parameters };
|
|
281
|
+
}
|
|
282
|
+
function decodeServerSetupPayload(r) {
|
|
283
|
+
const selected_version = r.readVarInt();
|
|
284
|
+
const parameters = decodeParams(r);
|
|
285
|
+
return { type: "server_setup", selected_version, parameters };
|
|
286
|
+
}
|
|
287
|
+
function decodeSubscribePayload(r) {
|
|
288
|
+
const request_id = r.readVarInt();
|
|
289
|
+
const track_namespace = r.readTuple();
|
|
290
|
+
const track_name = r.readString();
|
|
291
|
+
const subscriber_priority = BigInt(r.readUint8());
|
|
292
|
+
const group_order = r.readVarInt();
|
|
293
|
+
const forward = r.readVarInt();
|
|
294
|
+
const filter_type = r.readVarInt();
|
|
295
|
+
const ft = Number(filter_type);
|
|
296
|
+
if (ft < 1 || ft > 4) {
|
|
297
|
+
throw new DecodeError("CONSTRAINT_VIOLATION", `Invalid filter_type: ${ft}`, r.offset);
|
|
298
|
+
}
|
|
299
|
+
let start_group;
|
|
300
|
+
let start_object;
|
|
301
|
+
let end_group;
|
|
302
|
+
if (ft >= 3) {
|
|
303
|
+
start_group = r.readVarInt();
|
|
304
|
+
start_object = r.readVarInt();
|
|
305
|
+
}
|
|
306
|
+
if (ft === 4) {
|
|
307
|
+
end_group = r.readVarInt();
|
|
308
|
+
}
|
|
309
|
+
const parameters = decodeParams(r);
|
|
310
|
+
const msg = {
|
|
311
|
+
type: "subscribe",
|
|
312
|
+
request_id,
|
|
313
|
+
track_namespace,
|
|
314
|
+
track_name,
|
|
315
|
+
subscriber_priority,
|
|
316
|
+
group_order,
|
|
317
|
+
forward,
|
|
318
|
+
filter_type,
|
|
319
|
+
parameters,
|
|
320
|
+
};
|
|
321
|
+
if (start_group !== undefined) {
|
|
322
|
+
return { ...msg, start_group, start_object, end_group };
|
|
323
|
+
}
|
|
324
|
+
return msg;
|
|
325
|
+
}
|
|
326
|
+
function decodeSubscribeOkPayload(r) {
|
|
327
|
+
const request_id = r.readVarInt();
|
|
328
|
+
const track_alias = r.readVarInt();
|
|
329
|
+
const expires = r.readVarInt();
|
|
330
|
+
const group_order = r.readVarInt();
|
|
331
|
+
const content_exists = r.readVarInt();
|
|
332
|
+
let largest_group;
|
|
333
|
+
let largest_object;
|
|
334
|
+
if (Number(content_exists) === 1) {
|
|
335
|
+
largest_group = r.readVarInt();
|
|
336
|
+
largest_object = r.readVarInt();
|
|
337
|
+
}
|
|
338
|
+
const parameters = decodeParams(r);
|
|
339
|
+
const msg = {
|
|
340
|
+
type: "subscribe_ok",
|
|
341
|
+
request_id,
|
|
342
|
+
track_alias,
|
|
343
|
+
expires,
|
|
344
|
+
group_order,
|
|
345
|
+
content_exists,
|
|
346
|
+
parameters,
|
|
347
|
+
...(largest_group !== undefined ? { largest_group, largest_object } : {}),
|
|
348
|
+
};
|
|
349
|
+
return msg;
|
|
350
|
+
}
|
|
351
|
+
function decodeSubscribeUpdatePayload(r) {
|
|
352
|
+
const request_id = r.readVarInt();
|
|
353
|
+
const start_group = r.readVarInt();
|
|
354
|
+
const start_object = r.readVarInt();
|
|
355
|
+
const end_group = r.readVarInt();
|
|
356
|
+
const subscriber_priority = BigInt(r.readUint8());
|
|
357
|
+
const forward = r.readVarInt();
|
|
358
|
+
const parameters = decodeParams(r);
|
|
359
|
+
return {
|
|
360
|
+
type: "subscribe_update",
|
|
361
|
+
request_id,
|
|
362
|
+
start_group,
|
|
363
|
+
start_object,
|
|
364
|
+
end_group,
|
|
365
|
+
subscriber_priority,
|
|
366
|
+
forward,
|
|
367
|
+
parameters,
|
|
368
|
+
};
|
|
369
|
+
}
|
|
370
|
+
function decodeSubscribeErrorPayload(r) {
|
|
371
|
+
const request_id = r.readVarInt();
|
|
372
|
+
const error_code = r.readVarInt();
|
|
373
|
+
const reason_phrase = r.readString();
|
|
374
|
+
return { type: "subscribe_error", request_id, error_code, reason_phrase };
|
|
375
|
+
}
|
|
376
|
+
function decodeUnsubscribePayload(r) {
|
|
377
|
+
const request_id = r.readVarInt();
|
|
378
|
+
return { type: "unsubscribe", request_id };
|
|
379
|
+
}
|
|
380
|
+
function decodePublishPayload(r) {
|
|
381
|
+
const request_id = r.readVarInt();
|
|
382
|
+
const track_namespace = r.readTuple();
|
|
383
|
+
const track_name = r.readString();
|
|
384
|
+
const forward = r.readVarInt();
|
|
385
|
+
const parameters = decodeParams(r);
|
|
386
|
+
return { type: "publish", request_id, track_namespace, track_name, forward, parameters };
|
|
387
|
+
}
|
|
388
|
+
function decodePublishOkPayload(r) {
|
|
389
|
+
const request_id = r.readVarInt();
|
|
390
|
+
const track_alias = r.readVarInt();
|
|
391
|
+
const forward = r.readVarInt();
|
|
392
|
+
const parameters = decodeParams(r);
|
|
393
|
+
return { type: "publish_ok", request_id, track_alias, forward, parameters };
|
|
394
|
+
}
|
|
395
|
+
function decodePublishErrorPayload(r) {
|
|
396
|
+
const request_id = r.readVarInt();
|
|
397
|
+
const error_code = r.readVarInt();
|
|
398
|
+
const reason_phrase = r.readString();
|
|
399
|
+
return { type: "publish_error", request_id, error_code, reason_phrase };
|
|
400
|
+
}
|
|
401
|
+
function decodePublishDonePayload(r) {
|
|
402
|
+
const request_id = r.readVarInt();
|
|
403
|
+
const status_code = r.readVarInt();
|
|
404
|
+
const reason_phrase = r.readString();
|
|
405
|
+
return { type: "publish_done", request_id, status_code, reason_phrase };
|
|
406
|
+
}
|
|
407
|
+
function decodePublishNamespacePayload(r) {
|
|
408
|
+
const request_id = r.readVarInt();
|
|
409
|
+
const track_namespace = r.readTuple();
|
|
410
|
+
const parameters = decodeParams(r);
|
|
411
|
+
return { type: "publish_namespace", request_id, track_namespace, parameters };
|
|
412
|
+
}
|
|
413
|
+
function decodePublishNamespaceOkPayload(r) {
|
|
414
|
+
const request_id = r.readVarInt();
|
|
415
|
+
const parameters = decodeParams(r);
|
|
416
|
+
return { type: "publish_namespace_ok", request_id, parameters };
|
|
417
|
+
}
|
|
418
|
+
function decodePublishNamespaceErrorPayload(r) {
|
|
419
|
+
const request_id = r.readVarInt();
|
|
420
|
+
const error_code = r.readVarInt();
|
|
421
|
+
const reason_phrase = r.readString();
|
|
422
|
+
return { type: "publish_namespace_error", request_id, error_code, reason_phrase };
|
|
423
|
+
}
|
|
424
|
+
function decodePublishNamespaceDonePayload(r) {
|
|
425
|
+
const request_id = r.readVarInt();
|
|
426
|
+
const status_code = r.readVarInt();
|
|
427
|
+
const reason_phrase = r.readString();
|
|
428
|
+
return { type: "publish_namespace_done", request_id, status_code, reason_phrase };
|
|
429
|
+
}
|
|
430
|
+
function decodePublishNamespaceCancelPayload(r) {
|
|
431
|
+
const request_id = r.readVarInt();
|
|
432
|
+
return { type: "publish_namespace_cancel", request_id };
|
|
433
|
+
}
|
|
434
|
+
function decodeSubscribeNamespacePayload(r) {
|
|
435
|
+
const request_id = r.readVarInt();
|
|
436
|
+
const namespace_prefix = r.readTuple();
|
|
437
|
+
const parameters = decodeParams(r);
|
|
438
|
+
return { type: "subscribe_namespace", request_id, namespace_prefix, parameters };
|
|
439
|
+
}
|
|
440
|
+
function decodeSubscribeNamespaceOkPayload(r) {
|
|
441
|
+
const request_id = r.readVarInt();
|
|
442
|
+
const parameters = decodeParams(r);
|
|
443
|
+
return { type: "subscribe_namespace_ok", request_id, parameters };
|
|
444
|
+
}
|
|
445
|
+
function decodeSubscribeNamespaceErrorPayload(r) {
|
|
446
|
+
const request_id = r.readVarInt();
|
|
447
|
+
const error_code = r.readVarInt();
|
|
448
|
+
const reason_phrase = r.readString();
|
|
449
|
+
return { type: "subscribe_namespace_error", request_id, error_code, reason_phrase };
|
|
450
|
+
}
|
|
451
|
+
function decodeUnsubscribeNamespacePayload(r) {
|
|
452
|
+
const request_id = r.readVarInt();
|
|
453
|
+
return { type: "unsubscribe_namespace", request_id };
|
|
454
|
+
}
|
|
455
|
+
function decodeFetchPayload(r) {
|
|
456
|
+
const request_id = r.readVarInt();
|
|
457
|
+
const track_namespace = r.readTuple();
|
|
458
|
+
const track_name = r.readString();
|
|
459
|
+
const start_group = r.readVarInt();
|
|
460
|
+
const start_object = r.readVarInt();
|
|
461
|
+
const end_group = r.readVarInt();
|
|
462
|
+
const parameters = decodeParams(r);
|
|
463
|
+
return {
|
|
464
|
+
type: "fetch",
|
|
465
|
+
request_id,
|
|
466
|
+
track_namespace,
|
|
467
|
+
track_name,
|
|
468
|
+
start_group,
|
|
469
|
+
start_object,
|
|
470
|
+
end_group,
|
|
471
|
+
parameters,
|
|
472
|
+
};
|
|
473
|
+
}
|
|
474
|
+
function decodeFetchOkPayload(r) {
|
|
475
|
+
const request_id = r.readVarInt();
|
|
476
|
+
const track_alias = r.readVarInt();
|
|
477
|
+
const end_of_track = r.readVarInt();
|
|
478
|
+
const parameters = decodeParams(r);
|
|
479
|
+
return { type: "fetch_ok", request_id, track_alias, end_of_track, parameters };
|
|
480
|
+
}
|
|
481
|
+
function decodeFetchErrorPayload(r) {
|
|
482
|
+
const request_id = r.readVarInt();
|
|
483
|
+
const error_code = r.readVarInt();
|
|
484
|
+
const reason_phrase = r.readString();
|
|
485
|
+
return { type: "fetch_error", request_id, error_code, reason_phrase };
|
|
486
|
+
}
|
|
487
|
+
function decodeFetchCancelPayload(r) {
|
|
488
|
+
const request_id = r.readVarInt();
|
|
489
|
+
return { type: "fetch_cancel", request_id };
|
|
490
|
+
}
|
|
491
|
+
function decodeTrackStatusPayload(r) {
|
|
492
|
+
const request_id = r.readVarInt();
|
|
493
|
+
const track_namespace = r.readTuple();
|
|
494
|
+
const track_name = r.readString();
|
|
495
|
+
const parameters = decodeParams(r);
|
|
496
|
+
return { type: "track_status", request_id, track_namespace, track_name, parameters };
|
|
497
|
+
}
|
|
498
|
+
function decodeTrackStatusOkPayload(r) {
|
|
499
|
+
const request_id = r.readVarInt();
|
|
500
|
+
const status_code = r.readVarInt();
|
|
501
|
+
const sc = Number(status_code);
|
|
502
|
+
let largest_group;
|
|
503
|
+
let largest_object;
|
|
504
|
+
if (sc === 0 || sc === 3) {
|
|
505
|
+
largest_group = r.readVarInt();
|
|
506
|
+
largest_object = r.readVarInt();
|
|
507
|
+
}
|
|
508
|
+
const parameters = decodeParams(r);
|
|
509
|
+
return {
|
|
510
|
+
type: "track_status_ok",
|
|
511
|
+
request_id,
|
|
512
|
+
status_code,
|
|
513
|
+
parameters,
|
|
514
|
+
...(largest_group !== undefined ? { largest_group, largest_object } : {}),
|
|
515
|
+
};
|
|
516
|
+
}
|
|
517
|
+
function decodeTrackStatusErrorPayload(r) {
|
|
518
|
+
const request_id = r.readVarInt();
|
|
519
|
+
const error_code = r.readVarInt();
|
|
520
|
+
const reason_phrase = r.readString();
|
|
521
|
+
return { type: "track_status_error", request_id, error_code, reason_phrase };
|
|
522
|
+
}
|
|
523
|
+
function decodeGoAwayPayload(r) {
|
|
524
|
+
const new_session_uri = r.readString();
|
|
525
|
+
return { type: "goaway", new_session_uri };
|
|
526
|
+
}
|
|
527
|
+
function decodeMaxRequestIdPayload(r) {
|
|
528
|
+
const request_id = r.readVarInt();
|
|
529
|
+
return { type: "max_request_id", request_id };
|
|
530
|
+
}
|
|
531
|
+
function decodeRequestsBlockedPayload(r) {
|
|
532
|
+
const request_id = r.readVarInt();
|
|
533
|
+
return { type: "requests_blocked", request_id };
|
|
534
|
+
}
|
|
535
|
+
// ─── Payload dispatch tables ───────────────────────────────────────────────────
|
|
536
|
+
const payloadDecoders = new Map([
|
|
537
|
+
[MSG_CLIENT_SETUP, decodeClientSetupPayload],
|
|
538
|
+
[MSG_SERVER_SETUP, decodeServerSetupPayload],
|
|
539
|
+
[MSG_SUBSCRIBE, decodeSubscribePayload],
|
|
540
|
+
[MSG_SUBSCRIBE_OK, decodeSubscribeOkPayload],
|
|
541
|
+
[MSG_SUBSCRIBE_UPDATE, decodeSubscribeUpdatePayload],
|
|
542
|
+
[MSG_SUBSCRIBE_ERROR, decodeSubscribeErrorPayload],
|
|
543
|
+
[MSG_UNSUBSCRIBE, decodeUnsubscribePayload],
|
|
544
|
+
[MSG_PUBLISH, decodePublishPayload],
|
|
545
|
+
[MSG_PUBLISH_OK, decodePublishOkPayload],
|
|
546
|
+
[MSG_PUBLISH_ERROR, decodePublishErrorPayload],
|
|
547
|
+
[MSG_PUBLISH_DONE, decodePublishDonePayload],
|
|
548
|
+
[MSG_PUBLISH_NAMESPACE, decodePublishNamespacePayload],
|
|
549
|
+
[MSG_PUBLISH_NAMESPACE_OK, decodePublishNamespaceOkPayload],
|
|
550
|
+
[MSG_PUBLISH_NAMESPACE_ERROR, decodePublishNamespaceErrorPayload],
|
|
551
|
+
[MSG_PUBLISH_NAMESPACE_DONE, decodePublishNamespaceDonePayload],
|
|
552
|
+
[MSG_PUBLISH_NAMESPACE_CANCEL, decodePublishNamespaceCancelPayload],
|
|
553
|
+
[MSG_SUBSCRIBE_NAMESPACE, decodeSubscribeNamespacePayload],
|
|
554
|
+
[MSG_SUBSCRIBE_NAMESPACE_OK, decodeSubscribeNamespaceOkPayload],
|
|
555
|
+
[MSG_SUBSCRIBE_NAMESPACE_ERROR, decodeSubscribeNamespaceErrorPayload],
|
|
556
|
+
[MSG_UNSUBSCRIBE_NAMESPACE, decodeUnsubscribeNamespacePayload],
|
|
557
|
+
[MSG_FETCH, decodeFetchPayload],
|
|
558
|
+
[MSG_FETCH_OK, decodeFetchOkPayload],
|
|
559
|
+
[MSG_FETCH_ERROR, decodeFetchErrorPayload],
|
|
560
|
+
[MSG_FETCH_CANCEL, decodeFetchCancelPayload],
|
|
561
|
+
[MSG_TRACK_STATUS, decodeTrackStatusPayload],
|
|
562
|
+
[MSG_TRACK_STATUS_OK, decodeTrackStatusOkPayload],
|
|
563
|
+
[MSG_TRACK_STATUS_ERROR, decodeTrackStatusErrorPayload],
|
|
564
|
+
[MSG_GOAWAY, decodeGoAwayPayload],
|
|
565
|
+
[MSG_MAX_REQUEST_ID, decodeMaxRequestIdPayload],
|
|
566
|
+
[MSG_REQUESTS_BLOCKED, decodeRequestsBlockedPayload],
|
|
567
|
+
]);
|
|
568
|
+
// ─── Public API ────────────────────────────────────────────────────────────────
|
|
569
|
+
/**
|
|
570
|
+
* Encode a draft-14 control message with type(varint) + length(uint16 BE) + payload.
|
|
571
|
+
*/
|
|
572
|
+
export function encodeMessage(message) {
|
|
573
|
+
const typeId = MESSAGE_ID_MAP.get(message.type);
|
|
574
|
+
if (typeId === undefined) {
|
|
575
|
+
throw new Error(`Unknown message type: ${message.type}`);
|
|
576
|
+
}
|
|
577
|
+
// Encode payload into a separate buffer
|
|
578
|
+
const payloadWriter = new BufferWriter();
|
|
579
|
+
encodePayload(message, payloadWriter);
|
|
580
|
+
const payload = payloadWriter.finish();
|
|
581
|
+
if (payload.byteLength > 0xffff) {
|
|
582
|
+
throw new Error(`Payload too large for 16-bit length: ${payload.byteLength}`);
|
|
583
|
+
}
|
|
584
|
+
// Write framed message: type(varint) + length(uint16 BE) + payload
|
|
585
|
+
const writer = new BufferWriter();
|
|
586
|
+
writer.writeVarInt(typeId);
|
|
587
|
+
writer.writeUint8((payload.byteLength >> 8) & 0xff);
|
|
588
|
+
writer.writeUint8(payload.byteLength & 0xff);
|
|
589
|
+
writer.writeBytes(payload);
|
|
590
|
+
return writer.finish();
|
|
591
|
+
}
|
|
592
|
+
function encodePayload(msg, w) {
|
|
593
|
+
switch (msg.type) {
|
|
594
|
+
case "client_setup":
|
|
595
|
+
return encodeClientSetupPayload(msg, w);
|
|
596
|
+
case "server_setup":
|
|
597
|
+
return encodeServerSetupPayload(msg, w);
|
|
598
|
+
case "subscribe":
|
|
599
|
+
return encodeSubscribePayload(msg, w);
|
|
600
|
+
case "subscribe_ok":
|
|
601
|
+
return encodeSubscribeOkPayload(msg, w);
|
|
602
|
+
case "subscribe_update":
|
|
603
|
+
return encodeSubscribeUpdatePayload(msg, w);
|
|
604
|
+
case "subscribe_error":
|
|
605
|
+
return encodeSubscribeErrorPayload(msg, w);
|
|
606
|
+
case "unsubscribe":
|
|
607
|
+
return encodeUnsubscribePayload(msg, w);
|
|
608
|
+
case "publish":
|
|
609
|
+
return encodePublishPayload(msg, w);
|
|
610
|
+
case "publish_ok":
|
|
611
|
+
return encodePublishOkPayload(msg, w);
|
|
612
|
+
case "publish_error":
|
|
613
|
+
return encodePublishErrorPayload(msg, w);
|
|
614
|
+
case "publish_done":
|
|
615
|
+
return encodePublishDonePayload(msg, w);
|
|
616
|
+
case "publish_namespace":
|
|
617
|
+
return encodePublishNamespacePayload(msg, w);
|
|
618
|
+
case "publish_namespace_ok":
|
|
619
|
+
return encodePublishNamespaceOkPayload(msg, w);
|
|
620
|
+
case "publish_namespace_error":
|
|
621
|
+
return encodePublishNamespaceErrorPayload(msg, w);
|
|
622
|
+
case "publish_namespace_done":
|
|
623
|
+
return encodePublishNamespaceDonePayload(msg, w);
|
|
624
|
+
case "publish_namespace_cancel":
|
|
625
|
+
return encodePublishNamespaceCancelPayload(msg, w);
|
|
626
|
+
case "subscribe_namespace":
|
|
627
|
+
return encodeSubscribeNamespacePayload(msg, w);
|
|
628
|
+
case "subscribe_namespace_ok":
|
|
629
|
+
return encodeSubscribeNamespaceOkPayload(msg, w);
|
|
630
|
+
case "subscribe_namespace_error":
|
|
631
|
+
return encodeSubscribeNamespaceErrorPayload(msg, w);
|
|
632
|
+
case "unsubscribe_namespace":
|
|
633
|
+
return encodeUnsubscribeNamespacePayload(msg, w);
|
|
634
|
+
case "fetch":
|
|
635
|
+
return encodeFetchPayload(msg, w);
|
|
636
|
+
case "fetch_ok":
|
|
637
|
+
return encodeFetchOkPayload(msg, w);
|
|
638
|
+
case "fetch_error":
|
|
639
|
+
return encodeFetchErrorPayload(msg, w);
|
|
640
|
+
case "fetch_cancel":
|
|
641
|
+
return encodeFetchCancelPayload(msg, w);
|
|
642
|
+
case "track_status":
|
|
643
|
+
return encodeTrackStatusPayload(msg, w);
|
|
644
|
+
case "track_status_ok":
|
|
645
|
+
return encodeTrackStatusOkPayload(msg, w);
|
|
646
|
+
case "track_status_error":
|
|
647
|
+
return encodeTrackStatusErrorPayload(msg, w);
|
|
648
|
+
case "goaway":
|
|
649
|
+
return encodeGoAwayPayload(msg, w);
|
|
650
|
+
case "max_request_id":
|
|
651
|
+
return encodeMaxRequestIdPayload(msg, w);
|
|
652
|
+
case "requests_blocked":
|
|
653
|
+
return encodeRequestsBlockedPayload(msg, w);
|
|
654
|
+
default: {
|
|
655
|
+
const _exhaustive = msg;
|
|
656
|
+
throw new Error(`Unhandled message type: ${_exhaustive.type}`);
|
|
657
|
+
}
|
|
658
|
+
}
|
|
659
|
+
}
|
|
660
|
+
/**
|
|
661
|
+
* Decode a draft-14 control message from bytes (type + uint16 length + payload).
|
|
662
|
+
*/
|
|
663
|
+
export function decodeMessage(bytes) {
|
|
664
|
+
try {
|
|
665
|
+
const reader = new BufferReader(bytes);
|
|
666
|
+
const typeId = reader.readVarInt();
|
|
667
|
+
// Read 16-bit big-endian payload length
|
|
668
|
+
const lenHi = reader.readUint8();
|
|
669
|
+
const lenLo = reader.readUint8();
|
|
670
|
+
const payloadLength = (lenHi << 8) | lenLo;
|
|
671
|
+
// Read exactly payloadLength bytes
|
|
672
|
+
const payloadBytes = reader.readBytes(payloadLength);
|
|
673
|
+
const payloadReader = new BufferReader(payloadBytes);
|
|
674
|
+
const decoder = payloadDecoders.get(typeId);
|
|
675
|
+
if (!decoder) {
|
|
676
|
+
return {
|
|
677
|
+
ok: false,
|
|
678
|
+
error: new DecodeError("UNKNOWN_MESSAGE_TYPE", `Unknown message type ID: 0x${typeId.toString(16)}`, 0),
|
|
679
|
+
};
|
|
680
|
+
}
|
|
681
|
+
const message = decoder(payloadReader);
|
|
682
|
+
return { ok: true, value: message, bytesRead: reader.offset };
|
|
683
|
+
}
|
|
684
|
+
catch (e) {
|
|
685
|
+
if (e instanceof DecodeError) {
|
|
686
|
+
return { ok: false, error: e };
|
|
687
|
+
}
|
|
688
|
+
throw e;
|
|
689
|
+
}
|
|
690
|
+
}
|
|
691
|
+
// ─── Data Stream Re-exports ───────────────────────────────────────────────────
|
|
692
|
+
import { encodeSubgroupStream, decodeSubgroupStream, encodeDatagram, decodeDatagram, encodeFetchStream, decodeFetchStream, decodeDataStream, createSubgroupStreamDecoder, createFetchStreamDecoder, createDataStreamDecoder, } from "./data-streams.js";
|
|
693
|
+
export { encodeSubgroupStream, decodeSubgroupStream, encodeDatagram, decodeDatagram, encodeFetchStream, decodeFetchStream, decodeDataStream, createSubgroupStreamDecoder, createFetchStreamDecoder, createDataStreamDecoder, };
|
|
694
|
+
// ─── Stream Decoders ───────────────────────────────────────────────────────────
|
|
695
|
+
/**
|
|
696
|
+
* Create a TransformStream that decodes a continuous byte stream (e.g. the
|
|
697
|
+
* WebTransport bidirectional control stream) into individual Draft14Message
|
|
698
|
+
* objects. Uses the varint(type) + uint16_BE(length) + payload framing.
|
|
699
|
+
*/
|
|
700
|
+
export function createStreamDecoder() {
|
|
701
|
+
let buffer = new Uint8Array(0);
|
|
702
|
+
return new TransformStream({
|
|
703
|
+
transform(chunk, controller) {
|
|
704
|
+
// Accumulate incoming data
|
|
705
|
+
const newBuffer = new Uint8Array(buffer.length + chunk.length);
|
|
706
|
+
newBuffer.set(buffer, 0);
|
|
707
|
+
newBuffer.set(chunk, buffer.length);
|
|
708
|
+
buffer = newBuffer;
|
|
709
|
+
// Try to decode messages from the buffer
|
|
710
|
+
while (buffer.length > 0) {
|
|
711
|
+
const result = decodeMessage(buffer);
|
|
712
|
+
if (!result.ok) {
|
|
713
|
+
if (result.error.code === "UNEXPECTED_END") {
|
|
714
|
+
// Need more data -- wait for next chunk
|
|
715
|
+
break;
|
|
716
|
+
}
|
|
717
|
+
// Fatal decode error
|
|
718
|
+
controller.error(result.error);
|
|
719
|
+
return;
|
|
720
|
+
}
|
|
721
|
+
controller.enqueue(result.value);
|
|
722
|
+
// Advance the buffer past the consumed bytes
|
|
723
|
+
buffer = buffer.slice(result.bytesRead);
|
|
724
|
+
}
|
|
725
|
+
},
|
|
726
|
+
flush(controller) {
|
|
727
|
+
// If there is remaining data in the buffer, it is a truncated message
|
|
728
|
+
if (buffer.length > 0) {
|
|
729
|
+
controller.error(new DecodeError("UNEXPECTED_END", "Stream ended with incomplete message data", 0));
|
|
730
|
+
}
|
|
731
|
+
},
|
|
732
|
+
});
|
|
733
|
+
}
|
|
734
|
+
export function createDraft14Codec() {
|
|
735
|
+
return {
|
|
736
|
+
draft: "draft-ietf-moq-transport-14",
|
|
737
|
+
encodeMessage,
|
|
738
|
+
decodeMessage,
|
|
739
|
+
encodeSubgroupStream,
|
|
740
|
+
encodeDatagram,
|
|
741
|
+
encodeFetchStream,
|
|
742
|
+
decodeSubgroupStream,
|
|
743
|
+
decodeDatagram,
|
|
744
|
+
decodeFetchStream,
|
|
745
|
+
decodeDataStream,
|
|
746
|
+
createStreamDecoder,
|
|
747
|
+
createSubgroupStreamDecoder,
|
|
748
|
+
createFetchStreamDecoder,
|
|
749
|
+
createDataStreamDecoder,
|
|
750
|
+
};
|
|
751
|
+
}
|
|
752
|
+
//# sourceMappingURL=codec.js.map
|