REGISTRY ?= ghcr.io USERNAME ?= siderolabs PROJECT ?= talos-cloud-controller-manager IMAGE ?= $(REGISTRY)/$(USERNAME)/$(PROJECT) HELMREPO ?= $(REGISTRY)/$(USERNAME)/charts PLATFORM ?= linux/arm64,linux/amd64 PUSH ?= false VERSION ?= $(shell git describe --dirty --tag --match='v*') SHA ?= $(shell git describe --match=none --always --abbrev=8 --dirty) TAG ?= $(VERSION) GO_LDFLAGS := -s -w GO_LDFLAGS += -X k8s.io/component-base/version.gitVersion=$(VERSION) OS ?= $(shell go env GOOS) ARCH ?= $(shell go env GOARCH) ARCHS = amd64 arm64 TESTARGS ?= "-v" BUILD_ARGS := --platform=$(PLATFORM) ifeq ($(PUSH),true) BUILD_ARGS += --push=$(PUSH) else BUILD_ARGS += --output type=docker endif COSING_ARGS ?= ###### # Help Menu define HELP_MENU_HEADER # Getting Started To build this project, you must have the following installed: - git - make - golang 1.20+ - golangci-lint endef export HELP_MENU_HEADER .PHONY: help help: ## This help menu. @echo "$$HELP_MENU_HEADER" @grep -E '^[a-zA-Z0-9%_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}' ############ # # Build Abstractions # ############ build-all-archs: @for arch in $(ARCHS); do $(MAKE) ARCH=$${arch} build ; done .PHONY: clean clean: ## Clean rm -rf dist/ rm -f talos-cloud-controller-manager-* .PHONY: build build: ## Build CGO_ENABLED=0 GOOS=$(OS) GOARCH=$(ARCH) go build -ldflags "$(GO_LDFLAGS)" \ -o talos-cloud-controller-manager-$(ARCH) ./cmd/talos-cloud-controller-manager .PHONY: run run: build ./talos-cloud-controller-manager-$(ARCH) --v=5 --kubeconfig=kubeconfig --cloud-config=hack/ccm-config.yaml --controllers=cloud-node,node-csr-approval,node-ipam-controller \ --allocate-node-cidrs \ --node-cidr-mask-size-ipv4=24 --node-cidr-mask-size-ipv6=80 \ --cidr-allocator-type=CloudAllocator \ --use-service-account-credentials --leader-elect=false --bind-address=127.0.0.1 --secure-port=8443 --authorization-always-allow-paths=/healthz,/livez,/readyz,/metrics .PHONY: lint lint: ## Lint Code golangci-lint run --config .golangci.yml .PHONY: unit unit: ## Unit Tests go test -tags=unit $(shell go list ./...) $(TESTARGS) .PHONY: conformance conformance: ## Conformance docker run --rm -it -v $(PWD):/src -w /src ghcr.io/siderolabs/conform:v0.1.0-alpha.30 enforce ############ .PHONY: helm-unit helm-unit: ## Helm Unit Tests @helm lint charts/talos-cloud-controller-manager @helm template -f charts/talos-cloud-controller-manager/ci/values.yaml \ talos-cloud-controller-manager charts/talos-cloud-controller-manager >/dev/null .PHONY: helm-login helm-login: ## Helm Login @echo "${HELM_TOKEN}" | helm registry login $(REGISTRY) --username $(USERNAME) --password-stdin .PHONY: helm-release helm-release: ## Helm Release @rm -rf dist/ @helm package charts/talos-cloud-controller-manager -d dist @helm push dist/talos-cloud-controller-manager-*.tgz oci://$(HELMREPO) 2>&1 | tee dist/.digest @cosign sign --yes $(COSING_ARGS) $(HELMREPO)/talos-cloud-controller-manager@$$(cat dist/.digest | awk -F "[, ]+" '/Digest/{print $$NF}') ############ .PHONY: docs docs: yq -i '.appVersion = "$(TAG)"' charts/talos-cloud-controller-manager/Chart.yaml helm template -n kube-system talos-cloud-controller-manager \ --set-string image.tag=$(TAG) \ charts/talos-cloud-controller-manager > docs/deploy/cloud-controller-manager.yml helm template -n kube-system talos-cloud-controller-manager \ -f charts/talos-cloud-controller-manager/values.edge.yaml \ charts/talos-cloud-controller-manager > docs/deploy/cloud-controller-manager-edge.yml helm template -n kube-system talos-cloud-controller-manager \ --set-string image.tag=$(TAG) \ --set daemonSet.enabled=true \ charts/talos-cloud-controller-manager > docs/deploy/cloud-controller-manager-daemonset.yml helm template -n kube-system talos-cloud-controller-manager \ -f charts/talos-cloud-controller-manager/values.edge.yaml \ --set daemonSet.enabled=true \ charts/talos-cloud-controller-manager > docs/deploy/cloud-controller-manager-daemonset-edge.yml helm-docs charts/talos-cloud-controller-manager release-update: git-chglog --config hack/chglog-config.yml -o CHANGELOG.md ############ # # Docker Abstractions # ############ docker-init: docker run --rm --privileged multiarch/qemu-user-static:register --reset docker context create multiarch ||: docker buildx create --name multiarch --driver docker-container --use ||: docker context use multiarch docker buildx inspect --bootstrap multiarch .PHONY: images-cosign images-cosign: @cosign sign --yes $(COSING_ARGS) --recursive $(IMAGE):$(TAG) .PHONY: images images: @docker buildx build $(BUILD_ARGS) \ --build-arg VERSION="$(VERSION)" \ -t $(IMAGE):$(TAG) \ -f Dockerfile .