-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathMakefile
272 lines (226 loc) · 8.66 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
# force serial execution
.NOTPARALLEL:
ifneq (,$(shell ls -1 private.mk 2>/dev/null))
include private.mk
else
$(info info:For a better user experience you can customize variables by adding them to the 'private.mk' file)
endif
# Read the parent image that is used for building the container image
PARENT_IMG ?= $(shell source ci/config/env; echo $${PARENT_IMG})
# This makefile make life easier for playing with the different
# proof of concepts.
# Customizable cluster domain for deploying wherever we want
INGRESS_DOMAIN_CMD = kubectl get ingresses.config/cluster -o jsonpath='{.spec.domain}'
INGRESS_DOMAIN ?= $(shell $(INGRESS_DOMAIN_CMD))
REALM_CMD = $(INGRESS_DOMAIN_CMD) | tr '[:lower:]' '[:upper:]'
REALM ?= $(shell $(REALM_CMD))
NAMESPACE_CMD = oc project --short=true 2>/dev/null
NAMESPACE ?= $(shell $(NAMESPACE_CMD))
IPA_SERVER_HOSTNAME_CMD = echo "$(NAMESPACE).$(INGRESS_DOMAIN)"
IPA_SERVER_HOSTNAME ?= $(shell $(IPA_SERVER_HOSTNAME_CMD))
TIMESTAMP ?= $(shell date +%Y%m%d%H%M%S)
CA_CN := freeipa-$(TIMESTAMP)
CA_O := $(REALM)
CA_SUBJECT := CN=$(CA_CN), O=$(CA_O)
TESTS_LIST ?= $(wildcard test/unit/*.bats)
TESTS_E2E_LIST ?= $(wildcard test/e2e/*.bats)
# Set the container runtime interface
ifneq (,$(shell bash -c "command -v podman 2>/dev/null"))
DOCKER ?= podman
else
ifneq (,$(shell bash -c "command -v docker 2>/dev/null"))
DOCKER ?= docker
else
ifeq (,$(DOCKER))
$(error No podman nor docker were found in your environment; you can override by doing 'export DOCKER=/path/to/docker/or/podman')
endif
endif
endif
# linux
ifneq (,$(shell bash -c "command -v xdg-open" 2>/dev/null))
OPEN := xdg-open
else
# macos
ifneq (,$(shell bash -c "command -v open" 2>/dev/null))
OPEN := open
else
OPEN := echo Open
endif
endif
# Change IMG_BASE on your pipeline settings to point to your upstream
ifeq (,$(IMG_BASE))
$(error IMG_BASE is empty. You can do 'export IMG_BASE=quay.io/namespace' or add this variable to the 'private.mk' file; see the 'README.md' file for further information)
endif
IMG_TAG ?= dev-$(shell git rev-parse --short HEAD)
IMG ?= $(IMG_BASE)/freeipa-openshift-container:$(IMG_TAG)
QUAY_EXPIRATION ?= 1d
CONTAINER_BUILD_FLAGS ?=
default: help
.PHONY: .FORCE
.FORCE:
.PHONY: help
help: .FORCE
@cat HELP
.PHONY: dump-vars
dump-vars:
@echo INGRESS_DOMAIN=$(INGRESS_DOMAIN)
@echo REALM=$(REALM)
@echo TIMESTAMP=$(TIMESTAMP)
@echo DOCKER=$(DOCKER)
@echo NAMESPACE=$(NAMESPACE)
@echo IMG_BASE=$(IMG_BASE)
@echo IMG=$(IMG)
# Check IMG is not empty
.PHONY: .check-docker-image-not-empty
.check-docker-image-not-empty: .FORCE
ifeq (,$(IMG))
@echo "'IMG' can not be empty. You can do 'export IMG=quay.io/scope-name/my-image:my-tag' or add the variable to the 'private.mk' file for a better user experience"
@exit 1
endif
# Build the container image
.PHONY: container-build
container-build: .check-docker-image-not-empty Dockerfile
@echo "PARENT_IMG=$(PARENT_IMG)"
$(DOCKER) build -t $(IMG) \
--build-arg PARENT_IMG=$(PARENT_IMG) \
--build-arg QUAY_EXPIRATION=$(QUAY_EXPIRATION) \
$(CONTAINER_BUILD_FLAGS) \
-f Dockerfile .
# Push the container image to the container registry
.PHONY: container-push
container-push: .check-docker-image-not-empty .FORCE
$(DOCKER) push $(IMG)
# Remove container image from the local storage
.PHONY: container-remove
container-remove: .check-docker-image-not-empty .FORCE
$(DOCKER) image rm $(IMG)
.PHONY: container-shell
container-shell:
$(DOCKER) run -it --entrypoint "" $(IMG) /bin/bash
PORTS ?= -p 8053:53/udp -p 8053:53 -p 8443:443 -p 8389:389 -p 8636:636 -p 8088:88 -p 8464:464 -p 8088:88/udp -p 8464:464/udp
.PHONY: container-run
container-run: .check-not-empty-password
$(DOCKER) volume exists freeipa-data || $(DOCKER) volume create freeipa-data
$(DOCKER) run -it -d --cap-add FSETID -v "freeipa-data:/data:z" --name freeipa-server-container --hostname ipa.example.test $(PORTS) $(IMG) no-exit ipa-server-install -U -r EXAMPLE.TEST --hostname=ipa.example.test --ds-password=$(IPA_DM_PASSWORD) --admin-password=$(IPA_ADMIN_PASSWORD) --no-ntp --no-sshd --no-ssh
.PHONY: container-logs
container-logs:
$(DOCKER) logs -f freeipa-server-container | less
.PHONY: container-stop
container-stop:
-$(DOCKER) container stop freeipa-server-container
-$(DOCKER) container rm freeipa-server-container
.PHONY: container-clean
container-clean: container-stop
$(DOCKER) volume rm freeipa-data
# Validate kubernetes object for the app
.PHONY: app-validate
app-validate: .check-logged-in-openshift .validate-admin .validate-user .FORCE
.validate-admin:
kustomize build deploy/admin | oc create -f - --dry-run=client --validate=true
.validate-user:
kustomize build deploy/user | oc create -f - --dry-run=client --validate=true
JOB_SPEC ?= avisiedo/freeipa-openshift-container-alternative
.PHONY: ci-operator
ci-operator:
# ci-operator --config .ci-operator.yaml --git-ref avisiedo/freeipa-openshift-container-alternative@master
JOB_SPEC="$(JOB_SPEC)" ci-operator --config .ci-operator.yaml
# Check that cluster domain is not empty
.PHONY: .check-ingress-domain-not-empty
.check-ingress-domain-not-empty: .FORCE
ifeq (,$(INGRESS_DOMAIN))
@echo "'INGRESS_DOMAIN' can not be empty; You can do 'export INGRESS_DOMAIN=my.cluster.domain.com' or add it to the 'private.mk' file for a better user experience"
@exit 1
endif
# Check logged in OpenShift cluster
.PHONY: .check-logged-in-openshift
.check-logged-in-openshift: .FORCE
ifeq (,$(shell oc whoami 2>/dev/null))
@echo "ERROR: You must be logged in OpenShift cluster. Try 'oc login https://mycluster:6443' matching your cluster API endpoint"
@exit 1
endif
# Check not empty password
.PHONY: .check-not-empty-password
.check-not-empty-password: .FORCE
ifeq (,$(IPA_ADMIN_PASSWORD))
@echo "ERROR: IPA_ADMIN_PASSWORD can not be empty. You can add this variable to the 'private.mk' file; see the 'README.md' file for further information"
@exit 2
endif
ifeq (,$(IPA_DM_PASSWORD))
@echo "ERROR: IPA_DM_PASSWORD can not be empty. You can add this variable to the 'private.mk' file; see the 'README.md' file for further information"
@exit 2
endif
.PHONY: .generate-secret
.generate-secret: .FORCE
@{ \
echo "IPA_ADMIN_PASSWORD=$(IPA_ADMIN_PASSWORD)"; \
echo "IPA_DM_PASSWORD=$(IPA_DM_PASSWORD)"; \
} > deploy/user/admin-pass.txt
.PHONY: .generate-config
.generate-config: .FORCE
@{ \
echo "DEBUG_TRACE=$(DEBUG_TRACE)" ; \
echo "CLUSTER_DOMAIN=$(CLUSTER_DOMAIN)" ; \
echo "IPA_SERVER_HOSTNAME=$(IPA_SERVER_HOSTNAME)" ; \
echo "CA_SUBJECT=$(CA_SUBJECT)" ; \
echo "REALM=$(REALM)" ; \
} > deploy/user/config.txt
# Deploy the application
.PHONY: app-create
app-create: .check-not-empty-password .check-ingress-domain-not-empty .check-docker-image-not-empty .check-logged-in-openshift .generate-secret .generate-config app-validate .FORCE
cd deploy/user; kustomize edit set image workload=$(IMG)
$(MAKE) .app-create-admin
kustomize build deploy/user | oc create -f - --as freeipa
.app-create-admin:
kustomize build deploy/admin | oc create -f -
# Delete the application from the cluster
.PHONY: app-delete
app-delete: .check-logged-in-openshift .FORCE
-kustomize build deploy/user | oc delete -f - --as freeipa
-$(MAKE) .app-delete-admin
.app-delete-admin:
kustomize build deploy/admin | oc delete -f -
.PHONY: app-print-out
app-print-out: .generate-secret .generate-config .FORCE
@cd deploy/user; kustomize edit set image workload=$(IMG)
@kustomize build deploy/admin
@echo "---"
@kustomize build deploy/user
.PHONY: app-open-console
app-open-console:
$(OPEN) "https://$(IPA_SERVER_HOSTNAME)"
.PHONY: test
test: install-test-deps test-unit
.PHONY: test-unit
test-unit:
./test/libs/bats/bin/bats $(TESTS_LIST)
.PHONY: install-test-deps
install-test-deps: .venv
.venv:
python3 -m venv --copies .venv
source .venv/bin/activate; pip install --upgrade pip
source .venv/bin/activate ; \
pip install --requirement test/e2e/requirements.txt ; \
ansible-galaxy collection install containers.podman
##@ Templates
template-create: ## Create the template
oc create -f deploy/template.yaml
TEMPLATE_ARGS =
ifneq (,$(IPA_ADMIN_PASSWORD))
TEMPLATE_ARGS += --param IPA_ADMIN_PASSWORD="$(IPA_ADMIN_PASSWORD)"
endif
ifneq (,$(IPA_DM_PASSWORD))
TEMPLATE_ARGS += --param IPA_DM_PASSWORD="$(IPA_DM_PASSWORD)"
endif
template-new-app: ## Use the template for creating a new application
oc new-app --template=freeipa \
--param APPLICATION_NAME="freeipa" \
--param IPA_REALM="$(REALM)" \
--param IPA_CA_CN="$(CA_CN)" \
--param IPA_CA_O="$(CA_O)" \
--param IPA_SERVER_HOSTNAME="$(IPA_SERVER_HOSTNAME)" \
--param RELATED_IMAGE_FREEIPA="$(IMG)" \
$(TEMPLATE_ARGS)
template-rm-app:: ## Remove the application created by the template
oc delete route,services,pods,configmaps,secrets -l app=freeipa
template-delete:: ## Delete the template
oc delete template/freeipa