mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-28 14:35:27 +08:00
issue: https://github.com/milvus-io/milvus/issues/46166 --------- Signed-off-by: sijie-ni-0214 <sijie.ni@zilliz.com>
228 lines
5.6 KiB
Go
228 lines
5.6 KiB
Go
package adaptor
|
|
|
|
import (
|
|
"github.com/milvus-io/milvus-proto/go-api/v2/commonpb"
|
|
"github.com/milvus-io/milvus/pkg/v2/mq/msgstream"
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/util/message"
|
|
)
|
|
|
|
var (
|
|
_ msgstream.TsMsg = &tsMsgImpl{}
|
|
_ msgstream.TsMsg = &FlushMessageBody{}
|
|
)
|
|
|
|
type tsMsgImpl struct {
|
|
msgstream.BaseMsg
|
|
ts uint64
|
|
sz int
|
|
msgType commonpb.MsgType
|
|
}
|
|
|
|
func (t *tsMsgImpl) ID() msgstream.UniqueID {
|
|
panic("should never use")
|
|
}
|
|
|
|
func (t *tsMsgImpl) SetID(id msgstream.UniqueID) {
|
|
panic("should never use")
|
|
}
|
|
|
|
func (t *tsMsgImpl) Type() commonpb.MsgType {
|
|
return t.msgType
|
|
}
|
|
|
|
func (t *tsMsgImpl) SourceID() int64 {
|
|
panic("should never use")
|
|
}
|
|
|
|
func (t *tsMsgImpl) Marshal(msgstream.TsMsg) (msgstream.MarshalType, error) {
|
|
panic("should never use")
|
|
}
|
|
|
|
func (t *tsMsgImpl) Unmarshal(msgstream.MarshalType) (msgstream.TsMsg, error) {
|
|
panic("should never use")
|
|
}
|
|
|
|
func (t *tsMsgImpl) Size() int {
|
|
return t.sz
|
|
}
|
|
|
|
func (t *tsMsgImpl) SetTs(ts uint64) {
|
|
t.ts = ts
|
|
}
|
|
|
|
type CreateSegmentMessageBody struct {
|
|
*tsMsgImpl
|
|
CreateSegmentMessage message.ImmutableCreateSegmentMessageV2
|
|
}
|
|
|
|
func NewCreateSegmentMessageBody(msg message.ImmutableMessage) (msgstream.TsMsg, error) {
|
|
createMsg, err := message.AsImmutableCreateSegmentMessageV2(msg)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &CreateSegmentMessageBody{
|
|
tsMsgImpl: &tsMsgImpl{
|
|
BaseMsg: msgstream.BaseMsg{
|
|
BeginTimestamp: msg.TimeTick(),
|
|
EndTimestamp: msg.TimeTick(),
|
|
},
|
|
ts: msg.TimeTick(),
|
|
sz: msg.EstimateSize(),
|
|
msgType: MustGetCommonpbMsgTypeFromMessageType(msg.MessageType()),
|
|
},
|
|
CreateSegmentMessage: createMsg,
|
|
}, nil
|
|
}
|
|
|
|
type FlushMessageBody struct {
|
|
*tsMsgImpl
|
|
FlushMessage message.ImmutableFlushMessageV2
|
|
}
|
|
|
|
func NewFlushMessageBody(msg message.ImmutableMessage) (msgstream.TsMsg, error) {
|
|
flushMsg, err := message.AsImmutableFlushMessageV2(msg)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &FlushMessageBody{
|
|
tsMsgImpl: &tsMsgImpl{
|
|
BaseMsg: msgstream.BaseMsg{
|
|
BeginTimestamp: msg.TimeTick(),
|
|
EndTimestamp: msg.TimeTick(),
|
|
},
|
|
ts: msg.TimeTick(),
|
|
sz: msg.EstimateSize(),
|
|
msgType: MustGetCommonpbMsgTypeFromMessageType(msg.MessageType()),
|
|
},
|
|
FlushMessage: flushMsg,
|
|
}, nil
|
|
}
|
|
|
|
type ManualFlushMessageBody struct {
|
|
*tsMsgImpl
|
|
ManualFlushMessage message.ImmutableManualFlushMessageV2
|
|
}
|
|
|
|
func NewManualFlushMessageBody(msg message.ImmutableMessage) (msgstream.TsMsg, error) {
|
|
flushMsg, err := message.AsImmutableManualFlushMessageV2(msg)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &ManualFlushMessageBody{
|
|
tsMsgImpl: &tsMsgImpl{
|
|
BaseMsg: msgstream.BaseMsg{
|
|
BeginTimestamp: msg.TimeTick(),
|
|
EndTimestamp: msg.TimeTick(),
|
|
},
|
|
ts: msg.TimeTick(),
|
|
sz: msg.EstimateSize(),
|
|
msgType: MustGetCommonpbMsgTypeFromMessageType(msg.MessageType()),
|
|
},
|
|
ManualFlushMessage: flushMsg,
|
|
}, nil
|
|
}
|
|
|
|
type FlushAllMessageBody struct {
|
|
*tsMsgImpl
|
|
FlushAllMessage message.ImmutableFlushAllMessageV2
|
|
}
|
|
|
|
func NewFlushAllMessageBody(msg message.ImmutableMessage) (msgstream.TsMsg, error) {
|
|
flushAllMsg, err := message.AsImmutableFlushAllMessageV2(msg)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &FlushAllMessageBody{
|
|
tsMsgImpl: &tsMsgImpl{
|
|
BaseMsg: msgstream.BaseMsg{
|
|
BeginTimestamp: msg.TimeTick(),
|
|
EndTimestamp: msg.TimeTick(),
|
|
},
|
|
ts: msg.TimeTick(),
|
|
sz: msg.EstimateSize(),
|
|
msgType: MustGetCommonpbMsgTypeFromMessageType(msg.MessageType()),
|
|
},
|
|
FlushAllMessage: flushAllMsg,
|
|
}, nil
|
|
}
|
|
|
|
type SchemaChangeMessageBody struct {
|
|
*tsMsgImpl
|
|
SchemaChangeMessage message.ImmutableSchemaChangeMessageV2
|
|
}
|
|
|
|
func (s *SchemaChangeMessageBody) ID() msgstream.UniqueID {
|
|
return 0
|
|
}
|
|
|
|
func NewSchemaChangeMessageBody(msg message.ImmutableMessage) (msgstream.TsMsg, error) {
|
|
schChgMsg, err := message.AsImmutableSchemaChangeMessageV2(msg)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &SchemaChangeMessageBody{
|
|
tsMsgImpl: &tsMsgImpl{
|
|
BaseMsg: msgstream.BaseMsg{
|
|
BeginTimestamp: msg.TimeTick(),
|
|
EndTimestamp: msg.TimeTick(),
|
|
},
|
|
ts: msg.TimeTick(),
|
|
sz: msg.EstimateSize(),
|
|
msgType: MustGetCommonpbMsgTypeFromMessageType(msg.MessageType()),
|
|
},
|
|
SchemaChangeMessage: schChgMsg,
|
|
}, nil
|
|
}
|
|
|
|
type AlterCollectionMessageBody struct {
|
|
*tsMsgImpl
|
|
AlterCollectionMessage message.ImmutableAlterCollectionMessageV2
|
|
}
|
|
|
|
func (p *AlterCollectionMessageBody) ID() msgstream.UniqueID {
|
|
return 0
|
|
}
|
|
|
|
func NewAlterCollectionMessageBody(msg message.ImmutableMessage) (msgstream.TsMsg, error) {
|
|
alterCollMsg, err := message.AsImmutableAlterCollectionMessageV2(msg)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &AlterCollectionMessageBody{
|
|
tsMsgImpl: &tsMsgImpl{
|
|
BaseMsg: msgstream.BaseMsg{
|
|
BeginTimestamp: msg.TimeTick(),
|
|
EndTimestamp: msg.TimeTick(),
|
|
},
|
|
ts: msg.TimeTick(),
|
|
sz: msg.EstimateSize(),
|
|
msgType: MustGetCommonpbMsgTypeFromMessageType(msg.MessageType()),
|
|
},
|
|
AlterCollectionMessage: alterCollMsg,
|
|
}, nil
|
|
}
|
|
|
|
type TruncateCollectionMessageBody struct {
|
|
*tsMsgImpl
|
|
TruncateCollectionMessage message.ImmutableTruncateCollectionMessageV2
|
|
}
|
|
|
|
func NewTruncateCollectionMessageBody(msg message.ImmutableMessage) (msgstream.TsMsg, error) {
|
|
truncateCollMsg, err := message.AsImmutableTruncateCollectionMessageV2(msg)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &TruncateCollectionMessageBody{
|
|
tsMsgImpl: &tsMsgImpl{
|
|
BaseMsg: msgstream.BaseMsg{
|
|
BeginTimestamp: msg.TimeTick(),
|
|
EndTimestamp: msg.TimeTick(),
|
|
},
|
|
ts: msg.TimeTick(),
|
|
sz: msg.EstimateSize(),
|
|
msgType: MustGetCommonpbMsgTypeFromMessageType(msg.MessageType()),
|
|
},
|
|
TruncateCollectionMessage: truncateCollMsg,
|
|
}, nil
|
|
}
|