Zhen Ye 6982f007e2
enhance: add walimpls access mode options (#40591)
issue: #40532

Signed-off-by: chyezh <chyezh@outlook.com>
2025-03-14 10:58:11 +08:00

44 lines
1.0 KiB
Go

package rmq
import (
"context"
"github.com/milvus-io/milvus/pkg/v2/mq/mqimpl/rocksmq/client"
"github.com/milvus-io/milvus/pkg/v2/streaming/util/types"
"github.com/milvus-io/milvus/pkg/v2/streaming/walimpls"
"github.com/milvus-io/milvus/pkg/v2/streaming/walimpls/helper"
)
var _ walimpls.OpenerImpls = (*openerImpl)(nil)
// openerImpl is the implementation of walimpls.Opener interface.
type openerImpl struct {
c client.Client
}
// Open opens a new wal.
func (o *openerImpl) Open(ctx context.Context, opt *walimpls.OpenOption) (walimpls.WALImpls, error) {
if err := opt.Validate(); err != nil {
return nil, err
}
var p client.Producer
if opt.Channel.AccessMode == types.AccessModeRW {
var err error
if p, err = o.c.CreateProducer(client.ProducerOptions{
Topic: opt.Channel.Name,
}); err != nil {
return nil, err
}
}
return &walImpl{
WALHelper: helper.NewWALHelper(opt),
p: p,
c: o.c,
}, nil
}
// Close closes the opener resources.
func (o *openerImpl) Close() {
o.c.Close()
}