Open
Description
Dear,
I was wondering, could a websocket be multiplexed so it really mirrors the java/go api? So you create 1 connection per stub, this would allow grpc-web to have a huge amount of streams.
Maybe a simple protocol could be defined in protobuf itself to make it easy to implement in other languages to have an InProcessProxy reducing the need for proxies.
The only disadvantage is that the proxy then has to keep state to track which message maps to which stream.
Would you be interested in such a feature or would it be too complex to implement?
For the protocol i was thinking along the lines of:
syntax = "proto3";
option go_package = "./main";
message Message{
uint32 streamId = 1;
oneof payload {
Start start = 2;
Body body = 3;
Complete complete = 4;
Error error = 5;
Cancel cancel = 6;
}
}
message Start {
string operation = 1;
repeated Header headers = 2;
}
message Body {
bytes data = 1;
}
message Complete {
}
message Error {
}
message Cancel {
}
message Header {
string name = 1;
bytes data = 2;
}
Metadata
Metadata
Assignees
Labels
No labels