-
-
Notifications
You must be signed in to change notification settings - Fork 18
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Possible replacements for JSON communication between frontend and backend #538
Comments
Automatic message validation seems reasonable and easier/goes along with syncing types. Could you give me a hint where we transfer binary data (within our code scope)? |
There are 3 places specifically, all of which currently use different websocket connections from the main one to allow transferring raw binary data. Uploading and downloading files/zip-encoded folders use |
Ah right, upload/download files of course. What benefit of a message wrapper do you think of? For the terminal I thought so that this is all handled in the xterm module so that we cannot hook well inside, respectively it won't benefit.
If there is no additional conversion required when generating binary data from information respectively parsing binary data vs JSON, then I agree. I just remember from some Python coding where transfer modules require binary data at some point and it added an additional conversion step on both ends as e.g. first a JSON string is (manually) generated and then needs to be binary-encoded, and at the other end first decoded before the information is accessible. So there I thought that sending the only minimally larger data in plain text would be easier. But if e.g. the binary format is generated directly, instead of first a plain text JSON, then of course it doesn't matter. |
No, there is no need to convert between JSON and the binary format, we could convert directly to it from the Rust structs (probably faster than we could convert to JSON, actually). Using a wrapper format would let us remove the separate websocket for uploading and downloading files, as the raw file data could be wrapped by the binary format and parsed the same way as everything else. In addition (I just thought of this), adding a binary wrapper could let us add checksums to the file data as it's being sent, to make sure that it isn't being corrupted. |
There are 3 main things that I would like when communicating between the frontend and backend that JSON doesn't provide:
1 and 2 can easily be provided by using some sort of schema, which I think would probably be a good idea because the dashboard's communication is completely internal, with no outside process trying to interface with it. 3 would be useful to encode file data (for instance) in actual messages instead of just sending it without any metadata. After looking, there are a number of possible solutions:
tsync
)ajv
, Both (codegen):jtd-codegen
)u64
msgpackr
, Rust:rmp
,rmp-serde
)@protobuf-ts/plugin
,@protobuf-ts/runtime
orts-proto
, Rust:prost
)u16
, for instance)flatbuffers
, Rust:flatbuffers
)capnp-ts
, Rust:capnp
)capnpc-ts
(typescript complier) seems to be brokenAt first glance, FlatBuffers look like the way to go for our needs, but I'll have to do some more testing before making a decision.
The text was updated successfully, but these errors were encountered: