Clevis
This material is work-in-progress ... Do not follow instructions here until this notice is removed. |
What is clevis
It is a software that allows to encrypt/decrypt a disk by bounding to tang (network bound encryption/decryption) or a TPM (hardware chip encryption/decryption).
Why use clevis
With tang, you may automatically decrypt device block/files for convenience, it is encrypted and built to prevent man-in-the-middle attacks as well.
- It is recommended to use a tang docker with this
Auto Disk decryption using clevis + tang
You need to run tang in a separate server, from the one you want to decrypt. I recommend running a tang server on a docker.
mkinitfs + kernel-hooks + secureboot-hook
Using mkinitfs, it is possible to force tang/clevis in initramfs generation. It is recommended to make a chroot or docker so you don't mess with your system files, and by adding these files:
apk add cryptsetup
Edit /sbin/mkinitfs (put "# Copy custom init" before "# copy modloop signature"):
Contents of /etc/mkinitfs
PUT "# Clevis + tang script" AFTER "ebegin "Mounting root""
Contents of /initramfs/init
Contents of /etc/mkinitfs/features.d/curl.files
Contents of /etc/mkinitfs/features.d/clevis.files
Contents of /etc/mkinitfs/mkinitfs.conf
Then just do:
apk add secureboot-hook gummiboot gummiboot-efistub efibootmgr kernel-hooks secureboot-hook
mkinitfs -c /etc/mkinitfs/mkinitfs.conf -b / $(uname -r)
Decompress:
mkdir /tmp/initramfs cd /tmp/initramfs zcat /boot/initramfs-$KERNEL | cpio -idmv
Test if "init" works by just executing it and see how it runs:
./init
dracut