This repository has been archived by the owner on Dec 25, 2024. It is now read-only.
forked from EyeCantCU/kernel-signer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsign-kernel.sh
executable file
·68 lines (58 loc) · 1.95 KB
/
sign-kernel.sh
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
#!/usr/bin/bash
set -ouex pipefail
kernel_version=""
alt_kernels=$(sed 's/$/-/' /tmp/kernel_options.txt | paste -sd'|')
if command -v rpm; then
kernel_version=$(rpm -qa | grep -P "kernel-(|$alt_kernels)(\d+\.\d+\.\d+)" | sed -E "s/kernel-(|$alt_kernels)//")
fi
if command -v rpm-ostree; then
rpm-ostree install sbsigntools openssl
elif command -v dnf; then
dnf install sbsigntools openssl
elif command -v dnf5; then
dnf5 install sbsigntools openssl
fi
# Private key
if [[ "${PRIVKEY}" == /* ]]; then
PRIVKEY_PATH="${PRIVKEY}"
else
PRIVKEY_PATH="/etc/pki/kernel/private/private_key.priv"
mkdir -p "$(dirname "$PRIVKEY_PATH")"
if [[ "${PRIVKEY}" == ./* ]]; then
cp "${PRIVKEY}" "${PRIVKEY_PATH}"
elif [[ "${PRIVKEY}" == http* ]]; then
wget -q "${PRIVKEY}" -O "${PRIVKEY_PATH}"
else
echo "${PRIVKEY}" > "${PRIVKEY_PATH}"
fi
fi
# Public key
if [[ "${PUBKEY}" == /* ]]; then
PUBKEY_PATH="${PUBKEY}"
else
PUBKEY_PATH="/etc/pki/kernel/public/public_key.der"
mkdir -p "$(dirname "$PUBKEY_PATH")"
if [[ "${PUBKEY}" == ./* ]]; then
cp "${PUBKEY}" "${PUBKEY_PATH}"
elif [[ "${PUBKEY}" == http* ]]; then
wget -q "${PUBKEY}" -O "${PUBKEY_PATH}"
else
echo "${PUBKEY}" > "${PUBKEY_PATH}"
fi
fi
echo "Signing kernel..."
CRT_PATH=$(echo $(dirname "$PUBKEY_PATH")/public_key.crt)
openssl x509 -in $PUBKEY_PATH -out $CRT_PATH
EXISTING_SIGNATURES="$(sbverify --list /usr/lib/modules/$kernel_version/vmlinuz | grep '^signature \([0-9]\+\)$' | sed 's/^signature \([0-9]\+\)$/\1/')"
for SIGNUM in $EXISTING_SIGNATURES
do
echo "Found existing signature at signum $SIGNUM, removing..."
sbattach --remove /usr/lib/modules/$kernel_version/vmlinuz
done
sbsign --cert $CRT_PATH --key $PRIVKEY_PATH /usr/lib/modules/$kernel_version/vmlinuz --output /usr/lib/modules/$kernel_version/vmlinuz
sbverify --list /usr/lib/modules/$kernel_version/vmlinuz
if command -v ostree; then
rm -rf /tmp/* /var/*
mkdir -p /var/lib/bluetooth
ostree container commit
fi