2020-12-09 01:55:56 +00:00
|
|
|
package storage
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"errors"
|
|
|
|
"strconv"
|
|
|
|
|
|
|
|
"github.com/zilliztech/milvus-distributed/internal/proto/schemapb"
|
|
|
|
)
|
|
|
|
|
|
|
|
type EventReader struct {
|
|
|
|
eventHeader
|
|
|
|
eventData
|
|
|
|
PayloadReaderInterface
|
|
|
|
buffer *bytes.Buffer
|
|
|
|
isClosed bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func (reader *EventReader) checkClose() error {
|
|
|
|
if reader.isClosed {
|
|
|
|
return errors.New("event reader is closed")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (reader *EventReader) readHeader() (*eventHeader, error) {
|
|
|
|
if err := reader.checkClose(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
header, err := readEventHeader(reader.buffer)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
reader.eventHeader = *header
|
|
|
|
return &reader.eventHeader, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (reader *EventReader) readData() (eventData, error) {
|
|
|
|
if err := reader.checkClose(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
var data eventData
|
|
|
|
var err error
|
|
|
|
switch reader.TypeCode {
|
|
|
|
case InsertEventType:
|
2020-12-09 03:18:13 +00:00
|
|
|
data, err = readInsertEventDataFixPart(reader.buffer)
|
2020-12-09 01:55:56 +00:00
|
|
|
case DeleteEventType:
|
2020-12-09 03:18:13 +00:00
|
|
|
data, err = readDeleteEventDataFixPart(reader.buffer)
|
2020-12-09 01:55:56 +00:00
|
|
|
case CreateCollectionEventType:
|
2020-12-09 03:18:13 +00:00
|
|
|
data, err = readCreateCollectionEventDataFixPart(reader.buffer)
|
2020-12-09 01:55:56 +00:00
|
|
|
case DropCollectionEventType:
|
2020-12-09 03:18:13 +00:00
|
|
|
data, err = readDropCollectionEventDataFixPart(reader.buffer)
|
2020-12-09 01:55:56 +00:00
|
|
|
case CreatePartitionEventType:
|
2020-12-09 03:18:13 +00:00
|
|
|
data, err = readCreatePartitionEventDataFixPart(reader.buffer)
|
2020-12-09 01:55:56 +00:00
|
|
|
case DropPartitionEventType:
|
2020-12-09 03:18:13 +00:00
|
|
|
data, err = readDropPartitionEventDataFixPart(reader.buffer)
|
2020-12-09 01:55:56 +00:00
|
|
|
default:
|
|
|
|
return nil, errors.New("unknown header type code: " + strconv.Itoa(int(reader.TypeCode)))
|
|
|
|
}
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
reader.eventData = data
|
|
|
|
return reader.eventData, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (reader *EventReader) Close() error {
|
|
|
|
if !reader.isClosed {
|
|
|
|
reader.isClosed = true
|
|
|
|
return reader.PayloadReaderInterface.Close()
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
func newEventReader(datatype schemapb.DataType, buffer *bytes.Buffer) (*EventReader, error) {
|
|
|
|
reader := &EventReader{
|
|
|
|
eventHeader: eventHeader{
|
|
|
|
baseEventHeader{},
|
|
|
|
},
|
|
|
|
buffer: buffer,
|
|
|
|
isClosed: false,
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := reader.readHeader(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := reader.readData(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
payloadReader, err := NewPayloadReader(datatype, buffer.Bytes())
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
reader.PayloadReaderInterface = payloadReader
|
|
|
|
return reader, nil
|
|
|
|
}
|