-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
254 lines (215 loc) · 7.99 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
.DEFAULT_GOAL := help
###
# CONSTANTS
###
ifneq (,$(findstring xterm,$(TERM)))
BLACK := $(shell tput -Txterm setaf 0)
RED := $(shell tput -Txterm setaf 1)
GREEN := $(shell tput -Txterm setaf 2)
YELLOW := $(shell tput -Txterm setaf 3)
BLUE := $(shell tput -Txterm setaf 4)
MAGENTA := $(shell tput -Txterm setaf 5)
CYAN := $(shell tput -Txterm setaf 6)
WHITE := $(shell tput -Txterm setaf 7)
RESET := $(shell tput -Txterm sgr0)
else
BLACK := ""
RED := ""
GREEN := ""
YELLOW := ""
BLUE := ""
MAGENTA := ""
CYAN := ""
WHITE := ""
RESET := ""
endif
#---
SERVICE_APP = custom-caddy
#---
WEBSITE_URL = https://localhost
#---
HOST_USER_ID := $(shell id --user)
HOST_USER_NAME := $(shell id --user --name)
HOST_GROUP_ID := $(shell id --group)
HOST_GROUP_NAME := $(shell id --group --name)
#---
DOCKER_COMPOSE = docker compose --file docker-compose.yml --file docker-compose.override.$(env).yml
DOCKER_BUILD_ARGUMENTS = --build-arg="HOST_USER_ID=$(HOST_USER_ID)" --build-arg="HOST_USER_NAME=$(HOST_USER_NAME)" --build-arg="HOST_GROUP_ID=$(HOST_GROUP_ID)" --build-arg="HOST_GROUP_NAME=$(HOST_GROUP_NAME)"
DOCKER_RUN = $(DOCKER_COMPOSE) run --rm $(SERVICE_APP)
DOCKER_RUN_AS_USER = $(DOCKER_COMPOSE) run --rm --user $(HOST_USER_ID):$(HOST_GROUP_ID) $(SERVICE_APP)
###
# FUNCTIONS
###
require-%:
@if [ -z "$($(*))" ] ; then \
echo "" ; \
echo " ${RED}⨉${RESET} Parameter [ ${YELLOW}${*}${RESET} ] is required!" ; \
echo "" ; \
echo " ${YELLOW}ℹ${RESET} Usage [ ${YELLOW}make <command>${RESET} ${RED}${*}=${RESET}${YELLOW}xxxxxx${RESET} ]" ; \
echo "" ; \
exit 1 ; \
fi;
define taskDone
@echo ""
@echo " ${GREEN}✓${RESET} ${GREEN}Task done!${RESET}"
@echo ""
endef
# $(1)=TEXT $(2)=EXTRA
define showInfo
@echo " ${YELLOW}ℹ${RESET} $(1) $(2)"
endef
# $(1)=TEXT $(2)=EXTRA
define showAlert
@echo " ${RED}!${RESET} $(1) $(2)"
endef
# $(1)=NUMBER $(2)=TEXT
define orderedList
@echo ""
@echo " ${CYAN}$(1).${RESET} ${CYAN}$(2)${RESET}"
@echo ""
endef
# $(1)=PADDING NUMBER
define pad
$(shell printf "%-$(1)s" " ")
endef
###
# HELP
###
.PHONY: help
help:
@clear
@echo "${BLACK}"
@echo "╔════════════════════════════════════════════════════════════════════════════════════════════════════════╗"
@echo "║ $(call pad,96) ║"
@echo "║ $(call pad,32) ${YELLOW}.:${RESET} AVAILABLE COMMANDS ${YELLOW}:.${BLACK} $(call pad,32) ║"
@echo "║ $(call pad,96) ║"
@echo "╚════════════════════════════════════════════════════════════════════════════════════════════════════════╝"
@echo "${BLACK}·${RESET} ${MAGENTA}DOMAIN(s)${BLACK} .... ${CYAN}$(WEBSITE_URL)${BLACK}"
@echo "${BLACK}·${RESET} ${MAGENTA}SERVICE(s)${BLACK} ... ${CYAN}$(shell docker ps --format "{{.Names}}")${BLACK}"
@echo "${BLACK}·${RESET} ${MAGENTA}USER${BLACK} ......... ${WHITE}(${CYAN}$(HOST_USER_ID)${WHITE})${BLACK} ${CYAN}$(HOST_USER_NAME)${BLACK}"
@echo "${BLACK}·${RESET} ${MAGENTA}GROUP${BLACK} ........ ${WHITE}(${CYAN}$(HOST_GROUP_ID)${WHITE})${BLACK} ${CYAN}$(HOST_GROUP_NAME)${BLACK}"
@echo "${RESET}"
@grep -E '^[a-zA-Z_0-9%-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "${BLACK}·${RESET} ${YELLOW}%-35s${RESET} %s\n", $$1, $$2}'
@echo ""
###
# DOCKER RELATED
###
.PHONY: build
build: ## Docker: builds the service <env=[dev|prod]>
@$(eval env ?= 'dev')
$(call showInfo,"Building Docker image\(s\)...")
@echo ""
@$(DOCKER_COMPOSE) build $(DOCKER_BUILD_ARGUMENTS)
$(call taskDone)
.PHONY: up
up: ## Docker: starts the service <env=[dev|prod]>
@$(eval env ?= 'dev')
$(call showInfo,"Starting service\(s\)...")
@echo ""
@$(DOCKER_COMPOSE) up --remove-orphans --detach
$(call taskDone)
.PHONY: restart
restart: ## Docker: restarts the service <env=[dev|prod]>
@$(eval env ?= 'dev')
$(call showInfo,"Restarting service\(s\)...")
@echo ""
@$(DOCKER_COMPOSE) restart
$(call taskDone)
.PHONY: down
down: ## Docker: stops the service <env=[dev|prod]>
@$(eval env ?= 'dev')
$(call showInfo,"Stopping service\(s\)...")
@echo ""
@$(DOCKER_COMPOSE) down $(DOCKER_COMPOSE_FILES) --remove-orphans
$(call taskDone)
.PHONY: logs
logs: ## Docker: exposes the service logs <env=[dev|prod]> <service=[app1|caddy]>
@$(eval env ?= 'dev')
@$(eval service ?= $(SERVICE_APP))
$(call showInfo,"Exposing service\(s\) logs...")
@echo ""
@$(DOCKER_COMPOSE) logs -f $(service)
$(call taskDone)
.PHONY: shell
shell: ## Docker: establish a shell session into main container
@$(eval env ?= 'dev')
$(call showInfo,"Establishing a shell terminal with main service...")
@echo ""
@$(DOCKER_RUN_AS_USER) sh
$(call taskDone)
.PHONY: inspect
inspect: ## Docker: inspect the health for specific service <service=[app1|caddy]>
@$(eval service ?= $(SERVICE_APP))
$(call showInfo,"Inspecting the health for a specific service...")
@echo ""
@docker inspect --format "{{json .State.Health}}" $(service) | jq
@echo ""
$(call taskDone)
###
# CADDY
###
.PHONY: install-caddy-certificate
install-caddy-certificate: up ## Setup: extracts the Caddy Local Authority certificate
$(call showInfo,"Extracting Caddy Certificate Authority file...")
@echo ""
@echo "How to install [ $(YELLOW)Caddy Local Authority - 20XX ECC Root$(RESET) ] as a valid Certificate Authority"
$(call orderedList,1,"Copy the root certificate from Caddy Docker container")
@docker cp $(SERVICE_APP):/data/caddy/pki/authorities/local/root.crt ./caddy-root-ca-authority.crt
$(call orderedList,2,"Install the Caddy Authority certificate into your browser")
@echo "$(YELLOW)Chrome-based browsers (Chrome, Brave, etc)$(RESET)"
@echo "- Go to [ Settings / Privacy & Security / Security / Manage Certificates / Authorities ]"
@echo "- Import [ ./caddy-root-ca-authority.crt ]"
@echo "- Check on [ Trust this certificate for identifying websites ]"
@echo "- Save changes"
@echo ""
@echo "$(YELLOW)Firefox browser$(RESET)"
@echo "- Go to [ Settings / Privacy & Security / Security / Certificates / View Certificates / Authorities ]"
@echo "- Import [ ./caddy-root-ca-authority.crt ]"
@echo "- Check on [ This certificate can identify websites ]"
@echo "- Save changes"
@echo ""
$(call showInfo,"For further information, please visit https://caddyserver.com/docs/running#docker-compose")
$(call taskDone)
###
# APPLICATION
###
.PHONY: install-skeleton
install-skeleton: ## Application: installs PHP Skeleton
@$(eval env ?= 'dev')
$(call showInfo,"Installing PHP Skeleton...")
@echo ""
@$(DOCKER_RUN_AS_USER) composer create-project alcidesrc/php-skeleton .
$(call taskDone)
.PHONY: install-laravel
install-laravel: ## Application: installs Laravel
@$(eval env ?= 'dev')
$(call showInfo,"Installing Laravel...")
@echo ""
@$(DOCKER_RUN_AS_USER) composer create-project laravel/laravel .
$(call taskDone)
.PHONY: install-symfony
install-symfony: ## Application: installs Symfony
@$(eval env ?= 'dev')
$(call showInfo,"Installing Symfony...")
@echo ""
@$(DOCKER_RUN_AS_USER) composer create-project symfony/skeleton .
$(call taskDone)
.PHONY: uninstall
uninstall: require-confirm ## Application: removes the PHP application
$(call showInfo,"Uninstalling PHP application...")
@rm -Rf ./src && mkdir ./src
$(call taskDone)
###
# MISCELANEOUS
###
.PHONY: open-website
open-website: ## Application: open the application website
$(call showInfo,"Opening web application...")
@echo ""
@xdg-open $(WEBSITE_URL)
@$(call showAlert,"Press Ctrl+C to resume your session")
$(call taskDone)
.PHONY: init
init: build install-caddy-certificate ## Application: initializes the application
$(call showInfo,"When ready just execute [ make open-website ] to visit the website with your preferred browser")
$(call taskDone)