mirror of https://github.com/hashicorp/consul
grpc client default in plaintext mode (#19412)
* grpc client default in plaintext mode * renaming and fix linter * update the description and remove the context * trim testspull/19605/head
parent
419677cc9e
commit
9dc24448ae
|
@ -19,10 +19,11 @@ import (
|
||||||
"sync"
|
"sync"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/hashicorp/consul/api"
|
|
||||||
"github.com/hashicorp/go-cleanhttp"
|
"github.com/hashicorp/go-cleanhttp"
|
||||||
"github.com/hashicorp/go-hclog"
|
"github.com/hashicorp/go-hclog"
|
||||||
"github.com/hashicorp/go-rootcerts"
|
"github.com/hashicorp/go-rootcerts"
|
||||||
|
|
||||||
|
"github.com/hashicorp/consul/api"
|
||||||
)
|
)
|
||||||
|
|
||||||
// NOTE: This client is copied from the api module to temporarily facilitate the resource cli commands
|
// NOTE: This client is copied from the api module to temporarily facilitate the resource cli commands
|
||||||
|
@ -72,12 +73,6 @@ const (
|
||||||
// whether or not to disable certificate checking.
|
// whether or not to disable certificate checking.
|
||||||
HTTPSSLVerifyEnvName = "CONSUL_HTTP_SSL_VERIFY"
|
HTTPSSLVerifyEnvName = "CONSUL_HTTP_SSL_VERIFY"
|
||||||
|
|
||||||
// GRPCAddrEnvName defines an environment variable name which sets the gRPC
|
|
||||||
// address for consul connect envoy. Note this isn't actually used by the api
|
|
||||||
// client in this package but is defined here for consistency with all the
|
|
||||||
// other ENV names we use.
|
|
||||||
GRPCAddrEnvName = "CONSUL_GRPC_ADDR"
|
|
||||||
|
|
||||||
// GRPCCAFileEnvName defines an environment variable name which sets the
|
// GRPCCAFileEnvName defines an environment variable name which sets the
|
||||||
// CA file to use for talking to Consul gRPC over TLS.
|
// CA file to use for talking to Consul gRPC over TLS.
|
||||||
GRPCCAFileEnvName = "CONSUL_GRPC_CACERT"
|
GRPCCAFileEnvName = "CONSUL_GRPC_CACERT"
|
||||||
|
|
|
@ -0,0 +1,39 @@
|
||||||
|
// Copyright (c) HashiCorp, Inc.
|
||||||
|
// SPDX-License-Identifier: BUSL-1.1
|
||||||
|
|
||||||
|
package client
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"google.golang.org/grpc"
|
||||||
|
"google.golang.org/grpc/credentials/insecure"
|
||||||
|
|
||||||
|
"github.com/hashicorp/consul/proto-public/pbresource"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GRPCClient struct {
|
||||||
|
Client pbresource.ResourceServiceClient
|
||||||
|
Config *GRPCConfig
|
||||||
|
Conn *grpc.ClientConn
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewGRPCClient(config *GRPCConfig) (*GRPCClient, error) {
|
||||||
|
conn, err := dial(config)
|
||||||
|
if err != nil {
|
||||||
|
return nil, fmt.Errorf("**** error dialing grpc: %+v", err)
|
||||||
|
}
|
||||||
|
return &GRPCClient{
|
||||||
|
Client: pbresource.NewResourceServiceClient(conn),
|
||||||
|
Config: config,
|
||||||
|
Conn: conn,
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func dial(c *GRPCConfig) (*grpc.ClientConn, error) {
|
||||||
|
// TODO: decide if we use TLS mode based on the config
|
||||||
|
dialOpts := []grpc.DialOption{
|
||||||
|
grpc.WithTransportCredentials(insecure.NewCredentials()),
|
||||||
|
}
|
||||||
|
return grpc.Dial(c.Address, dialOpts...)
|
||||||
|
}
|
|
@ -0,0 +1,51 @@
|
||||||
|
// Copyright (c) HashiCorp, Inc.
|
||||||
|
// SPDX-License-Identifier: BUSL-1.1
|
||||||
|
|
||||||
|
package client
|
||||||
|
|
||||||
|
import (
|
||||||
|
"context"
|
||||||
|
"fmt"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
"google.golang.org/protobuf/proto"
|
||||||
|
|
||||||
|
"github.com/hashicorp/consul/agent"
|
||||||
|
"github.com/hashicorp/consul/internal/resource/demo"
|
||||||
|
"github.com/hashicorp/consul/proto-public/pbresource"
|
||||||
|
"github.com/hashicorp/consul/proto/private/prototest"
|
||||||
|
"github.com/hashicorp/consul/sdk/testutil"
|
||||||
|
"github.com/hashicorp/consul/testrpc"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestResourceRead(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
a := agent.NewTestAgent(t, "ports { grpc = 8502 }")
|
||||||
|
testrpc.WaitForTestAgent(t, a.RPC, "dc1")
|
||||||
|
grpcConfig := GetDefaultGRPCConfig()
|
||||||
|
gRPCClient, err := NewGRPCClient(grpcConfig)
|
||||||
|
|
||||||
|
t.Cleanup(func() {
|
||||||
|
a.Shutdown()
|
||||||
|
gRPCClient.Conn.Close()
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("test", func(t *testing.T) {
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println("error when create new grpc client")
|
||||||
|
}
|
||||||
|
|
||||||
|
v2Artist, err := demo.GenerateV2Artist()
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
writeRsp, err := gRPCClient.Client.Write(testutil.TestContext(t), &pbresource.WriteRequest{Resource: v2Artist})
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
readRsp, err := gRPCClient.Client.Read(context.Background(), &pbresource.ReadRequest{Id: v2Artist.Id})
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Equal(t, proto.Equal(readRsp.Resource.Id.Type, demo.TypeV2Artist), true)
|
||||||
|
prototest.AssertDeepEqual(t, writeRsp.Resource, readRsp.Resource)
|
||||||
|
})
|
||||||
|
}
|
|
@ -0,0 +1,43 @@
|
||||||
|
// Copyright (c) HashiCorp, Inc.
|
||||||
|
// SPDX-License-Identifier: BUSL-1.1
|
||||||
|
|
||||||
|
package client
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
// GRPCAddrEnvName defines an environment variable name which sets the gRPC
|
||||||
|
// server address for the consul CLI.
|
||||||
|
GRPCAddrEnvName = "CONSUL_GRPC_ADDR"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GRPCConfig struct {
|
||||||
|
Address string
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetDefaultGRPCConfig() *GRPCConfig {
|
||||||
|
return &GRPCConfig{
|
||||||
|
Address: "localhost:8502",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func LoadGRPCConfig(defaultConfig *GRPCConfig) *GRPCConfig {
|
||||||
|
if defaultConfig == nil {
|
||||||
|
defaultConfig = GetDefaultGRPCConfig()
|
||||||
|
}
|
||||||
|
|
||||||
|
overwrittenConfig := loadEnvToDefaultConfig(defaultConfig)
|
||||||
|
|
||||||
|
return overwrittenConfig
|
||||||
|
}
|
||||||
|
|
||||||
|
func loadEnvToDefaultConfig(config *GRPCConfig) *GRPCConfig {
|
||||||
|
|
||||||
|
if addr := os.Getenv(GRPCAddrEnvName); addr != "" {
|
||||||
|
config.Address = addr
|
||||||
|
}
|
||||||
|
|
||||||
|
return config
|
||||||
|
}
|
|
@ -0,0 +1,58 @@
|
||||||
|
// Copyright (c) HashiCorp, Inc.
|
||||||
|
// SPDX-License-Identifier: BUSL-1.1
|
||||||
|
|
||||||
|
package client
|
||||||
|
|
||||||
|
import (
|
||||||
|
"flag"
|
||||||
|
)
|
||||||
|
|
||||||
|
type GRPCFlags struct {
|
||||||
|
address StringValue
|
||||||
|
}
|
||||||
|
|
||||||
|
// mergeFlagsIntoGRPCConfig merges flag values into grpc config
|
||||||
|
// caller has to parse the CLI args before loading them into flag values
|
||||||
|
func (f *GRPCFlags) mergeFlagsIntoGRPCConfig(c *GRPCConfig) {
|
||||||
|
f.address.Merge(&c.Address)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *GRPCFlags) ClientFlags() *flag.FlagSet {
|
||||||
|
fs := flag.NewFlagSet("", flag.ContinueOnError)
|
||||||
|
fs.Var(&f.address, "grpc-addr",
|
||||||
|
"The `address` and port of the Consul GRPC agent. The value can be an IP "+
|
||||||
|
"address or DNS address, but it must also include the port. This can "+
|
||||||
|
"also be specified via the CONSUL_GRPC_ADDR environment variable. The "+
|
||||||
|
"default value is 127.0.0.1:8502. It supports TLS communication "+
|
||||||
|
"by setting the environment variable CONSUL_GRPC_TLS=true.")
|
||||||
|
return fs
|
||||||
|
}
|
||||||
|
|
||||||
|
type StringValue struct {
|
||||||
|
v *string
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set implements the flag.Value interface.
|
||||||
|
func (s *StringValue) Set(v string) error {
|
||||||
|
if s.v == nil {
|
||||||
|
s.v = new(string)
|
||||||
|
}
|
||||||
|
*(s.v) = v
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// String implements the flag.Value interface.
|
||||||
|
func (s *StringValue) String() string {
|
||||||
|
var current string
|
||||||
|
if s.v != nil {
|
||||||
|
current = *(s.v)
|
||||||
|
}
|
||||||
|
return current
|
||||||
|
}
|
||||||
|
|
||||||
|
// Merge will overlay this value if it has been set.
|
||||||
|
func (s *StringValue) Merge(onto *string) {
|
||||||
|
if s.v != nil {
|
||||||
|
*onto = *(s.v)
|
||||||
|
}
|
||||||
|
}
|
|
@ -86,10 +86,6 @@ func (c *cmd) Run(args []string) int {
|
||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if len(args) < 2 {
|
|
||||||
c.UI.Error("Incorrect argument format: Must specify two arguments: resource type and resource name")
|
|
||||||
return 1
|
|
||||||
}
|
|
||||||
var err error
|
var err error
|
||||||
gvk, resourceName, err = resource.GetTypeAndResourceName(args)
|
gvk, resourceName, err = resource.GetTypeAndResourceName(args)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
Loading…
Reference in New Issue