forked from artix/artools
Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 04d3472173 | |||
| 117e0d2f55 | |||
| 4dc7aa8e65 | |||
| 2fc3044e40 | |||
| 77e6e9dfb4 |
15
Makefile
15
Makefile
@@ -1,4 +1,4 @@
|
|||||||
VERSION=0.13
|
VERSION=0.14
|
||||||
|
|
||||||
CHROOT_VERSION=0.9
|
CHROOT_VERSION=0.9
|
||||||
|
|
||||||
@@ -8,7 +8,6 @@ SYSCONFDIR = /etc
|
|||||||
BINDIR = $(PREFIX)/bin
|
BINDIR = $(PREFIX)/bin
|
||||||
LIBDIR = $(PREFIX)/lib
|
LIBDIR = $(PREFIX)/lib
|
||||||
DATADIR = $(PREFIX)/share
|
DATADIR = $(PREFIX)/share
|
||||||
CPIODIR = $(SYSCONFDIR)/initcpio
|
|
||||||
|
|
||||||
CONF = \
|
CONF = \
|
||||||
data/artools.conf
|
data/artools.conf
|
||||||
@@ -109,8 +108,8 @@ ISO_LIBS = \
|
|||||||
|
|
||||||
ISO_UTIL = lib/util-iso.sh
|
ISO_UTIL = lib/util-iso.sh
|
||||||
|
|
||||||
ISO_DATA = \
|
DRACUT = \
|
||||||
data/iso/mkinitcpio.conf
|
data/dracut.conf
|
||||||
|
|
||||||
DIRMODE = -dm0755
|
DIRMODE = -dm0755
|
||||||
FILEMODE = -m0644
|
FILEMODE = -m0644
|
||||||
@@ -185,10 +184,8 @@ install_pkg:
|
|||||||
|
|
||||||
install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)/pkglists
|
install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)/pkglists
|
||||||
install $(FILEMODE) $(PKG_LISTS) $(DESTDIR)$(DATADIR)/$(TOOLS)/pkglists
|
install $(FILEMODE) $(PKG_LISTS) $(DESTDIR)$(DATADIR)/$(TOOLS)/pkglists
|
||||||
install_cpio:
|
|
||||||
+make CPIODIR=$(CPIODIR) DESTDIR=$(DESTDIR) -C initcpio install
|
|
||||||
|
|
||||||
install_iso: install_cpio
|
install_iso:
|
||||||
install $(DIRMODE) $(DESTDIR)$(BINDIR)
|
install $(DIRMODE) $(DESTDIR)$(BINDIR)
|
||||||
install $(MODE) $(ISO_BIN) $(DESTDIR)$(BINDIR)
|
install $(MODE) $(ISO_BIN) $(DESTDIR)$(BINDIR)
|
||||||
|
|
||||||
@@ -198,8 +195,8 @@ install_iso: install_cpio
|
|||||||
install $(FILEMODE) $(ISO_UTIL) $(DESTDIR)$(LIBDIR)/$(TOOLS)
|
install $(FILEMODE) $(ISO_UTIL) $(DESTDIR)$(LIBDIR)/$(TOOLS)
|
||||||
install $(FILEMODE) $(ISO_LIBS) $(DESTDIR)$(LIBDIR)/$(TOOLS)/iso
|
install $(FILEMODE) $(ISO_LIBS) $(DESTDIR)$(LIBDIR)/$(TOOLS)/iso
|
||||||
|
|
||||||
install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS)
|
install $(DIRMODE) $(DESTDIR)$(SYSCONFDIR)/dracut.cond.d
|
||||||
install $(FILEMODE) $(ISO_DATA) $(DESTDIR)$(DATADIR)/$(TOOLS)
|
install $(FILEMODE) $(DRACUT) $(DESTDIR)$(SYSCONFDIR)/dracut.cond.d/90-artix-live.conf
|
||||||
|
|
||||||
install: install_base install_pkg install_iso
|
install: install_base install_pkg install_iso
|
||||||
|
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ artools
|
|||||||
* dosfstools
|
* dosfstools
|
||||||
* libisoburn
|
* libisoburn
|
||||||
* squashfs-tools
|
* squashfs-tools
|
||||||
* mkinitcpio
|
* dracut
|
||||||
* grub
|
* grub
|
||||||
|
|
||||||
#### Configuration
|
#### Configuration
|
||||||
|
|||||||
@@ -57,9 +57,6 @@
|
|||||||
# possible values: openrc, runit (s6 not yet supported)
|
# possible values: openrc, runit (s6 not yet supported)
|
||||||
# INITSYS="openrc"
|
# INITSYS="openrc"
|
||||||
|
|
||||||
# gpg key; leave empty or commented to skip sfs signing
|
|
||||||
# GPG_KEY=""
|
|
||||||
|
|
||||||
# set upload bandwidth limit in kB/s
|
# set upload bandwidth limit in kB/s
|
||||||
# UPLIMIT=1000
|
# UPLIMIT=1000
|
||||||
|
|
||||||
|
|||||||
@@ -1,5 +0,0 @@
|
|||||||
MODULES=(loop dm-snapshot)
|
|
||||||
|
|
||||||
HOOKS=(base udev artix_shutdown artix artix_loop_mnt artix_pxe_common artix_pxe_http artix_pxe_nbd artix_pxe_nfs artix_kms modconf block filesystems keyboard keymap)
|
|
||||||
|
|
||||||
COMPRESSION="xz"
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
DIRMODE = -dm0755
|
|
||||||
MODE = -m0755
|
|
||||||
|
|
||||||
CPIOHOOKS = \
|
|
||||||
$(wildcard hooks/*)
|
|
||||||
|
|
||||||
CPIOINST = \
|
|
||||||
$(wildcard install/*)
|
|
||||||
|
|
||||||
SCRIPT = \
|
|
||||||
$(wildcard script/*)
|
|
||||||
|
|
||||||
install_initcpio:
|
|
||||||
install $(DIRMODE) $(DESTDIR)$(CPIODIR)/hooks
|
|
||||||
install $(MODE) $(CPIOHOOKS) $(DESTDIR)$(CPIODIR)/hooks
|
|
||||||
|
|
||||||
install $(DIRMODE) $(DESTDIR)$(CPIODIR)/install
|
|
||||||
install $(MODE) $(CPIOINST) $(DESTDIR)$(CPIODIR)/install
|
|
||||||
install $(MODE) $(SCRIPT) $(DESTDIR)$(CPIODIR)
|
|
||||||
|
|
||||||
install: install_initcpio
|
|
||||||
|
|
||||||
.PHONY: install
|
|
||||||
@@ -1,250 +0,0 @@
|
|||||||
# args: source, newroot, mountpoint
|
|
||||||
_mnt_dmsnapshot() {
|
|
||||||
local img="${1}"
|
|
||||||
local mnt="${2}"
|
|
||||||
local img_fullname="${img##*/}";
|
|
||||||
local img_name="${img_fullname%%.*}"
|
|
||||||
local dm_snap_name="${dm_snap_prefix}_${img_name}"
|
|
||||||
local ro_dev ro_dev_size rw_dev
|
|
||||||
|
|
||||||
ro_dev=$(losetup --find --show --read-only "${img}")
|
|
||||||
echo ${ro_dev} >> /run/artix/used_block_devices
|
|
||||||
ro_dev_size=$(blockdev --getsz ${ro_dev})
|
|
||||||
|
|
||||||
if [[ "${cow_persistent}" == "P" ]]; then
|
|
||||||
if [[ -f "/run/artix/cowspace/${cow_directory}/${img_name}.cow" ]]; then
|
|
||||||
msg ":: Found '/run/artix/cowspace/${cow_directory}/${img_name}.cow', using as persistent."
|
|
||||||
else
|
|
||||||
msg ":: Creating '/run/artix/cowspace/${cow_directory}/${img_name}.cow' as persistent."
|
|
||||||
truncate -s "${cow_spacesize}" "/run/artix/cowspace/${cow_directory}/${img_name}.cow"
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
if [[ -f "/run/artix/cowspace/${cow_directory}/${img_name}.cow" ]]; then
|
|
||||||
msg ":: Found '/run/artix/cowspace/${cow_directory}/${img_name}.cow' but non-persistent requested, removing."
|
|
||||||
rm -f "/run/artix/cowspace/${cow_directory}/${img_name}.cow"
|
|
||||||
fi
|
|
||||||
msg ":: Creating '/run/artix/cowspace/${cow_directory}/${img_name}.cow' as non-persistent."
|
|
||||||
truncate -s "${cow_spacesize}" "/run/artix/cowspace/${cow_directory}/${img_name}.cow"
|
|
||||||
fi
|
|
||||||
|
|
||||||
rw_dev=$(losetup --find --show "/run/artix/cowspace/${cow_directory}/${img_name}.cow")
|
|
||||||
echo ${rw_dev} >> /run/artix/used_block_devices
|
|
||||||
|
|
||||||
dmsetup create ${dm_snap_name} --table "0 ${ro_dev_size} snapshot ${ro_dev} ${rw_dev} ${cow_persistent} ${cow_chunksize}"
|
|
||||||
|
|
||||||
if [[ "${cow_persistent}" != "P" ]]; then
|
|
||||||
rm -f "/run/artix/cowspace/${cow_directory}/${img_name}.cow"
|
|
||||||
fi
|
|
||||||
|
|
||||||
_mnt_dev "/dev/mapper/${dm_snap_name}" "${mnt}" "-w" "defaults"
|
|
||||||
echo $(readlink -f /dev/mapper/${dm_snap_name}) >> /run/artix/used_block_devices
|
|
||||||
}
|
|
||||||
|
|
||||||
# args: source, newroot, mountpoint
|
|
||||||
_mnt_overlayfs() {
|
|
||||||
local src="${1}"
|
|
||||||
local newroot="${2}"
|
|
||||||
local mnt="${3}"
|
|
||||||
local work_dir="/run/artix/overlay_root/work"
|
|
||||||
local upper_dir="/run/artix/overlay_root/upper"
|
|
||||||
|
|
||||||
mkdir -p "${upper_dir}" "${work_dir}"
|
|
||||||
|
|
||||||
mount -t overlay overlay -o lowerdir="${src}",upperdir="${upper_dir}",workdir="${work_dir}" "${newroot}${mnt}"
|
|
||||||
}
|
|
||||||
|
|
||||||
# args: /path/to/image_file, mountpoint
|
|
||||||
_mnt_sfs() {
|
|
||||||
local img="${1}"
|
|
||||||
local mnt="${2}"
|
|
||||||
local img_fullname="${img##*/}"
|
|
||||||
local sfs_dev
|
|
||||||
local oper=$( [[ -n "${ip}" && -n "${miso_http_srv}" ]] && echo "mv" || echo "cp" )
|
|
||||||
|
|
||||||
if [[ "${copytoram}" == "y" ]]; then
|
|
||||||
msg -n ":: Copying squashfs image to RAM..."
|
|
||||||
if ! "${oper}" "${img}" "/run/artix/copytoram/${img_fullname}" ; then
|
|
||||||
echo "ERROR: while copy '${img}' to '/run/artix/copytoram/${img_fullname}'"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
img="/run/artix/copytoram/${img_fullname}"
|
|
||||||
msg "done."
|
|
||||||
fi
|
|
||||||
sfs_dev=$(losetup --find --show --read-only "${img}")
|
|
||||||
echo ${sfs_dev} >> /run/artix/used_block_devices
|
|
||||||
_mnt_dev "${sfs_dev}" "${mnt}" "-r" "defaults"
|
|
||||||
}
|
|
||||||
|
|
||||||
# args: device, mountpoint, flags, opts
|
|
||||||
_mnt_dev() {
|
|
||||||
local dev="${1}"
|
|
||||||
local mnt="${2}"
|
|
||||||
local flg="${3}"
|
|
||||||
local opts="${4}"
|
|
||||||
|
|
||||||
mkdir -p "${mnt}"
|
|
||||||
|
|
||||||
msg ":: Mounting '${dev}' to '${mnt}'"
|
|
||||||
|
|
||||||
while ! poll_device "${dev}" 30; do
|
|
||||||
echo "ERROR: '${dev}' device did not show up after 30 seconds..."
|
|
||||||
echo " Falling back to interactive prompt"
|
|
||||||
echo " You can try to fix the problem manually, log out when you are finished"
|
|
||||||
launch_interactive_shell
|
|
||||||
done
|
|
||||||
|
|
||||||
if mount -o "${opts}" "${flg}" "${dev}" "${mnt}"; then
|
|
||||||
msg ":: Device '${dev}' mounted successfully."
|
|
||||||
else
|
|
||||||
echo "ERROR; Failed to mount '${dev}'"
|
|
||||||
echo " Falling back to interactive prompt"
|
|
||||||
echo " You can try to fix the problem manually, log out when you are finished"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
_verify_checksum() {
|
|
||||||
local _status
|
|
||||||
cd "/run/artix/bootmnt/${artixbasedir}/${arch}"
|
|
||||||
sha512sum -c $1.sha512 > /tmp/checksum.log 2>&1
|
|
||||||
_status=$?
|
|
||||||
cd "${OLDPWD}"
|
|
||||||
return ${_status}
|
|
||||||
}
|
|
||||||
|
|
||||||
_verify_signature() {
|
|
||||||
local _status
|
|
||||||
cd "/run/artix/bootmnt/${artixbasedir}/${arch}"
|
|
||||||
gpg --homedir /gpg --status-fd 1 --verify $1.sfs.sig 2>/dev/null | grep -qE '^\[GNUPG:\] GOODSIG'
|
|
||||||
_status=$?
|
|
||||||
cd "${OLDPWD}"
|
|
||||||
return ${_status}
|
|
||||||
}
|
|
||||||
|
|
||||||
run_hook() {
|
|
||||||
[[ -z "${arch}" ]] && arch="$(uname -m)"
|
|
||||||
[[ -z "${copytoram_size}" ]] && copytoram_size="75%"
|
|
||||||
[[ -z "${artixbasedir}" ]] && artixbasedir="artix"
|
|
||||||
|
|
||||||
[[ -z "${dm_snap_prefix}" ]] && dm_snap_prefix="arch"
|
|
||||||
[[ -z "${artixdevice}" ]] && artixdevice="/dev/disk/by-label/${artixlabel}"
|
|
||||||
[[ -z "${cow_spacesize}" ]] && cow_spacesize="256M"
|
|
||||||
[[ -z "${overlay_root_size}" ]] && overlay_root_size="75%"
|
|
||||||
|
|
||||||
if [[ -n "${cow_label}" ]]; then
|
|
||||||
cow_device="/dev/disk/by-label/${cow_label}"
|
|
||||||
[[ -z "${cow_persistent}" ]] && cow_persistent="P"
|
|
||||||
elif [[ -n "${cow_device}" ]]; then
|
|
||||||
[[ -z "${cow_persistent}" ]] && cow_persistent="P"
|
|
||||||
else
|
|
||||||
cow_persistent="N"
|
|
||||||
fi
|
|
||||||
|
|
||||||
[[ -z "${cow_flags}" ]] && cow_flags="defaults"
|
|
||||||
[[ -z "${cow_directory}" ]] && cow_directory="persistent_${artixlabel}/${arch}"
|
|
||||||
[[ -z "${cow_chunksize}" ]] && cow_chunksize="8"
|
|
||||||
|
|
||||||
# set mount handler for artix
|
|
||||||
mount_handler="artix_mount_handler"
|
|
||||||
}
|
|
||||||
|
|
||||||
# This function is called normally from init script, but it can be called
|
|
||||||
# as chain from other mount handlers.
|
|
||||||
# args: /path/to/newroot
|
|
||||||
artix_mount_handler() {
|
|
||||||
local newroot="${1}"
|
|
||||||
|
|
||||||
if ! mountpoint -q "/run/artix/bootmnt"; then
|
|
||||||
_mnt_dev "${artixdevice}" "/run/artix/bootmnt" "-r" "defaults"
|
|
||||||
if [[ "${copytoram}" != "y" ]]; then
|
|
||||||
echo $(readlink -f ${artixdevice}) >> /run/artix/used_block_devices
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${checksum}" == "y" ]]; then
|
|
||||||
for fs in rootfs desktopfs livefs;do
|
|
||||||
if [[ -f "/run/artix/bootmnt/${artixbasedir}/${arch}/${fs}.sfs" ]]; then
|
|
||||||
if [[ -f "/run/artix/bootmnt/${artixbasedir}/${arch}/${fs}.sha512" ]]; then
|
|
||||||
msg -n ":: Self-test requested, please wait..."
|
|
||||||
if _verify_checksum "${fs}"; then
|
|
||||||
msg "done. Checksum is OK, continue booting."
|
|
||||||
else
|
|
||||||
echo "ERROR: one or more files are corrupted"
|
|
||||||
echo "see /tmp/checksum.log for details"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "ERROR: checksum=y option specified but ${artixbasedir}/${arch}/${fs}.sha512 not found"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${verify}" == "y" ]]; then
|
|
||||||
for fs in rootfs desktopfs livefs;do
|
|
||||||
if [[ -f "/run/artix/bootmnt/${artixbasedir}/${arch}/${fs}.sfs" ]]; then
|
|
||||||
if [[ -f "/run/artix/bootmnt/${artixbasedir}/${arch}/${fs}.sfs.sig" ]]; then
|
|
||||||
msg -n ":: Signature verification requested, please wait..."
|
|
||||||
if _verify_signature "${fs}"; then
|
|
||||||
msg "done. Signature is OK, continue booting."
|
|
||||||
else
|
|
||||||
echo "ERROR: one or more files are corrupted"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
echo "ERROR: verify=y option specified but ${artixbasedir}/${arch}/${fs}.sfs.sig not found"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${copytoram}" == "y" ]]; then
|
|
||||||
msg ":: Mounting /run/artix/copytoram (tmpfs) filesystem, size=${copytoram_size}"
|
|
||||||
mkdir -p /run/artix/copytoram
|
|
||||||
mount -t tmpfs -o "size=${copytoram_size}",mode=0755 copytoram /run/artix/copytoram
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -n "${cow_device}" ]]; then
|
|
||||||
_mnt_dev "${cow_device}" "/run/artix/cowspace" "-r" "${cow_flags}"
|
|
||||||
echo $(readlink -f ${cow_device}) >> /run/artix/used_block_devices
|
|
||||||
mount -o remount,rw "/run/artix/cowspace"
|
|
||||||
else
|
|
||||||
msg ":: Mounting /run/artix/cowspace (tmpfs) filesystem, size=${cow_spacesize}..."
|
|
||||||
mkdir -p /run/artix/cowspace
|
|
||||||
mount -t tmpfs -o "size=${cow_spacesize}",mode=0755 cowspace /run/artix/cowspace
|
|
||||||
fi
|
|
||||||
mkdir -p -m 0700 "/run/artix/cowspace/${cow_directory}"
|
|
||||||
|
|
||||||
msg -n ":: Mounting overlay root (tmpfs) filesystem, size=${overlay_root_size}..."
|
|
||||||
mkdir -p /run/artix/overlay_root
|
|
||||||
mount -t tmpfs -o "size=${overlay_root_size}",mode=0755 overlay_root /run/artix/overlay_root
|
|
||||||
|
|
||||||
local src="/run/artix/bootmnt/${artixbasedir}/${arch}"
|
|
||||||
local dest_sfs="/run/artix/sfs" dest_img="/run/artix/img"
|
|
||||||
local lower_dir
|
|
||||||
|
|
||||||
for sfs in livefs desktopfs rootfs;do
|
|
||||||
if [[ -f "${src}/${sfs}.sfs" ]]; then
|
|
||||||
_mnt_sfs "${src}/${sfs}.sfs" "${dest_sfs}/${sfs}"
|
|
||||||
if [[ -f "${dest_sfs}/${sfs}/${sfs}.img" ]]; then
|
|
||||||
mkdir -p ${dest_img}
|
|
||||||
lower_dir=${lower_dir:-}${lower_dir:+:}"${dest_img}/${sfs}"
|
|
||||||
_mnt_dmsnapshot "${dest_sfs}/${sfs}/${sfs}.img" "${dest_img}/${sfs}"
|
|
||||||
else
|
|
||||||
lower_dir=${lower_dir:-}${lower_dir:+:}"${dest_sfs}/${sfs}"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
_mnt_overlayfs "${lower_dir}" "${newroot}" "/"
|
|
||||||
|
|
||||||
if [[ "${copytoram}" == "y" ]]; then
|
|
||||||
umount -d /run/artix/bootmnt
|
|
||||||
mkdir -p /run/artix/bootmnt/${artixbasedir}/${arch}
|
|
||||||
mount -o bind /run/artix/copytoram /run/artix/bootmnt/${artixbasedir}/${arch}
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim:ft=sh:ts=4:sw=4:et:
|
|
||||||
@@ -1,35 +0,0 @@
|
|||||||
# vim: set ft=sh:
|
|
||||||
|
|
||||||
run_hook () {
|
|
||||||
[[ -n "${img_label}" ]] && img_dev="/dev/disk/by-label/${img_label}"
|
|
||||||
[[ -z "${img_flags}" ]] && img_flags="defaults"
|
|
||||||
if [[ -n "${img_dev}" && -n "${img_loop}" ]]; then
|
|
||||||
mount_handler="artix_loop_mount_handler"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
artix_loop_mount_handler () {
|
|
||||||
newroot="${1}"
|
|
||||||
|
|
||||||
local _dev_loop
|
|
||||||
|
|
||||||
msg ":: Setup a loop device from ${img_loop} located at device ${img_dev}"
|
|
||||||
_mnt_dev "${img_dev}" "/run/artix/img_dev" "-r" "${img_flags}"
|
|
||||||
if [[ "${copytoram}" != "y" ]]; then
|
|
||||||
echo $(readlink -f ${img_dev}) >> /run/artix/used_block_devices
|
|
||||||
fi
|
|
||||||
|
|
||||||
if _dev_loop=$(losetup --find --show --read-only "/run/artix/img_dev/${img_loop}"); then
|
|
||||||
artixdevice="${_dev_loop}"
|
|
||||||
else
|
|
||||||
echo "ERROR: Setting loopback device for file '/run/artix/img_dev/${img_loop}'"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
|
|
||||||
artix_mount_handler ${newroot}
|
|
||||||
|
|
||||||
if [[ "${copytoram}" == "y" ]]; then
|
|
||||||
losetup -d ${_dev_loop} 2>/dev/null
|
|
||||||
umount /run/artix/img_dev
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
@@ -1,72 +0,0 @@
|
|||||||
# vim: set ft=sh:
|
|
||||||
|
|
||||||
run_hook () {
|
|
||||||
# Do *not* declare 'bootif_dev' local! We need it in run_latehook().
|
|
||||||
local i net_mac bootif_mac
|
|
||||||
# These variables will be parsed from /tmp/net-*.conf generated by ipconfig
|
|
||||||
local DEVICE
|
|
||||||
local IPV4ADDR IPV4BROADCAST IPV4NETMASK IPV4GATEWAY IPV4DNS0 IPV4DNS1
|
|
||||||
local HOSTNAME DNSDOMAIN NISDOMAIN ROOTSERVER ROOTPATH
|
|
||||||
local filename
|
|
||||||
# /tmp/net-*.conf
|
|
||||||
|
|
||||||
if [[ -n "${ip}" ]]; then
|
|
||||||
if [[ -n "${BOOTIF}" ]]; then
|
|
||||||
bootif_mac=${BOOTIF#01-}
|
|
||||||
bootif_mac=${bootif_mac//-/:}
|
|
||||||
for i in /sys/class/net/*/address; do
|
|
||||||
read net_mac < ${i}
|
|
||||||
if [[ "${bootif_mac}" == "${net_mac}" ]]; then
|
|
||||||
bootif_dev=${i#/sys/class/net/}
|
|
||||||
bootif_dev=${bootif_dev%/address}
|
|
||||||
break
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
if [[ "${ip}" == "dhcp" ]]; then
|
|
||||||
ip=":::::${bootif_dev}:dhcp"
|
|
||||||
else
|
|
||||||
ip="${ip}::${bootif_dev}"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# setup network and save some values
|
|
||||||
if ! ipconfig -t 20 "ip=${ip}"; then
|
|
||||||
echo "ERROR; Failed to configure network"
|
|
||||||
echo " Falling back to interactive prompt"
|
|
||||||
echo " You can try to fix the problem manually, log out when you are finished"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
|
|
||||||
. /tmp/net-*.conf
|
|
||||||
|
|
||||||
pxeserver=${ROOTSERVER}
|
|
||||||
|
|
||||||
# setup DNS resolver
|
|
||||||
if [[ "${IPV4DNS0}" != "0.0.0.0" ]]; then
|
|
||||||
echo "# added by artix_pxe_common hook" > /etc/resolv.conf
|
|
||||||
echo "nameserver ${IPV4DNS0}" >> /etc/resolv.conf
|
|
||||||
fi
|
|
||||||
if [[ "${IPV4DNS1}" != "0.0.0.0" ]]; then
|
|
||||||
echo "nameserver ${IPV4DNS1}" >> /etc/resolv.conf
|
|
||||||
fi
|
|
||||||
if [[ -n "${DNSDOMAIN}" ]]; then
|
|
||||||
echo "search ${DNSDOMAIN}" >> /etc/resolv.conf
|
|
||||||
echo "domain ${DNSDOMAIN}" >> /etc/resolv.conf
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
run_latehook () {
|
|
||||||
if [[ -n "${ip}" ]]; then
|
|
||||||
[[ -z "${copy_resolvconf}" ]] && copy_resolvconf="y"
|
|
||||||
|
|
||||||
if [[ "${copytoram}" == "y" ]]; then
|
|
||||||
if [[ -n "${bootif_dev}" ]]; then
|
|
||||||
ip addr flush dev "${bootif_dev}"
|
|
||||||
ip link set "${bootif_dev}" down
|
|
||||||
fi
|
|
||||||
elif [[ "${copy_resolvconf}" != "n" && -f /etc/resolv.conf ]]; then
|
|
||||||
cp /etc/resolv.conf /new_root/etc/resolv.conf
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
@@ -1,59 +0,0 @@
|
|||||||
# vim: set ft=sh:
|
|
||||||
|
|
||||||
run_hook() {
|
|
||||||
if [[ -n "${ip}" && -n "${artix_http_srv}" ]]; then
|
|
||||||
|
|
||||||
# booting with http is always copy-to-ram, so set here to make sure
|
|
||||||
# addresses are flushed and interface is set down
|
|
||||||
copytoram="y"
|
|
||||||
|
|
||||||
artix_http_srv=$(eval echo ${artix_http_srv})
|
|
||||||
[[ -z "${artix_http_spc}" ]] && artix_http_spc="75%"
|
|
||||||
|
|
||||||
mount_handler="artix_pxe_http_mount_handler"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Fetch a file with CURL
|
|
||||||
#
|
|
||||||
# $1 URL
|
|
||||||
# $2 Destination directory inside httpspace/${artixbasedir}
|
|
||||||
_curl_get() {
|
|
||||||
local _url="${1}"
|
|
||||||
local _dst="${2}"
|
|
||||||
|
|
||||||
msg ":: Downloading '${_url}'"
|
|
||||||
if ! curl -L -f -o "/run/artix/httpspace/${artixbasedir}${_dst}/${_url##*/}" --create-dirs "${_url}"; then
|
|
||||||
echo "ERROR: Downloading '${_url}'"
|
|
||||||
echo " Falling back to interactive prompt"
|
|
||||||
echo " You can try to fix the problem manually, log out when you are finished"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
artix_pxe_http_mount_handler () {
|
|
||||||
newroot="${1}"
|
|
||||||
|
|
||||||
msg ":: Mounting /run/artix/httpspace (tmpfs) filesystem, size='${artix_http_spc}'"
|
|
||||||
mkdir -p "/run/artix/httpspace"
|
|
||||||
mount -t tmpfs -o size="${artix_http_spc}",mode=0755 httpspace "/run/artix/httpspace"
|
|
||||||
|
|
||||||
local _src=${artix_http_srv}${artixbasedir}/${arch}
|
|
||||||
|
|
||||||
for sfs in livefs desktopfs rootfs;do
|
|
||||||
if [[ ! -z "$( curl -s --head "${_src}/${sfs}.sfs" | grep "OK" )" ]]; then
|
|
||||||
_curl_get "${_src}/${sfs}.sfs" "/${arch}"
|
|
||||||
|
|
||||||
if [[ "${checksum}" == "y" ]]; then
|
|
||||||
_curl_get "${_src}/${sfs}.md5" "/${arch}"
|
|
||||||
fi
|
|
||||||
if [[ "${verify}" == "y" ]]; then
|
|
||||||
_curl_get "${_src}/${sfs}.sfs.sig" "/${arch}"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
mkdir -p "/run/artix/bootmnt"
|
|
||||||
mount -o bind /run/artix/httpspace /run/artix/bootmnt
|
|
||||||
|
|
||||||
artix_mount_handler ${newroot}
|
|
||||||
}
|
|
||||||
@@ -1,47 +0,0 @@
|
|||||||
# vim: set ft=sh:
|
|
||||||
|
|
||||||
run_earlyhook() {
|
|
||||||
if [[ -n "${ip}" && -n "${artix_nbd_srv}" ]]; then
|
|
||||||
# Module autoloading like with loop devices does not work, doing manually...
|
|
||||||
modprobe nbd 2> /dev/null
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
run_hook() {
|
|
||||||
if [[ -n "${ip}" && -n "${artix_nbd_srv}" ]]; then
|
|
||||||
|
|
||||||
artix_nbd_srv=$(eval echo ${artix_nbd_srv})
|
|
||||||
[[ -z "${artix_nbd_name}" ]] && artix_nbd_name="artix"
|
|
||||||
|
|
||||||
mount_handler="artix_pxe_nbd_mount_handler"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
artix_pxe_nbd_mount_handler () {
|
|
||||||
newroot="${1}"
|
|
||||||
|
|
||||||
msg ":: Waiting for boot device..."
|
|
||||||
while ! poll_device /dev/nbd0 30; do
|
|
||||||
echo "ERROR: boot device didn't show up after 30 seconds..."
|
|
||||||
echo " Falling back to interactive prompt"
|
|
||||||
echo " You can try to fix the problem manually, log out when you are finished"
|
|
||||||
launch_interactive_shell
|
|
||||||
done
|
|
||||||
|
|
||||||
msg ":: Setup NBD from ${artix_nbd_srv} at /dev/nbd0"
|
|
||||||
if [[ "${copytoram}" != "n" ]]; then
|
|
||||||
nbd-client ${artix_nbd_srv} -N ${artix_nbd_name} /dev/nbd0
|
|
||||||
copytoram="y"
|
|
||||||
else
|
|
||||||
nbd-client ${artix_nbd_srv} -N ${artix_nbd_name} -persist /dev/nbd0
|
|
||||||
fi
|
|
||||||
|
|
||||||
artixdevice=/dev/nbd0
|
|
||||||
|
|
||||||
artix_mount_handler ${newroot}
|
|
||||||
|
|
||||||
if [[ "${copytoram}" == "y" ]]; then
|
|
||||||
msg ":: Disconnect NBD from ${artix_nbd_srv} at /dev/nbd0"
|
|
||||||
nbd-client -d /dev/nbd0
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
# vim: set ft=sh:
|
|
||||||
|
|
||||||
run_hook() {
|
|
||||||
if [[ -n "${ip}" && -n "${artix_nfs_srv}" ]]; then
|
|
||||||
|
|
||||||
artix_nfs_srv=$(eval echo ${artix_nfs_srv})
|
|
||||||
[[ -n "${artix_nfs_opt}" ]] && artix_nfs_opt="-o ${artix_nfs_opt}"
|
|
||||||
|
|
||||||
mount_handler="artix_nfs_mount_handler"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
artix_nfs_mount_handler() {
|
|
||||||
newroot="${1}"
|
|
||||||
mkdir -p "/run/artix/bootmnt"
|
|
||||||
msg ":: Mounting '${artix_nfs_srv}'"
|
|
||||||
# Do not put "${artix_nfs_opt}" nfsmount fails!
|
|
||||||
if ! nfsmount ${artix_nfs_opt} "${artix_nfs_srv}" "/run/artix/bootmnt"; then
|
|
||||||
echo "ERROR: Mounting '${artix_nfs_srv}'"
|
|
||||||
echo " Falling back to interactive prompt"
|
|
||||||
echo " You can try to fix the problem manually, log out when you are finished"
|
|
||||||
launch_interactive_shell
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${copytoram}" != "n" ]]; then
|
|
||||||
copytoram="y"
|
|
||||||
fi
|
|
||||||
|
|
||||||
artix_mount_handler ${newroot}
|
|
||||||
}
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
run_cleanuphook() {
|
|
||||||
rm -rf /usr/lib/modules
|
|
||||||
cp -ax / /run/initramfs
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ft=sh ts=4 sw=4 et:
|
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
build() {
|
|
||||||
add_module "cdrom"
|
|
||||||
add_module "loop"
|
|
||||||
add_module "dm-snapshot"
|
|
||||||
add_module "overlay"
|
|
||||||
|
|
||||||
add_runscript
|
|
||||||
|
|
||||||
add_binary /usr/lib/udev/cdrom_id
|
|
||||||
add_binary blockdev
|
|
||||||
add_binary dmsetup
|
|
||||||
add_binary losetup
|
|
||||||
add_binary mountpoint
|
|
||||||
add_binary truncate
|
|
||||||
add_binary gpg
|
|
||||||
add_binary grep
|
|
||||||
|
|
||||||
add_file /usr/lib/udev/rules.d/60-cdrom_id.rules
|
|
||||||
add_file /usr/lib/udev/rules.d/10-dm.rules
|
|
||||||
add_file /usr/lib/udev/rules.d/95-dm-notify.rules
|
|
||||||
add_file /usr/lib/initcpio/udev/11-dm-initramfs.rules /usr/lib/udev/rules.d/11-dm-initramfs.rules
|
|
||||||
if [[ $ARTIX_GNUPG_FD ]]; then
|
|
||||||
mkdir -p "$BUILDROOT$dest"/gpg
|
|
||||||
gpg --homedir "$BUILDROOT$dest"/gpg --import <&$ARTIX_GNUPG_FD
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ft=sh ts=4 sw=4 et:
|
|
||||||
@@ -1,16 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
build() {
|
|
||||||
add_module "radeon"
|
|
||||||
add_module "nouveau"
|
|
||||||
add_module "i915"
|
|
||||||
add_module "via-agp"
|
|
||||||
add_module "sis-agp"
|
|
||||||
add_module "intel-agp"
|
|
||||||
}
|
|
||||||
|
|
||||||
help() {
|
|
||||||
cat << HELPEOF
|
|
||||||
Adds all common KMS drivers to the initramfs image.
|
|
||||||
HELPEOF
|
|
||||||
}
|
|
||||||
@@ -1,13 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
build() {
|
|
||||||
add_runscript
|
|
||||||
}
|
|
||||||
|
|
||||||
help() {
|
|
||||||
cat<<HELPEOF
|
|
||||||
This hook loads the necessary modules for boot via loop device.
|
|
||||||
HELPEOF
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ft=sh ts=4 sw=4 et:
|
|
||||||
@@ -1,26 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
build() {
|
|
||||||
add_checked_modules -f "(irda|phy|wimax|wireless|ppp_|plip|pppoe)" "/drivers/net/"
|
|
||||||
|
|
||||||
add_runscript
|
|
||||||
|
|
||||||
add_binary /usr/lib/initcpio/ipconfig /bin/ipconfig
|
|
||||||
|
|
||||||
# Add hosts support files+dns
|
|
||||||
add_symlink /usr/lib/libnss_files.so.2 $(readlink /usr/lib/libnss_files.so.2)
|
|
||||||
add_binary $(readlink -f /usr/lib/libnss_files.so.2)
|
|
||||||
add_symlink /usr/lib/libnss_dns.so.2 $(readlink /usr/lib/libnss_dns.so.2)
|
|
||||||
add_binary $(readlink -f /usr/lib/libnss_dns.so.2)
|
|
||||||
|
|
||||||
add_dir /etc
|
|
||||||
echo "hosts: files dns" > $BUILDROOT/etc/nsswitch.conf
|
|
||||||
}
|
|
||||||
|
|
||||||
help() {
|
|
||||||
cat<<HELPEOF
|
|
||||||
This hook loads the necessary modules for boot via PXE.
|
|
||||||
HELPEOF
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ft=sh ts=4 sw=4 et:
|
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
build() {
|
|
||||||
add_runscript
|
|
||||||
|
|
||||||
add_binary curl
|
|
||||||
|
|
||||||
add_file $(readlink -f /etc/ssl/certs/ca-certificates.crt) /etc/ssl/certs/ca-certificates.crt
|
|
||||||
}
|
|
||||||
|
|
||||||
help() {
|
|
||||||
cat<<HELPEOF
|
|
||||||
This hook loads the necessary modules for boot via PXE and HTTP.
|
|
||||||
HELPEOF
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ft=sh ts=4 sw=4 et:
|
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
build() {
|
|
||||||
add_module "nbd"
|
|
||||||
|
|
||||||
add_runscript
|
|
||||||
|
|
||||||
add_binary nbd-client
|
|
||||||
}
|
|
||||||
|
|
||||||
help() {
|
|
||||||
cat<<HELPEOF
|
|
||||||
This hook loads the necessary modules for boot via PXE and NBD.
|
|
||||||
HELPEOF
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ft=sh ts=4 sw=4 et:
|
|
||||||
@@ -1,17 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
build() {
|
|
||||||
add_module "nfs"
|
|
||||||
|
|
||||||
add_runscript
|
|
||||||
|
|
||||||
add_binary /usr/lib/initcpio/nfsmount /bin/nfsmount
|
|
||||||
}
|
|
||||||
|
|
||||||
help() {
|
|
||||||
cat <<HELPEOF
|
|
||||||
This hook loads the necessary modules for boot via PXE and NFS.
|
|
||||||
HELPEOF
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ft=sh ts=4 sw=4 et:
|
|
||||||
@@ -1,20 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
build() {
|
|
||||||
add_binary cp
|
|
||||||
|
|
||||||
add_runscript
|
|
||||||
|
|
||||||
add_file /etc/initcpio/artix_shutdown /shutdown
|
|
||||||
}
|
|
||||||
|
|
||||||
help() {
|
|
||||||
cat <<HELPEOF
|
|
||||||
This hook will create a shutdown initramfs in /run/initramfs
|
|
||||||
that we can pivot to on shutdown in order to unmount / and
|
|
||||||
and others mount points, dm-snapshot devices and loopback devices.
|
|
||||||
Mostly usefull for dm-snapshot persistent.
|
|
||||||
HELPEOF
|
|
||||||
}
|
|
||||||
|
|
||||||
# vim: set ft=sh ts=4 sw=4 et:
|
|
||||||
@@ -1,38 +0,0 @@
|
|||||||
#!/bin/ash
|
|
||||||
|
|
||||||
# /oldroot depends on things inside /oldroot/run/artix...
|
|
||||||
mkdir /oldrun
|
|
||||||
mount -n --move /oldroot/run /oldrun
|
|
||||||
|
|
||||||
# Unmount all mounts now.
|
|
||||||
#umount $(mount | awk '$3 ~/^\/oldroot/ {print $3}' | sort -r)
|
|
||||||
umount $(mount | awk '$3 ~/^\/oldroot/ {if($3 != "/run/artix/bootmnt") print $3}' | sort -r)
|
|
||||||
|
|
||||||
# Remove all dm-snapshot devices.
|
|
||||||
dmsetup remove_all
|
|
||||||
|
|
||||||
# Remove all loopback devices.
|
|
||||||
for _lup in $(grep ^/dev/loop /oldrun/artix/used_block_devices | tac); do
|
|
||||||
if ! losetup -d ${_lup} 2> /dev/null; then
|
|
||||||
umount -d ${_lup}
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Unmount the space used to store *.cow.
|
|
||||||
umount /oldrun/artix/cowspace
|
|
||||||
|
|
||||||
# Unmount boot device if needed (no copytoram=y used)
|
|
||||||
if [[ ! -d /oldrun/artix/copytoram ]]; then
|
|
||||||
if [[ -d /oldrun/artix/img_dev ]]; then
|
|
||||||
umount /oldrun/artix/img_dev
|
|
||||||
else
|
|
||||||
umount /oldrun/artix/bootmnt
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# reboot / poweroff / halt, depending on the argument passed by init
|
|
||||||
# if something invalid is passed, we halt
|
|
||||||
case "$1" in
|
|
||||||
reboot|poweroff|halt) "$1" -f ;;
|
|
||||||
*) halt -f;;
|
|
||||||
esac
|
|
||||||
@@ -125,8 +125,6 @@ init_artools_iso(){
|
|||||||
|
|
||||||
INITSYS=${INITSYS:-'openrc'}
|
INITSYS=${INITSYS:-'openrc'}
|
||||||
|
|
||||||
GPG_KEY=${GPG_KEY:-''}
|
|
||||||
|
|
||||||
UPLIMIT=${UPLIMIT:-1000}
|
UPLIMIT=${UPLIMIT:-1000}
|
||||||
|
|
||||||
FILE_HOST="download.${DOMAIN}"
|
FILE_HOST="download.${DOMAIN}"
|
||||||
|
|||||||
@@ -153,7 +153,7 @@ configure_calamares(){
|
|||||||
msg2 "Configuring Calamares"
|
msg2 "Configuring Calamares"
|
||||||
write_users_conf > "$mods"/users.conf
|
write_users_conf > "$mods"/users.conf
|
||||||
write_servicescfg_conf > "$mods"/services-"${INITSYS}".conf
|
write_servicescfg_conf > "$mods"/services-"${INITSYS}".conf
|
||||||
[[ -z ${DESKTOP_LIST} ]] && write_unpackfs_conf > "$mods"/unpackfs.conf
|
write_unpackfs_conf > "$mods"/unpackfs.conf
|
||||||
sed -e "s|openrc|${INITSYS}|" -i "$mods"/postcfg.conf
|
sed -e "s|openrc|${INITSYS}|" -i "$mods"/postcfg.conf
|
||||||
sed -e "s|services-openrc|services-${INITSYS}|" -i "$1"/etc/calamares/settings.conf
|
sed -e "s|services-openrc|services-${INITSYS}|" -i "$1"/etc/calamares/settings.conf
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -12,38 +12,11 @@
|
|||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
# GNU General Public License for more details.
|
# GNU General Public License for more details.
|
||||||
|
|
||||||
prepare_initcpio(){
|
|
||||||
msg2 "Copying initcpio ..."
|
|
||||||
local dest="$1"
|
|
||||||
cp /etc/initcpio/hooks/artix* $dest/etc/initcpio/hooks
|
|
||||||
cp /etc/initcpio/install/artix* $dest/etc/initcpio/install
|
|
||||||
cp /etc/initcpio/artix_shutdown $dest/etc/initcpio
|
|
||||||
}
|
|
||||||
|
|
||||||
prepare_initramfs(){
|
prepare_initramfs(){
|
||||||
local mnt="$1"
|
local src="$1" dest="$2"
|
||||||
cp ${DATADIR}/mkinitcpio.conf $mnt/etc/mkinitcpio-artix.conf
|
local kver=$(cat $src/usr/lib/modules/extramodules-ARTIX/version)
|
||||||
|
|
||||||
if [[ "${PROFILE}" != 'base' ]];then
|
dracut -fqM $dest/initramfs-${ARCH}.img $kver
|
||||||
sed -e 's/artix_pxe_common artix_pxe_http artix_pxe_nbd artix_pxe_nfs //' -i $mnt/etc/mkinitcpio-artix.conf
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -n ${GPG_KEY} ]]; then
|
|
||||||
user_run "gpg --export ${GPG_KEY} >${USERCONFDIR}/artools/gpgkey"
|
|
||||||
exec 17<>${USERCONFDIR}/artools/GPG_KEY
|
|
||||||
fi
|
|
||||||
local _kernel=$(cat $mnt/usr/lib/modules/*/version)
|
|
||||||
ARTIX_GNUPG_FD=${GPG_KEY:+17} chroot-run $mnt \
|
|
||||||
/usr/bin/mkinitcpio -k ${_kernel} \
|
|
||||||
-c /etc/mkinitcpio-artix.conf \
|
|
||||||
-g /boot/initramfs.img
|
|
||||||
|
|
||||||
if [[ -n ${GPG_KEY} ]]; then
|
|
||||||
exec 17<&-
|
|
||||||
fi
|
|
||||||
if [[ -f ${USERCONFDIR}/artools/GPG_KEY ]]; then
|
|
||||||
rm ${USERCONFDIR}/artools/GPG_KEY
|
|
||||||
fi
|
|
||||||
}
|
}
|
||||||
|
|
||||||
prepare_boot_extras(){
|
prepare_boot_extras(){
|
||||||
@@ -61,6 +34,17 @@ prepare_boot_extras(){
|
|||||||
configure_grub(){
|
configure_grub(){
|
||||||
local conf="$1/boot/grub/kernels.cfg"
|
local conf="$1/boot/grub/kernels.cfg"
|
||||||
sed -e "s|@iso_label@|${iso_label}|" -i $conf
|
sed -e "s|@iso_label@|${iso_label}|" -i $conf
|
||||||
|
|
||||||
|
# rd.vconsole.keymap=
|
||||||
|
# rd.live.overlay.size=
|
||||||
|
# root=live:<URL>
|
||||||
|
# rd.live.ram=1
|
||||||
|
# rd.live.overlay.readonly
|
||||||
|
# rd.live.overlay=none
|
||||||
|
# rd.writable.fsimg=1
|
||||||
|
# rd.live.dir=<path>
|
||||||
|
# rd.live.squashimg=<filename of SquashFS image>
|
||||||
|
# rd.live.overlay.overlayfs=1
|
||||||
}
|
}
|
||||||
|
|
||||||
prepare_grub(){
|
prepare_grub(){
|
||||||
|
|||||||
@@ -33,24 +33,6 @@ clean_iso_root(){
|
|||||||
rm -rf --one-file-system "$dest"
|
rm -rf --one-file-system "$dest"
|
||||||
}
|
}
|
||||||
|
|
||||||
make_sig () {
|
|
||||||
local idir="$1" file="$2"
|
|
||||||
msg2 "Creating signature file..."
|
|
||||||
cd "$idir"
|
|
||||||
user_own "$idir"
|
|
||||||
user_run "gpg --detach-sign --default-key ${GPG_KEY} $file.sfs"
|
|
||||||
chown -R root "$idir"
|
|
||||||
cd ${OLDPWD}
|
|
||||||
}
|
|
||||||
|
|
||||||
make_checksum(){
|
|
||||||
local idir="$1" file="$2"
|
|
||||||
msg2 "Creating sha512sum ..."
|
|
||||||
cd $idir
|
|
||||||
sha512sum $file.sfs > $file.sha512
|
|
||||||
cd ${OLDPWD}
|
|
||||||
}
|
|
||||||
|
|
||||||
# $1: image path
|
# $1: image path
|
||||||
make_sfs() {
|
make_sfs() {
|
||||||
local src="$1"
|
local src="$1"
|
||||||
@@ -108,13 +90,8 @@ make_sfs() {
|
|||||||
|
|
||||||
mksquashfs "${mksfs_args[@]}"
|
mksquashfs "${mksfs_args[@]}"
|
||||||
|
|
||||||
make_checksum "${dest}" "${name}"
|
|
||||||
${persist} && rm "${src}.img"
|
${persist} && rm "${src}.img"
|
||||||
|
|
||||||
if [[ -n ${GPG_KEY} ]];then
|
|
||||||
make_sig "${dest}" "${name}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
show_elapsed_time "${FUNCNAME}" "${timer_start}"
|
show_elapsed_time "${FUNCNAME}" "${timer_start}"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -39,21 +39,14 @@ track_fs() {
|
|||||||
|
|
||||||
mount_overlay(){
|
mount_overlay(){
|
||||||
FS_ACTIVE_MOUNTS=()
|
FS_ACTIVE_MOUNTS=()
|
||||||
local lower= upper="$1" work="$2" pkglist="$3"
|
local lower= upper="$1" work="$2"
|
||||||
local fs=${upper##*/}
|
local fs=${upper##*/}
|
||||||
local rootfs="$work/rootfs" desktopfs="$work/desktopfs" livefs="$work/livefs"
|
local rootfs="$work/rootfs" livefs="$work/livefs"
|
||||||
mkdir -p "${mnt_dir}/work"
|
mkdir -p "${mnt_dir}/work"
|
||||||
mkdir -p "$upper"
|
mkdir -p "$upper"
|
||||||
case $fs in
|
case $fs in
|
||||||
desktopfs) lower="$rootfs" ;;
|
livefs) lower="$rootfs" ;;
|
||||||
livefs)
|
bootfs) lower="$livefs":"$rootfs" ;;
|
||||||
lower="$rootfs"
|
|
||||||
[[ -f $pkglist ]] && lower="$desktopfs":"$rootfs"
|
|
||||||
;;
|
|
||||||
bootfs)
|
|
||||||
lower="$livefs":"$rootfs"
|
|
||||||
[[ -f $pkglist ]] && lower="$livefs":"$desktopfs":"$rootfs"
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
track_fs -t overlay overlay -olowerdir="$lower",upperdir="$upper",workdir="${mnt_dir}/work" "$upper"
|
track_fs -t overlay overlay -olowerdir="$lower",upperdir="$upper",workdir="${mnt_dir}/work" "$upper"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -23,9 +23,6 @@ init_profile(){
|
|||||||
[[ -f "$profdir/$prof/Packages-Root" ]] && ROOT_LIST="$profdir/$prof/Packages-Root"
|
[[ -f "$profdir/$prof/Packages-Root" ]] && ROOT_LIST="$profdir/$prof/Packages-Root"
|
||||||
[[ -d "$profdir/$prof/root-overlay" ]] && ROOT_OVERLAY="$profdir/$prof/root-overlay"
|
[[ -d "$profdir/$prof/root-overlay" ]] && ROOT_OVERLAY="$profdir/$prof/root-overlay"
|
||||||
|
|
||||||
[[ -f "$profdir/$prof/Packages-Desktop" ]] && DESKTOP_LIST="$profdir/$prof/Packages-Desktop"
|
|
||||||
[[ -d "$profdir/$prof/desktop-overlay" ]] && DESKTOP_OVERLAY="$profdir/$prof/desktop-overlay"
|
|
||||||
|
|
||||||
[[ -f "$profdir/$prof/Packages-Live" ]] && LIVE_LIST="$profdir/$prof/Packages-Live"
|
[[ -f "$profdir/$prof/Packages-Live" ]] && LIVE_LIST="$profdir/$prof/Packages-Live"
|
||||||
[[ -d "$profdir/$prof/live-overlay" ]] && LIVE_OVERLAY="$profdir/$prof/live-overlay"
|
[[ -d "$profdir/$prof/live-overlay" ]] && LIVE_OVERLAY="$profdir/$prof/live-overlay"
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -173,26 +173,6 @@ make_rootfs() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
make_desktopfs() {
|
|
||||||
if [[ ! -e ${work_dir}/desktopfs.lock ]]; then
|
|
||||||
msg "Prepare [Desktop installation] (desktopfs)"
|
|
||||||
local desktopfs="${work_dir}/desktopfs"
|
|
||||||
|
|
||||||
prepare_dir "${desktopfs}"
|
|
||||||
|
|
||||||
mount_overlay "${desktopfs}" "${work_dir}"
|
|
||||||
|
|
||||||
install_packages "${desktopfs}"
|
|
||||||
|
|
||||||
copy_overlay "${DESKTOP_OVERLAY}" "${desktopfs}"
|
|
||||||
|
|
||||||
umount_overlay
|
|
||||||
clean_up_image "${desktopfs}"
|
|
||||||
|
|
||||||
msg "Done [Desktop installation] (desktopfs)"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
make_livefs() {
|
make_livefs() {
|
||||||
if [[ ! -e ${work_dir}/livefs.lock ]]; then
|
if [[ ! -e ${work_dir}/livefs.lock ]]; then
|
||||||
msg "Prepare [Live installation] (livefs)"
|
msg "Prepare [Live installation] (livefs)"
|
||||||
@@ -200,7 +180,7 @@ make_livefs() {
|
|||||||
|
|
||||||
prepare_dir "${livefs}"
|
prepare_dir "${livefs}"
|
||||||
|
|
||||||
mount_overlay "${livefs}" "${work_dir}" "${DESKTOP_LIST}"
|
mount_overlay "${livefs}" "${work_dir}"
|
||||||
|
|
||||||
install_packages "${livefs}"
|
install_packages "${livefs}"
|
||||||
|
|
||||||
@@ -227,12 +207,11 @@ make_bootfs() {
|
|||||||
|
|
||||||
local bootfs="${work_dir}/bootfs"
|
local bootfs="${work_dir}/bootfs"
|
||||||
|
|
||||||
mount_overlay "${bootfs}" "${work_dir}" "${DESKTOP_LIST}"
|
mount_overlay "${bootfs}" "${work_dir}"
|
||||||
|
|
||||||
prepare_initcpio "${bootfs}"
|
prepare_initramfs "${bootfs}" "${boot}"
|
||||||
prepare_initramfs "${bootfs}"
|
|
||||||
|
|
||||||
cp ${bootfs}/boot/initramfs.img ${boot}/initramfs-${ARCH}.img
|
# cp ${bootfs}/boot/initramfs.img ${boot}/initramfs-${ARCH}.img
|
||||||
prepare_boot_extras "${bootfs}" "${boot}"
|
prepare_boot_extras "${bootfs}" "${boot}"
|
||||||
|
|
||||||
umount_overlay
|
umount_overlay
|
||||||
@@ -267,10 +246,6 @@ prepare_images(){
|
|||||||
local timer=$(get_timer)
|
local timer=$(get_timer)
|
||||||
load_pkgs "${ROOT_LIST}" "${INITSYS}"
|
load_pkgs "${ROOT_LIST}" "${INITSYS}"
|
||||||
run_safe "make_rootfs"
|
run_safe "make_rootfs"
|
||||||
if [[ -f "${DESKTOP_LIST}" ]] ; then
|
|
||||||
load_pkgs "${DESKTOP_LIST}" "${INITSYS}"
|
|
||||||
run_safe "make_desktopfs"
|
|
||||||
fi
|
|
||||||
if [[ -f ${LIVE_LIST} ]]; then
|
if [[ -f ${LIVE_LIST} ]]; then
|
||||||
load_pkgs "${LIVE_LIST}" "${INITSYS}"
|
load_pkgs "${LIVE_LIST}" "${INITSYS}"
|
||||||
run_safe "make_livefs"
|
run_safe "make_livefs"
|
||||||
|
|||||||
Reference in New Issue
Block a user