130 lines
5.2 KiB
Makefile
130 lines
5.2 KiB
Makefile
# IMAGE_TAG_BASE defines the docker.io namespace and part of the image name for remote images.
|
|
IMAGE_TAG_BASE ?= getontime/ontime-operator
|
|
|
|
# Set the Operator SDK version to use. By default, what is installed on the system is used.
|
|
# This is useful for CI or a project to utilize a specific version of the operator-sdk toolkit.
|
|
OPERATOR_SDK_VERSION ?= v1.41.1
|
|
|
|
# Container tool to use for building and pushing images
|
|
CONTAINER_TOOL ?= docker
|
|
|
|
# Image URL to use all building/pushing image targets
|
|
IMG ?= controller:latest
|
|
|
|
.PHONY: all
|
|
all: docker-build
|
|
|
|
##@ General
|
|
|
|
# The help target prints out all targets with their descriptions organized
|
|
# beneath their categories. The categories are represented by '##@' and the
|
|
# target descriptions by '##'. The awk commands is responsible for reading the
|
|
# entire set of makefiles included in this invocation, looking for lines of the
|
|
# file as xyz: ## something, and then pretty-format the target and help. Then,
|
|
# if there's a line with ##@ something, that gets pretty-printed as a category.
|
|
# More info on the usage of ANSI control characters for terminal formatting:
|
|
# https://en.wikipedia.org/wiki/ANSI_escape_code#SGR_parameters
|
|
# More info on the awk command:
|
|
# http://linuxcommand.org/lc3_adv_awk.php
|
|
|
|
.PHONY: help
|
|
help: ## Display this help.
|
|
@awk 'BEGIN {FS = ":.*##"; printf "\nUsage:\n make \033[36m<target>\033[0m\n"} /^[a-zA-Z_0-9-]+:.*?##/ { printf " \033[36m%-15s\033[0m %s\n", $$1, $$2 } /^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)
|
|
|
|
##@ Build
|
|
|
|
.PHONY: run
|
|
run: helm-operator ## Run against the configured Kubernetes cluster in ~/.kube/config
|
|
$(HELM_OPERATOR) run
|
|
|
|
.PHONY: docker-build
|
|
docker-build: ## Build docker image with the manager.
|
|
$(CONTAINER_TOOL) build -t ${IMG} .
|
|
|
|
.PHONY: docker-push
|
|
docker-push: ## Push docker image with the manager.
|
|
$(CONTAINER_TOOL) push ${IMG}
|
|
|
|
# PLATFORMS defines the target platforms for the manager image be build to provide support to multiple
|
|
# architectures. (i.e. make docker-buildx IMG=myregistry/mypoperator:0.0.1). To use this option you need to:
|
|
# - able to use docker buildx . More info: https://docs.docker.com/build/buildx/
|
|
# - have enable BuildKit, More info: https://docs.docker.com/develop/develop-images/build_enhancements/
|
|
# - be able to push the image for your registry (i.e. if you do not inform a valid value via IMG=<myregistry/image:<tag>> than the export will fail)
|
|
# To properly provided solutions that supports more than one platform you should use this option.
|
|
PLATFORMS ?= linux/arm64,linux/amd64,linux/s390x,linux/ppc64le
|
|
.PHONY: docker-buildx
|
|
docker-buildx: ## Build and push docker image for the manager for cross-platform support
|
|
- $(CONTAINER_TOOL) buildx create --name project-v3-builder
|
|
$(CONTAINER_TOOL) buildx use project-v3-builder
|
|
- $(CONTAINER_TOOL) buildx build --push --platform=$(PLATFORMS) --tag ${IMG} -f Dockerfile .
|
|
- $(CONTAINER_TOOL) buildx rm project-v3-builder
|
|
|
|
##@ Deployment
|
|
|
|
.PHONY: install
|
|
install: kustomize ## Install CRDs into the K8s cluster specified in ~/.kube/config.
|
|
$(KUSTOMIZE) build config/crd | kubectl apply -f -
|
|
|
|
.PHONY: uninstall
|
|
uninstall: kustomize ## Uninstall CRDs from the K8s cluster specified in ~/.kube/config.
|
|
$(KUSTOMIZE) build config/crd | kubectl delete -f -
|
|
|
|
.PHONY: deploy
|
|
deploy: kustomize ## Deploy controller to the K8s cluster specified in ~/.kube/config.
|
|
cd config/manager && $(KUSTOMIZE) edit set image controller=${IMG}
|
|
$(KUSTOMIZE) build config/default | kubectl apply -f -
|
|
|
|
.PHONY: undeploy
|
|
undeploy: ## Undeploy controller from the K8s cluster specified in ~/.kube/config.
|
|
$(KUSTOMIZE) build config/default | kubectl delete -f -
|
|
|
|
OS := $(shell uname -s | tr '[:upper:]' '[:lower:]')
|
|
ARCH := $(shell uname -m | sed 's/x86_64/amd64/' | sed 's/aarch64/arm64/')
|
|
|
|
.PHONY: kustomize
|
|
KUSTOMIZE = $(shell pwd)/bin/kustomize
|
|
kustomize: ## Download kustomize locally if necessary.
|
|
ifeq (,$(wildcard $(KUSTOMIZE)))
|
|
ifeq (,$(shell which kustomize 2>/dev/null))
|
|
@{ \
|
|
set -e ;\
|
|
mkdir -p $(dir $(KUSTOMIZE)) ;\
|
|
curl -sSLo - https://github.com/kubernetes-sigs/kustomize/releases/download/kustomize/v5.6.0/kustomize_v5.6.0_$(OS)_$(ARCH).tar.gz | \
|
|
tar xzf - -C bin/ ;\
|
|
}
|
|
else
|
|
KUSTOMIZE = $(shell which kustomize)
|
|
endif
|
|
endif
|
|
|
|
.PHONY: helm-operator
|
|
HELM_OPERATOR = $(shell pwd)/bin/helm-operator
|
|
helm-operator: ## Download helm-operator locally if necessary, preferring the $(pwd)/bin path over global if both exist.
|
|
ifeq (,$(wildcard $(HELM_OPERATOR)))
|
|
ifeq (,$(shell which helm-operator 2>/dev/null))
|
|
@{ \
|
|
set -e ;\
|
|
mkdir -p $(dir $(HELM_OPERATOR)) ;\
|
|
curl -sSLo $(HELM_OPERATOR) https://github.com/operator-framework/operator-sdk/releases/download/v1.41.1/helm-operator_$(OS)_$(ARCH) ;\
|
|
chmod +x $(HELM_OPERATOR) ;\
|
|
}
|
|
else
|
|
HELM_OPERATOR = $(shell which helm-operator)
|
|
endif
|
|
endif
|
|
|
|
.PHONY: operator-sdk
|
|
OPERATOR_SDK ?= $(LOCALBIN)/operator-sdk
|
|
operator-sdk: ## Download operator-sdk locally if necessary.
|
|
ifeq (,$(wildcard $(OPERATOR_SDK)))
|
|
ifeq (, $(shell which operator-sdk 2>/dev/null))
|
|
@{ \
|
|
set -e ;\
|
|
mkdir -p $(dir $(OPERATOR_SDK)) ;\
|
|
curl -sSLo $(OPERATOR_SDK) https://github.com/operator-framework/operator-sdk/releases/download/$(OPERATOR_SDK_VERSION)/operator-sdk_$(OS)_$(ARCH) ;\
|
|
chmod +x $(OPERATOR_SDK) ;\
|
|
}
|
|
else
|
|
OPERATOR_SDK = $(shell which operator-sdk)
|
|
endif
|
|
endif |