first commit
This commit is contained in:
85
pkg/websocket/codec/protobuf/protobuf.go
Normal file
85
pkg/websocket/codec/protobuf/protobuf.go
Normal file
@ -0,0 +1,85 @@
|
||||
package protobuf
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"fmt"
|
||||
|
||||
"git.bvbej.com/bvbej/base-golang/pkg/websocket/codec"
|
||||
"git.bvbej.com/bvbej/base-golang/pkg/websocket/codec/protobuf/protocol"
|
||||
"google.golang.org/protobuf/proto"
|
||||
)
|
||||
|
||||
type protobufCodec struct{}
|
||||
|
||||
func init() {
|
||||
codec.RegisterCodec("protobuf_codec", new(protobufCodec))
|
||||
}
|
||||
|
||||
func (*protobufCodec) Marshal(router string, dataPtr any, retErr error) ([]byte, error) {
|
||||
if router == "" {
|
||||
return nil, fmt.Errorf("marshal: empty router")
|
||||
}
|
||||
if dataPtr == nil && retErr == nil {
|
||||
return nil, fmt.Errorf("marshal: empty data")
|
||||
}
|
||||
ack := &protocol.TransPack{
|
||||
Router: router,
|
||||
}
|
||||
if dataPtr != nil {
|
||||
pbMsg, ok := dataPtr.(proto.Message)
|
||||
if !ok {
|
||||
return nil, fmt.Errorf("marshal: dataptr only support proto.Message type. router:%s dt:%T ",
|
||||
router, dataPtr)
|
||||
}
|
||||
data, err := proto.Marshal(pbMsg)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("marshal:protocol buffer marshal failed. router:%s dt:%T err:%v",
|
||||
router, dataPtr, err)
|
||||
}
|
||||
ack.Data = data
|
||||
} else {
|
||||
ack.Error = retErr.Error()
|
||||
}
|
||||
ackByte, err := proto.Marshal(ack)
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("marshal:protocol buffer marshal failed. router:%s dt:%T err:%v",
|
||||
router, ack, err)
|
||||
}
|
||||
return ackByte, nil
|
||||
}
|
||||
|
||||
func (*protobufCodec) Unmarshal(msg []byte) (int, *codec.MsgPack, error) {
|
||||
var l = len(msg)
|
||||
req := &protocol.TransPack{}
|
||||
err := proto.Unmarshal(msg, req)
|
||||
if err != nil {
|
||||
return l, nil, errors.New("unmarshal split message id failed.")
|
||||
}
|
||||
var router = req.Router
|
||||
msgPack := &codec.MsgPack{Router: router}
|
||||
dt := codec.GetMessage(router)
|
||||
if dt == nil {
|
||||
return l, nil, fmt.Errorf("unmarshal message not registed. router:%s",
|
||||
router)
|
||||
}
|
||||
if req.Data != nil {
|
||||
err = proto.Unmarshal(req.Data, dt.(proto.Message))
|
||||
if err != nil {
|
||||
return l, nil, fmt.Errorf("unmarshal failed. router:%s", router)
|
||||
}
|
||||
}
|
||||
msgPack.DataPtr = dt
|
||||
if req.Error != "" {
|
||||
msgPack.Err = errors.New(req.Error)
|
||||
}
|
||||
return l, msgPack, nil
|
||||
}
|
||||
|
||||
func (*protobufCodec) ToString(data any) string {
|
||||
pbMsg, ok := data.(proto.Message)
|
||||
if !ok {
|
||||
return fmt.Sprintf("invalid type %T", data)
|
||||
}
|
||||
marshal, _ := proto.Marshal(pbMsg)
|
||||
return string(marshal)
|
||||
}
|
226
pkg/websocket/codec/protobuf/protocol/base.pb.go
Normal file
226
pkg/websocket/codec/protobuf/protocol/base.pb.go
Normal file
@ -0,0 +1,226 @@
|
||||
// Code generated by protoc-gen-go. DO NOT EDIT.
|
||||
// versions:
|
||||
// protoc-gen-go v1.26.0
|
||||
// protoc v3.21.1
|
||||
// source: base.proto
|
||||
|
||||
package protocol
|
||||
|
||||
import (
|
||||
protoreflect "google.golang.org/protobuf/reflect/protoreflect"
|
||||
protoimpl "google.golang.org/protobuf/runtime/protoimpl"
|
||||
reflect "reflect"
|
||||
sync "sync"
|
||||
)
|
||||
|
||||
const (
|
||||
// Verify that this generated code is sufficiently up-to-date.
|
||||
_ = protoimpl.EnforceVersion(20 - protoimpl.MinVersion)
|
||||
// Verify that runtime/protoimpl is sufficiently up-to-date.
|
||||
_ = protoimpl.EnforceVersion(protoimpl.MaxVersion - 20)
|
||||
)
|
||||
|
||||
// 通信包装
|
||||
type TransPack struct {
|
||||
state protoimpl.MessageState
|
||||
sizeCache protoimpl.SizeCache
|
||||
unknownFields protoimpl.UnknownFields
|
||||
|
||||
Router string `protobuf:"bytes,1,opt,name=router,proto3" json:"router,omitempty"`
|
||||
Data []byte `protobuf:"bytes,2,opt,name=data,proto3" json:"data,omitempty"`
|
||||
Error string `protobuf:"bytes,3,opt,name=error,proto3" json:"error,omitempty"`
|
||||
}
|
||||
|
||||
func (x *TransPack) Reset() {
|
||||
*x = TransPack{}
|
||||
if protoimpl.UnsafeEnabled {
|
||||
mi := &file_base_proto_msgTypes[0]
|
||||
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||
ms.StoreMessageInfo(mi)
|
||||
}
|
||||
}
|
||||
|
||||
func (x *TransPack) String() string {
|
||||
return protoimpl.X.MessageStringOf(x)
|
||||
}
|
||||
|
||||
func (*TransPack) ProtoMessage() {}
|
||||
|
||||
func (x *TransPack) ProtoReflect() protoreflect.Message {
|
||||
mi := &file_base_proto_msgTypes[0]
|
||||
if protoimpl.UnsafeEnabled && x != nil {
|
||||
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||
if ms.LoadMessageInfo() == nil {
|
||||
ms.StoreMessageInfo(mi)
|
||||
}
|
||||
return ms
|
||||
}
|
||||
return mi.MessageOf(x)
|
||||
}
|
||||
|
||||
// Deprecated: Use TransPack.ProtoReflect.Descriptor instead.
|
||||
func (*TransPack) Descriptor() ([]byte, []int) {
|
||||
return file_base_proto_rawDescGZIP(), []int{0}
|
||||
}
|
||||
|
||||
func (x *TransPack) GetRouter() string {
|
||||
if x != nil {
|
||||
return x.Router
|
||||
}
|
||||
return ""
|
||||
}
|
||||
|
||||
func (x *TransPack) GetData() []byte {
|
||||
if x != nil {
|
||||
return x.Data
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (x *TransPack) GetError() string {
|
||||
if x != nil {
|
||||
return x.Error
|
||||
}
|
||||
return ""
|
||||
}
|
||||
|
||||
// 连接检测
|
||||
type PingPang struct {
|
||||
state protoimpl.MessageState
|
||||
sizeCache protoimpl.SizeCache
|
||||
unknownFields protoimpl.UnknownFields
|
||||
|
||||
Timestamp int64 `protobuf:"varint,1,opt,name=timestamp,proto3" json:"timestamp,omitempty"` //时间戳
|
||||
}
|
||||
|
||||
func (x *PingPang) Reset() {
|
||||
*x = PingPang{}
|
||||
if protoimpl.UnsafeEnabled {
|
||||
mi := &file_base_proto_msgTypes[1]
|
||||
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||
ms.StoreMessageInfo(mi)
|
||||
}
|
||||
}
|
||||
|
||||
func (x *PingPang) String() string {
|
||||
return protoimpl.X.MessageStringOf(x)
|
||||
}
|
||||
|
||||
func (*PingPang) ProtoMessage() {}
|
||||
|
||||
func (x *PingPang) ProtoReflect() protoreflect.Message {
|
||||
mi := &file_base_proto_msgTypes[1]
|
||||
if protoimpl.UnsafeEnabled && x != nil {
|
||||
ms := protoimpl.X.MessageStateOf(protoimpl.Pointer(x))
|
||||
if ms.LoadMessageInfo() == nil {
|
||||
ms.StoreMessageInfo(mi)
|
||||
}
|
||||
return ms
|
||||
}
|
||||
return mi.MessageOf(x)
|
||||
}
|
||||
|
||||
// Deprecated: Use PingPang.ProtoReflect.Descriptor instead.
|
||||
func (*PingPang) Descriptor() ([]byte, []int) {
|
||||
return file_base_proto_rawDescGZIP(), []int{1}
|
||||
}
|
||||
|
||||
func (x *PingPang) GetTimestamp() int64 {
|
||||
if x != nil {
|
||||
return x.Timestamp
|
||||
}
|
||||
return 0
|
||||
}
|
||||
|
||||
var File_base_proto protoreflect.FileDescriptor
|
||||
|
||||
var file_base_proto_rawDesc = []byte{
|
||||
0x0a, 0x0a, 0x62, 0x61, 0x73, 0x65, 0x2e, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x12, 0x08, 0x70, 0x72,
|
||||
0x6f, 0x74, 0x6f, 0x63, 0x6f, 0x6c, 0x22, 0x4d, 0x0a, 0x09, 0x54, 0x72, 0x61, 0x6e, 0x73, 0x50,
|
||||
0x61, 0x63, 0x6b, 0x12, 0x16, 0x0a, 0x06, 0x72, 0x6f, 0x75, 0x74, 0x65, 0x72, 0x18, 0x01, 0x20,
|
||||
0x01, 0x28, 0x09, 0x52, 0x06, 0x72, 0x6f, 0x75, 0x74, 0x65, 0x72, 0x12, 0x12, 0x0a, 0x04, 0x64,
|
||||
0x61, 0x74, 0x61, 0x18, 0x02, 0x20, 0x01, 0x28, 0x0c, 0x52, 0x04, 0x64, 0x61, 0x74, 0x61, 0x12,
|
||||
0x14, 0x0a, 0x05, 0x65, 0x72, 0x72, 0x6f, 0x72, 0x18, 0x03, 0x20, 0x01, 0x28, 0x09, 0x52, 0x05,
|
||||
0x65, 0x72, 0x72, 0x6f, 0x72, 0x22, 0x28, 0x0a, 0x08, 0x50, 0x69, 0x6e, 0x67, 0x50, 0x61, 0x6e,
|
||||
0x67, 0x12, 0x1c, 0x0a, 0x09, 0x74, 0x69, 0x6d, 0x65, 0x73, 0x74, 0x61, 0x6d, 0x70, 0x18, 0x01,
|
||||
0x20, 0x01, 0x28, 0x03, 0x52, 0x09, 0x74, 0x69, 0x6d, 0x65, 0x73, 0x74, 0x61, 0x6d, 0x70, 0x42,
|
||||
0x27, 0x5a, 0x25, 0x70, 0x6b, 0x67, 0x2f, 0x77, 0x65, 0x62, 0x73, 0x6f, 0x63, 0x6b, 0x65, 0x74,
|
||||
0x2f, 0x63, 0x6f, 0x64, 0x65, 0x63, 0x2f, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x62, 0x75, 0x66, 0x2f,
|
||||
0x70, 0x72, 0x6f, 0x74, 0x6f, 0x63, 0x6f, 0x6c, 0x62, 0x06, 0x70, 0x72, 0x6f, 0x74, 0x6f, 0x33,
|
||||
}
|
||||
|
||||
var (
|
||||
file_base_proto_rawDescOnce sync.Once
|
||||
file_base_proto_rawDescData = file_base_proto_rawDesc
|
||||
)
|
||||
|
||||
func file_base_proto_rawDescGZIP() []byte {
|
||||
file_base_proto_rawDescOnce.Do(func() {
|
||||
file_base_proto_rawDescData = protoimpl.X.CompressGZIP(file_base_proto_rawDescData)
|
||||
})
|
||||
return file_base_proto_rawDescData
|
||||
}
|
||||
|
||||
var file_base_proto_msgTypes = make([]protoimpl.MessageInfo, 2)
|
||||
var file_base_proto_goTypes = []any{
|
||||
(*TransPack)(nil), // 0: protocol.TransPack
|
||||
(*PingPang)(nil), // 1: protocol.PingPang
|
||||
}
|
||||
var file_base_proto_depIdxs = []int32{
|
||||
0, // [0:0] is the sub-list for method output_type
|
||||
0, // [0:0] is the sub-list for method input_type
|
||||
0, // [0:0] is the sub-list for extension type_name
|
||||
0, // [0:0] is the sub-list for extension extendee
|
||||
0, // [0:0] is the sub-list for field type_name
|
||||
}
|
||||
|
||||
func init() { file_base_proto_init() }
|
||||
func file_base_proto_init() {
|
||||
if File_base_proto != nil {
|
||||
return
|
||||
}
|
||||
if !protoimpl.UnsafeEnabled {
|
||||
file_base_proto_msgTypes[0].Exporter = func(v any, i int) any {
|
||||
switch v := v.(*TransPack); i {
|
||||
case 0:
|
||||
return &v.state
|
||||
case 1:
|
||||
return &v.sizeCache
|
||||
case 2:
|
||||
return &v.unknownFields
|
||||
default:
|
||||
return nil
|
||||
}
|
||||
}
|
||||
file_base_proto_msgTypes[1].Exporter = func(v any, i int) any {
|
||||
switch v := v.(*PingPang); i {
|
||||
case 0:
|
||||
return &v.state
|
||||
case 1:
|
||||
return &v.sizeCache
|
||||
case 2:
|
||||
return &v.unknownFields
|
||||
default:
|
||||
return nil
|
||||
}
|
||||
}
|
||||
}
|
||||
type x struct{}
|
||||
out := protoimpl.TypeBuilder{
|
||||
File: protoimpl.DescBuilder{
|
||||
GoPackagePath: reflect.TypeOf(x{}).PkgPath(),
|
||||
RawDescriptor: file_base_proto_rawDesc,
|
||||
NumEnums: 0,
|
||||
NumMessages: 2,
|
||||
NumExtensions: 0,
|
||||
NumServices: 0,
|
||||
},
|
||||
GoTypes: file_base_proto_goTypes,
|
||||
DependencyIndexes: file_base_proto_depIdxs,
|
||||
MessageInfos: file_base_proto_msgTypes,
|
||||
}.Build()
|
||||
File_base_proto = out.File
|
||||
file_base_proto_rawDesc = nil
|
||||
file_base_proto_goTypes = nil
|
||||
file_base_proto_depIdxs = nil
|
||||
}
|
15
pkg/websocket/codec/protobuf/protocol/base.proto
Normal file
15
pkg/websocket/codec/protobuf/protocol/base.proto
Normal file
@ -0,0 +1,15 @@
|
||||
syntax = "proto3";
|
||||
package protocol;
|
||||
option go_package = "pkg/websocket/codec/protobuf/protocol";
|
||||
|
||||
//通信包装
|
||||
message TransPack {
|
||||
string router = 1;
|
||||
bytes data = 2;
|
||||
string error = 3;
|
||||
}
|
||||
|
||||
//连接检测
|
||||
message PingPang {
|
||||
int64 timestamp = 1; //时间戳
|
||||
}
|
Reference in New Issue
Block a user