-
Notifications
You must be signed in to change notification settings - Fork 35
/
Copy pathMakefile
116 lines (91 loc) · 4.52 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
.DEFAULT_GOAL := build
# ocp
OPENSHIFT_MIRROR?=https://mirror.openshift.com/pub/openshift-v4
OCP_RELEASE_CHANNEL?=stable-4.13
# okd
OKD_MIRROR?=https://github.com/okd-project/okd/releases/download
# either okd or ocp
DEPLOYMENT_TYPE?=okd
# fixed release version
OPENSHIFT_RELEASE?=none
# image name
CONTAINER_NAME?=quay.io/slauger/hcloud-okd4
CONTAINER_TAG?=$(OPENSHIFT_RELEASE)
# coreos
ifeq ($(DEPLOYMENT_TYPE),ocp)
COREOS_IMAGE=rhcos
else ifeq ($(DEPLOYMENT_TYPE),okd)
COREOS_IMAGE=fcos
else
$(error installer only supports ocp or okd)
endif
# terraform switches
BOOTSTRAP?=false
MODE?=apply
# openshift version
.PHONY: latest_version
latest_version: latest_version_$(DEPLOYMENT_TYPE)
.PHONY: latest_version_okd
latest_version_okd:
@curl -s -H "Accept: application/vnd.github.v3+json" https://api.github.com/repos/okd-project/okd/tags | jq -j -r .[0].name
.PHONY: latest_version_ocp
latest_version_ocp:
@curl -s https://raw.githubusercontent.com/openshift/cincinnati-graph-data/master/channels/$(OCP_RELEASE_CHANNEL).yaml | egrep '(4\.[0-9]+\.[0-9]+)' | tail -n1 | cut -d" " -f2
# fetch
.PHONY: fetch
fetch: fetch_$(DEPLOYMENT_TYPE)
.PHONY: fetch_okd
fetch_okd:
wget -O openshift-install-linux-$(OPENSHIFT_RELEASE).tar.gz $(OKD_MIRROR)/$(OPENSHIFT_RELEASE)/openshift-install-linux-$(OPENSHIFT_RELEASE).tar.gz
wget -O openshift-client-linux-$(OPENSHIFT_RELEASE).tar.gz $(OKD_MIRROR)/$(OPENSHIFT_RELEASE)/openshift-client-linux-$(OPENSHIFT_RELEASE).tar.gz
.PHONY: fetch_ocp
fetch_ocp:
wget -O openshift-install-linux-$(OPENSHIFT_RELEASE).tar.gz $(OPENSHIFT_MIRROR)/clients/ocp/$(OPENSHIFT_RELEASE)/openshift-install-linux-$(OPENSHIFT_RELEASE).tar.gz
wget -O openshift-client-linux-$(OPENSHIFT_RELEASE).tar.gz $(OPENSHIFT_MIRROR)/clients/ocp/$(OPENSHIFT_RELEASE)/openshift-client-linux-$(OPENSHIFT_RELEASE).tar.gz
.PHONY: build
build:
docker build --build-arg DEPLOYMENT_TYPE=$(DEPLOYMENT_TYPE) --build-arg OPENSHIFT_RELEASE=$(OPENSHIFT_RELEASE) -t $(CONTAINER_NAME):$(CONTAINER_TAG) .
.PHONY: test
test:
docker run -v /var/run/docker.sock:/var/run/docker.sock -v $(shell pwd):/src:ro gcr.io/gcp-runtimes/container-structure-test:latest test --image $(CONTAINER_NAME):$(CONTAINER_TAG) --config /src/tests/image.tests.yaml
.PHONY: push
push:
docker push $(CONTAINER_NAME):$(CONTAINER_TAG)
.PHONY: run
run:
docker run -it --hostname openshift-toolbox --mount type=bind,source="$(shell pwd)",target=/workspace --mount type=bind,source="$(HOME)/.ssh,target=/root/.ssh" $(CONTAINER_NAME):$(CONTAINER_TAG) /bin/bash
.PHONY: generate_manifests
generate_manifests:
mkdir config
cp install-config.yaml config/install-config.yaml
openshift-install create manifests --dir=config
.PHONY: generate_ignition
generate_ignition:
rsync -av config/ ignition
openshift-install create ignition-configs --dir=ignition
.PHONY: hcloud_image
hcloud_image:
@if [ -z "$(HCLOUD_TOKEN)" ]; then echo "ERROR: HCLOUD_TOKEN is not set"; exit 1; fi
if [ "$(DEPLOYMENT_TYPE)" == "okd" ]; then (cd packer && packer build -var fcos_url=$(shell openshift-install coreos print-stream-json | jq -r '.architectures.x86_64.artifacts.qemu.formats."qcow2.xz".disk.location') hcloud-fcos.json); fi
if [ "$(DEPLOYMENT_TYPE)" == "ocp" ]; then (cd packer && packer build -var rhcos_url=$(shell openshift-install coreos print-stream-json | jq -r '.architectures.x86_64.artifacts.qemu.formats."qcow2.gz".disk.location') hcloud-rhcos.json); fi
.PHONY: sign_csr
sign_csr:
@if [ ! -f "ignition/auth/kubeconfig" ]; then echo "ERROR: ignition/auth/kubeconfig not found"; exit 1; fi
bash -c "export KUBECONFIG=$(shell pwd)/ignition/auth/kubeconfig; oc get csr -o name | xargs oc adm certificate approve || true"
.PHONY: wait_bootstrap
wait_bootstrap:
openshift-install --dir=ignition/ wait-for bootstrap-complete --log-level=debug
.PHONY: wait_completion
wait_completion:
openshift-install --dir=ignition/ wait-for install-complete --log-level=debug
.PHONY: infrastructure
infrastructure:
@if [ -z "$(TF_VAR_dns_domain)" ]; then echo "ERROR: TF_VAR_dns_domain is not set"; exit 1; fi
@if [ -z "$(TF_VAR_dns_zone_id)" ]; then echo "ERROR: TF_VAR_dns_zone_id is not set"; exit 1; fi
@if [ -z "$(HCLOUD_TOKEN)" ]; then echo "ERROR: HCLOUD_TOKEN is not set"; exit 1; fi
@if [ -z "$(CLOUDFLARE_EMAIL)" ]; then echo "ERROR: CLOUDFLARE_EMAIL is not set"; exit 1; fi
(cd terraform && terraform init && terraform $(MODE) -var image=$(COREOS_IMAGE) -var bootstrap=$(BOOTSTRAP))
if [ "$(MODE)" == "apply" ]; then (cd ansible && ansible-playbook site.yml); fi
.PHONY: destroy
destroy:
(cd terraform && terraform init && terraform destroy)