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 | ||||
|  | ||||
| @@ -8,7 +8,6 @@ SYSCONFDIR = /etc | ||||
| BINDIR = $(PREFIX)/bin | ||||
| LIBDIR = $(PREFIX)/lib | ||||
| DATADIR = $(PREFIX)/share | ||||
| CPIODIR = $(SYSCONFDIR)/initcpio | ||||
|  | ||||
| CONF = \ | ||||
| 	data/artools.conf | ||||
| @@ -109,8 +108,8 @@ ISO_LIBS = \ | ||||
|  | ||||
| ISO_UTIL = lib/util-iso.sh | ||||
|  | ||||
| ISO_DATA = \ | ||||
| 	data/iso/mkinitcpio.conf | ||||
| DRACUT = \ | ||||
| 	data/dracut.conf | ||||
|  | ||||
| DIRMODE = -dm0755 | ||||
| FILEMODE = -m0644 | ||||
| @@ -185,10 +184,8 @@ install_pkg: | ||||
|  | ||||
| 	install $(DIRMODE) $(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 $(MODE) $(ISO_BIN) $(DESTDIR)$(BINDIR) | ||||
|  | ||||
| @@ -198,8 +195,8 @@ install_iso: install_cpio | ||||
| 	install $(FILEMODE) $(ISO_UTIL) $(DESTDIR)$(LIBDIR)/$(TOOLS) | ||||
| 	install $(FILEMODE) $(ISO_LIBS) $(DESTDIR)$(LIBDIR)/$(TOOLS)/iso | ||||
|  | ||||
| 	install $(DIRMODE) $(DESTDIR)$(DATADIR)/$(TOOLS) | ||||
| 	install $(FILEMODE) $(ISO_DATA) $(DESTDIR)$(DATADIR)/$(TOOLS) | ||||
| 	install $(DIRMODE) $(DESTDIR)$(SYSCONFDIR)/dracut.cond.d | ||||
| 	install $(FILEMODE) $(DRACUT) $(DESTDIR)$(SYSCONFDIR)/dracut.cond.d/90-artix-live.conf | ||||
|  | ||||
| install: install_base install_pkg install_iso | ||||
|  | ||||
|   | ||||
| @@ -34,7 +34,7 @@ artools | ||||
|   * dosfstools | ||||
|   * libisoburn | ||||
|   * squashfs-tools | ||||
|   * mkinitcpio | ||||
|   * dracut | ||||
|   * grub | ||||
|  | ||||
| #### Configuration | ||||
|   | ||||
| @@ -78,7 +78,7 @@ from_arch(){ | ||||
|     [[ -z $git_tree_arch ]] && die "Package '%s' does not exist!" "$pkg" | ||||
|  | ||||
|     local package=${TREE_DIR_ARCH}/$git_tree_arch/$pkg | ||||
|     local repo=$(find_repo "$package" "${staging}" "${unstable}") | ||||
|     local repo=$(find_repo "$package") | ||||
|  | ||||
|     src=$package/repos/$repo | ||||
|  | ||||
| @@ -114,7 +114,7 @@ view_build(){ | ||||
|     [[ -z $git_tree_arch ]] && die "Package '%s' does not exist!" "$pkg" | ||||
|  | ||||
|     local pkg_path=${TREE_DIR_ARCH}/$git_tree_arch/$pkg | ||||
|     local repo=$(find_repo "$pkg_path" "${staging}" "${unstable}") | ||||
|     local repo=$(find_repo "$pkg_path") | ||||
|  | ||||
|     src=$pkg_path/repos/$repo | ||||
|  | ||||
| @@ -139,8 +139,6 @@ import=false | ||||
| view=false | ||||
| createnew=false | ||||
| conf=false | ||||
| unstable=false | ||||
| staging=true | ||||
|  | ||||
| PACKAGE='' | ||||
|  | ||||
| @@ -159,8 +157,6 @@ usage() { | ||||
|     echo "    -y            Don't clone or pull artix repos" | ||||
|     echo '    -i            Import a package from arch repos' | ||||
|     echo '    -n            Make new remote subrepo and clone it' | ||||
|     echo '    -u            Include kde & gnome unstable (only with -i)' | ||||
|     echo '    -w            Exclude staging (only with -i)' | ||||
|     echo '    -v            View package depends' | ||||
|     echo '    -h            This help' | ||||
|     echo '' | ||||
| @@ -170,7 +166,7 @@ usage() { | ||||
|  | ||||
| orig_argv=("$0" "$@") | ||||
|  | ||||
| opts='p:t:g:uwsinzyvh' | ||||
| opts='p:t:g:sinzyvh' | ||||
|  | ||||
| while getopts "${opts}" arg; do | ||||
|     case "${arg}" in | ||||
| @@ -182,8 +178,6 @@ while getopts "${opts}" arg; do | ||||
|         y) sync_artix=false ;; | ||||
|         i) import=true ;; | ||||
|         n) createnew=true ;; | ||||
|         w) staging=false ;; | ||||
|         u) unstable=true ;; | ||||
|         v) view=true ;; | ||||
|         h|?) usage 0 ;; | ||||
|         *) echo "invalid argument '${arg}'"; usage 1 ;; | ||||
|   | ||||
| @@ -15,22 +15,6 @@ | ||||
| . @libdir@/artools/util-base.sh | ||||
| . @libdir@/artools/util-pkg.sh | ||||
|  | ||||
| get_path(){ | ||||
|     local repo="$1" pkg=trunk/PKGBUILD | ||||
|     if [[ $repo != trunk ]]; then | ||||
|         [[ -f repos/$repo-${ARCH}/PKGBUILD ]] && pkg=repos/$repo-${ARCH}/PKGBUILD | ||||
|         [[ -f repos/$repo-any/PKGBUILD ]] && pkg=repos/$repo-any/PKGBUILD | ||||
|     fi | ||||
|     echo $pkg | ||||
| } | ||||
|  | ||||
| prepare_commit(){ | ||||
|     local dest="$1" | ||||
|     [[ -d repos/$dest ]] && git rm -r repos/$dest | ||||
|     [[ ! -d repos ]] && mkdir repos | ||||
|     [[ ! -d repos/$dest ]] && mkdir repos/$dest | ||||
| } | ||||
|  | ||||
| commit_pkg(){ | ||||
|     local git_tree=$(find_tree "${TREE_DIR_ARTIX}" "${PACKAGE}") | ||||
|     if [[ -n ${git_tree} ]];then | ||||
| @@ -41,13 +25,9 @@ commit_pkg(){ | ||||
|  | ||||
|         cd ${TREE_DIR_ARTIX}/${git_tree}/${PACKAGE} | ||||
|  | ||||
|         local pkgbuild=$(get_path "${REPO_SRC}") | ||||
|  | ||||
|         . $pkgbuild | ||||
|         . trunk/PKGBUILD | ||||
|         [[ $arch == 'any' ]] && CARCH=any | ||||
|  | ||||
|         local version=$(get_full_version) | ||||
|  | ||||
|         local ver=$(get_full_version "${PACKAGE}") | ||||
|         local commit_msg="" | ||||
|  | ||||
|         if ${remove};then | ||||
| @@ -56,14 +36,14 @@ commit_pkg(){ | ||||
|                 local pkg=${PACKAGE} | ||||
|                 git rm -r trunk | ||||
|             else | ||||
|                 local pkg="${PACKAGE}-$version" | ||||
|                 local pkg="${PACKAGE}-$ver" | ||||
|                 git rm -r repos/"${REPO_SRC}-$CARCH" | ||||
|             fi | ||||
|             commit_msg="[${REPO_SRC}] '$pkg' ${action}" | ||||
|             msg "Action: %s" "$commit_msg" | ||||
|         else | ||||
|             local action='modify' | ||||
|             commit_msg="[${REPO_SRC}] '${PACKAGE}-$version' ${action}" | ||||
|             commit_msg="[${REPO_SRC}] '${PACKAGE}-$ver' ${action}" | ||||
|             msg "Action: %s" "$commit_msg" | ||||
|             git add . | ||||
|  | ||||
| @@ -96,18 +76,17 @@ symlink_commit_pkg(){ | ||||
|  | ||||
|         cd ${TREE_DIR_ARTIX}/${git_tree}/${PACKAGE} | ||||
|  | ||||
|         local pkgbuild=$(get_path "${REPO_SRC}") | ||||
|  | ||||
|         . $pkgbuild | ||||
|         . trunk/PKGBUILD | ||||
|         [[ $arch == 'any' ]] && CARCH=any | ||||
|  | ||||
|         local version=$(get_full_version) | ||||
|         local ver=$(get_full_version "${PACKAGE}") | ||||
|  | ||||
|         if [[ ${REPO_SRC} == 'trunk' ]];then | ||||
|             local action='add' | ||||
|             local dest="${REPO_DEST}-$CARCH" | ||||
|  | ||||
|             prepare_commit "$dest" | ||||
|             [[ -d repos/$dest ]] && git rm -r repos/$dest | ||||
|             [[ ! -d repos ]] && mkdir repos | ||||
|             [[ ! -d repos/$dest ]] && mkdir repos/$dest | ||||
|  | ||||
|             cp trunk/* repos/$dest/ | ||||
|         else | ||||
| @@ -115,12 +94,14 @@ symlink_commit_pkg(){ | ||||
|             local src="${REPO_SRC}-$CARCH" dest="${REPO_DEST}-$CARCH" | ||||
|  | ||||
|             [[ ! -f repos/$src/PKGBUILD ]] && die "%s does not exist!" "repos/$src/PKGBUILD" | ||||
|             prepare_commit "$dest" | ||||
|             [[ -d repos/$dest ]] && git rm -r repos/$dest | ||||
|             [[ ! -d repos ]] && mkdir repos | ||||
|             [[ ! -d repos/$dest ]] && mkdir repos/$dest | ||||
|  | ||||
|             cp repos/$src/* repos/$dest/ | ||||
|             git rm -r repos/$src | ||||
|         fi | ||||
|         local commit_msg="[${REPO_SRC}] -> [${REPO_DEST}] '${PACKAGE}-$version' ${action}" | ||||
|         local commit_msg="[${REPO_SRC}] -> [${REPO_DEST}] '${PACKAGE}-$ver' ${action}" | ||||
|         msg "Action: %s" "$commit_msg" | ||||
|  | ||||
|         git add . | ||||
|   | ||||
| @@ -57,9 +57,6 @@ | ||||
| # possible values: openrc, runit (s6 not yet supported) | ||||
| # INITSYS="openrc" | ||||
|  | ||||
| # gpg key; leave empty or commented to skip sfs signing | ||||
| # GPG_KEY="" | ||||
|  | ||||
| # set upload bandwidth limit in kB/s | ||||
| # 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'} | ||||
|  | ||||
|     GPG_KEY=${GPG_KEY:-''} | ||||
|  | ||||
|     UPLIMIT=${UPLIMIT:-1000} | ||||
|  | ||||
|     FILE_HOST="download.${DOMAIN}" | ||||
|   | ||||
| @@ -153,7 +153,7 @@ configure_calamares(){ | ||||
|         msg2 "Configuring Calamares" | ||||
|         write_users_conf > "$mods"/users.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|services-openrc|services-${INITSYS}|" -i "$1"/etc/calamares/settings.conf | ||||
|     fi | ||||
|   | ||||
| @@ -12,38 +12,11 @@ | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||
| # 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(){ | ||||
|     local mnt="$1" | ||||
|     cp ${DATADIR}/mkinitcpio.conf $mnt/etc/mkinitcpio-artix.conf | ||||
|     local src="$1" dest="$2" | ||||
|     local kver=$(cat $src/usr/lib/modules/extramodules-ARTIX/version) | ||||
|  | ||||
|     if [[ "${PROFILE}" != 'base' ]];then | ||||
|         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 | ||||
|     dracut -fqM $dest/initramfs-${ARCH}.img $kver | ||||
| } | ||||
|  | ||||
| prepare_boot_extras(){ | ||||
| @@ -61,6 +34,17 @@ prepare_boot_extras(){ | ||||
| configure_grub(){ | ||||
|     local conf="$1/boot/grub/kernels.cfg" | ||||
|     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(){ | ||||
|   | ||||
| @@ -33,24 +33,6 @@ clean_iso_root(){ | ||||
|     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 | ||||
| make_sfs() { | ||||
|     local src="$1" | ||||
| @@ -108,13 +90,8 @@ make_sfs() { | ||||
|  | ||||
|     mksquashfs "${mksfs_args[@]}" | ||||
|  | ||||
|     make_checksum "${dest}" "${name}" | ||||
|     ${persist} && rm "${src}.img" | ||||
|  | ||||
|     if [[ -n ${GPG_KEY} ]];then | ||||
|         make_sig "${dest}" "${name}" | ||||
|     fi | ||||
|  | ||||
|     show_elapsed_time "${FUNCNAME}" "${timer_start}" | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -39,21 +39,14 @@ track_fs() { | ||||
|  | ||||
| mount_overlay(){ | ||||
|     FS_ACTIVE_MOUNTS=() | ||||
|     local lower= upper="$1" work="$2" pkglist="$3" | ||||
|     local lower= upper="$1" work="$2" | ||||
|     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 "$upper" | ||||
|     case $fs in | ||||
|         desktopfs) lower="$rootfs" ;; | ||||
|         livefs) | ||||
|             lower="$rootfs" | ||||
|             [[ -f $pkglist ]] && lower="$desktopfs":"$rootfs" | ||||
|         ;; | ||||
|         bootfs) | ||||
|             lower="$livefs":"$rootfs" | ||||
|             [[ -f $pkglist ]] && lower="$livefs":"$desktopfs":"$rootfs" | ||||
|         ;; | ||||
|         livefs) lower="$rootfs" ;; | ||||
|         bootfs) lower="$livefs":"$rootfs" ;; | ||||
|     esac | ||||
|     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" | ||||
|     [[ -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" | ||||
|     [[ -d "$profdir/$prof/live-overlay" ]] && LIVE_OVERLAY="$profdir/$prof/live-overlay" | ||||
| } | ||||
|   | ||||
| @@ -173,26 +173,6 @@ make_rootfs() { | ||||
|     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() { | ||||
|     if [[ ! -e ${work_dir}/livefs.lock ]]; then | ||||
|         msg "Prepare [Live installation] (livefs)" | ||||
| @@ -200,7 +180,7 @@ make_livefs() { | ||||
|  | ||||
|         prepare_dir "${livefs}" | ||||
|  | ||||
|         mount_overlay "${livefs}" "${work_dir}" "${DESKTOP_LIST}" | ||||
|         mount_overlay "${livefs}" "${work_dir}" | ||||
|  | ||||
|         install_packages "${livefs}" | ||||
|  | ||||
| @@ -227,12 +207,11 @@ make_bootfs() { | ||||
|  | ||||
|         local bootfs="${work_dir}/bootfs" | ||||
|  | ||||
|         mount_overlay "${bootfs}" "${work_dir}" "${DESKTOP_LIST}" | ||||
|         mount_overlay "${bootfs}" "${work_dir}" | ||||
|  | ||||
|         prepare_initcpio "${bootfs}" | ||||
|         prepare_initramfs "${bootfs}" | ||||
|         prepare_initramfs "${bootfs}" "${boot}" | ||||
|  | ||||
|         cp ${bootfs}/boot/initramfs.img ${boot}/initramfs-${ARCH}.img | ||||
| #         cp ${bootfs}/boot/initramfs.img ${boot}/initramfs-${ARCH}.img | ||||
|         prepare_boot_extras "${bootfs}" "${boot}" | ||||
|  | ||||
|         umount_overlay | ||||
| @@ -267,10 +246,6 @@ prepare_images(){ | ||||
|     local timer=$(get_timer) | ||||
|     load_pkgs "${ROOT_LIST}" "${INITSYS}" | ||||
|     run_safe "make_rootfs" | ||||
|     if [[ -f "${DESKTOP_LIST}" ]] ; then | ||||
|         load_pkgs "${DESKTOP_LIST}" "${INITSYS}" | ||||
|         run_safe "make_desktopfs" | ||||
|     fi | ||||
|     if [[ -f ${LIVE_LIST} ]]; then | ||||
|         load_pkgs "${LIVE_LIST}" "${INITSYS}" | ||||
|         run_safe "make_livefs" | ||||
|   | ||||
		Reference in New Issue
	
	Block a user