archboot/usr/bin/archboot-x86_64-release.sh

60 lines
2.5 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
# created by Tobias Powalowski <tpowa@archlinux.org>
_BASENAME="$(basename "${0}")"
usage () {
echo "${_BASENAME}:"
echo "CREATE ARCHBOOT RELEASE IMAGE"
echo "-----------------------------"
echo "Usage: ${_BASENAME} <directory>"
echo "This will create an archboot release image in <directory>."
exit 0
}
[[ -z "${1}" ]] && usage
### check for root
if ! [[ ${UID} -eq 0 ]]; then
echo "ERROR: Please run as root user!"
exit 1
fi
mkdir -p $1
cd $1
2021-09-11 10:26:04 +02:00
# create container
archboot-create-container.sh archboot-release
2021-09-22 18:59:33 +02:00
# generate tarball in container, umount tmp it's a tmpfs and weird things could happen then
systemd-nspawn -D /bin/bash -c "umount /tmp;archboot-release archboot-x86_64-iso.sh -t -i=archrelease"
2021-09-11 10:26:04 +02:00
# generate iso in container
2021-09-22 18:59:33 +02:00
systemd-nspawn -D /bin/bash -c "umount /tmp;archboot-release archboot-x86_64-iso.sh -g -T=archrelease.tar"
2021-09-11 10:26:04 +02:00
# move iso out of container
mv archboot-release/*.iso ./
# remove container
rm -r archboot-release
2021-09-11 10:26:04 +02:00
# create boot directory with ramdisks
mkdir boot
mkdir -p boot/licenses/amd-ucode
mkdir -p boot/licenses/intel-ucode
2021-09-11 10:26:04 +02:00
isoinfo -R -i *.iso -x /boot/amd-ucode.img > boot/amd-ucode.img
isoinfo -R -i *.iso -x /boot/intel-ucode.img > boot/intel-ucode.img
2021-09-13 16:18:46 +02:00
isoinfo -R -i *.iso -x /boot/initramfs_x86_64.img > boot/initramfs_archboot_x86_64.img
isoinfo -R -i *.iso -x /boot/vmlinuz_x86_64 > boot/vmlinuz_archboot_x86_64
cp /usr/share/licenses/amd-ucode/* boot/licenses/amd-ucode/
cp /usr/share/licenses/intel-ucode/* boot/licenses/intel-ucode/
2021-09-11 10:26:04 +02:00
# create torrent file
archboot-mktorrent.sh archboot/$1 *.iso
2021-09-18 08:45:47 +02:00
# create Release.txt with included main archlinux packages
2021-09-18 08:55:21 +02:00
echo "Welcome to ARCHBOOT INSTALLATION / RESCUEBOOT SYSTEM" >>Release.txt
echo "Creation Tool: 'archboot' Tobias Powalowski <tpowa@archlinux.org>" >>Release.txt
echo "Homepage: https://wiki.archlinux.org/title/Archboot" >>Release.txt
2021-09-18 09:01:03 +02:00
echo "Architecture: x86_64" >>Release.txt
echo "RAM requirement to boot: 1024 MB or greater" >>Release.txt
2021-09-22 09:02:56 +02:00
echo "Kernel:$(systemd-nspawn -D archboot-release pacman -Qi linux | grep Version | cut -d ":" -f2)" >>Release.txt
echo "Pacman:$(systemd-nspawn -D archboot-release pacman -Qi pacman | grep Version | cut -d ":" -f2)" >>Release.txt
echo "Systemd:$(systemd-nspawn -D archboot-release pacman -Qi systemd | grep Version | cut -d ":" -f2)" >>Release.txt
echo "Have fun" >>Release.txt
echo "Tobias Powalowski" >>Release.txt
echo "tpowa@archlinux.org" >>Release.txt
2021-09-11 10:26:04 +02:00
# create sha256sums
sha256sum boot/* >> boot/sha256sum.txt
sha256sum * >> sha256sum.txt