Finding ID | Version | Rule ID | IA Controls | Severity |
---|---|---|---|---|
V-242415 | CNTR-K8-001160 | SV-242415r712601_rule | High |
Description |
---|
Secrets, such as passwords, keys, tokens, and certificates should not be stored as environment variables. These environment variables are accessible inside Kubernetes by the "Get Pod" API call, and by any system, such as CI/CD pipeline, which has access to the definition file of the container. Secrets must be mounted from files or stored within password vaults. |
STIG | Date |
---|---|
Kubernetes Security Technical Implementation Guide | 2021-06-17 |
Check Text ( C-45690r712599_chk ) |
---|
On the Kubernetes Master node, run the following command: kubectl get all -o jsonpath='{range .items[?(@..secretKeyRef)]} {.kind} {.metadata.name} {"\n"}{end}' -A If any of the values returned reference environment variables, this is a finding. |
Fix Text (F-45648r712600_fix) |
---|
Any secrets stored as environment variables must be moved to the secret files with the proper protections and enforcements or placed within a password vault. |