You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
(gogoproto.gogoproto_import) = false in proto files
WKTs (google.protobuf.Timestamp and friends) are used
github.com/golang/protobuf version >= v1.4.0
WKT fields stop being recognized as such by gogo/protobuf/jsonpb in this case, breaking serialization.
Analysis
With option (gogoproto.gogoproto_import) = false set, WKTs are imported from github.com/golang/protobuf/ptypes packages.
For golang/protobuf >= v1.4.0 (more exactly golang/protobuf@b9f5089), the XXX_WellKnownType methods on WKT types are gone, but gogo/protobuf/jsonpb is not aware of the protobuf API v2.
Notably, one of the affected downstream packages is gogo/gateway, which is mandatory for grpc-gateway users depending on (gogoproto.stdtime) = true fields.
The protobuf API v2 compatibility, as implemented in grpc-gateway, cannot easily be ported to gogo/protobuf. Because golang/protobuf WKT types don't register to the gogo registry, the crucial proto.MessageName() call will return nothing. And the types cannot just be registered in app code either, because the gogo WKTs also have accompanying func init()'s doing the same thing, the names will collide if one does so.
If we don't allow gogo/protobuf/jsonpb to somehow lookup the message type in golang/protobuf registry, which would create a dependency on the latter package, the bug seems impossible to fix without bumping the fork (which I imagine is non-trivial work) or downgrading golang/protobuf (the easiest solution for now).
Any thoughts?
The text was updated successfully, but these errors were encountered:
@FelixSeptem First check if you're affected (if you don't use (gogoproto.gogoproto_import) = false or gogo/gateway or gogo/protobuf/jsonpb then you're NOT affected). If you're as unfortunate as me, it seems the only short-term solution is to downgrade. Keeping 1.4.0 version of upstream protobuf seemingly needs updates to gogo/protobuf, which at this point seems unlikely, all maintainers disappeared last year without reason.
tl;dr
The following combination is broken:
(gogoproto.gogoproto_import) = false
in proto filesgoogle.protobuf.Timestamp
and friends) are usedgithub.com/golang/protobuf
version >= v1.4.0WKT fields stop being recognized as such by
gogo/protobuf/jsonpb
in this case, breaking serialization.Analysis
With
option (gogoproto.gogoproto_import) = false
set, WKTs are imported fromgithub.com/golang/protobuf/ptypes
packages.For
golang/protobuf
>= v1.4.0 (more exactly golang/protobuf@b9f5089), theXXX_WellKnownType
methods on WKT types are gone, butgogo/protobuf/jsonpb
is not aware of the protobuf API v2.protobuf/jsonpb/jsonpb.go
Lines 163 to 165 in 5628607
protobuf/jsonpb/jsonpb.go
Lines 206 to 207 in 5628607
Notably, one of the affected downstream packages is
gogo/gateway
, which is mandatory for grpc-gateway users depending on(gogoproto.stdtime) = true
fields.The protobuf API v2 compatibility, as implemented in
grpc-gateway
, cannot easily be ported togogo/protobuf
. Becausegolang/protobuf
WKT types don't register to the gogo registry, the crucialproto.MessageName()
call will return nothing. And the types cannot just be registered in app code either, because the gogo WKTs also have accompanyingfunc init()
's doing the same thing, the names will collide if one does so.If we don't allow
gogo/protobuf/jsonpb
to somehow lookup the message type ingolang/protobuf
registry, which would create a dependency on the latter package, the bug seems impossible to fix without bumping the fork (which I imagine is non-trivial work) or downgradinggolang/protobuf
(the easiest solution for now).Any thoughts?
The text was updated successfully, but these errors were encountered: