forked from openfun/ralph
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
286 lines (239 loc) · 8.93 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
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
# -- General
SHELL := /bin/bash
# -- Docker
# Get the current user ID to use for docker run and docker exec commands
DOCKER_UID = $(shell id -u)
DOCKER_GID = $(shell id -g)
DOCKER_USER = $(DOCKER_UID):$(DOCKER_GID)
COMPOSE = DOCKER_USER=$(DOCKER_USER) docker compose
COMPOSE_RUN = $(COMPOSE) run --rm
COMPOSE_TEST_RUN = $(COMPOSE_RUN)
COMPOSE_TEST_RUN_APP = $(COMPOSE_TEST_RUN) app
MKDOCS = $(COMPOSE_RUN) --no-deps --publish "8000:8000" app mkdocs
# -- Elasticsearch
ES_PROTOCOL = http
ES_HOST = localhost
ES_PORT = 9200
ES_INDEX = statements
ES_URL = $(ES_PROTOCOL)://$(ES_HOST):$(ES_PORT)
# -- Arnold
ARNOLD = ARNOLD_IMAGE_TAG=master bin/arnold
ARNOLD_APP = ralph
ARNOLD_APP_VARS = group_vars/customer/$(ARNOLD_CUSTOMER)/$(ARNOLD_ENVIRONMENT)/main.yml
ARNOLD_CUSTOMER ?= ralph
ARNOLD_ENVIRONMENT ?= development
# -- RALPH
RALPH_IMAGE_NAME ?= ralph
RALPH_IMAGE_TAG ?= development
RALPH_IMAGE_BUILD_TARGET ?= development
RALPH_LRS_AUTH_USER_NAME = ralph
RALPH_LRS_AUTH_USER_PWD = secret
RALPH_LRS_AUTH_USER_SCOPE = ralph_scope
# -- K3D
K3D_CLUSTER_NAME ?= ralph
K3D_REGISTRY_HOST ?= registry.127.0.0.1.nip.io
K3D_REGISTRY_NAME ?= k3d-registry.127.0.0.1.nip.io
K3D_REGISTRY_PORT ?= 5000
K3D_REGISTRY_RALPH_IMAGE_NAME = $(K3D_REGISTRY_NAME):$(K3D_REGISTRY_PORT)/$(ARNOLD_ENVIRONMENT)-$(ARNOLD_APP)/$(RALPH_IMAGE_NAME)
K8S_NAMESPACE = $(ARNOLD_ENVIRONMENT)-$(ARNOLD_CUSTOMER)
# ==============================================================================
# RULES
default: help
bin/arnold:
curl -Lo "bin/arnold" "https://raw.githubusercontent.com/openfun/arnold/master/bin/arnold"
chmod +x bin/arnold
bin/init-cluster:
curl -Lo "bin/init-cluster" "https://raw.githubusercontent.com/openfun/arnold/master/bin/init-cluster"
chmod +x bin/init-cluster
.env:
cp .env.dist .env
.ralph/auth.json:
@$(COMPOSE_RUN) app ralph \
auth \
-u $(RALPH_LRS_AUTH_USER_NAME) \
-p $(RALPH_LRS_AUTH_USER_PWD) \
-s $(RALPH_LRS_AUTH_USER_SCOPE) \
-w
# -- Docker/compose
arnold-bootstrap: ## bootstrap arnold's project
arnold-bootstrap: \
bin/arnold
source .k3d-cluster.env.sh && \
$(ARNOLD) -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) setup && \
$(ARNOLD) -d -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) -a $(ARNOLD_APP) create_app_vaults && \
$(ARNOLD) -d -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) -a elasticsearch create_app_vaults && \
$(ARNOLD) -d -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) -- vault -a $(ARNOLD_APP) decrypt
sed -i 's/^# RALPH_BACKENDS__DATABASE__ES/RALPH_BACKENDS__DATABASE__ES/g' group_vars/customer/$(ARNOLD_CUSTOMER)/$(ARNOLD_ENVIRONMENT)/secrets/$(ARNOLD_APP).vault.yml
source .k3d-cluster.env.sh && \
$(ARNOLD) -d -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) -- vault -a $(ARNOLD_APP) encrypt
echo "skip_verification: True" > $(ARNOLD_APP_VARS)
echo "apps:" >> $(ARNOLD_APP_VARS)
echo " - name: elasticsearch" >> $(ARNOLD_APP_VARS)
echo " - name: $(ARNOLD_APP)" >> $(ARNOLD_APP_VARS)
echo "ralph_image_name: $(K3D_REGISTRY_RALPH_IMAGE_NAME)" >> $(ARNOLD_APP_VARS)
echo "ralph_image_tag: $(RALPH_IMAGE_TAG)" >> $(ARNOLD_APP_VARS)
echo "ralph_app_replicas: 1" >> $(ARNOLD_APP_VARS)
echo "ralph_cronjobs:" >> $(ARNOLD_APP_VARS)
echo " - name: $(ARNOLD_ENVIRONMENT)-test" >> $(ARNOLD_APP_VARS)
echo " schedule: '* * * * *'" >> $(ARNOLD_APP_VARS)
echo " command: ['date']" >> $(ARNOLD_APP_VARS)
.PHONY: arnold-bootstrap
arnold-deploy: ## deploy Ralph to k3d using Arnold
source .k3d-cluster.env.sh && \
$(ARNOLD) -d -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) -a $(ARNOLD_APP) deploy && \
$(ARNOLD) -d -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) -a $(ARNOLD_APP) switch
.PHONY: arnold-deploy
arnold-init: ## initialize Ralph k3d project using Arnold
source .k3d-cluster.env.sh && \
$(ARNOLD) -d -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) -a elasticsearch,ralph init && \
$(ARNOLD) -d -c $(ARNOLD_CUSTOMER) -e $(ARNOLD_ENVIRONMENT) -a elasticsearch deploy && \
kubectl -n $(K8S_NAMESPACE) wait --for=condition=ready pod --selector=type=es-node --timeout=120s && \
kubectl -n $(K8S_NAMESPACE) exec svc/elasticsearch -- curl -s -X PUT "localhost:9200/statements?pretty"
.PHONY: arnold-init
bootstrap: ## bootstrap the project for development
bootstrap: \
.env \
build \
dev \
.ralph/auth.json \
es-index
.PHONY: bootstrap
build: ## build the app container
build: .env
RALPH_IMAGE_BUILD_TARGET=$(RALPH_IMAGE_BUILD_TARGET) \
RALPH_IMAGE_NAME=$(RALPH_IMAGE_NAME) \
RALPH_IMAGE_TAG=$(RALPH_IMAGE_TAG) \
$(COMPOSE) build app
.PHONY: build
dev: ## perform editable install from mounted project sources
DOCKER_USER=0 docker compose run --rm app pip install -e ".[dev]"
.PHONY: dev
docker-hub: ## Publish locally built image
docker-hub: build
@$(COMPOSE) push
.PHONY: docker-hub
docs-build: ## build documentation site
@$(MKDOCS) build
.PHONY: docs-build
docs-deploy: ## deploy documentation site
@$(MKDOCS) gh-deploy
.PHONY: docs-deploy
docs-serve: ## run mkdocs live server
@$(MKDOCS) serve --dev-addr 0.0.0.0:8000
.PHONY: docs-serve
down: ## stop and remove backend containers
@$(COMPOSE) down
.PHONY: down
es-index: ## create elasticsearch index
es-index: run-es
@echo "Creating $(ES_INDEX) index..."
curl -X PUT $(ES_URL)/$(ES_INDEX)
@echo -e "\nConfiguring $(ES_INDEX) index..."
curl -X PUT $(ES_URL)/$(ES_INDEX)/_settings -H 'Content-Type: application/json' -d '{"index": {"number_of_replicas": 0}}'
.PHONY: es-index
k3d-cluster: ## boot a k3d cluster for k8s-related development
k3d-cluster: \
bin/init-cluster
source .k3d-cluster.env.sh && \
bin/init-cluster "$(K3D_CLUSTER_NAME)"
.PHONY: k3d-cluster
k3d-push: ## push build image to local k3d docker registry
k3d-push: build
source .k3d-cluster.env.sh && \
docker tag \
$(RALPH_IMAGE_NAME):$(RALPH_IMAGE_TAG) \
"$(K3D_REGISTRY_RALPH_IMAGE_NAME):$(RALPH_IMAGE_TAG)" && \
docker push \
"$(K3D_REGISTRY_RALPH_IMAGE_NAME):$(RALPH_IMAGE_TAG)"
.PHONY: k3d-push
k3d-stop: ## stop local k8s cluster
source .k3d-cluster.env.sh && \
k3d cluster stop "$(K3D_CLUSTER_NAME)"
.PHONY: k3d-stop
# Nota bene: Black should come after isort just in case they don't agree...
lint: ## lint back-end python sources
lint: \
lint-isort \
lint-black \
lint-flake8 \
lint-pylint \
lint-bandit \
lint-pydocstyle
.PHONY: lint
lint-black: ## lint back-end python sources with black
@echo 'lint:black started…'
@$(COMPOSE_TEST_RUN_APP) black src/ralph tests
.PHONY: lint-black
lint-flake8: ## lint back-end python sources with flake8
@echo 'lint:flake8 started…'
@$(COMPOSE_TEST_RUN_APP) flake8
.PHONY: lint-flake8
lint-isort: ## automatically re-arrange python imports in back-end code base
@echo 'lint:isort started…'
@$(COMPOSE_TEST_RUN_APP) isort --atomic .
.PHONY: lint-isort
lint-pylint: ## lint back-end python sources with pylint
@echo 'lint:pylint started…'
@$(COMPOSE_TEST_RUN_APP) pylint src/ralph tests
.PHONY: lint-pylint
lint-bandit: ## lint back-end python sources with bandit
@echo 'lint:bandit started…'
@$(COMPOSE_TEST_RUN_APP) bandit -qr src/ralph
.PHONY: lint-bandit
lint-pydocstyle: ## lint Python docstrings with pydocstyle
@echo 'lint:pydocstyle started…'
@$(COMPOSE_TEST_RUN_APP) pydocstyle
.PHONY: lint-pydocstyle
logs: ## display app logs (follow mode)
@$(COMPOSE) logs -f app
.PHONY: logs
run: ## run LRS server with the runserver backends (development mode)
run: \
run-databases
@$(COMPOSE) up -d app
.PHONY: run
run-all: ## start all supported local backends
run-all: \
run-databases \
run-swift
.PHONY: run-all
run-clickhouse: ## start clickhouse backend
@$(COMPOSE) up -d clickhouse
@echo "Waiting for clickhouse to be up and running..."
@$(COMPOSE_RUN) dockerize -wait tcp://clickhouse:9000 -timeout 60s
.PHONY: run-clickhouse
run-databases: ## alias for running database services
run-databases: \
run-es \
run-mongo \
run-clickhouse
.PHONY: run-databases
run-es: ## start elasticsearch backend
@$(COMPOSE) up -d elasticsearch
@echo "Waiting for elasticsearch to be up and running..."
@$(COMPOSE_RUN) dockerize -wait tcp://elasticsearch:9200 -timeout 60s
.PHONY: run-es
run-mongo: ## start mongodb backend
@$(COMPOSE) up -d mongo
@echo "Waiting for mongo to be up and running..."
@$(COMPOSE_RUN) dockerize -wait tcp://mongo:27017 -timeout 60s
.PHONY: run-mongo
run-swift: ## start swift backend
@$(COMPOSE) up -d swift
@echo "Waiting for swift to be up and running..."
@$(COMPOSE_RUN) dockerize -wait tcp://swift:8080 -wait tcp://swift:35357 -timeout 60s
.PHONY: run-swift
status: ## an alias for "docker compose ps"
@$(COMPOSE) ps
.PHONY: status
stop: ## stops backend servers
@$(COMPOSE) stop
.PHONY: stop
test: ## run back-end tests
test: run
bin/pytest
.PHONY: test
# -- Misc
help:
@grep -E '^[a-zA-Z0-9_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
.PHONY: help