aboutsummarylogtreecommitdiffstats
path: root/pgp-encrypt-install
blob: 159bdaf87ecec1b3c6e0e4fe4b7065c043881d70 (plain)
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
#!/bin/bash

build() {
    set +e
    local mod pub_key
    
    map add_module 'dm-crypt' 'dm-integrity' 'hid-generic?'
    if [[ -n "$CRYPTO_MODULES" ]]; then
        for mod in $CRYPTO_MODULES; do
            add_module "$mod"
        done
    else
        add_all_modules '/crypto/'
    fi

    add_binary 'cryptsetup'

    map add_udev_rule \
        '10-dm.rules' \
        '13-dm-disk.rules' \
        '95-dm-notify.rules' \
        '/usr/lib/initcpio/udev/11-dm-initramfs.rules'

    # cryptsetup calls pthread_create(), which dlopen()s libgcc_s.so.1
    add_binary '/usr/lib/libgcc_s.so.1'

    # cryptsetup loads the legacy provider which is required for whirlpool
    add_binary '/usr/lib/ossl-modules/legacy.so'

    # above is from encrypt hook, below is for gpg

    if [ -d $BUILDROOT/etc/initcpio/gpg ]; then
        echo "WARNING! /etc/initcpio/gpg exists in initramfs buildroot. Huh?"
        rm -rf "$BUILDROOT/etc/initcpio/gpg"
    fi

    mkdir -p $BUILDROOT/etc/initcpio/gpg
    chmod 0700 $BUILDROOT/etc/initcpio/gpg

    add_binary "tr"
    add_binary "dmsetup"
    add_binary "gpg"
    add_binary "gpg-agent"
    add_binary "gpg-connect-agent"
    add_binary "/usr/lib/gnupg/scdaemon"

    add_file "/root/disk.bin.gpg"

    pub_key="/root/disk.pub.key"
    if [[ ! -f "$pub_key" ]]; then
        error "file not found: '%s'" "$pub_key"
        return 1
    fi

    gpg --homedir "$BUILDROOT/etc/initcpio/gpg" --import "$pub_key"

    rm -f "$BUILDROOT/etc/initcpio/gpg/S.gpg-agent"*

    add_runscript
}

help() {
    cat <<HELPEOF
Plese refer to the help for the regular Arch encrypt hook, and the
docs in initramfs-pgp-encrypt.install for how to set up the PGP keys
HELPEOF
}

# vim: set ft=sh ts=4 sw=4 et: