2020-11-08 19:28:33 +01:00
|
|
|
package client
|
|
|
|
|
|
|
|
import (
|
2020-11-27 14:00:45 +01:00
|
|
|
"context"
|
2020-11-08 19:28:33 +01:00
|
|
|
"crypto/tls"
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"google.golang.org/grpc"
|
|
|
|
"google.golang.org/grpc/credentials"
|
|
|
|
"google.golang.org/grpc/resolver"
|
|
|
|
|
2021-07-17 22:40:06 +02:00
|
|
|
"go.linka.cloud/grpc/registry/noop"
|
2020-11-08 19:28:33 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type Client interface {
|
2020-11-27 14:00:45 +01:00
|
|
|
grpc.ClientConnInterface
|
2020-11-08 19:28:33 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func New(opts ...Option) (Client, error) {
|
|
|
|
c := &client{opts: &options{}}
|
|
|
|
for _, o := range opts {
|
|
|
|
o(c.opts)
|
|
|
|
}
|
|
|
|
if c.opts.registry == nil {
|
|
|
|
c.opts.registry = noop.New()
|
|
|
|
}
|
|
|
|
resolver.Register(c.opts.registry.ResolverBuilder())
|
|
|
|
c.pool = newPool(DefaultPoolSize, DefaultPoolTTL, DefaultPoolMaxIdle, DefaultPoolMaxStreams)
|
2020-11-27 14:00:45 +01:00
|
|
|
if c.opts.tlsConfig == nil && c.opts.Secure() {
|
|
|
|
c.opts.tlsConfig = &tls.Config{InsecureSkipVerify: true}
|
|
|
|
}
|
|
|
|
if c.opts.tlsConfig != nil {
|
|
|
|
c.opts.dialOptions = append(c.opts.dialOptions, grpc.WithTransportCredentials(credentials.NewTLS(c.opts.tlsConfig)))
|
|
|
|
}
|
|
|
|
c.addr = fmt.Sprintf("%s:///%s", c.opts.registry.String(), c.opts.name)
|
|
|
|
if c.opts.version != "" {
|
|
|
|
c.addr = c.addr + ":" + strings.TrimSpace(c.opts.version)
|
|
|
|
}
|
2020-11-08 19:28:33 +01:00
|
|
|
return c, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type client struct {
|
2020-11-27 14:00:45 +01:00
|
|
|
addr string
|
2020-11-08 19:28:33 +01:00
|
|
|
pool *pool
|
|
|
|
opts *options
|
|
|
|
}
|
|
|
|
|
2020-11-27 14:00:45 +01:00
|
|
|
func (c *client) Invoke(ctx context.Context, method string, args interface{}, reply interface{}, opts ...grpc.CallOption) error {
|
|
|
|
pc, err := c.pool.getConn(c.addr, c.opts.dialOptions...)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
2020-11-08 19:28:33 +01:00
|
|
|
}
|
2020-11-27 14:00:45 +01:00
|
|
|
return pc.Invoke(ctx, method, args, reply, opts...)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *client) NewStream(ctx context.Context, desc *grpc.StreamDesc, method string, opts ...grpc.CallOption) (grpc.ClientStream, error) {
|
|
|
|
pc, err := c.pool.getConn(c.addr, c.opts.dialOptions...)
|
2020-11-08 19:28:33 +01:00
|
|
|
if err != nil {
|
2020-11-27 14:00:45 +01:00
|
|
|
return nil, err
|
2020-11-08 19:28:33 +01:00
|
|
|
}
|
2020-11-27 14:00:45 +01:00
|
|
|
return pc.NewStream(ctx, desc, method, opts...)
|
2020-11-08 19:28:33 +01:00
|
|
|
}
|