-
Notifications
You must be signed in to change notification settings - Fork 17
/
ACS-ESS-LifeCycleModifyMongoDBIPWhitelist.json
188 lines (188 loc) · 5.46 KB
/
ACS-ESS-LifeCycleModifyMongoDBIPWhitelist.json
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
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
{
"FormatVersion": "OOS-2019-06-01",
"Description": {
"en": "Use lifecycleHook to modify the IP whitelist of the MongoDB instance",
"zh-cn": "使用生命周期挂钩设置MongoDB实例的IP白名单",
"name-en": "ACS-ESS-LifeCycleModifyMongoDBIPWhitelist",
"name-zh-cn": "使用生命周期挂钩设置MongoDB实例的IP白名单",
"categories": [
"elastic_manage"
]
},
"Parameters": {
"dbInstanceId": {
"Label": {
"en": "DBInstanceId",
"zh-cn": "MongoDB实例ID"
},
"Type": "String"
},
"modifyMode": {
"Label": {
"en": "ModifyMode",
"zh-cn": "修改IP白名单的方式"
},
"Description": {
"en": "The method to modify the IP whitelist, Delete is used for elastic contraction activities, and Append is used for elastic expansion activities",
"zh-cn": "修改IP白名单的方式,Append用于弹性扩张活动,Delete用于弹性收缩活动"
},
"Type": "String",
"AllowedValues": [
"Append",
"Delete"
]
},
"regionId": {
"Label": {
"en": "RegionId",
"zh-cn": "地域ID"
},
"Description": {
"en": "The ID of region",
"zh-cn": "地域ID,请使用弹性伸缩系统默认值 ${regionId}"
},
"Type": "String",
"Default": "${regionId}"
},
"instanceIds": {
"Label": {
"en": "InstanceIds",
"zh-cn": "ECS实例ID列表"
},
"Description": {
"en": "The ID list of the ECS instance",
"zh-cn": "ECS实例ID列表,请使用弹性伸缩系统默认值 [\"${instanceId}\"]"
},
"Type": "List",
"Default": [
"${instanceIds}"
]
},
"lifecycleHookId": {
"Label": {
"en": "LifecycleHookId",
"zh-cn": "生命周期挂钩ID"
},
"Description": {
"en": "The ID of the lifecycle hook",
"zh-cn": "生命周期挂钩ID,请使用弹性伸缩系统默认值 ${lifecycleHookId}"
},
"Type": "String",
"Default": "${lifecycleHookId}"
},
"lifecycleActionToken": {
"Label": {
"en": "LifecycleActionToken",
"zh-cn": "实例关联的特定伸缩活动的令牌"
},
"Description": {
"en": "The token that indicates a specific scaling activity associated with an instance",
"zh-cn": "实例关联的特定伸缩活动的令牌,请使用弹性伸缩系统默认值 ${lifecycleActionToken}"
},
"Type": "String",
"Default": "${lifecycleActionToken}"
},
"OOSAssumeRole": {
"Label": {
"en": "OOSAssumeRole",
"zh-cn": "OOS扮演的RAM角色"
},
"Type": "String",
"Default": "OOSServiceRole"
}
},
"RamRole": "{{ OOSAssumeRole }}",
"Tasks": [
{
"Name": "getInstanceIpAddress",
"Action": "ACS::ExecuteAPI",
"Description": {
"en": "Gets ECS instance network type and ip address",
"zh-cn": "获取ECS实例的网络类型和Ip地址"
},
"OnError": "CompleteLifecycleActionForAbandon",
"Properties": {
"Service": "ECS",
"API": "DescribeInstances",
"Parameters": {
"RegionId": "{{ regionId }}",
"InstanceIds": "{{ instanceIds }}"
}
},
"Outputs": {
"Ips": {
"Type": "List",
"ValueSelector": ".Instances.Instance[]|.VpcAttributes.PrivateIpAddress.IpAddress+.InnerIpAddress.IpAddress|.[]"
}
}
},
{
"Name": "modifySecurityIps",
"Action": "ACS::ExecuteAPI",
"Description": {
"en": "Modifies the whitelist",
"zh-cn": "修改白名单"
},
"OnError": "CompleteLifecycleActionForAbandon",
"OnSuccess": "CompleteLifecycleActionForContinue",
"Properties": {
"Service": "DDS",
"API": "ModifySecurityIps",
"Parameters": {
"RegionId": "{{ regionId }}",
"ModifyMode": "{{ modifyMode }}",
"DBInstanceId": "{{ dbInstanceId }}",
"SecurityIps": {
"Fn::Join": [
",",
"{{ getInstanceIpAddress.Ips }}"
]
}
}
}
},
{
"Name": "CompleteLifecycleActionForContinue",
"Action": "ACS::ExecuteAPI",
"Description": {
"en": "Modify lifecycle action for continue",
"zh-cn": "修改伸缩活动的等待状态为继续完成"
},
"OnSuccess": "ACS::END",
"Properties": {
"Service": "ESS",
"API": "CompleteLifecycleAction",
"Parameters": {
"RegionId": "{{ regionId }}",
"LifecycleHookId": "{{ lifecycleHookId }}",
"LifecycleActionToken": "{{ lifecycleActionToken }}",
"LifecycleActionResult": "CONTINUE"
}
}
},
{
"Name": "CompleteLifecycleActionForAbandon",
"Action": "ACS::ExecuteAPI",
"Description": {
"en": "Complete lifecycle action for Abandon",
"zh-cn": "修改伸缩活动的等待状态为弃用"
},
"Properties": {
"Service": "ESS",
"API": "CompleteLifecycleAction",
"Parameters": {
"RegionId": "{{ regionId }}",
"LifecycleHookId": "{{ lifecycleHookId }}",
"LifecycleActionToken": "{{ lifecycleActionToken }}",
"LifecycleActionResult": "ABANDON"
}
}
}
],
"Outputs": {
"ipAddresses": {
"Type": "List",
"Value": "{{ getInstanceIpAddress.Ips }}"
}
}
}