-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathMakefile
47 lines (38 loc) · 1.51 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
# Makefile to kickoff terraform.
#
# Before you run this Makefile, you should set the following environment variables to authenticate with AWS,
# which allows you to store and retrieve the remote state.
#
# export AWS_ACCESS_KEY_ID= <your key>
# export AWS_SECRET_ACCESS_KEY= <your secret>
# export AWS_DEFAULT_REGION= <your bucket region e.g. us-west-2>
# export TF_VAR_access_key=$AWS_ACCESS_KEY # exposed as access_key in the terraform scripts
# export TF_VAR_secret_key=$AWS_SECRET_ACCESS_KEY
# ####################################################
#
STATEBUCKET = mycompany-terraform
PREFIX = jenkins
# # Before we start test that we have the mandatory executables available
EXECUTABLES = git terraform
K := $(foreach exec,$(EXECUTABLES),\
$(if $(shell which $(exec)),some string,$(error "No $(exec) in PATH, consider apt-get install $(exec)")))
#
# .PHONY: all s3bucket plan
.PHONY: all plan apply
all: init.txt plan
echo "All"
plan:
@echo "running terraform plan"
terraform plan
apply:
@echo running terraform apply
terraform apply
destroy:
@echo running terraform destroy
terraform destroy
# little hack target to prevent it running again without need
# for second nested Makefile
init.txt:
@echo "initialize remote state file"
terraform remote config -backend=s3 -backend-config="bucket=$(STATEBUCKET)" -backend-config="key=$(PREFIX)/terraform.tfstate"
echo "ran terraform remote config -backend=s3 -backend-config=\"bucket=$(STATEBUCKET)\" -backend-config=\"key=$(PREFIX)/terraform.tfstate\"" > ./init.txt