mirror of
https://gitee.com/milvus-io/milvus.git
synced 2025-12-06 09:08:43 +08:00
39 lines
1007 B
Go
39 lines
1007 B
Go
package walimpls
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/cockroachdb/errors"
|
|
|
|
"github.com/milvus-io/milvus/pkg/v2/streaming/util/types"
|
|
)
|
|
|
|
// OpenOption is the option for allocating wal impls instance.
|
|
type OpenOption struct {
|
|
Channel types.PChannelInfo // Channel to open.
|
|
}
|
|
|
|
// Validate validates the OpenOption.
|
|
func (oo OpenOption) Validate() error {
|
|
if oo.Channel.Name == "" {
|
|
return errors.New("channel name is empty")
|
|
}
|
|
if oo.Channel.Term < 0 {
|
|
return errors.New("channel term is negative")
|
|
}
|
|
if oo.Channel.AccessMode != types.AccessModeRO && oo.Channel.AccessMode != types.AccessModeRW {
|
|
return errors.New("undefined access mode")
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// OpenerImpls is the interface for build WALImpls instance.
|
|
type OpenerImpls interface {
|
|
// Open open a WALImpls instance.
|
|
// If the opt.AccessMode is AccessModeRO, the WALImpls should be read-only, the append operation will panic.
|
|
Open(ctx context.Context, opt *OpenOption) (WALImpls, error)
|
|
|
|
// Close release the resources.
|
|
Close()
|
|
}
|