-
Notifications
You must be signed in to change notification settings - Fork 526
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
Support Binary Types (like UUID) #1186
Comments
I have some ideas about implementing encoder/decoder for specific types. This will increase the flexibility of field types. That could make is possible to use However, this requires significant work (both coding and reviewing). If you can provide help (time or money), please let me know. |
I don't mind contributing, if not just for my own selfish reasons. 😉 It initially looked like things might just need a refactoring of |
So the rough plan I am thinking of is:
Maybe we can have an audio meeting using Discord to work out a plan together. You can find me in the |
Motivation
There are a of number data types that have binary encodings which cannot be expressed in
prost
. The most obvious is UUID. An attempt was made provide this functionality, albeit without discussion, in #637. While Protocol Buffers does not describe how to deal with UUID specifically, it does describe how to deal with binary values. RFC 9562 (formerly RFC 4122) very clearly defines how such a value is to be encoded in binary.While I can appreciate the stance that consumers may use UUID in different ways, the binary value is the binary value. In the spirit of Protocol Buffers, it doesn't make sense to store the value in any other format aside from the binary representation. The smallest text representation takes twice the storage! Using or presenting a UUID in any other format, especially textually, should be external and unsupported by
prost
. If someone really, really wants it as a string, they can already do that by defining the field asstring
.UUID isn't the only binary format that someone might want to encode. There are a number well-known date and time encodings, which use binary formats as opposed to strings.
prost
doesn't need to support them all, but it should be possible for someone else to provide an implementation. It would be nice if heavily used types, like uuid were supported behind a feature. In my opinion, it's more than fair to say the only supported format is binary.Desired State
What I would love to be able to do is use strongly-typed binary values in a message like so:
Blockers
Given the popularity of certain types, it would certainly be convenient and impactful if
prost
provided an implementation, but I also understand it can't support everything. I'm more than willing to create my own adapter and I'm sure others would too, but unfortunately, it's impossible due to #829. Naturally, you can convert toVec<u8>
orBytes
, but that loses all of the idiomatic benefits of the type.Prior Art
uuid-rs/uuid#716 provided an efficient way to encode/decode the value (more so than #637), but it was rejected. That was probably the right call because
uuid
depending onprost
feels like an inverse dependency. Regardless, the desired end state would still be blocked by #829.Feature Request
The text was updated successfully, but these errors were encountered: