raspberry-pi-tools/sd_setup.sh

279 lines
8.9 KiB
Bash
Raw Normal View History

2020-04-29 14:21:46 +02:00
#!/bin/bash
2020-04-29 18:35:35 +02:00
# shellcheck disable=SC2010 # ls | grep allowed
2020-04-30 09:29:57 +02:00
# shellcheck disable=SC2143 # Suppress wrong grep -q warning
2020-04-29 14:21:46 +02:00
echo "Setupscript for Raspberry Pi SD's"
echo
echo "@author Kevin Veen-Birkenbach [kevin@veen.world]"
echo "@since 2017-03-12"
echo
2020-04-29 18:21:18 +02:00
echo "Starting setup..."
2020-04-29 22:26:43 +02:00
echo "Define variables..."
2020-04-29 20:20:26 +02:00
working_folder="/tmp/raspberry-pi-tools-$(date +%s)/";
2020-04-29 18:35:35 +02:00
2020-04-29 22:26:43 +02:00
echo "Define functions..."
2020-04-29 23:15:06 +02:00
warning(){
echo "WARNING: $1";
}
destructor(){
echo "Cleaning up..."
umount -v "$root_mount_path" "$boot_mount_path" || warning "Umounting $root_mount_path and/or $boot_mount_path failed!"
rm -vr "$working_folder" || warning "Removing $working_folder failed!"
}
2020-04-29 22:26:43 +02:00
error(){
2020-04-29 23:15:06 +02:00
echo "ERROR: $1 Leaving program."
destructor
exit 1;
2020-04-29 22:26:43 +02:00
}
2020-04-29 18:35:35 +02:00
2020-04-29 14:21:46 +02:00
echo "Create temporary working folder in $working_folder";
mkdir -v "$working_folder"
2020-04-29 18:21:18 +02:00
echo "Checking if root..."
if [ "$(id -u)" != "0" ];then
2020-04-29 22:26:43 +02:00
error "This script must be executed as root!"
2020-04-29 14:21:46 +02:00
fi
2020-04-29 18:21:18 +02:00
echo "Configure user..."
echo "Please type in a valid username from which the SSH-Key should be copied:" && read -r origin_username;
2020-04-29 22:26:43 +02:00
getent passwd "$origin_username" > /dev/null 2 || error "User $origin_username doesn't exist.";
2020-04-29 18:35:35 +02:00
origin_user_home="/home/$origin_username/";
2020-04-29 16:56:31 +02:00
2020-04-29 18:59:04 +02:00
echo "Image routine starts..."
2020-04-29 19:06:39 +02:00
image_folder="$origin_user_home""Images/";
2020-04-29 16:39:19 +02:00
echo "The images will be stored in \"$image_folder\"."
2020-04-29 19:06:39 +02:00
if [ ! -d "$image_folder" ]; then
2020-04-29 16:39:19 +02:00
echo "Folder \"$image_folder\" doesn't exist. It will be created now."
mkdir -v "$image_folder"
fi
2020-04-29 18:21:18 +02:00
echo "Select sd-card..."
2020-04-29 14:21:46 +02:00
echo "List of actual mounted devices:"
ls -lasi /dev/ | grep -E "sd|mm"
echo
2020-04-29 18:35:35 +02:00
while [ ! -b "$sd_card_path" ]
2020-04-29 14:21:46 +02:00
do
2020-04-29 18:21:18 +02:00
echo "Please type in the name of the correct sd-card."
echo "/dev/:" && read -r device
2020-04-29 18:21:18 +02:00
sd_card_path="/dev/$device"
2020-04-29 14:21:46 +02:00
done
2020-04-29 18:21:18 +02:00
echo "Select which Raspberry Pi version should be used:" && read -r version
2020-04-29 18:21:18 +02:00
2020-04-29 18:56:07 +02:00
echo "Select which operation system should be used..."
2020-04-29 18:21:18 +02:00
echo
2020-04-29 14:21:46 +02:00
echo "1) arch"
echo "2) moode"
echo "3) retropie"
2020-04-29 18:21:18 +02:00
echo
echo "Please type in the os:" && read -r os
2020-04-29 18:56:07 +02:00
os_does_not_support_raspberry_version_error () {
2020-04-29 22:26:43 +02:00
error "$os for Raspberry Pi Version $version is not supported!";
2020-04-29 18:56:07 +02:00
}
2020-04-29 14:21:46 +02:00
case "$os" in
"arch")
base_download_url="http://os.archlinuxarm.org/os/";
case "$version" in
"1")
imagename="ArchLinuxARM-rpi-latest.tar.gz"
;;
"2" | "3")
imagename="ArchLinuxARM-rpi-2-latest.tar.gz"
;;
"4")
imagename="ArchLinuxARM-rpi-4-latest.tar.gz"
;;
*)
2020-04-29 21:44:50 +02:00
os_does_not_support_raspberry_version_error
2020-04-29 14:21:46 +02:00
;;
esac
;;
"moode")
2020-04-29 21:01:53 +02:00
image_checksum="185cbc9a4994534bb7a4bc2744c78197"
2020-04-29 14:21:46 +02:00
base_download_url="https://github.com/moode-player/moode/releases/download/r651prod/"
imagename="moode-r651-iso.zip";
;;
"retropie")
base_download_url="https://github.com/RetroPie/RetroPie-Setup/releases/download/4.6/";
case "$version" in
"1")
2020-04-29 21:01:53 +02:00
image_checksum="98b4205ad0248d378c6776e20c54e487"
2020-04-29 14:21:46 +02:00
imagename="retropie-buster-4.6-rpi1_zero.img.gz"
;;
"2" | "3")
2020-04-29 21:01:53 +02:00
image_checksum="2e082ef5fc2d7cf7d910494cf0f7185b"
2020-04-29 14:21:46 +02:00
imagename="retropie-buster-4.6-rpi2_rpi3.img.gz"
;;
"4")
2020-04-29 21:01:53 +02:00
image_checksum="9154d998cba5219ddf23de46d8845f6c"
2020-04-29 14:21:46 +02:00
imagename="retropie-buster-4.6-rpi4.img.gz"
;;
*)
2020-04-29 21:44:50 +02:00
os_does_not_support_raspberry_version_error
2020-04-29 14:21:46 +02:00
;;
esac
;;
*)
2020-04-29 22:26:43 +02:00
error "The operation system \"$os\" is not supported yet!"
2020-04-29 14:21:46 +02:00
;;
esac
2020-04-29 18:21:18 +02:00
2020-04-29 18:56:07 +02:00
echo "Download os-image..."
2020-04-29 14:21:46 +02:00
download_url="$base_download_url$imagename"
2020-04-29 19:24:43 +02:00
image_path="$image_folder$imagename"
2020-04-29 18:21:18 +02:00
2020-04-29 18:35:35 +02:00
if [ ! -f "$image_path" ]
2020-04-29 14:21:46 +02:00
then
2020-04-29 16:56:31 +02:00
echo "The selected image \"$imagename\" doesn't exist under local path \"$image_path\"."
2020-04-29 18:35:35 +02:00
if [ ! -f "$image_path" ]
2020-04-29 14:21:46 +02:00
then
2020-04-29 18:56:07 +02:00
echo "Image \"$imagename\" gets downloaded from \"$download_url\"..."
2020-04-29 22:26:43 +02:00
wget "$download_url" -P "$image_folder" || error "Download failed."
2020-04-29 14:21:46 +02:00
fi
fi
2020-04-29 18:21:18 +02:00
2020-04-29 21:01:53 +02:00
echo "Verifying image..."
if [[ -v image_checksum ]]
then
2020-04-29 22:26:43 +02:00
echo "$image_checksum $image_path"| md5sum -c -|| error "Verification failed."
2020-04-29 21:01:53 +02:00
else
2020-04-29 23:15:06 +02:00
warning "Verification is not possible. No checksum is define."
2020-04-29 21:01:53 +02:00
fi
2020-04-29 21:33:26 +02:00
2020-04-29 18:56:07 +02:00
echo "Preparing mount paths..."
2020-04-29 18:21:18 +02:00
boot_mount_path="$working_folder""boot"
root_mount_path="$working_folder""root"
mkdir -v "$boot_mount_path"
mkdir -v "$root_mount_path"
2020-04-29 18:56:07 +02:00
echo "Defining partition paths..."
2020-04-29 18:21:18 +02:00
if [ "${sd_card_path:5:1}" != "s" ]
then
partion="p"
else
partion=""
fi
boot_partition_path=$sd_card_path$partion"1"
root_partition_path=$sd_card_path$partion"2"
mount_partitions(){
echo "Mount boot and root partition..."
2020-04-29 22:26:43 +02:00
mount "$boot_partition_path" "$boot_mount_path" || error "Mount from $boot_partition_path to $boot_mount_path failed..."
mount "$root_partition_path" "$root_mount_path" || error "Mount from $root_partition_path to $root_mount_path failed..."
2020-04-29 20:20:26 +02:00
echo "The following mounts refering this setup exist:" && mount | grep "$working_folder"
2020-04-29 18:21:18 +02:00
}
echo "Should the image be transfered to $sd_card_path?(y/n)" && read -r transfer_image
2020-04-30 09:29:57 +02:00
if [ "$transfer_image" = "y" ]
then
echo "Starting image transfer..."
case "$os" in
"arch")
echo "Execute fdisk..."
( echo "o" #Type o. This will clear out any partitions on the drive.
echo "p" #Type p to list partitions. There should be no partitions left
echo "n" #Type n,
echo "p" #then p for primary,
echo "1" #1 for the first partition on the drive,
echo "" #press ENTER to accept the default first sector,
echo "+100M" #then type +100M for the last sector.
echo "t" #Type t,
echo "c" #then c to set the first partition to type W95 FAT32 (LBA).
echo "n" #Type n,
echo "p" #then p for primary,
echo "2" #2 for the second partition on the drive,
echo "" #and then press ENTER twice to accept the default first and last sector.
echo ""
echo "w" #Write the partition table and exit by typing w.
)| fdisk "$sd_card_path" || error "Creating partitions failed. Try \"sudo dd if=/dev/zero of=$sd_card_path bs=1M\""
echo "Format boot partition..."
mkfs.vfat "$boot_partition_path" || error "Format boot is not possible."
echo "Format root partition..."
mkfs.ext4 "$root_partition_path" || error "Format root is not possible."
mount_partitions;
echo "Root files will be transfered to sd-card..."
bsdtar -xpf "$image_path" -C "$root_mount_path"
sync
echo "Boot files will be transfered to sd-card..."
mv -v "$root_mount_path/boot/"* "$boot_mount_path"
2020-04-29 20:20:26 +02:00
2020-04-30 09:29:57 +02:00
;;
"moode")
unzip -p "$image_path" | sudo dd of="$sd_card_path" bs=1M conv=fsync || error "DD to $sd_card_path failed."
sync
;;
"retropie")
gunzip -c "$image_path" | sudo dd of="$sd_card_path" bs=1M conv=fsync
sync
;;
*)
error "Image transfer for operation system \"$os\" is not supported yet!";
;;
esac
else
echo "Skipping image transfer..."
fi
2020-04-29 20:20:26 +02:00
2020-04-30 09:29:57 +02:00
echo "Start regular mounting procedure..."
if [ "$(mount | grep -q "$boot_mount_path")" ] && [ "$(mount | grep -q "$root_mount_path")" ]
then
echo "Everything allready mounted. Skipping..."
else
mount_partitions
fi
2020-04-29 18:21:18 +02:00
echo "Define target paths..."
target_home_path="$root_mount_path/home/";
2020-04-29 18:35:35 +02:00
target_username=$(ls "$target_home_path");
2020-04-29 18:21:18 +02:00
target_user_home_folder_path="$target_home_path$target_username/";
echo "Copy ssh key to target..."
target_user_ssh_folder_path="$target_user_home_folder_path"".ssh/"
2020-04-29 23:15:06 +02:00
target_authorized_keys="$target_user_ssh_folder_path""authorized_keys"
2020-04-29 18:21:18 +02:00
origin_user_rsa_pub="$origin_user_home/.ssh/id_rsa.pub";
if [ -f "$origin_user_rsa_pub" ]
then
mkdir -v "$target_user_ssh_folder_path"
cat "$origin_user_rsa_pub" > "$target_authorized_keys"
2020-04-29 20:20:26 +02:00
target_authorized_keys_content=$(cat "$target_authorized_keys")
echo "$target_authorized_keys contains the following: $target_authorized_keys_content"
chown -vR 1000 "$target_user_ssh_folder_path"
2020-04-29 23:33:37 +02:00
chmod -v 700 "$target_user_ssh_folder_path"
chmod -v 600 "$target_authorized_keys"
2020-04-29 18:21:18 +02:00
else
echo "The ssh key \"$origin_user_rsa_pub\" can't be copied to \"$target_authorized_keys\" because it doesn't exist."
fi
2020-04-29 18:56:07 +02:00
echo "Change password of user \"$target_username\"..."
2020-04-29 23:15:06 +02:00
(chroot "$root_mount_path" /bin/passwd "$target_username") || error "Password change for \"$target_username\" wasn't possible."
2020-04-29 18:56:07 +02:00
echo "Change password of root user..."
2020-04-29 23:15:06 +02:00
(chroot "$root_mount_path" /bin/passwd root) || error "Password change for \"root\" wasn't possible."
2020-04-29 18:56:07 +02:00
echo "Do you want to copy all Wifi passwords to the sd-card?(y/n)" && read -r copy_wifi
2020-04-29 18:56:07 +02:00
if [ "$copy_wifi" = "y" ]
then
origin_wifi_config_path="/etc/NetworkManager/system-connections/"
target_wifi_config_path="$root_mount_path$origin_wifi_config_path"
rsync -av "$origin_wifi_config_path" "$target_wifi_config_path"
fi
2020-04-29 20:20:26 +02:00
echo "The first level folder structure on $root_mount_path is now:" && tree -laL 1 "$root_mount_path"
echo "The first level folder structure on $boot_mount_path is now:" && tree -laL 1 "$boot_mount_path"
2020-04-29 21:33:26 +02:00
2020-04-29 23:15:06 +02:00
destructor
2020-04-29 18:21:18 +02:00
echo "Setup successfull :)" && exit 0