Flux2 is an open and extensible continuous delivery solution for Kubernetes. Flux2 versions between 0.1.0 and 0.29.0, helm-controller 0.1.0 to v0.19.0, and kustomize-controller 0.1.0 to v0.23.0 are vulnerable to Code Injection via malicious Kubeconfig. In multi-tenancy deployments this can also lead to privilege escalation if the controllerβs service account has elevated permissions. Workarounds include disabling functionality via Validating Admission webhooks by restricting users from setting the spec.kubeConfig
field in Flux Kustomization
and HelmRelease
objects. Additional mitigations include applying restrictive AppArmor and SELinux profiles on the controllerβs pod to limit what binaries can be executed. This vulnerability is fixed in kustomize-controller v0.23.0 and helm-controller v0.19.0, both included in flux2 v0.29.0
CPE | Name | Operator | Version |
---|---|---|---|
flux2 | eq | api/v0.4.2 | |
flux2 | eq | api/v0.20.0 | |
flux2 | eq | api/v0.21.0 | |
flux2 | eq | 0.11.2 | |
flux2 | eq | 0.28.4 | |
flux2 | eq | 0.1.1 | |
flux2 | eq | 0.7.7 | |
flux2 | eq | 0.2.0 | |
flux2 | eq | api/v0.1.2 | |
flux2 | eq | api/v0.18.2 |