milvus/pkg/mq/mqimpl/rocksmq/client/streaming.go
Zhen Ye bb8d1ab3bf
enhance: make new go package to manage proto (#39114)
issue: #39095

---------

Signed-off-by: chyezh <chyezh@outlook.com>
2025-01-10 10:49:01 +08:00

54 lines
1.7 KiB
Go

package client
import (
"bytes"
"github.com/cockroachdb/errors"
"google.golang.org/protobuf/proto"
"github.com/milvus-io/milvus/pkg/mq/common"
"github.com/milvus-io/milvus/pkg/mq/mqimpl/rocksmq/server"
"github.com/milvus-io/milvus/pkg/proto/messagespb"
)
var (
// magicPrefix is used to identify the rocksmq legacy message and new message for streaming service.
// Make a low probability of collision with the legacy proto message.
magicPrefix = append([]byte{0xFF, 0xFE, 0xFD, 0xFC}, []byte("STREAM")...)
errNotStreamingServiceMessage = errors.New("not a streaming service message")
)
// marshalStreamingMessage marshals a streaming message to bytes.
func marshalStreamingMessage(message *common.ProducerMessage) ([]byte, error) {
rmqMessage := &messagespb.RMQMessageLayout{
Payload: message.Payload,
Properties: message.Properties,
}
payload, err := proto.Marshal(rmqMessage)
if err != nil {
return nil, err
}
finalPayload := make([]byte, len(payload)+len(magicPrefix))
copy(finalPayload, magicPrefix)
copy(finalPayload[len(magicPrefix):], payload)
return finalPayload, nil
}
// unmarshalStreamingMessage unmarshals a streaming message from bytes.
func unmarshalStreamingMessage(topic string, msg server.ConsumerMessage) (*RmqMessage, error) {
if !bytes.HasPrefix(msg.Payload, magicPrefix) {
return nil, errNotStreamingServiceMessage
}
var rmqMessage messagespb.RMQMessageLayout
if err := proto.Unmarshal(msg.Payload[len(magicPrefix):], &rmqMessage); err != nil {
return nil, err
}
return &RmqMessage{
msgID: msg.MsgID,
payload: rmqMessage.Payload,
properties: rmqMessage.Properties,
topic: topic,
}, nil
}