C-0015 - List Kubernetes secrets
Framework
MITRE, ClusterScan, AllControls
Severity
High
Description of the the issue
A Kubernetes secret is an object that lets users store and manage sensitive information, such as passwords and connection strings in the cluster. Secrets can be consumed by reference in the pod configuration. Attackers who have permissions to retrieve the secrets from the API server (by using the pod service account, for example) can access sensitive information that might include credentials to various services.
Related resources
ClusterRole, ClusterRoleBinding, Role, RoleBinding
What does this control test
Alerting on users which have get/list/watch RBAC permissions on secrets.
Remediation
Monitor and approve list of users, groups and service accounts that can access secrets. Use exception mechanism to prevent repetitive the notifications.
Example
kind: Role
apiVersion: rbac.authorization.k8s.io/v1
metadata:
namespace: default
name: pod-exec
rules:
- apiGroups: ["*"]
resources: ["secrets"] # we look for this resource or *
verbs: ["get","list","watch"] # we look for this verb or *
Updated 6 days ago