8-8-0,8-8-1
This commit is contained in:
parent
a31d85f16a
commit
9e9434e8e0
1 changed files with 182 additions and 0 deletions
|
@ -130,6 +130,188 @@ else
|
|||
fi
|
||||
}
|
||||
|
||||
function hetzner-rescue-wipe-8-8-0 {
|
||||
local device
|
||||
local devices=(
|
||||
'/dev/sdc'
|
||||
'/dev/sda'
|
||||
'/dev/sdb'
|
||||
)
|
||||
local members
|
||||
local number
|
||||
local passphrase
|
||||
local unit='mib'
|
||||
# read passphrase
|
||||
echo -n 'PassPhrase: '
|
||||
read -r -s passphrase
|
||||
#
|
||||
lsblk
|
||||
echo -n 'WIPE' "${devices[@]}" '/?\ OR CANCEL /!\'
|
||||
read
|
||||
#
|
||||
number=0
|
||||
for device in "${devices[@]}" ; do
|
||||
((number++))
|
||||
echo ; echo "#${number}: ${device}"
|
||||
#
|
||||
parted "${device}" --script mktable gpt
|
||||
#
|
||||
parted "${device}" unit "${unit}" \
|
||||
mkpart "crypt-${number}" 22359 9537535
|
||||
#
|
||||
parted "${device}" unit "${unit}" \
|
||||
mkpart "boot-${number}" 513 22359
|
||||
#
|
||||
parted "${device}" unit "${unit}" \
|
||||
mkpart "esp-${number}" 2 513
|
||||
parted "${device}" set 3 esp on
|
||||
#
|
||||
parted "${device}" unit "${unit}" \
|
||||
mkpart "bios-${number}" 1 2
|
||||
parted "${device}" set 4 bios_grub on
|
||||
done
|
||||
#
|
||||
parted "${device}" unit "${unit}" \
|
||||
mkpart 'extra' 9537535 11444223
|
||||
#
|
||||
number=0
|
||||
for device in "${devices[@]}" ; do
|
||||
((number++))
|
||||
echo ; echo "#${number}: ${device}4"
|
||||
# wipe bios
|
||||
dd \
|
||||
if='/dev/zero' of="${device}4"
|
||||
done
|
||||
#
|
||||
number=0
|
||||
for device in "${devices[@]}" ; do
|
||||
((number++))
|
||||
echo ; echo "#${number}: ${device}3"
|
||||
# format esp
|
||||
dd \
|
||||
if='/dev/zero' of="${device}3" bs='1M'
|
||||
mkfs.vfat -F 32 -n "esp-${number}" "${device}3"
|
||||
done
|
||||
#
|
||||
number=0
|
||||
for device in "${devices[@]}" ; do
|
||||
((number++))
|
||||
echo ; echo "#${number}: ${device}2"
|
||||
# wipe boot
|
||||
dd status='progress' \
|
||||
if='/dev/zero' of="${device}2" bs='1G'
|
||||
done
|
||||
#
|
||||
members=()
|
||||
for device in "${devices[@]}" ; do
|
||||
members+=("${device}2")
|
||||
done
|
||||
mdadm \
|
||||
--create '/dev/md/boot' \
|
||||
--name 'boot' \
|
||||
--uuid '6234a0eb:29a3a847:1dbd5ec4:bada5579' \
|
||||
--metadata 1 \
|
||||
--level 0 \
|
||||
--raid-devices ${#devices[@]} \
|
||||
"${members[@]}"
|
||||
#
|
||||
number=0
|
||||
for device in "${devices[@]}" ; do
|
||||
((number++))
|
||||
echo ; echo "#${number}: ${device}1"
|
||||
# wipe crypt head
|
||||
dd status='progress' \
|
||||
if='/dev/zero' of="${device}1" bs='1G' count=1
|
||||
done
|
||||
#
|
||||
members=()
|
||||
for device in "${devices[@]}" ; do
|
||||
members+=("${device}1")
|
||||
done
|
||||
mdadm \
|
||||
--create '/dev/md/crypt' \
|
||||
--name 'crypt' \
|
||||
--uuid '006234a0:eb29a3a8:471dbd5e:c4bada55' \
|
||||
--metadata 1 \
|
||||
--level 0 \
|
||||
--raid-devices ${#devices[@]} \
|
||||
"${members[@]}"
|
||||
# format boot
|
||||
mkfs.ext4 \
|
||||
-F \
|
||||
-L 'boot' \
|
||||
-U '6234a0eb-29a3-a847-1dbd-5ec4bada5579' \
|
||||
'/dev/md/boot'
|
||||
# encrypt
|
||||
echo "${passphrase}" \
|
||||
| cryptsetup \
|
||||
--verbose \
|
||||
--batch-mode \
|
||||
--type 'luks2' \
|
||||
--pbkdf 'argon2id' \
|
||||
--cipher 'aes-xts-plain64' \
|
||||
--iter-time 8192 \
|
||||
--key-size 512 \
|
||||
--hash 'sha512' \
|
||||
--use-random \
|
||||
luksFormat \
|
||||
'/dev/md/crypt'
|
||||
# open
|
||||
echo "${passphrase}" \
|
||||
| cryptsetup luksOpen '/dev/md/crypt' 'crypt'
|
||||
# wipe crypt
|
||||
dd status='progress' \
|
||||
if='/dev/zero' of='/dev/mapper/crypt' bs='16G'
|
||||
}
|
||||
|
||||
function hetzner-rescue-wipe-8-8-1 {
|
||||
local passphrase
|
||||
# close
|
||||
cryptsetup luksClose 'crypt'
|
||||
# read passphrase
|
||||
echo -n 'PassPhrase: '
|
||||
read -r -s passphrase
|
||||
# encrypt
|
||||
echo "${passphrase}" \
|
||||
| cryptsetup \
|
||||
--verbose \
|
||||
--batch-mode \
|
||||
--type 'luks2' \
|
||||
--pbkdf 'argon2id' \
|
||||
--cipher 'aes-xts-plain64' \
|
||||
--iter-time 8192 \
|
||||
--key-size 512 \
|
||||
--hash 'sha512' \
|
||||
--use-random \
|
||||
luksFormat \
|
||||
'/dev/md/crypt'
|
||||
# open
|
||||
echo "${passphrase}" \
|
||||
| cryptsetup luksOpen '/dev/md/crypt' 'crypt'
|
||||
# pv
|
||||
pvcreate '/dev/mapper/crypt'
|
||||
# vg
|
||||
vgcreate 'crypt' '/dev/mapper/crypt'
|
||||
# lv swap
|
||||
lvcreate --name 'swap' --size '137438953472b' 'crypt'
|
||||
# lv data
|
||||
lvcreate --name 'data' --extents '100%FREE' 'crypt'
|
||||
# format swap
|
||||
mkswap \
|
||||
--label 'swap' \
|
||||
-U '06234a0e-b29a-3a84-71db-d5ec4bada557' \
|
||||
'/dev/mapper/crypt-swap'
|
||||
# format data
|
||||
mkfs.ext4 \
|
||||
-L 'data' \
|
||||
-U '006234a0-eb29-a3a8-471d-bd5ec4bada55' \
|
||||
'/dev/mapper/crypt-data'
|
||||
# vg off
|
||||
vgchange --activate n 'crypt'
|
||||
# close
|
||||
cryptsetup luksClose 'crypt'
|
||||
}
|
||||
|
||||
function hetzner-rescue-wipe-12-10-10-0 {
|
||||
local device
|
||||
local devices=(
|
||||
|
|
Loading…
Reference in a new issue