2019-06-03 18:44:43 +01:00
|
|
|
// Package grpc provides a gRPC options
|
|
|
|
package grpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
2021-10-27 00:57:12 +03:00
|
|
|
"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 (
|
2024-02-14 19:14:56 +03:00
|
|
|
// DefaultPoolMaxStreams maximum streams on a connection
|
2019-12-27 20:25:58 +08:00
|
|
|
// (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
|
2024-02-29 16:57:38 +03:00
|
|
|
|
|
|
|
// DefaultServiceConfig enable load balancing
|
|
|
|
DefaultServiceConfig = `{"loadBalancingPolicy":"round_robin"}`
|
2019-06-03 18:44:43 +01:00
|
|
|
)
|
|
|
|
|
2019-12-29 21:07:55 +00:00
|
|
|
type poolMaxStreams struct{}
|
2019-06-03 18:44:43 +01:00
|
|
|
|
2019-12-27 20:25:58 +08: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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-26 19:17:29 +03:00
|
|
|
type poolMaxIdle struct{}
|
|
|
|
|
2019-12-27 20:25:58 +08:00
|
|
|
// 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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-26 19:17:29 +03:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-26 19:17:29 +03:00
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-26 19:17:29 +03:00
|
|
|
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
|
|
|
|
2021-04-26 19:17:29 +03:00
|
|
|
type grpcDialOptions struct{}
|
|
|
|
|
2019-10-09 14:45:51 +08:00
|
|
|
// DialOptions to be used to configure gRPC dial options
|
2023-06-22 23:43:38 +03:00
|
|
|
func DialOptions(opts ...grpc.DialOption) client.Option {
|
|
|
|
return func(o *client.Options) {
|
2019-10-09 14:45:51 +08:00
|
|
|
if o.Context == nil {
|
|
|
|
o.Context = context.Background()
|
|
|
|
}
|
|
|
|
o.Context = context.WithValue(o.Context, grpcDialOptions{}, opts)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-26 19:17:29 +03:00
|
|
|
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
|
|
|
}
|
|
|
|
}
|
2024-02-29 16:57:38 +03:00
|
|
|
|
|
|
|
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)
|
|
|
|
}
|
|
|
|
}
|