tinswzy 6fa68c1f16
enhance: Support Woodpecker as a WAL storage option for Milvus (#41095)
#40916 Support Woodpecker as a WAL storage option for Milvus

Signed-off-by: tinswzy <zhenyuan.wei@zilliz.com>
2025-04-20 22:22:42 +08:00

62 lines
1.4 KiB
Go

package wp
import (
"github.com/zilliztech/woodpecker/woodpecker/log"
"github.com/milvus-io/milvus/pkg/v2/mq/common"
)
func NewWoodpeckerID(id *log.LogMessageId) *woodpeckerID {
return &woodpeckerID{
messageID: id,
}
}
type woodpeckerID struct {
messageID *log.LogMessageId
}
func (w *woodpeckerID) WoodpeckerID() *log.LogMessageId {
return w.messageID
}
func (w *woodpeckerID) Serialize() []byte {
return w.messageID.Serialize()
}
func (w *woodpeckerID) AtEarliestPosition() bool {
if w.messageID.SegmentId <= 0 && w.messageID.EntryId <= 0 {
return true
}
return false
}
func (w *woodpeckerID) LessOrEqualThan(msgID []byte) (bool, error) {
id2, err := log.DeserializeLogMessageId(msgID)
if err != nil {
return false, err
}
if w.messageID.SegmentId < id2.SegmentId {
return true, nil
}
if w.messageID.SegmentId > id2.SegmentId {
return false, nil
}
return w.messageID.EntryId <= id2.EntryId, nil
}
func (w *woodpeckerID) Equal(msgID []byte) (bool, error) {
id2, err := log.DeserializeLogMessageId(msgID)
if err != nil {
return false, err
}
return w.messageID.SegmentId == id2.SegmentId && w.messageID.EntryId == id2.EntryId, nil
}
// Check if pulsarID implements and MessageID interface
var _ common.MessageID = &woodpeckerID{}
func DeserializeWoodpeckerMsgID(messageID []byte) (*log.LogMessageId, error) {
return log.DeserializeLogMessageId(messageID)
}