CVE-2024-3154
HIGH7.2EPSS 0.37%CRI-O vulnerable to an arbitrary systemd property injection
Description
### Impact On CRI-O, it looks like an arbitrary systemd property can be injected via a Pod annotation: ``` --- apiVersion: v1 kind: Pod metadata: name: poc-arbitrary-systemd-property-injection annotations: # I believe that ExecStart with an arbitrary command works here too, # but I haven't figured out how to marshalize the ExecStart struct to gvariant string. org.systemd.property.SuccessAction: "'poweroff-force'" spec: containers: - name: hello image: [quay.io/podman/hello](http://quay.io/podman/hello) ``` This means that any user who can create a pod with an arbitrary annotation may perform an arbitrary action on the host system. Tested with CRI-O v1.24 on minikube. I didn't test the latest v1.29 because it is incompatible with minikube: https://github.com/kubernetes/minikube/pull/18367 Thanks to Cédric Clerget (GitHub ID @cclerget) for finding out that CRI-O just passes pod annotations to OCI annotations: https://github.com/opencontainers/runc/pull/3923#discussion_r1532292536 CRI-O has to filter out annotations that have the prefix "org.systemd.property." See also: - https://github.com/opencontainers/runtime-spec/blob/main/features.md#unsafe-annotations-in-configjson - https://github.com/opencontainers/runc/pull/4217 ### Workarounds Unfortunately, the only workarounds would involve an external mutating webhook to disallow these annotations ### References
Affected packages (2)
- Go/github.com/cri-o/cri-o>= 1.29.0, < 1.29.4
- Go/github.com/cri-o/cri-ofrom 0, < 1.27.6, >= 1.28.0, < 1.28.6, >= 1.29.0, < 1.29.4
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 3.1 | HIGH7.2 | CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:H |
References (7)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2024-3154
- PATCHhttps://github.com/cri-o/cri-o
- WEBhttps://access.redhat.com/security/cve/CVE-2024-3154
- WEBhttps://bugzilla.redhat.com/show_bug.cgi?id=2272532
- WEBhttps://github.com/cri-o/cri-o/security/advisories/GHSA-2cgq-h8xw-2v5j
- WEBhttps://github.com/opencontainers/runc/pull/4217
- WEBhttps://github.com/opencontainers/runtime-spec/blob/main/features.md#unsafe-annotations-in-configjson