-
Notifications
You must be signed in to change notification settings - Fork 16
Expand file tree
/
Copy pathgenerate-env.py
More file actions
150 lines (122 loc) · 5.8 KB
/
generate-env.py
File metadata and controls
150 lines (122 loc) · 5.8 KB
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
import argparse
import json
import os
from enum import Enum
import boto3
from botocore.exceptions import ClientError
class Environments(str, Enum):
DEV = 'dev'
PROD = 'prod'
LOCAL = 'local'
TEST = 'test'
class ConfigAssembler:
"""
Assembles the TechTix (Backend) config file
"""
def __init__(self, aws_region='ap-southeast-1', environment=Environments.DEV.value):
self.__input_environment = environment
self.__project_name = 'sparcs-events'
# Determine the deployment stage, defaulting to 'dev' for None or 'local' environments
if not self.__input_environment or self.__input_environment == Environments.LOCAL.value:
self.__stage = Environments.DEV.value
else:
self.__stage = self.__input_environment
self.__region = 'ap-southeast-1' if aws_region is None else aws_region
self.__ssm_client = boto3.client('ssm', region_name=self.__region)
self.__secrets_client = boto3.client('secretsmanager', region_name=self.__region)
self.__base_dir = os.getcwd()
def __get_parameter(self, key, decrypt=False) -> str:
"""
Retrieves parameter values from SSM
:param key: key of parameter value to be retrieved
:param decrypt: flag if value is decrypted
:return: parameter value string
"""
kwargs = {'Name': key, 'WithDecryption': decrypt}
value = ''
try:
resp = self.__ssm_client.get_parameter(**kwargs)
except ClientError as e:
print(f'Error: {e.response["Error"]["Code"]} - {key}')
else:
value = resp['Parameter']['Value']
return value
def __get_secret(self, secret_arn) -> str:
"""
Retrieves secret value from AWS Secrets Manager
:param secret_arn: ARN of the secret to retrieve
:return: secret value string
"""
try:
resp = self.__secrets_client.get_secret_value(SecretId=secret_arn)
return resp['SecretString']
except ClientError as e:
print(f'Error retrieving secret: {e.response["Error"]["Code"]} - {secret_arn}')
return ''
@staticmethod
def escape_env_value(value: str) -> str:
return value.replace('$', '$$')
@staticmethod
def write_config(file_handle, key, value) -> None:
"""
Writes specified config key-value in the config file
:param file_handle: File pointer
:param key: key of config
:param value: value of config
:return: None
"""
entry = f'{key}={ConfigAssembler.escape_env_value(str(value))}\n'
file_handle.write(entry)
def construct_config_file(self) -> None:
"""
Constructs the config file for Helix
:return: None
"""
region = 'ap-southeast-1'
stage = self.__stage
entities_table = self.__get_parameter(f"/{stage}-sparcs-events-entities")
registrations_table = self.__get_parameter(f"/{stage}-sparcs-events-registrations")
preregistrations_table = self.__get_parameter(f"/{stage}-sparcs-events-preregistrations")
evaluations_table = self.__get_parameter(f"/{stage}-sparcs-events-evaluations")
events_table = self.__get_parameter(f"/{stage}-sparcs-events")
email_queue = self.__get_parameter(f"/sparcs-events-email-queue-url-{stage}")
certificate_queue = self.__get_parameter(f"/sparcs-events-certificate-queue-url-{stage}")
s3_bucket = self.__get_parameter(f"/{stage}-sparcs-events-file-bucket")
userpool_id = f"techtix/cognito-user-pool-id-{stage}"
userpool_client_id = f"techtix/cognito-user-pool-client-id-{stage}"
if self.__input_environment == Environments.LOCAL.value or stage == Environments.LOCAL.value:
frontend_url = 'http://localhost:3000'
else:
frontend_url = self.__get_parameter(f"techtix/frontend-url-{stage}")
# Determine if this is a local environment
is_local = (
self.__input_environment == Environments.LOCAL.value
or self.__input_environment == Environments.TEST.value
)
config_file = f'{self.__base_dir}/.env'
with open(config_file, 'w', encoding='utf-8') as file_handle:
self.write_config(file_handle, 'REGION', region)
self.write_config(file_handle, 'FRONTEND_URL', frontend_url)
self.write_config(file_handle, 'ENTITIES_TABLE', entities_table)
self.write_config(file_handle, 'REGISTRATIONS_TABLE', registrations_table)
self.write_config(file_handle, 'PREREGISTRATIONS_TABLE', preregistrations_table)
self.write_config(file_handle, 'EVALUATIONS_TABLE', evaluations_table)
self.write_config(file_handle, 'EVENTS_TABLE', events_table)
self.write_config(file_handle, 'EMAIL_QUEUE', email_queue)
self.write_config(file_handle, 'CERTIFICATE_QUEUE', certificate_queue)
self.write_config(file_handle, 'S3_BUCKET', s3_bucket)
self.write_config(file_handle, 'USERPOOL_ID', userpool_id)
self.write_config(file_handle, 'USERPOOL_CLIENT_ID', userpool_client_id)
self.write_config(file_handle, 'STAGE', stage)
print(f'Configuration file created successfully at: {config_file}')
if __name__ == '__main__':
print(Environments)
parser = argparse.ArgumentParser(description='TechTix (Backend) Configuration Assembler')
parser.add_argument('-r', '--region', help='AWS Region (default: ap-southeast-1)')
parser.add_argument('-s', '--stage', help='Environment Name (default: dev)')
args = parser.parse_args()
print('Arguments:', args)
region = args.region
input_stage = args.stage
config_assembler = ConfigAssembler(region, input_stage)
config_assembler.construct_config_file()