2019-06-03 20:44:43 +03:00
|
|
|
// Package grpc provides a gRPC options
|
|
|
|
package grpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"crypto/tls"
|
|
|
|
|
2020-08-19 17:47:17 +03:00
|
|
|
"github.com/unistack-org/micro/v3/client"
|
2019-10-09 11:48:45 +03:00
|
|
|
"google.golang.org/grpc"
|
2019-06-03 20:44:43 +03:00
|
|
|
"google.golang.org/grpc/encoding"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2019-12-27 15:25:58 +03:00
|
|
|
// DefaultPoolMaxStreams maximum streams on a connectioin
|
|
|
|
// (20)
|
|
|
|
DefaultPoolMaxStreams = 20
|
|
|
|
|
|
|
|
// DefaultPoolMaxIdle maximum idle conns of a pool
|
|
|
|
// (50)
|
|
|
|
DefaultPoolMaxIdle = 50
|
|
|
|
|
2019-06-03 20:44:43 +03: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
|
|
|
|
)
|
|
|
|
|
2019-12-30 00:07:55 +03:00
|
|
|
type poolMaxStreams struct{}
|
|
|
|
type poolMaxIdle struct{}
|
2019-06-03 20:44:43 +03:00
|
|
|
type codecsKey struct{}
|
|
|
|
type tlsAuth struct{}
|
|
|
|
type maxRecvMsgSizeKey struct{}
|
|
|
|
type maxSendMsgSizeKey struct{}
|
2019-10-09 09:45:51 +03:00
|
|
|
type grpcDialOptions struct{}
|
|
|
|
type grpcCallOptions struct{}
|
2019-06-03 20:44:43 +03:00
|
|
|
|
2019-12-27 15:25:58 +03: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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-03 20:44:43 +03: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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// AuthTLS should be used to setup a secure authentication using TLS
|
|
|
|
func AuthTLS(t *tls.Config) client.Option {
|
|
|
|
return func(o *client.Options) {
|
|
|
|
if o.Context == nil {
|
|
|
|
o.Context = context.Background()
|
|
|
|
}
|
|
|
|
o.Context = context.WithValue(o.Context, tlsAuth{}, t)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// 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)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// 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 09:45:51 +03:00
|
|
|
|
|
|
|
//
|
|
|
|
// DialOptions to be used to configure gRPC dial options
|
|
|
|
//
|
2019-10-10 08:55:16 +03:00
|
|
|
func DialOptions(opts ...grpc.DialOption) client.CallOption {
|
|
|
|
return func(o *client.CallOptions) {
|
2019-10-09 09:45:51 +03:00
|
|
|
if o.Context == nil {
|
|
|
|
o.Context = context.Background()
|
|
|
|
}
|
|
|
|
o.Context = context.WithValue(o.Context, grpcDialOptions{}, opts)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// CallOptions to be used to configure gRPC call options
|
|
|
|
//
|
2019-10-10 08:55:16 +03:00
|
|
|
func CallOptions(opts ...grpc.CallOption) client.CallOption {
|
|
|
|
return func(o *client.CallOptions) {
|
|
|
|
if o.Context == nil {
|
|
|
|
o.Context = context.Background()
|
2019-10-09 09:45:51 +03:00
|
|
|
}
|
2019-10-10 08:55:16 +03:00
|
|
|
o.Context = context.WithValue(o.Context, grpcCallOptions{}, opts)
|
2019-10-09 09:45:51 +03:00
|
|
|
}
|
|
|
|
}
|