chyezh dfe0416a70
enhance: implement streaming node server service (#34166)
issue: #33285

- implement producing and consuming server of message
- implement management operation for streaming node server

---------

Signed-off-by: chyezh <chyezh@outlook.com>
2024-07-09 07:58:14 +08:00

52 lines
1.5 KiB
Go

package contextutil
import (
"context"
"encoding/base64"
"fmt"
"github.com/cockroachdb/errors"
"github.com/golang/protobuf/proto"
"google.golang.org/grpc/metadata"
"github.com/milvus-io/milvus/internal/proto/streamingpb"
)
const (
createProducerKey = "create-producer"
)
// WithCreateProducer attaches create producer request to context.
func WithCreateProducer(ctx context.Context, req *streamingpb.CreateProducerRequest) context.Context {
bytes, err := proto.Marshal(req)
if err != nil {
panic(fmt.Sprintf("unreachable: marshal create producer request failed, %+v", err))
}
// use base64 encoding to transfer binary to text.
msg := base64.StdEncoding.EncodeToString(bytes)
return metadata.AppendToOutgoingContext(ctx, createProducerKey, msg)
}
// GetCreateProducer gets create producer request from context.
func GetCreateProducer(ctx context.Context) (*streamingpb.CreateProducerRequest, error) {
md, ok := metadata.FromIncomingContext(ctx)
if !ok {
return nil, errors.New("create producer metadata not found from incoming context")
}
msg := md.Get(createProducerKey)
if len(msg) == 0 {
return nil, errors.New("create consumer metadata not found")
}
bytes, err := base64.StdEncoding.DecodeString(msg[0])
if err != nil {
return nil, errors.Wrap(err, "decode create consumer metadata failed")
}
req := &streamingpb.CreateProducerRequest{}
if err := proto.Unmarshal(bytes, req); err != nil {
return nil, errors.Wrap(err, "unmarshal create producer request failed")
}
return req, nil
}