You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
30 lines
693 B
Go
30 lines
693 B
Go
3 years ago
|
package kafka
|
||
|
|
||
|
import (
|
||
|
"errors"
|
||
|
"git.noahlan.cn/northlan/ntools-go/kafka"
|
||
|
"google.golang.org/protobuf/proto"
|
||
|
)
|
||
|
|
||
|
var _ kafka.Marshaler = (*protobufMarshaler)(nil)
|
||
|
var _ kafka.UnMarshaler = (*protobufMarshaler)(nil)
|
||
|
|
||
|
var ProtobufMarshaler = &protobufMarshaler{}
|
||
|
|
||
|
type protobufMarshaler struct {
|
||
|
}
|
||
|
|
||
|
func (p *protobufMarshaler) Marshal(v interface{}) ([]byte, error) {
|
||
|
if msg, ok := v.(proto.Message); ok {
|
||
|
return proto.Marshal(msg)
|
||
|
}
|
||
|
return nil, errors.New("v must be proto message")
|
||
|
}
|
||
|
|
||
|
func (p *protobufMarshaler) UnMarshal(data []byte, v interface{}) error {
|
||
|
if msg, ok := v.(proto.Message); ok {
|
||
|
return proto.Unmarshal(data, msg)
|
||
|
}
|
||
|
return errors.New("v must be proto message")
|
||
|
}
|