-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathACS-ECS-BulkyModifyUserPasswordByCloudAssistantKeyPair.yml
144 lines (144 loc) · 3.79 KB
/
ACS-ECS-BulkyModifyUserPasswordByCloudAssistantKeyPair.yml
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
FormatVersion: OOS-2019-06-01
Description:
en: Bulky modify ECS instance user password by cloud assistant key pair
zh-cn: 批量在ECS通过云助手密钥对修改ECS实例用户密码
name-en: ACS-ECS-BulkyModifyUserPasswordByCloudAssistantKeyPair
name-zh-cn: 通过云助手密钥对修改ECS实例用户密码
categories:
- run_command
Parameters:
regionId:
Type: String
Label:
en: RegionId
zh-cn: 地域ID
AssociationProperty: RegionId
Default: '{{ ACS::RegionId }}'
targets:
Type: Json
Label:
en: TargetInstance
zh-cn: 目标实例
AssociationProperty: Targets
AssociationPropertyMetadata:
ResourceType: ALIYUN::ECS::Instance
RegionId: regionId
username:
Label:
en: Username
zh-cn: 要修改密码的用户名
Type: String
passwordInfo:
Type: Json
Label:
en: Password Information
zh-cn: 实例密码信息
Description:
en: |
Format:
<pre id="jsonShow">{
"$instanceId1": "$encrypedPassword1",
"$instanceId2": "$encrypedPassword2"
}</pre>
zh-cn: |
格式:
<pre id="jsonShow">{
"$instanceId1": "$encrypedPassword1",
"$instanceId2": "$encrypedPassword2"
}</pre>
rateControl:
Label:
en: RateControl
zh-cn: 任务执行的并发比率
Type: Json
AssociationProperty: RateControl
Default:
Mode: Concurrency
MaxErrors: 0
Concurrency: 10
OOSAssumeRole:
Label:
en: OOSAssumeRole
zh-cn: OOS扮演的RAM角色
Type: String
Default: ''
RamRole: '{{ OOSAssumeRole }}'
Tasks:
- Name: getInstance
Description:
en: Views the ECS instances
zh-cn: 获取ECS实例
Action: ACS::SelectTargets
Properties:
ResourceType: ALIYUN::ECS::Instance
RegionId: '{{ regionId }}'
Filters:
- '{{ targets }}'
Outputs:
instanceIds:
Type: List
ValueSelector: Instances.Instance[].InstanceId
instanceInfos:
Type: List
ValueSelector: .Instances.Instance[] | {"osType":.OSType, "instanceId":.InstanceId}
- Name: invokeCommand
Action: ACS::ECS::InvokeCommand
Properties:
instanceId: '{{ ACS::TaskLoopItem }}'
regionId: '{{ regionId }}'
parameters:
KEY_PAIR_ID: '{{ ACS::TaskLoopItem }}'
ENCRYPTED_PASSWORD:
Fn::Select:
- '{{ ACS::TaskLoopItem }}'
- '{{ passwordInfo }}'
USER_NAME: '{{ username }}'
commandId:
Fn::If:
- Fn::Equals:
- Fn::Jq:
- First
- .|map(select(.instanceId == "{{ ACS::TaskLoopItem }}").osType)[]
- '{{ getInstance.instanceInfos }}'
- linux
- ACS-ECS-ResetPassword-for-linux.sh
- ACS-ECS-ResetPassword-for-windows.ps1
Loop:
Items: '{{ getInstance.instanceIds }}'
RateControl: '{{ rateControl }}'
Outputs:
commandOutputs:
AggregateType: Fn::ListJoin
AggregateField: commandOutput
Outputs:
commandOutput:
Type: String
ValueSelector: invocationOutput
Outputs:
commandOutput:
Type: List
Value: '{{ invokeCommand.commandOutputs }}'
Metadata:
ALIYUN::OOS::Interface:
ParameterGroups:
- Parameters:
- regionId
- targets
Label:
default:
zh-cn: 选择实例
en: Select Ecs Instances
- Parameters:
- username
- passwordInfo
Label:
default:
zh-cn: 用户密码信息
en: User Password Information
- Parameters:
- rateControl
- OOSAssumeRole
Label:
default:
zh-cn: 高级选项
en: Control Options