summaryrefslogtreecommitdiffstats
path: root/bin/cryptdir
blob: eb63300c45bbe416068267a75a8559170a8fcbc8 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#!/bin/sh
set -eu
set -o pipefail

if [ -e /dev/mapper/cryptdir ]; then
    echo "only one instance can run at a time" 1>&2
    exit 1
fi

sudo -v || exit 1

if [ -z "${1:-}" ]; then
    size='16M'
else
    size=$1
fi

cryptfile=$(mktemp)
cryptdir=$(mktemp -d)
pass=$(dd if=/dev/urandom bs=1 count=80 | base64)

cleanup() {
    set +e
    cd
    sudo umount "$cryptdir"
    sudo cryptsetup close cryptdir
    rm -f "$cryptfile"
    rmdir "$cryptdir"
}

trap cleanup EXIT

dd if=/dev/urandom of="$cryptfile" bs="$size" count=1
echo "$pass" | sudo cryptsetup luksFormat "$cryptfile" -
echo "$pass" | sudo cryptsetup open "$cryptfile" cryptdir --key-file -
sudo mkfs.ext2 /dev/mapper/cryptdir
sudo mount /dev/mapper/cryptdir "$cryptdir"
sudo chown "$USER" "$cryptdir"
cd "$cryptdir"
$SHELL