/
data_source_alicloud_click_house_backup_policies.go
95 lines (89 loc) · 2.48 KB
/
data_source_alicloud_click_house_backup_policies.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
package alicloud
import (
"fmt"
"strconv"
"strings"
"time"
"github.com/aliyun/terraform-provider-alicloud/alicloud/connectivity"
"github.com/hashicorp/terraform-plugin-sdk/helper/schema"
)
func dataSourceAlicloudClickHouseBackupPolicies() *schema.Resource {
return &schema.Resource{
Read: dataSourceAlicloudClickHouseBackupPoliciesRead,
Schema: map[string]*schema.Schema{
"db_cluster_id": {
Type: schema.TypeString,
Required: true,
ForceNew: true,
},
"output_file": {
Type: schema.TypeString,
Optional: true,
},
"policies": {
Type: schema.TypeList,
Computed: true,
Elem: &schema.Resource{
Schema: map[string]*schema.Schema{
"backup_retention_period": {
Type: schema.TypeInt,
Computed: true,
},
"id": {
Type: schema.TypeString,
Computed: true,
},
"db_cluster_id": {
Type: schema.TypeString,
Computed: true,
},
"preferred_backup_period": {
Type: schema.TypeSet,
Elem: &schema.Schema{Type: schema.TypeString},
Computed: true,
},
"preferred_backup_time": {
Type: schema.TypeString,
Computed: true,
},
"status": {
Type: schema.TypeString,
Computed: true,
},
},
},
},
},
}
}
func dataSourceAlicloudClickHouseBackupPoliciesRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*connectivity.AliyunClient)
dbClusterId := d.Get("db_cluster_id")
clickhouseService := ClickhouseService{client}
object, err := clickhouseService.DescribeClickHouseBackupPolicy(dbClusterId.(string))
if err != nil {
if NotFoundError(err) {
d.SetId("ClickHouseBackupPolicy")
return nil
}
return WrapError(err)
}
s := make([]map[string]interface{}, 0)
mapping := map[string]interface{}{
"backup_retention_period": formatInt(object["BackupRetentionPeriod"]),
"id": fmt.Sprint(dbClusterId),
"db_cluster_id": fmt.Sprint(dbClusterId),
"preferred_backup_period": strings.Split(object["PreferredBackupPeriod"].(string), ","),
"preferred_backup_time": object["PreferredBackupTime"],
"status": fmt.Sprint(object["Switch"]),
}
s = append(s, mapping)
d.SetId(strconv.FormatInt(time.Now().Unix(), 16))
if err := d.Set("policies", s); err != nil {
return WrapError(err)
}
if output, ok := d.GetOk("output_file"); ok && output.(string) != "" {
writeToFile(output.(string), s)
}
return nil
}