-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathrun_create_ramiel_codedeploy.py
executable file
·112 lines (89 loc) · 3.38 KB
/
run_create_ramiel_codedeploy.py
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
#!/usr/bin/env python3
from env import env
from run_common import AWSCli
from run_common import print_message
from run_common import print_session
from run_common import re_sub_lines
from run_common import read_file
from run_common import reset_template_dir
options, args = dict(), list()
if __name__ == "__main__":
from run_common import parse_args
options, args = parse_args()
print_session('create codedeploy')
reset_template_dir(options)
settings = env.get('codedeploy', dict())
region = settings['AWS_REGION']
aws_cli = AWSCli(region)
print_message('create a user for codedeploy')
iam_policy_name = 'ramiel_codedeploy_iam_session_permission'
account_id = aws_cli.get_caller_account_id()
policy_arn = f'arn:aws:iam::{account_id}:policy/{iam_policy_name}'
if not aws_cli.get_iam_policy(policy_arn):
lines = read_file('aws_iam/aws-codedeploy-ramiel-permission.json')
lines = re_sub_lines(lines, 'ACCOUNT_ID', account_id)
pp = ' '.join(lines)
cc = ['iam', 'create-policy']
cc += ['--policy-name', iam_policy_name]
cc += ['--policy-document', pp]
aws_cli.run(cc)
iam_user_name = 'ramiel_codedeploy_iam_session_user'
rr = aws_cli.get_iam_user(iam_user_name)
if not rr:
cc = ['iam', 'create-user']
cc += ['--user-name', iam_user_name]
aws_cli.run(cc)
cc = ['iam', 'list-attached-user-policies']
cc += ['--user-name', iam_user_name]
rr = aws_cli.run(cc)
if not rr['AttachedPolicies']:
cc = ['iam', 'attach-user-policy']
cc += ['--user-name', iam_user_name]
cc += ['--policy-arn', policy_arn]
aws_cli.run(cc)
print_message('create a role for codedeploy')
iam_role_name = 'ramiel_codedeploy_iam_session_role'
role_arn = None
# noinspection PyBroadException
try:
role_arn = aws_cli.get_role_arn(iam_role_name)
except Exception:
cc = ['iam', 'create-role']
cc += ['--role-name', iam_role_name]
cc += ['--assume-role-policy-document', 'file://aws_iam/aws-codedeploy-ramiel-role.json']
rr = aws_cli.run(cc)
cc = ['iam', 'list-attached-role-policies']
cc += ['--role-name', iam_role_name]
rr = aws_cli.run(cc)
if not rr['AttachedPolicies']:
cc = ['iam', 'attach-role-policy']
cc += ['--role-name', iam_role_name]
cc += ['--policy-arn', policy_arn]
aws_cli.run(cc)
print_message('create codedeploy resources: applications and deployment groups')
for app in settings['APPLICATIONS']:
app_name = app['NAME']
cc = ['deploy', 'get-application']
cc += ['--application-name', app_name]
rr = aws_cli.run(cc, ignore_error=True)
if not rr:
cc = ['deploy', 'create-application']
cc += ['--application-name', app_name]
aws_cli.run(cc)
for dep_group in app['DEPLOYMENT_GROUPS']:
dep_name = dep_group['NAME']
on_premises_tag_set = dep_group['ON_PREMISES_TAG_SET']
cc = ['deploy', 'get-deployment-group']
cc += ['--application-name', app_name]
cc += ['--deployment-group-name', dep_name]
rr = aws_cli.run(cc, ignore_error=True)
if rr:
continue
cc = ['deploy', 'create-deployment-group']
cc += ['--application-name', app_name]
cc += ['--deployment-group-name', dep_name]
cc += ['--service-role-arn', role_arn]
if on_premises_tag_set:
cc += ['--on-premises-tag-set', on_premises_tag_set]
aws_cli.run(cc)
print_message(f'YOU SHOULD create Access key for codedeploy user {iam_user_name}')