micro-client-grpc/options.go

126 lines
2.9 KiB
Go
Raw Normal View History

2019-06-03 18:44:43 +01:00
// Package grpc provides a gRPC options
package grpc
import (
"context"
"go.unistack.org/micro/v3/client"
2019-10-09 16:48:45 +08:00
"google.golang.org/grpc"
2019-06-03 18:44:43 +01:00
"google.golang.org/grpc/encoding"
)
var (
// DefaultPoolMaxStreams maximum streams on a connectioin
// (20)
DefaultPoolMaxStreams = 20
// DefaultPoolMaxIdle maximum idle conns of a pool
// (50)
DefaultPoolMaxIdle = 50
2019-06-03 18:44:43 +01:00
// DefaultMaxRecvMsgSize maximum message that client can receive
// (4 MB).
DefaultMaxRecvMsgSize = 1024 * 1024 * 4
// DefaultMaxSendMsgSize maximum message that client can send
// (4 MB).
DefaultMaxSendMsgSize = 1024 * 1024 * 4
)
type poolMaxStreams struct{}
2019-06-03 18:44:43 +01:00
// maximum streams on a connectioin
func PoolMaxStreams(n int) client.Option {
return func(o *client.Options) {
if o.Context == nil {
o.Context = context.Background()
}
o.Context = context.WithValue(o.Context, poolMaxStreams{}, n)
}
}
type poolMaxIdle struct{}
// maximum idle conns of a pool
func PoolMaxIdle(d int) client.Option {
return func(o *client.Options) {
if o.Context == nil {
o.Context = context.Background()
}
o.Context = context.WithValue(o.Context, poolMaxIdle{}, d)
}
}
type codecsKey struct{}
2019-06-03 18:44:43 +01:00
// gRPC Codec to be used to encode/decode requests for a given content type
func Codec(contentType string, c encoding.Codec) client.Option {
return func(o *client.Options) {
codecs := make(map[string]encoding.Codec)
if o.Context == nil {
o.Context = context.Background()
}
if v := o.Context.Value(codecsKey{}); v != nil {
codecs = v.(map[string]encoding.Codec)
}
codecs[contentType] = c
o.Context = context.WithValue(o.Context, codecsKey{}, codecs)
}
}
type maxRecvMsgSizeKey struct{}
2019-06-03 18:44:43 +01:00
//
// MaxRecvMsgSize set the maximum size of message that client can receive.
//
func MaxRecvMsgSize(s int) client.Option {
return func(o *client.Options) {
if o.Context == nil {
o.Context = context.Background()
}
o.Context = context.WithValue(o.Context, maxRecvMsgSizeKey{}, s)
}
}
type maxSendMsgSizeKey struct{}
2019-06-03 18:44:43 +01:00
//
// MaxSendMsgSize set the maximum size of message that client can send.
//
func MaxSendMsgSize(s int) client.Option {
return func(o *client.Options) {
if o.Context == nil {
o.Context = context.Background()
}
o.Context = context.WithValue(o.Context, maxSendMsgSizeKey{}, s)
}
}
2019-10-09 14:45:51 +08:00
type grpcDialOptions struct{}
2019-10-09 14:45:51 +08:00
//
// DialOptions to be used to configure gRPC dial options
//
2019-10-10 13:55:16 +08:00
func DialOptions(opts ...grpc.DialOption) client.CallOption {
return func(o *client.CallOptions) {
2019-10-09 14:45:51 +08:00
if o.Context == nil {
o.Context = context.Background()
}
o.Context = context.WithValue(o.Context, grpcDialOptions{}, opts)
}
}
type grpcCallOptions struct{}
2019-10-09 14:45:51 +08:00
//
// CallOptions to be used to configure gRPC call options
//
2019-10-10 13:55:16 +08:00
func CallOptions(opts ...grpc.CallOption) client.CallOption {
return func(o *client.CallOptions) {
if o.Context == nil {
o.Context = context.Background()
2019-10-09 14:45:51 +08:00
}
2019-10-10 13:55:16 +08:00
o.Context = context.WithValue(o.Context, grpcCallOptions{}, opts)
2019-10-09 14:45:51 +08:00
}
}