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