-
Notifications
You must be signed in to change notification settings - Fork 998
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
Use SSZ union-types in RPC request/response #974
Conversation
b3e742d
to
f7ef9a1
Compare
Do SSZ unions (over the possible |
specs/networking/rpc-interface.md
Outdated
+ id (uint64) + | ||
| | | ||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | ||
| response_code (uint16) | result_len (uint32) | |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
can we keep these aligned a bit? ie life gets easier when types are aligned to their size, which in this case can be had by changing response_code
to uint32.. alternatively, stick another uint16
in there for future expansion set to 0 for now
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sure thing.
If we use specific stream for each RPC, we avoid having to do this correct? |
SSZ unions can be done with:
if you know all the type possibilities up-front and don't mind that lists in theory can have more than one item. in practice, this tends not to be a big deal (see for example the protobuf encoding where the last value with matching key is used for single-item (optional) fields, and lists simply collect them instead - the only difference is a cosmetic one, in the schema. in terms of forward/backward compatibility, it's a "heavy" solution - every change, even purely additive, needs a new "protocol" or "request". thus, at minimum, we need a new stream every time we add some field or request, even if technically we can have multiple message types in a single stream. |
@djrtwo using separate streams allows us to avoid some of this. You still won't be able to parse responses from multiple RPC requests at once without some identifier linking a response to a request. It does become much simpler, however - we'd only need to include an ID. |
We could also call everything else message header and encode it in SSZ. This wouldn't change anything on the wire (as long as we only use fixed size values in the header), but maybe it's a little bit simpler conceptually. |
Would a union type (#893) preclude us from having to define this external, non-ssz wrapper? |
@mslipper See above question |
My bad, missed that notification - a union type technically solves this, but introduces other problems. The union type would need to be over a list of all possible RPC request/responses, which IMO rapidly reduces maintainability. Beyond the desire for consistency, is there another reason for why we're leaning towards SSZ everywhere? |
The list of all possible RPC request/responses should be readily available, right? For example, every request type needs to have a corresponding request handler. As such, maintenance of the union can be abstracted away programmatically. |
@JustinDrake doesn't this seem needlessly complex to you? We're talking about creating tooling to work around SSZ's limitations in a specification that hasn't been implemented yet. Is there a specific reason for requiring SSZ everywhere? It seems to me that decoding a sequence of bytes on the wire then decoding the SSZ payload is far simpler than maintaining a union type programmatically. |
I'm suggesting reusing the existing query/response infrastructure that needs to exist anyway. (In other words, no extra tooling needs to be created.)
The reason is the long tail of benefits we get from standardisation :) As a side note, judging from internal conversations, I think those who expressed an opinion (Danny, Vitalik, myself) are inclined to stick with SSZ. Having said that, I don't particularly care too much either way 😂 |
Could you describe the tooling that would be needed? I also still don't get what the problem is here, as long as there is a finite enum of possible request types that's going to be used, it should be fine? It is even possible to maintain forwards compatibility by just adding new types to the union and make old clients ignore requests with unkown type numbers. |
This PR addresses #871 by using SSZ union types in request body