@@ -65,28 +65,50 @@ help: ## Display this help.
6565# ## CRD manifests (one per API group)
6666.PHONY : manifests-bootstrap manifests-controlplane manifests-infrastructure manifests-k0smotron
6767manifests-bootstrap : $(CONTROLLER_GEN ) # # Generate CRDs for bootstrap.cluster.x-k8s.io
68- $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook \
69- paths=" ./..." \
70- output:crd:artifacts:config=config/crd/bases/bootstrap
71- find ./config/crd/bases/bootstrap -type f ! -name " bootstrap*" ! -name " kustomization.yaml" -print0 | xargs -0 rm
68+ $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true \
69+ paths=" ./api/bootstrap/v1beta1/..." \
70+ paths=./internal/controller/bootstrap/... \
71+ output:crd:artifacts:config=config/clusterapi/bootstrap/crd \
72+ output:rbac:dir=config/clusterapi/bootstrap/rbac
7273
7374manifests-controlplane : $(CONTROLLER_GEN ) # # Generate CRDs for controlplane.cluster.x-k8s.io
7475 $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook \
75- paths=" ./..." \
76- output:crd:artifacts:config=config/crd/bases/controlplane
77- find ./config/crd/bases/controlplane -type f ! -name " controlplane*" ! -name " kustomization.yaml" -print0 | xargs -0 rm
76+ paths=" ./api/controlplane/v1beta1/..." \
77+ paths=" ./api/k0smotron.io/v1beta1/..." \
78+ paths=./internal/controller/controlplane/... \
79+ paths=./internal/controller/k0smotron.io/... \
80+ output:crd:artifacts:config=config/clusterapi/controlplane/crd \
81+ output:rbac:dir=config/clusterapi/controlplane/rbac \
82+ output:webhook:dir=config/clusterapi/controlplane/webhook
7883
7984manifests-infrastructure : $(CONTROLLER_GEN ) # # Generate CRDs for infrastructure.cluster.x-k8s.io
85+ $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true \
86+ paths=" ./api/infrastructure/v1beta1/..." \
87+ paths=./internal/controller/infrastructure/... \
88+ output:crd:artifacts:config=config/clusterapi/infrastructure/crd \
89+ output:rbac:dir=config/clusterapi/infrastructure/rbac
90+
91+ manifests-standalone : $(CONTROLLER_GEN ) # # Generate CRDs for k0smotron.io standalone
8092 $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook \
81- paths=" ./..." \
82- output:crd:artifacts:config=config/crd/bases/infrastructure
83- find ./config/crd/bases/infrastructure -type f ! -name " infrastructure*" ! -name " kustomization.yaml" -print0 | xargs -0 rm
93+ paths=" ./api/k0smotron.io/v1beta1/..." \
94+ paths=./internal/controller/k0smotron.io/... \
95+ output:crd:artifacts:config=config/standalone/crd \
96+ output:rbac:dir=config/standalone/rbac \
97+ output:webhook:dir=config/standalone/webhook
8498
85- manifests-k0smotron : $(CONTROLLER_GEN ) # # Generate CRDs for k0smotron.io
99+ manifests-capi-integration : $(CONTROLLER_GEN )
86100 $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook \
87- paths=" ./..." \
88- output:crd:artifacts:config=config/crd/bases/k0smotron.io
89- find ./config/crd/bases/k0smotron.io -type f ! -name " k0smotron.io*" ! -name " kustomization.yaml" -print0 | xargs -0 rm
101+ paths=" ./api/bootstrap/v1beta1/..." \
102+ paths=./internal/controller/bootstrap/... \
103+ paths=" ./api/controlplane/v1beta1/..." \
104+ paths=" ./api/k0smotron.io/v1beta1/..." \
105+ paths=./internal/controller/controlplane/... \
106+ paths=./internal/controller/k0smotron.io/... \
107+ paths=" ./api/infrastructure/v1beta1/..." \
108+ paths=./internal/controller/infrastructure/... \
109+ output:crd:artifacts:config=config/clusterapi/all/crd/bases \
110+ output:rbac:dir=config/clusterapi/all/rbac \
111+ output:webhook:dir=config/clusterapi/all/webhook
90112
91113.PHONY : manifests
92114manifests : manifests-bootstrap manifests-controlplane manifests-infrastructure manifests-k0smotron # # Generate all CRD YAMLs per group
@@ -99,7 +121,7 @@ generate_targets += api/infrastructure/v1beta1/zz_generated.deepcopy.go
99121$(generate_targets ) : $(CONTROLLER_GEN )
100122 $(CONTROLLER_GEN ) object:headerFile=" hack/boilerplate.go.txt" paths=" ./..."
101123
102- generate : $(generate_targets ) clusterapi- manifests # # Generate code containing DeepCopy, DeepCopyInto, and DeepCopyObject method implementations.
124+ generate : $(generate_targets ) manifests # # Generate code containing DeepCopy, DeepCopyInto, and DeepCopyObject method implementations.
103125
104126
105127GO_PKGS =$(shell go list ./...)
@@ -149,10 +171,6 @@ e2e-aws:
149171build :
150172 go build -o bin/manager cmd/main.go
151173
152- .PHONY : run
153- run : manifests generate fmt vet # # Run a controller from your host.
154- go run ./cmd/main.go
155-
156174# If you wish built the manager image targeting other platforms you can use the --platform flag.
157175# (i.e. docker build --platform linux/arm64 ). However, you must enable docker buildKit for it.
158176# More info: https://docs.docker.com/develop/develop-images/build_enhancements/
@@ -193,49 +211,43 @@ ifndef ignore-not-found
193211 ignore-not-found = false
194212endif
195213
196- .PHONY : install
197- install : manifests kustomize # # Install CRDs into the K8s cluster specified in ~/.kube/config.
198- $(KUSTOMIZE ) build config/crd | kubectl create -f -
199-
200- .PHONY : uninstall
201- uninstall : manifests kustomize # # Uninstall CRDs from the K8s cluster specified in ~/.kube/config. Call with ignore-not-found=true to ignore resource not found errors during deletion.
202- $(KUSTOMIZE ) build config/crd | kubectl delete --ignore-not-found=$(ignore-not-found ) -f -
203-
204214.PHONY : deploy
205215deploy : manifests kustomize # # Deploy controller to the K8s cluster specified in ~/.kube/config.
206- cd config/manager && $(KUSTOMIZE ) edit set image k0s/k0smotron=${IMG}
207- $(KUSTOMIZE ) build config/default | kubectl create -f -
216+ cd config/clusterapi/all/manager && $(KUSTOMIZE ) edit set image k0s/k0smotron=${IMG}
217+ $(KUSTOMIZE ) build config/clusterapi/all | kubectl create -f -
218+ git checkout config/clusterapi/all/manager/kustomization.yaml
208219
209220.PHONY : undeploy
210221undeploy : # # Undeploy controller from the K8s cluster specified in ~/.kube/config. Call with ignore-not-found=true to ignore resource not found errors during deletion.
211- $(KUSTOMIZE ) build config/default | kubectl delete --ignore-not-found=$(ignore-not-found ) -f -
222+ $(KUSTOMIZE ) build config/clusterapi/all | kubectl delete --ignore-not-found=$(ignore-not-found ) -f -
212223
213224.PHONY : release
214- release : manifests kustomize # # Deploy controller to the K8s cluster specified in ~/.kube/config.
215- cd config/manager && $(KUSTOMIZE ) edit set image controller=${IMG}
216- $(KUSTOMIZE ) build config/default > install.yaml
217- git checkout config/manager/kustomization.yaml
218-
219- clusterapi-manifests :
220- $( CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook paths= " ./api/bootstrap/... " output:crd:artifacts:config=config/clusterapi/bootstrap/bases
221- $( CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook paths= " ./api/controlplane/... " output:crd:artifacts:config=config/clusterapi/controlplane/bases
222- $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook paths= " ./api/infrastructure/... " output:crd:artifacts:config=config/clusterapi/infrastructure/bases
223- $( CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook paths= " ./api/k0smotron.io/... " output:crd:artifacts: config=config/clusterapi/k0smotron.io/bases
224-
225- bootstrap-components.yaml : $(CONTROLLER_GEN ) clusterapi- manifests kustomize
226- cd config/manager && $(KUSTOMIZE ) edit set image controller=${IMG}
225+ release : manifests-capi-integration kustomize # # Deploy controller to the K8s cluster specified in ~/.kube/config.
226+ cd config/clusterapi/all/ manager && $(KUSTOMIZE ) edit set image controller=${IMG}
227+ $(KUSTOMIZE ) build config/clusterapi/all > install.yaml
228+ git checkout config/clusterapi/all/ manager/kustomization.yaml
229+
230+ .PHONY : release-standalone
231+ release-standalone : manifests-standalone kustomize # # Generate install yaml for standalone mode
232+ cd config/standalone/manager && $( KUSTOMIZE ) edit set image controller= ${IMG}
233+ $(KUSTOMIZE ) build config/standalone > install-standalone.yaml
234+ git checkout config/standalone/manager/kustomization.yaml
235+
236+ bootstrap-components.yaml : $(CONTROLLER_GEN ) manifests-infrastructure kustomize
237+ cd config/clusterapi/bootstrap/ manager && $(KUSTOMIZE ) edit set image controller=${IMG}
227238 $(KUSTOMIZE ) build config/clusterapi/bootstrap/ > bootstrap-components.yaml
228- git checkout config/manager/kustomization.yaml
239+ git checkout config/clusterapi/bootstrap/ manager/kustomization.yaml
229240
230- control-plane-components.yaml : $(CONTROLLER_GEN ) clusterapi- manifests kustomize
231- cd config/manager && $(KUSTOMIZE ) edit set image controller=${IMG}
241+ control-plane-components.yaml : $(CONTROLLER_GEN ) manifests-controlplane kustomize
242+ cd config/clusterapi/controlplane/ manager && $(KUSTOMIZE ) edit set image controller=${IMG}
232243 $(KUSTOMIZE ) build config/clusterapi/controlplane/ > control-plane-components.yaml
233- git checkout config/manager/kustomization.yaml
244+ git checkout config/clusterapi/controlplane/ manager/kustomization.yaml
234245
235- infrastructure-components.yaml : $(CONTROLLER_GEN ) clusterapi- manifests kustomize
236- cd config/manager && $(KUSTOMIZE ) edit set image controller=${IMG}
246+ infrastructure-components.yaml : $(CONTROLLER_GEN ) manifests-infrastructure kustomize
247+ cd config/clusterapi/infrastructure/ manager && $(KUSTOMIZE ) edit set image controller=${IMG}
237248 $(KUSTOMIZE ) build config/clusterapi/infrastructure/ > infrastructure-components.yaml
238- git checkout config/manager/kustomization.yaml
249+ git checkout config/clusterapi/infrastructure/manager/kustomization.yaml
250+
239251# #@ Build Dependencies
240252
241253kustomize : $(KUSTOMIZE ) # # Download kustomize locally if necessary. If wrong version is installed, it will be removed before downloading.
@@ -270,23 +282,23 @@ $(CRDOC): Makefile.variables | $(LOCALBIN)
270282
271283.PHONY : docs-generate-bootstrap docs-generate-controlplane docs-generate-infrastructure docs-generate-k0smotron docs-generate-reference
272284docs-generate-bootstrap : $(CRDOC ) # # Generate docs for bootstrap CRDs
273- $(CRDOC ) --resources config/crd/bases/ bootstrap --output docs/resource-reference/bootstrap.cluster.x-k8s.io-v1beta1.md
285+ $(CRDOC ) --resources config/clusterapi/ bootstrap/crd --output docs/resource-reference/bootstrap.cluster.x-k8s.io-v1beta1.md
274286
275287docs-generate-controlplane : $(CRDOC ) # # Generate docs for controlplane CRDs
276- $(CRDOC ) --resources config/crd/bases/ controlplane --output docs/resource-reference/controlplane.cluster.x-k8s.io-v1beta1.md
288+ $(CRDOC ) --resources config/clusterapi/ controlplane/crd --output docs/resource-reference/controlplane.cluster.x-k8s.io-v1beta1.md
277289
278290docs-generate-infrastructure : $(CRDOC ) # # Generate docs for infrastructure CRDs
279- $(CRDOC ) --resources config/crd/bases/ infrastructure --output docs/resource-reference/infrastructure.cluster.x-k8s.io-v1beta1.md
291+ $(CRDOC ) --resources config/clusterapi/ infrastructure/crd --output docs/resource-reference/infrastructure.cluster.x-k8s.io-v1beta1.md
280292
281293docs-generate-k0smotron : $(CRDOC ) # # Generate docs for k0smotron CRDs
282- $(CRDOC ) --resources config/crd/bases/k0smotron.io --output docs/resource-reference/k0smotron.io-v1beta1.md
294+ $(CRDOC ) --resources config/standalone/crd --output docs/resource-reference/k0smotron.io-v1beta1.md
283295
284296# Generate docs for all CRDs apis
285297docs-generate-reference : docs-generate-bootstrap docs-generate-controlplane docs-generate-infrastructure docs-generate-k0smotron
286298
287299# # Generate all code, manifests, documentation, and release artifacts
288300.PHONY : generate-all
289- generate-all : clean generate manifests clusterapi-manifests docs-generate-reference release
301+ generate-all : clean generate docs-generate-reference release
290302
291303.PHONY : $(smoketests )
292304$(smoketests ) : release k0smotron-image-bundle.tar
@@ -338,7 +350,7 @@ kind-deploy-capi:
338350
339351.PHONY : kind-deploy-k0smotron
340352kind-deploy-k0smotron : release k0smotron-image-bundle.tar
341- kind load image-archive k0smotron-image-bundle.tar --name k0smotron
353+ kind load image-archive k0smotron-image-bundle.tar
342354 kubectl apply --server-side=true -f install.yaml
343355 kubectl rollout restart -n k0smotron deployment/k0smotron-controller-manager
344356
0 commit comments