-
Notifications
You must be signed in to change notification settings - Fork 260
/
Copy pathMakefile
210 lines (179 loc) · 5.87 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
198
199
200
201
202
203
204
205
206
207
208
209
210
COMMIT_SHA?=$(shell git rev-parse --short HEAD)
ifeq ($(PUSH),true)
BUILDX_OP=--push
else
BUILDX_OP=--load
endif
ifdef PLATFORMS
PLATFORM_FLAGS=--platform $(PLATFORMS)
endif
BUILDX_FLAGS=$(BUILDX_OP) $(PLATFORM_FLAGS)
# The Rust version used by our containers
# Can be updated to the latest stable
RUSTUP_TOOLCHAIN=1.83.0
TAG?=$(shell git describe --tags --abbrev=0)
AUTH_TAG?=$(TAG)
DEPLOYER_TAG?=$(TAG)
GATEWAY_TAG?=$(TAG)
LOGGER_TAG?=$(TAG)
PROVISIONER_TAG?=$(TAG)
RESOURCE_RECORDER_TAG?=$(TAG)
DOCKER_BUILD?=docker buildx build
ifeq ($(CI),true)
DOCKER_BUILD+= --progress plain
endif
DOCKER_COMPOSE=$(shell which docker-compose)
ifeq ($(DOCKER_COMPOSE),)
DOCKER_COMPOSE=docker compose
endif
DOCKER_SOCK?=/var/run/docker.sock
POSTGRES_PASSWORD?=postgres
MONGO_INITDB_ROOT_USERNAME?=mongodb
MONGO_INITDB_ROOT_PASSWORD?=password
STRIPE_SECRET_KEY?=""
AUTH_JWTSIGNING_PRIVATE_KEY?=""
PERMIT_API_KEY?=""
# log level set in all backends
RUST_LOG?=shuttle=debug,info
# production/staging/dev
SHUTTLE_ENV?=dev
DD_ENV=$(SHUTTLE_ENV)
ifeq ($(SHUTTLE_ENV),production)
DOCKER_COMPOSE_FILES=docker-compose.yml
STACK=shuttle-prod
APPS_FQDN=shuttleapp.rs
DB_FQDN=db.shuttle.rs
CONTAINER_REGISTRY=public.ecr.aws/shuttle
# make sure we only ever go to production with `--tls=enable`
USE_TLS=enable
CARGO_PROFILE=release
else
# add local development overrides to compose
DOCKER_COMPOSE_FILES=docker-compose.yml docker-compose.dev.yml
STACK?=shuttle-dev
APPS_FQDN=unstable.shuttleapp.rs
DB_FQDN=db.unstable.shuttle.rs
CONTAINER_REGISTRY=public.ecr.aws/shuttle-dev
USE_TLS?=disable
# default for local run
CARGO_PROFILE?=debug
ifeq ($(CI),true)
# use release builds for staging deploys so that the DLC cache can be re-used for prod deploys
CARGO_PROFILE=release
endif
DEV_SUFFIX=-dev
DEPLOYS_API_KEY?=gateway4deployes
GATEWAY_ADMIN_KEY?=dh9z58jttoes3qvt
CORS_ORIGIN?=localhost:3001
# this should use the same version as our prod RDS database
CONTROL_DB_POSTGRES_TAG?=15
CONTROL_DB_POSTGRES_PASSWORD?=postgres
CONTROL_DB_POSTGRES_URI?=postgres://postgres:${CONTROL_DB_POSTGRES_PASSWORD}@control-db:5432/postgres
# this should use the same version as our prod RDS logger database
LOGGER_POSTGRES_TAG?=15
LOGGER_POSTGRES_PASSWORD?=postgres
LOGGER_POSTGRES_URI?=postgres://postgres:${LOGGER_POSTGRES_PASSWORD}@logger-postgres:5432/postgres
endif
POSTGRES_EXTRA_PATH?=./extras/postgres
POSTGRES_TAG?=14
OTEL_EXTRA_PATH?=./extras/otel
OTEL_TAG?=0.90.1
ifeq ($(SHUTTLE_DETACH), disable)
SHUTTLE_DETACH=
else
SHUTTLE_DETACH=--detach
endif
DOCKER_COMPOSE_ENV=\
STACK=$(STACK)\
AUTH_TAG=$(AUTH_TAG)\
DEPLOYER_TAG=$(DEPLOYER_TAG)\
GATEWAY_TAG=$(GATEWAY_TAG)\
LOGGER_TAG=$(LOGGER_TAG)\
PROVISIONER_TAG=$(PROVISIONER_TAG)\
RESOURCE_RECORDER_TAG=$(RESOURCE_RECORDER_TAG)\
POSTGRES_TAG=${POSTGRES_TAG}\
CONTROL_DB_POSTGRES_TAG=${CONTROL_DB_POSTGRES_TAG}\
CONTROL_DB_POSTGRES_PASSWORD=${CONTROL_DB_POSTGRES_PASSWORD}\
CONTROL_DB_POSTGRES_URI=${CONTROL_DB_POSTGRES_URI}\
LOGGER_POSTGRES_TAG=${LOGGER_POSTGRES_TAG}\
LOGGER_POSTGRES_PASSWORD=${LOGGER_POSTGRES_PASSWORD}\
LOGGER_POSTGRES_URI=${LOGGER_POSTGRES_URI}\
OTEL_TAG=${OTEL_TAG}\
APPS_FQDN=$(APPS_FQDN)\
DB_FQDN=$(DB_FQDN)\
POSTGRES_PASSWORD=$(POSTGRES_PASSWORD)\
RUST_LOG=$(RUST_LOG)\
DEPLOYS_API_KEY=$(DEPLOYS_API_KEY)\
CONTAINER_REGISTRY=$(CONTAINER_REGISTRY)\
MONGO_INITDB_ROOT_USERNAME=$(MONGO_INITDB_ROOT_USERNAME)\
MONGO_INITDB_ROOT_PASSWORD=$(MONGO_INITDB_ROOT_PASSWORD)\
STRIPE_SECRET_KEY=$(STRIPE_SECRET_KEY)\
AUTH_JWTSIGNING_PRIVATE_KEY=$(AUTH_JWTSIGNING_PRIVATE_KEY)\
GATEWAY_ADMIN_KEY=$(GATEWAY_ADMIN_KEY)\
CORS_ORIGIN=$(CORS_ORIGIN)\
DD_ENV=$(DD_ENV)\
USE_TLS=$(USE_TLS)\
COMPOSE_PROFILES=$(COMPOSE_PROFILES)\
DOCKER_SOCK=$(DOCKER_SOCK)\
SHUTTLE_ENV=$(SHUTTLE_ENV)\
SHUTTLE_SERVICE_VERSION=$(SHUTTLE_SERVICE_VERSION)\
PERMIT_API_KEY=$(PERMIT_API_KEY)\
PERMIT_DEV_API_KEY=$(PERMIT_DEV_API_KEY)
.PHONY: envfile clean deep-clean images the-shuttle-images shuttle-% postgres otel deploy test docker-compose.rendered.yml up down
envfile:
echo $(DOCKER_COMPOSE_ENV) > dockerenv
clean:
rm .shuttle-*
rm docker-compose.rendered.yml
deep-clean:
find . -type d \( -name target -or -name .shuttle-executables -or -name node_modules \) | xargs rm -rf
images: the-shuttle-images postgres otel
the-shuttle-images: shuttle-auth shuttle-deployer shuttle-gateway shuttle-logger shuttle-provisioner shuttle-resource-recorder
shuttle-%:
$(DOCKER_BUILD) \
--target $(@)$(DEV_SUFFIX) \
--build-arg folder=$(*) \
--build-arg crate=$(@) \
--build-arg prepare_args=$(PREPARE_ARGS) \
--build-arg SHUTTLE_ENV=$(SHUTTLE_ENV) \
--build-arg SHUTTLE_SERVICE_VERSION=$(SHUTTLE_SERVICE_VERSION) \
--build-arg RUSTUP_TOOLCHAIN=$(RUSTUP_TOOLCHAIN) \
--build-arg CARGO_PROFILE=$(CARGO_PROFILE) \
--tag $(CONTAINER_REGISTRY)/$(*):$(COMMIT_SHA) \
--tag $(CONTAINER_REGISTRY)/$(*):$(TAG) \
--tag $(CONTAINER_REGISTRY)/$(*):latest \
$(BUILDX_FLAGS) \
-f Containerfile \
.
postgres:
$(DOCKER_BUILD) \
--build-arg POSTGRES_TAG=$(POSTGRES_TAG) \
--tag $(CONTAINER_REGISTRY)/postgres:$(POSTGRES_TAG) \
$(BUILDX_FLAGS) \
-f $(POSTGRES_EXTRA_PATH)/Containerfile \
$(POSTGRES_EXTRA_PATH)
otel:
$(DOCKER_BUILD) \
--build-arg OTEL_TAG=$(OTEL_TAG) \
--tag $(CONTAINER_REGISTRY)/otel:$(OTEL_TAG) \
$(BUILDX_FLAGS) \
-f $(OTEL_EXTRA_PATH)/Containerfile \
$(OTEL_EXTRA_PATH)
deploy: docker-compose.yml
$(DOCKER_COMPOSE_ENV) docker stack deploy -c $< $(STACK)
docker-compose.rendered.yml: docker-compose.yml docker-compose.dev.yml
$(DOCKER_COMPOSE_ENV) $(DOCKER_COMPOSE) -f docker-compose.yml -f docker-compose.dev.yml $(DOCKER_COMPOSE_CONFIG_FLAGS) -p $(STACK) config > $@
# Start the containers locally.
up: $(DOCKER_COMPOSE_FILES)
$(DOCKER_COMPOSE_ENV) \
$(DOCKER_COMPOSE) \
$(addprefix -f ,$(DOCKER_COMPOSE_FILES)) \
-p $(STACK) \
up \
$(SHUTTLE_DETACH)
down: $(DOCKER_COMPOSE_FILES)
$(DOCKER_COMPOSE_ENV) \
$(DOCKER_COMPOSE) \
$(addprefix -f ,$(DOCKER_COMPOSE_FILES)) \
-p $(STACK) \
down