-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathMakefile
197 lines (155 loc) · 6.86 KB
/
Makefile
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
189
190
191
192
193
194
195
196
197
ifndef env
# $(error env is not set)
env ?= dev
endif
include config-files/config.$(env)
export
ifndef MAIN_STACK_NAME
$(error MAIN_STACK_NAME is not set)
endif
ifndef BUCKET
$(error BUCKET is not set)
endif
ifndef version
export version := $(shell date +%Y%b%d-%H%M)
endif
# Global Vars
export DEPLOY_PREFIX=deploy-packages
# Local to this Makefile Vars
CONFIG_PREFIX=config-files
MAIN_TEMPLATE=cloudformation/antiope-Template.yaml
OUTPUT_TEMPLATE_PREFIX=antiope-Template-Transformed
OUTPUT_TEMPLATE=$(OUTPUT_TEMPLATE_PREFIX)-$(version).yaml
TEMPLATE_URL ?= https://s3.amazonaws.com/$(BUCKET)/$(DEPLOY_PREFIX)/$(OUTPUT_TEMPLATE)
# Create and Package the Lambda Layer, copy it to S3
layer:
cd lambda_layer && $(MAKE) layer
# Execute Code tests to validate syntax
test:
cd aws-inventory && $(MAKE) test
cd search-cluster && $(MAKE) test
# Add the library dependencies into the lamda folders before cloudformation package is run
deps:
cd aws-inventory/lambda && $(MAKE) deps
# cd search-cluster/lambda $(MAKE) deps
#
# Deploy New Code Targets
#
# Everything and the post-deploy scripts
install: deploy post-deploy
# Everything to deploy a fresh version of code
deploy: test cft-validate package cft-deploy push-config
# Package up the nested stacks and code which are copied to S3. Then copy the transformed template to S3 where it will be deployed from
package: deps
@aws cloudformation package --template-file $(MAIN_TEMPLATE) --s3-bucket $(BUCKET) --s3-prefix $(DEPLOY_PREFIX)/transform --output-template-file cloudformation/$(OUTPUT_TEMPLATE) --metadata build_ver=$(version)
@aws s3 cp cloudformation/$(OUTPUT_TEMPLATE) s3://$(BUCKET)/$(DEPLOY_PREFIX)/
rm cloudformation/$(OUTPUT_TEMPLATE)
# Actually perform the deploy using cft-deploy and the manifest file (for params) from the code bundle and templates in the S3 bucket
cft-deploy: package
ifndef MANIFEST
$(error MANIFEST is not set)
endif
ifndef LAYER_URL
$(error LAYER_URL is not set)
endif
cft-deploy -m config-files/$(MANIFEST) --template-url $(TEMPLATE_URL) pTemplateURL=$(TEMPLATE_URL) pBucketName=$(BUCKET) pAWSLambdaLayerPackage=$(LAYER_URL) --force
# Execute the post-deploy scripts required to make it all work
post-deploy:
# cd aws-inventory && $(MAKE) post-deploy
cd cognito && $(MAKE) post-deploy
cd search-cluster && $(MAKE) post-deploy
#
# Promote Existing Code Targets
#
# promote an existing stack to a new environment
# Assumes cross-account access to the lower environment's DEPLOY_PREFIX
promote: cft-promote push-config
# Run cft-deploy with a different manifest on a previously uploaded code bundle and transformed template
cft-promote:
ifndef MANIFEST
$(error MANIFEST is not set)
endif
ifndef LAYER_URL
$(error LAYER_URL is not set)
endif
ifndef template
$(error template is not set)
endif
cft-deploy -m config-files/$(MANIFEST) --template-url $(template) pTemplateURL=$(template) pBucketName=$(BUCKET) pAWSLambdaLayerPackage=$(LAYER_URL) --force
#
# Testing & Cleanup Targets
#
# Validate all the CFTs. Inventory is so large it can only be validated from S3
cft-validate:
cft-validate -t cloudformation/antiope-Template.yaml
cft-validate -t cognito/cloudformation/Cognito-Template.yaml
cft-validate -t search-cluster/cloudformation/SearchCluster-Template.yaml
@aws s3 cp aws-inventory/cloudformation/Inventory-Template.yaml s3://$(BUCKET)/$(DEPLOY_PREFIX)/validate/Inventory-Template.yaml
aws cloudformation validate-template --template-url https://s3.amazonaws.com/$(BUCKET)/$(DEPLOY_PREFIX)/validate/Inventory-Template.yaml > /dev/null
@aws s3 rm s3://$(BUCKET)/$(DEPLOY_PREFIX)/validate/Inventory-Template.yaml
# Clean up dev artifacts
clean:
cd aws-inventory && $(MAKE) clean
cd search-cluster && $(MAKE) clean
cd lambda_layer && $(MAKE) clean
rm -f cloudformation/$(OUTPUT_TEMPLATE_PREFIX)*
# Run pep8 style checks on lambda
pep8:
cd aws-inventory/lambda && $(MAKE) pep8
cd search-cluster/lambda && $(MAKE) pep8
# Purge all deploy packages in the Antiope bucket.
# WARNING - if you do this, you will no longer be able to promote code.
purge-deploy-packages:
aws s3 rm s3://$(BUCKET)/$(DEPLOY_PREFIX)/ --recursive
# Pull down the deploy packages from the Antiope Bucket.
# Use this when you want to see what Cloudformation serverless transforms has done
sync-deploy-packages:
aws s3 sync s3://$(BUCKET)/$(DEPLOY_PREFIX)/ Scratch/$(DEPLOY_PREFIX)/ --delete
#
# Management Targets
#
# target to generate a manifest file. Only do this once
# we use a lowercase manifest to force the user to specify on the command line and not overwrite existing one
manifest:
ifndef manifest
$(error manifest is not set)
endif
cft-generate-manifest -t $(MAIN_TEMPLATE) -m $(manifest) --stack-name $(MAIN_STACK_NAME) --region $(AWS_DEFAULT_REGION)
# Copy the manifest and config file up to S3 for backup & sharing
push-config:
@aws s3 cp config-files/$(MANIFEST) s3://$(BUCKET)/${CONFIG_PREFIX}/$(MANIFEST)
@aws s3 cp config-files/config.$(env) s3://$(BUCKET)/${CONFIG_PREFIX}/config.$(env)
# Pull down the latest config and manifest from S3
pull-config:
aws s3 sync s3://$(BUCKET)/${CONFIG_PREFIX}/ config-files/
# Copy _all_ the AWS resources discovered locally. This can be a lot of files
sync-resources:
aws s3 sync s3://$(BUCKET)/Resources/$(type) Scratch/Resources/$(env)/$(type)
open Scratch/Resources/$(env)/$(type)
# Copy down all the reports Antiope has created
sync-reports:
aws s3 sync s3://$(BUCKET)/Reports Scratch/Reports/$(MAIN_STACK_NAME)
open Scratch/Reports/$(MAIN_STACK_NAME)
# Manually trigger the Antiope Stepfunction
trigger-inventory:
@./bin/trigger_inventory.sh $(MAIN_STACK_NAME)
# Disable the CloudWatch Event that triggers Antiope
disable-inventory:
$(eval EVENT := $(shell aws cloudformation describe-stacks --stack-name $(MAIN_STACK_NAME) --query 'Stacks[0].Outputs[?OutputKey==`TriggerEventName`].OutputValue' --output text --region $(AWS_DEFAULT_REGION)))
aws events disable-rule --name $(EVENT) --output text --region $(AWS_DEFAULT_REGION)
# Enable the CloudWatch Event that triggers Antiope
enable-inventory:
$(eval EVENT := $(shell aws cloudformation describe-stacks --stack-name $(MAIN_STACK_NAME) --query 'Stacks[0].Outputs[?OutputKey==`TriggerEventName`].OutputValue' --output text --region $(AWS_DEFAULT_REGION)))
aws events enable-rule --name $(EVENT) --output text --region $(AWS_DEFAULT_REGION)
# FIXME <- move this into stepfunction
get-inventory-errors:
$(eval QUEUE := $(shell aws cloudformation describe-stacks --stack-name $(MAIN_STACK_NAME) --query 'Stacks[0].Outputs[?OutputKey==`ErrorQueue`].OutputValue' --output text --region $(AWS_DEFAULT_REGION)))
./bin/pull_errors.py --queue $(QUEUE) --filename $(MAIN_STACK_NAME)-Errors.html --delete
open $(MAIN_STACK_NAME)-Errors.html
python-requirements:
pip3 install -r requirements.txt
python-env:
python3 -m venv .env
@echo "now run:\n\tsource .env/bin/activate"
python-env-activate:
@echo "You need to run this from the parent shell: \n\tsource .env/bin/activate"