forked from aliyun/terraform-provider-alicloud
/
service_alicloud_cs.go
115 lines (101 loc) · 3.12 KB
/
service_alicloud_cs.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
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
package alicloud
import (
"fmt"
"strings"
"time"
"github.com/denverdino/aliyungo/cs"
"github.com/terraform-providers/terraform-provider-alicloud/alicloud/connectivity"
)
type CsService struct {
client *connectivity.AliyunClient
}
func (s *CsService) GetContainerClusterByName(name string) (cluster cs.ClusterType, err error) {
name = Trim(name)
invoker := NewInvoker()
var clusters []cs.ClusterType
err = invoker.Run(func() error {
raw, e := s.client.WithCsClient(func(csClient *cs.Client) (interface{}, error) {
return csClient.DescribeClusters(name)
})
if e != nil {
return e
}
clusters, _ = raw.([]cs.ClusterType)
return nil
})
if err != nil {
return cluster, fmt.Errorf("Describe cluster failed by name %s: %#v.", name, err)
}
if len(clusters) < 1 {
return cluster, GetNotFoundErrorFromString(GetNotFoundMessage("Container Cluster", name))
}
for _, c := range clusters {
if c.Name == name {
return c, nil
}
}
return cluster, GetNotFoundErrorFromString(GetNotFoundMessage("Container Cluster", name))
}
func (s *CsService) GetContainerClusterAndCertsByName(name string) (*cs.ClusterType, *cs.ClusterCerts, error) {
cluster, err := s.GetContainerClusterByName(name)
if err != nil {
return nil, nil, err
}
var certs cs.ClusterCerts
invoker := NewInvoker()
err = invoker.Run(func() error {
raw, e := s.client.WithCsClient(func(csClient *cs.Client) (interface{}, error) {
return csClient.GetClusterCerts(cluster.ClusterID)
})
if e != nil {
return e
}
certs, _ = raw.(cs.ClusterCerts)
return nil
})
if err != nil {
return nil, nil, err
}
return &cluster, &certs, nil
}
func (s *CsService) DescribeContainerApplication(clusterName, appName string) (app cs.GetProjectResponse, err error) {
appName = Trim(appName)
cluster, certs, err := s.GetContainerClusterAndCertsByName(clusterName)
if err != nil {
return app, err
}
raw, err := s.client.WithCsProjectClient(cluster.ClusterID, cluster.MasterURL, *certs, func(csProjectClient *cs.ProjectClient) (interface{}, error) {
return csProjectClient.GetProject(appName)
})
app, _ = raw.(cs.GetProjectResponse)
if err != nil {
if IsExceptedError(err, ApplicationNotFound) {
return app, GetNotFoundErrorFromString(GetNotFoundMessage("Container Application", appName))
}
return app, fmt.Errorf("Getting Application failed by name %s: %#v.", appName, err)
}
if app.Name != appName {
return app, GetNotFoundErrorFromString(GetNotFoundMessage("Container Application", appName))
}
return
}
func (s *CsService) WaitForContainerApplication(clusterName, appName string, status Status, timeout int) error {
if timeout <= 0 {
timeout = DefaultTimeout
}
for {
app, err := s.DescribeContainerApplication(clusterName, appName)
if err != nil {
return err
}
if strings.ToLower(app.CurrentState) == strings.ToLower(string(status)) {
break
}
timeout = timeout - DefaultIntervalShort
if timeout <= 0 {
return GetTimeErrorFromString(fmt.Sprintf("Waitting for container application %s is timeout and current status is %s.", string(status), app.CurrentState))
}
time.Sleep(DefaultIntervalShort * time.Second)
}
return nil
}