Evstigneev Denis
0f8ead6acc
Some checks failed
automerge / automerge (pull_request) Has been skipped
dependabot-automerge / automerge (pull_request) Has been skipped
autoapprove / autoapprove (pull_request) Successful in 10s
codeql / analyze (go) (pull_request) Has been cancelled
prbuild / test (pull_request) Has been cancelled
prbuild / lint (pull_request) Has been cancelled
132 lines
3.3 KiB
Go
132 lines
3.3 KiB
Go
// Package grpc provides a gRPC options
|
|
package grpc
|
|
|
|
import (
|
|
"context"
|
|
|
|
"go.unistack.org/micro/v3/client"
|
|
"google.golang.org/grpc"
|
|
"google.golang.org/grpc/encoding"
|
|
)
|
|
|
|
var (
|
|
// DefaultPoolMaxStreams maximum streams on a connection
|
|
// (20)
|
|
DefaultPoolMaxStreams = 20
|
|
|
|
// DefaultPoolMaxIdle maximum idle conns of a pool
|
|
// (50)
|
|
DefaultPoolMaxIdle = 50
|
|
|
|
// 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
|
|
|
|
// DefaultServiceConfig enable load balancing
|
|
DefaultServiceConfig = `{"loadBalancingPolicy":"round_robin"}`
|
|
)
|
|
|
|
type poolMaxStreams struct{}
|
|
|
|
// 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{}
|
|
|
|
// 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{}
|
|
|
|
// 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{}
|
|
|
|
// 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)
|
|
}
|
|
}
|
|
|
|
type grpcDialOptions struct{}
|
|
|
|
// DialOptions to be used to configure gRPC dial options
|
|
func DialOptions(opts ...grpc.DialOption) client.CallOption {
|
|
return func(o *client.CallOptions) {
|
|
if o.Context == nil {
|
|
o.Context = context.Background()
|
|
}
|
|
o.Context = context.WithValue(o.Context, grpcDialOptions{}, opts)
|
|
}
|
|
}
|
|
|
|
type grpcCallOptions struct{}
|
|
|
|
// CallOptions to be used to configure gRPC call options
|
|
func CallOptions(opts ...grpc.CallOption) client.CallOption {
|
|
return func(o *client.CallOptions) {
|
|
if o.Context == nil {
|
|
o.Context = context.Background()
|
|
}
|
|
o.Context = context.WithValue(o.Context, grpcCallOptions{}, opts)
|
|
}
|
|
}
|
|
|
|
type serviceConfigKey struct{}
|
|
|
|
func ServiceConfig(str string) client.CallOption {
|
|
return func(options *client.CallOptions) {
|
|
if options.Context == nil {
|
|
options.Context = context.Background()
|
|
}
|
|
options.Context = context.WithValue(options.Context, serviceConfigKey{}, str)
|
|
}
|
|
}
|