-
Notifications
You must be signed in to change notification settings - Fork 39
Expand file tree
/
Copy pathdescribe.go
More file actions
140 lines (121 loc) · 3.91 KB
/
describe.go
File metadata and controls
140 lines (121 loc) · 3.91 KB
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
package describe
import (
"context"
"fmt"
"strings"
"github.com/stackitcloud/stackit-cli/internal/pkg/types"
"github.com/spf13/cobra"
"github.com/stackitcloud/stackit-cli/internal/pkg/args"
"github.com/stackitcloud/stackit-cli/internal/pkg/errors"
"github.com/stackitcloud/stackit-cli/internal/pkg/examples"
"github.com/stackitcloud/stackit-cli/internal/pkg/globalflags"
"github.com/stackitcloud/stackit-cli/internal/pkg/print"
"github.com/stackitcloud/stackit-cli/internal/pkg/services/ske/client"
"github.com/stackitcloud/stackit-cli/internal/pkg/tables"
"github.com/stackitcloud/stackit-cli/internal/pkg/utils"
ske "github.com/stackitcloud/stackit-sdk-go/services/ske/v2api"
)
const (
clusterNameArg = "CLUSTER_NAME"
)
type inputModel struct {
*globalflags.GlobalFlagModel
ClusterName string
}
func NewCmd(params *types.CmdParams) *cobra.Command {
cmd := &cobra.Command{
Use: fmt.Sprintf("describe %s", clusterNameArg),
Short: "Shows details of a SKE cluster",
Long: "Shows details of a STACKIT Kubernetes Engine (SKE) cluster.",
Args: args.SingleArg(clusterNameArg, nil),
Example: examples.Build(
examples.NewExample(
`Get details of a SKE cluster with name "my-cluster"`,
"$ stackit ske cluster describe my-cluster"),
examples.NewExample(
`Get details of a SKE cluster with name "my-cluster" in JSON format`,
"$ stackit ske cluster describe my-cluster --output-format json"),
),
RunE: func(cmd *cobra.Command, args []string) error {
ctx := context.Background()
model, err := parseInput(params.Printer, cmd, args)
if err != nil {
return err
}
// Configure API client
apiClient, err := client.ConfigureClient(params.Printer, params.CliVersion)
if err != nil {
return err
}
// Call API
req := buildRequest(ctx, model, apiClient)
resp, err := req.Execute()
if err != nil {
return fmt.Errorf("read SKE cluster: %w", err)
}
return outputResult(params.Printer, model.OutputFormat, resp)
},
}
return cmd
}
func parseInput(p *print.Printer, cmd *cobra.Command, inputArgs []string) (*inputModel, error) {
clusterName := inputArgs[0]
globalFlags := globalflags.Parse(p, cmd)
if globalFlags.ProjectId == "" {
return nil, &errors.ProjectIdError{}
}
model := inputModel{
GlobalFlagModel: globalFlags,
ClusterName: clusterName,
}
p.DebugInputModel(model)
return &model, nil
}
func buildRequest(ctx context.Context, model *inputModel, apiClient *ske.APIClient) ske.ApiGetClusterRequest {
req := apiClient.DefaultAPI.GetCluster(ctx, model.ProjectId, model.Region, model.ClusterName)
return req
}
func outputResult(p *print.Printer, outputFormat string, cluster *ske.Cluster) error {
if cluster == nil {
return fmt.Errorf("cluster is nil")
}
return p.OutputResult(outputFormat, cluster, func() error {
acl := []string{}
if cluster.Extensions != nil && cluster.Extensions.Acl != nil {
acl = cluster.Extensions.Acl.AllowedCidrs
}
table := tables.NewTable()
table.AddRow("NAME", utils.PtrString(cluster.Name))
table.AddSeparator()
if cluster.HasStatus() {
table.AddRow("STATE", utils.PtrString(cluster.Status.Aggregated))
table.AddSeparator()
if clusterErrs := cluster.Status.GetErrors(); len(clusterErrs) != 0 {
handleClusterErrors(clusterErrs, &table)
}
}
if cluster.Kubernetes.Version != "" {
table.AddRow("VERSION", cluster.Kubernetes.Version)
table.AddSeparator()
}
table.AddRow("ACL", acl)
err := table.Display(p)
if err != nil {
return fmt.Errorf("render table: %w", err)
}
return nil
})
}
func handleClusterErrors(clusterErrs []ske.ClusterError, table *tables.Table) {
errs := make([]string, 0, len(clusterErrs))
for _, e := range clusterErrs {
b := new(strings.Builder)
fmt.Fprint(b, e.GetCode())
if msg, ok := e.GetMessageOk(); ok {
fmt.Fprintf(b, ": %s", *msg)
}
errs = append(errs, b.String())
}
table.AddRow("ERRORS", strings.Join(errs, "\n"))
table.AddSeparator()
}