blob: b88c1794181a1b5e86cc1cf48d35ea3e029af212 (
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
|
#!/bin/sh
. /lib/partman/lib/crypto-base.sh
# 1. Check if active encrypted devices exist
crypto=no
for dev in $DEVICES/*; do
[ -d "$dev" ] || continue
cd $dev
if [ -f crypt_realdev ]; then
crypto=yes
break
fi
done
if [ $crypto = no ]; then
exit 0
fi
# 2. Check if unencrypted swap has been configured
for dev in $DEVICES/*; do
[ -d "$dev" ] || continue
cd $dev
# Accept swap on crypto
[ -f crypt_realdev ] && continue
device=$(cat $dev/device)
# Accept e.g. swap on lvm on crypto
if echo $device | grep -q "^/dev/mapper/"; then
if dm_is_safe "$device"; then
continue
fi
fi
partitions=
open_dialog PARTITIONS
while { read_line num id size type fs path name; [ "$id" ]; }; do
[ "$fs" != free ] || continue
partitions="$partitions $id"
done
close_dialog
for id in $partitions; do
[ -f $id/method ] || continue
method=$(cat $id/method)
if [ "$method" = swap ]; then
# Unsafe swap! Abort commit
db_fset partman-crypto/unsafe_swap seen false
db_input critical partman-crypto/unsafe_swap
db_go || true
exit 1
fi
done
done
|