-#!/bin/sh
+#!/bin/bash
size=1024
fstype=ext4
label=casper-rw
+config=''
+outputfile=persistence.dat
print_usage() {
- echo 'Usage: CreatePersistentImg.sh [ -s size ] [ -t fstype ] [ -l LABEL ]'
+ echo 'Usage: sudo ./CreatePersistentImg.sh [ -s size ] [ -t fstype ] [ -l LABEL ] [ -c CFG ] [ -e ]'
echo ' OPTION: (optional)'
echo ' -s size in MB, default is 1024'
echo ' -t filesystem type, default is ext4 ext2/ext3/ext4/xfs are supported now'
echo ' -l label, default is casper-rw'
+ echo ' -c configfile name inside the persistence file. File content is "/ union"'
+ echo ' -o outputfile name, default is persistence.dat'
+ echo ' -e enable encryption, disabled by default (only few distros support this)'
echo ''
}
elif [ "$1" = "-l" ]; then
shift
label=$1
+ elif [ "$1" = "-c" ]; then
+ shift
+ config=$1
+ elif [ "$1" = "-o" ]; then
+ shift
+ outputfile=$1
+ elif [ "$1" = "-e" ]; then
+ read -s -p "Encryption passphrase: " passphrase
+ echo
+ elif [ "$1" = "-h" ] || [ "$1" = "--help" ]; then
+ print_usage
+ exit 0
else
print_usage
exit 1
exit 1
fi
+if [ "$outputdir" != "persistence.dat" ]; then
+ mkdir -p "$(dirname "$outputfile")"
+fi
+
# 00->ff avoid sparse file
-dd if=/dev/zero bs=1M count=$size | tr '\000' '\377' > persistence.dat
+dd if=/dev/zero bs=1M count=$size | tr '\000' '\377' > "$outputfile"
sync
freeloop=$(losetup -f)
-losetup $freeloop persistence.dat
+losetup $freeloop "$outputfile"
+
+if [ ! -z "$passphrase" ]; then
+ printf "$passphrase" | cryptsetup -q --verbose luksFormat $freeloop -
+ printf "$passphrase" | cryptsetup -q --verbose luksOpen $freeloop persist_decrypted -
+ _freeloop=$freeloop
+ freeloop="/dev/mapper/persist_decrypted"
+fi
mkfs -t $fstype $fsopt -L $label $freeloop
sync
-losetup -d $freeloop
+if [ -n "$config" ]; then
+ if [ -d ./persist_tmp_mnt ]; then
+ rm -rf ./persist_tmp_mnt
+ fi
+
+ mkdir ./persist_tmp_mnt
+ if mount $freeloop ./persist_tmp_mnt; then
+ echo '/ union' > ./persist_tmp_mnt/$config
+ sync
+ umount ./persist_tmp_mnt
+ fi
+ rm -rf ./persist_tmp_mnt
+fi
+if [ ! -z "$passphrase" ]; then
+ cryptsetup luksClose $freeloop
+ freeloop=$_freeloop
+fi
+
+losetup -d $freeloop