/
cluster_k8s_vesrion.go
85 lines (66 loc) · 1.66 KB
/
cluster_k8s_vesrion.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
82
83
84
85
package cluster
import (
"bytes"
"encoding/json"
"fmt"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
"github.com/mumoshu/terraform-provider-eksctl/pkg/sdk"
"log"
"strconv"
)
type LiveClusterInfo struct {
KubernetesVersion string
Revision int
}
func getLiveClusterInfo(ctx *sdk.Context, d *schema.ResourceData) (*LiveClusterInfo, error) {
log.Printf("[DEBUG] getting eksctl cluster k8s version with id %q", d.Id())
m := &Manager{}
set, err := m.PrepareClusterSet(d)
if err != nil {
return nil, err
}
cluster := set.Cluster
clusterName := cluster.Name + "-" + d.Id()
args := []string{
"get",
"cluster",
"--name", clusterName,
"--region", cluster.Region,
"-o", "json",
}
cmd, err := newEksctlCommandWithAWSProfile(cluster, args...)
if err != nil {
return nil, err
}
cmd.Stdin = bytes.NewReader(set.ClusterConfig)
res, err := ctx.Run(cmd)
if err != nil {
return nil, err
}
type ClusterData struct {
Version string `json:"Version"`
Tags map[string]string `json:"Tags"`
}
var data []ClusterData
if err := json.Unmarshal([]byte(res.Output), &data); err != nil {
return nil, err
}
if len(data) != 1 {
return nil, fmt.Errorf("BUG: expected number of clusters found by running eksctl get cluster: %d\n\n%v", len(data), data)
}
var rev int
{
revisionTagKey := "tf-provider-eksctl/revision"
if r, ok := data[0].Tags[revisionTagKey]; ok {
v, err := strconv.Atoi(r)
if err != nil {
return nil, fmt.Errorf("converting tag value for %s to int: %w", revisionTagKey, err)
}
rev = v
}
}
return &LiveClusterInfo{
KubernetesVersion: data[0].Version,
Revision: rev,
}, nil
}