@@ -63,33 +63,61 @@ help: ## Display this help.
6363# #@ Development
6464
6565# ## CRD manifests (one per API group)
66- .PHONY : manifests-bootstrap manifests-controlplane manifests-infrastructure manifests-k0smotron
66+ .PHONY : manifests-bootstrap manifests-controlplane manifests-infrastructure manifests-standalone
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/bases \
72+ output:rbac:dir=config/clusterapi/bootstrap/rbac
7273
73- manifests-controlplane : $(CONTROLLER_GEN ) # # Generate CRDs for controlplane.cluster.x-k8s.io
74+ manifests-controlplane : $(CONTROLLER_GEN ) # # Generate CRDs for controlplane.cluster.x-k8s.io.
75+ $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true webhook \
76+ paths=" ./api/controlplane/v1beta1/..." \
77+ paths=./internal/controller/controlplane/... \
78+ output:crd:artifacts:config=config/clusterapi/controlplane/crd/bases
7479 $(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
80+ paths=" ./api/controlplane/v1beta1/..." \
81+ paths=" ./api/k0smotron.io/v1beta1/..." \
82+ paths=./internal/controller/controlplane/... \
83+ paths=./internal/controller/k0smotron.io/... \
84+ output:rbac:dir=config/clusterapi/controlplane/rbac \
85+ output:webhook:dir=config/clusterapi/controlplane/webhook
7886
7987manifests-infrastructure : $(CONTROLLER_GEN ) # # Generate CRDs for infrastructure.cluster.x-k8s.io
80- $(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
88+ $(CONTROLLER_GEN ) rbac:roleName=manager-role crd:generateEmbeddedObjectMeta=true \
89+ paths=" ./api/infrastructure/v1beta1/..." \
90+ paths=./internal/controller/infrastructure/... \
91+ output:crd:artifacts:config=config/clusterapi/infrastructure/crd/bases \
92+ output:rbac:dir=config/clusterapi/infrastructure/rbac
8493
85- manifests-k0smotron : $(CONTROLLER_GEN ) # # Generate CRDs for k0smotron.io
94+ manifests-standalone : $(CONTROLLER_GEN ) # # Generate CRDs for k0smotron.io standalone
8695 $(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
96+ paths=" ./api/k0smotron.io/v1beta1/..." \
97+ paths=./internal/controller/k0smotron.io/... \
98+ output:crd:artifacts:config=config/standalone/crd/bases \
99+ output:rbac:dir=config/standalone/rbac \
100+ output:webhook:dir=config/standalone/webhook
101+
102+ .PHONY : manifests-capi-integration
103+ manifests-capi-integration : manifests manifests-capi-integration-without-crd
104+
105+ .PHONY : manifests-capi-integration-without-crd
106+ manifests-capi-integration-without-crd : $(CONTROLLER_GEN ) # Generate RBAC and webhook manifests for all controllers except CRDs in order to reuse them from each config/clusterapi/{provider}
107+ $(CONTROLLER_GEN ) rbac:roleName=manager-role webhook \
108+ paths=" ./api/bootstrap/v1beta1/..." \
109+ paths=./internal/controller/bootstrap/... \
110+ paths=" ./api/controlplane/v1beta1/..." \
111+ paths=" ./api/k0smotron.io/v1beta1/..." \
112+ paths=./internal/controller/controlplane/... \
113+ paths=./internal/controller/k0smotron.io/... \
114+ paths=" ./api/infrastructure/v1beta1/..." \
115+ paths=./internal/controller/infrastructure/... \
116+ output:rbac:dir=config/clusterapi/all/rbac \
117+ output:webhook:dir=config/clusterapi/all/webhook
90118
91119.PHONY : manifests
92- manifests : manifests-bootstrap manifests-controlplane manifests-infrastructure manifests-k0smotron # # Generate all CRD YAMLs per group
120+ manifests : manifests-bootstrap manifests-controlplane manifests-infrastructure manifests-standalone # # Generate all CRD YAMLs per group
93121
94122# ## generate
95123generate_targets += api/k0smotron.io/v1beta1/zz_generated.deepcopy.go
@@ -99,7 +127,7 @@ generate_targets += api/infrastructure/v1beta1/zz_generated.deepcopy.go
99127$(generate_targets ) : $(CONTROLLER_GEN )
100128 $(CONTROLLER_GEN ) object:headerFile=" hack/boilerplate.go.txt" paths=" ./..."
101129
102- generate : $(generate_targets ) clusterapi- manifests # # Generate code containing DeepCopy, DeepCopyInto, and DeepCopyObject method implementations.
130+ generate : $(generate_targets ) manifests # # Generate code containing DeepCopy, DeepCopyInto, and DeepCopyObject method implementations.
103131
104132
105133GO_PKGS =$(shell go list ./...)
@@ -149,10 +177,6 @@ e2e-aws:
149177build :
150178 go build -o bin/manager cmd/main.go
151179
152- .PHONY : run
153- run : manifests generate fmt vet # # Run a controller from your host.
154- go run ./cmd/main.go
155-
156180# If you wish built the manager image targeting other platforms you can use the --platform flag.
157181# (i.e. docker build --platform linux/arm64 ). However, you must enable docker buildKit for it.
158182# More info: https://docs.docker.com/develop/develop-images/build_enhancements/
@@ -193,49 +217,43 @@ ifndef ignore-not-found
193217 ignore-not-found = false
194218endif
195219
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-
204220.PHONY : deploy
205221deploy : 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 -
222+ cd config/clusterapi/all/manager && $(KUSTOMIZE ) edit set image k0s/k0smotron=${IMG}
223+ $(KUSTOMIZE ) build config/clusterapi/all | kubectl create -f -
224+ git checkout config/clusterapi/all/manager/kustomization.yaml
208225
209226.PHONY : undeploy
210227undeploy : # # 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 -
228+ $(KUSTOMIZE ) build config/clusterapi/all | kubectl delete --ignore-not-found=$(ignore-not-found ) -f -
212229
213230.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}
231+ release : manifests-capi-integration kustomize # # Deploy controller to the K8s cluster specified in ~/.kube/config.
232+ cd config/clusterapi/all/ manager && $(KUSTOMIZE ) edit set image controller=${IMG}
233+ $(KUSTOMIZE ) build config/clusterapi/all > install.yaml
234+ git checkout config/clusterapi/all/ manager/kustomization.yaml
235+
236+ .PHONY : release-standalone
237+ release-standalone : manifests-standalone kustomize # # Generate install yaml for standalone mode
238+ cd config/standalone/manager && $( KUSTOMIZE ) edit set image controller= ${IMG}
239+ $(KUSTOMIZE ) build config/standalone > install-standalone.yaml
240+ git checkout config/standalone/manager/kustomization.yaml
241+
242+ bootstrap-components.yaml : $(CONTROLLER_GEN ) manifests-bootstrap kustomize
243+ cd config/clusterapi/bootstrap/ manager && $(KUSTOMIZE ) edit set image controller=${IMG}
227244 $(KUSTOMIZE ) build config/clusterapi/bootstrap/ > bootstrap-components.yaml
228- git checkout config/manager/kustomization.yaml
245+ git checkout config/clusterapi/bootstrap/ manager/kustomization.yaml
229246
230- control-plane-components.yaml : $(CONTROLLER_GEN ) clusterapi- manifests kustomize
231- cd config/manager && $(KUSTOMIZE ) edit set image controller=${IMG}
247+ control-plane-components.yaml : $(CONTROLLER_GEN ) manifests-controlplane kustomize
248+ cd config/clusterapi/controlplane/ manager && $(KUSTOMIZE ) edit set image controller=${IMG}
232249 $(KUSTOMIZE ) build config/clusterapi/controlplane/ > control-plane-components.yaml
233- git checkout config/manager/kustomization.yaml
250+ git checkout config/clusterapi/controlplane/ manager/kustomization.yaml
234251
235- infrastructure-components.yaml : $(CONTROLLER_GEN ) clusterapi- manifests kustomize
236- cd config/manager && $(KUSTOMIZE ) edit set image controller=${IMG}
252+ infrastructure-components.yaml : $(CONTROLLER_GEN ) manifests-infrastructure kustomize
253+ cd config/clusterapi/infrastructure/ manager && $(KUSTOMIZE ) edit set image controller=${IMG}
237254 $(KUSTOMIZE ) build config/clusterapi/infrastructure/ > infrastructure-components.yaml
238- git checkout config/manager/kustomization.yaml
255+ git checkout config/clusterapi/infrastructure/manager/kustomization.yaml
256+
239257# #@ Build Dependencies
240258
241259kustomize : $(KUSTOMIZE ) # # Download kustomize locally if necessary. If wrong version is installed, it will be removed before downloading.
@@ -270,23 +288,23 @@ $(CRDOC): Makefile.variables | $(LOCALBIN)
270288
271289.PHONY : docs-generate-bootstrap docs-generate-controlplane docs-generate-infrastructure docs-generate-k0smotron docs-generate-reference
272290docs-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
291+ $(CRDOC ) --resources config/clusterapi/bootstrap/ crd/bases --output docs/resource-reference/bootstrap.cluster.x-k8s.io-v1beta1.md
274292
275293docs-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
294+ $(CRDOC ) --resources config/clusterapi/controlplane/ crd/bases --output docs/resource-reference/controlplane.cluster.x-k8s.io-v1beta1.md
277295
278296docs-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
297+ $(CRDOC ) --resources config/clusterapi/infrastructure/ crd/bases --output docs/resource-reference/infrastructure.cluster.x-k8s.io-v1beta1.md
280298
281299docs-generate-k0smotron : $(CRDOC ) # # Generate docs for k0smotron CRDs
282- $(CRDOC ) --resources config/crd/bases/k0smotron.io --output docs/resource-reference/k0smotron.io-v1beta1.md
300+ $(CRDOC ) --resources config/standalone/ crd/bases --output docs/resource-reference/k0smotron.io-v1beta1.md
283301
284302# Generate docs for all CRDs apis
285303docs-generate-reference : docs-generate-bootstrap docs-generate-controlplane docs-generate-infrastructure docs-generate-k0smotron
286304
287305# # Generate all code, manifests, documentation, and release artifacts
288306.PHONY : generate-all
289- generate-all : clean generate manifests clusterapi-manifests docs-generate-reference release
307+ generate-all : clean generate docs-generate-reference release
290308
291309.PHONY : $(smoketests )
292310$(smoketests ) : release k0smotron-image-bundle.tar
@@ -338,7 +356,7 @@ kind-deploy-capi:
338356
339357.PHONY : kind-deploy-k0smotron
340358kind-deploy-k0smotron : release k0smotron-image-bundle.tar
341- kind load image-archive k0smotron-image-bundle.tar --name k0smotron
359+ kind load image-archive k0smotron-image-bundle.tar
342360 kubectl apply --server-side=true -f install.yaml
343361 kubectl rollout restart -n k0smotron deployment/k0smotron-controller-manager
344362
0 commit comments