Documentation ¶
Overview ¶
Package types defines a custom wrapper for google.protobuf.Any which supports cached values as well as InterfaceRegistry which keeps track of types which can be used with Any for both security and introspection
Index ¶
- Variables
- func UnpackInterfaces(x interface{}, unpacker AnyUnpacker) error
- type AminoJSONPacker
- type AminoJSONUnpacker
- type AminoPacker
- type AminoUnpacker
- type Any
- func (this *Any) Compare(that interface{}) int
- func (*Any) Descriptor() ([]byte, []int)
- func (this *Any) Equal(that interface{}) bool
- func (any *Any) GetCachedValue() interface{}
- func (m *Any) GetTypeUrl() string
- func (m *Any) GetValue() []byte
- func (any *Any) GoString() string
- func (m *Any) Marshal() (dAtA []byte, err error)
- func (any Any) MarshalAmino() ([]byte, error)
- func (any *Any) MarshalJSON() ([]byte, error)
- func (m *Any) MarshalTo(dAtA []byte) (int, error)
- func (m *Any) MarshalToSizedBuffer(dAtA []byte) (int, error)
- func (*Any) ProtoMessage()
- func (m *Any) Reset()
- func (any *Any) ResetCachedValue()
- func (m *Any) Size() (n int)
- func (any *Any) String() string
- func (m *Any) Unmarshal(dAtA []byte) error
- func (any *Any) UnmarshalAmino(bz []byte) error
- func (any *Any) UnmarshalJSON(bz []byte) error
- func (m *Any) XXX_DiscardUnknown()
- func (m *Any) XXX_Marshal(b []byte, deterministic bool) ([]byte, error)
- func (m *Any) XXX_Merge(src proto.Message)
- func (*Any) XXX_MessageName() string
- func (m *Any) XXX_Size() int
- func (m *Any) XXX_Unmarshal(b []byte) error
- func (*Any) XXX_WellKnownType() string
- type AnyUnpacker
- type ProtoJSONPacker
- type UnpackInterfacesMessage
Constants ¶
This section is empty.
Variables ¶
var ( ErrInvalidLengthAny = fmt.Errorf("proto: negative length found during unmarshaling") ErrIntOverflowAny = fmt.Errorf("proto: integer overflow") ErrUnexpectedEndOfGroupAny = fmt.Errorf("proto: unexpected end of group") )
var Debug = true
Functions ¶
func UnpackInterfaces ¶
func UnpackInterfaces(x interface{}, unpacker AnyUnpacker) error
UnpackInterfaces is a convenience function that calls UnpackInterfaces on x if x implements UnpackInterfacesMessage
Types ¶
type AminoJSONPacker ¶
type AminoJSONPacker struct {
Cdc *amino.Codec
}
AminoUnpacker is an AnyUnpacker provided for backwards compatibility with amino for the JSON un-marshaling phase
func (AminoJSONPacker) UnpackAny ¶
func (a AminoJSONPacker) UnpackAny(any *Any, _ interface{}) error
type AminoJSONUnpacker ¶
type AminoJSONUnpacker struct {
Cdc *amino.Codec
}
AminoUnpacker is an AnyUnpacker provided for backwards compatibility with amino for the JSON marshaling phase
func (AminoJSONUnpacker) UnpackAny ¶
func (a AminoJSONUnpacker) UnpackAny(any *Any, iface interface{}) error
type AminoPacker ¶
type AminoPacker struct {
Cdc *amino.Codec
}
AminoUnpacker is an AnyUnpacker provided for backwards compatibility with amino for the binary marshaling phase
func (AminoPacker) UnpackAny ¶
func (a AminoPacker) UnpackAny(any *Any, _ interface{}) error
type AminoUnpacker ¶
type AminoUnpacker struct {
Cdc *amino.Codec
}
AminoUnpacker is an AnyUnpacker provided for backwards compatibility with amino for the binary un-marshaling phase
func (AminoUnpacker) UnpackAny ¶
func (a AminoUnpacker) UnpackAny(any *Any, iface interface{}) error
type Any ¶
type Any struct { TypeUrl string `protobuf:"bytes,1,opt,name=type_url,json=typeUrl,proto3" json:"type_url,omitempty"` // Must be a valid serialized protocol buffer of the above specified type. Value []byte `protobuf:"bytes,2,opt,name=value,proto3" json:"value,omitempty"` XXX_NoUnkeyedLiteral struct{} `json:"-"` XXX_unrecognized []byte `json:"-"` XXX_sizecache int32 `json:"-"` // contains filtered or unexported fields }
func NewAnyWithCacheWithValue ¶
NewAnyWithCacheWithValue constructs a new Any packed with the value provided or returns an error if that value couldn't be packed. This also caches the packed value so that it can be retrieved from GetCachedValue without unmarshalling
func NewPopulatedAny ¶
func UnsafePackAnyWithCache ¶
func UnsafePackAnyWithCache(x interface{}) *Any
UnsafePackAnyWithCache packs the value x in the Any and instead of returning the error in the case of a packing failure, keeps the cached value. This should only be used in situations where compatibility is needed with amino. Amino-only values can safely be packed using this method when they will only be marshaled with amino and not protobuf.
func (*Any) Descriptor ¶
func (*Any) GetCachedValue ¶
func (any *Any) GetCachedValue() interface{}
GetCachedValue returns the cached value from the Any if present
func (*Any) GetTypeUrl ¶
func (*Any) GoString ¶
GoString returns a string representing valid go code to reproduce the current state of the struct.
func (Any) MarshalAmino ¶
func (*Any) MarshalJSON ¶
func (*Any) ProtoMessage ¶
func (*Any) ProtoMessage()
func (*Any) ResetCachedValue ¶
func (any *Any) ResetCachedValue()
ResetCachedValue seta a nil cachedValue
func (*Any) UnmarshalAmino ¶
func (*Any) UnmarshalJSON ¶
func (*Any) XXX_DiscardUnknown ¶
func (m *Any) XXX_DiscardUnknown()
func (*Any) XXX_MessageName ¶
func (*Any) XXX_Unmarshal ¶
func (*Any) XXX_WellKnownType ¶
type AnyUnpacker ¶
type AnyUnpacker interface { // UnpackAny unpacks the value in any to the interface pointer passed in as // iface. Note that the type in any must have been registered in the // underlying whitelist registry as a concrete type for that interface // Ex: // var msg sdk.Msg // err := cdc.UnpackAny(any, &msg) // ... UnpackAny(any *Any, iface interface{}) error }
AnyUnpacker is an interface which allows safely unpacking types packed in Any's against a whitelist of registered types
type ProtoJSONPacker ¶
ProtoJSONPacker is an AnyUnpacker provided for compatibility with jsonpb
func (ProtoJSONPacker) UnpackAny ¶
func (a ProtoJSONPacker) UnpackAny(any *Any, _ interface{}) error
type UnpackInterfacesMessage ¶
type UnpackInterfacesMessage interface { // UnpackInterfaces is implemented in order to unpack values packed within // Any's using the AnyUnpacker. It should generally be implemented as // follows: // func (s *MyStruct) UnpackInterfaces(unpacker AnyUnpacker) error { // var x AnyInterface // // where X is an Any field on MyStruct // err := unpacker.UnpackAny(s.X, &x) // if err != nil { // return nil // } // // where Y is a field on MyStruct that implements UnpackInterfacesMessage itself // err = s.Y.UnpackInterfaces(unpacker) // if err != nil { // return nil // } // return nil // } UnpackInterfaces(unpacker AnyUnpacker) error }
UnpackInterfacesMessage is meant to extend protobuf types (which implement proto.Message) to support a post-deserialization phase which unpacks types packed within Any's using the whitelist provided by AnyUnpacker