mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-06 17:18:35 +08:00
issue: #33285 - make message builder and message conversion type safe - add adaptor type and function to adapt old msgstream msgpack and message interface --------- Signed-off-by: chyezh <chyezh@outlook.com>
69 lines
1.5 KiB
Go
69 lines
1.5 KiB
Go
package rmq
|
|
|
|
import (
|
|
"github.com/cockroachdb/errors"
|
|
|
|
"github.com/milvus-io/milvus/pkg/streaming/util/message"
|
|
)
|
|
|
|
var _ message.MessageID = rmqID(0)
|
|
|
|
// NewRmqID creates a new rmqID.
|
|
// TODO: remove in future.
|
|
func NewRmqID(id int64) message.MessageID {
|
|
return rmqID(id)
|
|
}
|
|
|
|
// UnmarshalMessageID unmarshal the message id.
|
|
func UnmarshalMessageID(data string) (message.MessageID, error) {
|
|
id, err := unmarshalMessageID(data)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return id, nil
|
|
}
|
|
|
|
// unmashalMessageID unmarshal the message id.
|
|
func unmarshalMessageID(data string) (rmqID, error) {
|
|
v, err := message.DecodeUint64(data)
|
|
if err != nil {
|
|
return 0, errors.Wrapf(message.ErrInvalidMessageID, "decode rmqID fail with err: %s, id: %s", err.Error(), data)
|
|
}
|
|
return rmqID(v), nil
|
|
}
|
|
|
|
// rmqID is the message id for rmq.
|
|
type rmqID int64
|
|
|
|
// RmqID returns the message id for conversion
|
|
// Don't delete this function until conversion logic removed.
|
|
// TODO: remove in future.
|
|
func (id rmqID) RmqID() int64 {
|
|
return int64(id)
|
|
}
|
|
|
|
// WALName returns the name of message id related wal.
|
|
func (id rmqID) WALName() string {
|
|
return walName
|
|
}
|
|
|
|
// LT less than.
|
|
func (id rmqID) LT(other message.MessageID) bool {
|
|
return id < other.(rmqID)
|
|
}
|
|
|
|
// LTE less than or equal to.
|
|
func (id rmqID) LTE(other message.MessageID) bool {
|
|
return id <= other.(rmqID)
|
|
}
|
|
|
|
// EQ Equal to.
|
|
func (id rmqID) EQ(other message.MessageID) bool {
|
|
return id == other.(rmqID)
|
|
}
|
|
|
|
// Marshal marshal the message id.
|
|
func (id rmqID) Marshal() string {
|
|
return message.EncodeInt64(int64(id))
|
|
}
|