-
Notifications
You must be signed in to change notification settings - Fork 1.7k
/
dbcmd_cli_command_provider.go
81 lines (69 loc) · 2.56 KB
/
dbcmd_cli_command_provider.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
// Copyright 2022 Gravitational, Inc
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package clusters
import (
"fmt"
"strings"
"github.com/gravitational/trace"
"github.com/gravitational/teleport/lib/client/db/dbcmd"
"github.com/gravitational/teleport/lib/teleterm/gateway"
"github.com/gravitational/teleport/lib/tlsca"
)
// DbcmdCLICommandProvider provides CLI commands for database gateways. It needs Storage to read
// fresh profile state from the disk.
type DbcmdCLICommandProvider struct {
storage StorageByResourceURI
execer dbcmd.Execer
}
type StorageByResourceURI interface {
GetByResourceURI(string) (*Cluster, error)
}
func NewDbcmdCLICommandProvider(storage StorageByResourceURI, execer dbcmd.Execer) DbcmdCLICommandProvider {
return DbcmdCLICommandProvider{
storage: storage,
execer: execer,
}
}
func (d DbcmdCLICommandProvider) GetCommand(gateway *gateway.Gateway) (string, error) {
cluster, err := d.storage.GetByResourceURI(gateway.TargetURI())
if err != nil {
return "", trace.Wrap(err)
}
routeToDb := tlsca.RouteToDatabase{
ServiceName: gateway.TargetName(),
Protocol: gateway.Protocol(),
Username: gateway.TargetUser(),
Database: gateway.TargetSubresourceName(),
}
cmd, err := dbcmd.NewCmdBuilder(cluster.clusterClient, &cluster.status, &routeToDb,
// TODO(ravicious): Pass the root cluster name here. cluster.Name returns leaf name for leaf
// clusters.
//
// At this point it doesn't matter though because this argument is used only for
// generating correct CA paths. We use dbcmd.WithNoTLS here which means that the CA paths aren't
// included in the returned CLI command.
cluster.Name,
dbcmd.WithLogger(gateway.Log()),
dbcmd.WithLocalProxy(gateway.LocalAddress(), gateway.LocalPortInt(), ""),
dbcmd.WithNoTLS(),
dbcmd.WithPrintFormat(),
dbcmd.WithTolerateMissingCLIClient(),
dbcmd.WithExecer(d.execer),
).GetConnectCommandNoAbsPath()
if err != nil {
return "", trace.Wrap(err)
}
cmdString := strings.TrimSpace(fmt.Sprintf("%s %s", strings.Join(cmd.Env, " "), cmd.String()))
return cmdString, nil
}