Compare commits
	
		
			70 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 83b9a674a8 | |||
| 26ffee5d7c | |||
| 8c3a81d0ee | |||
| 91b23a5265 | |||
| aa58c995eb | |||
| 68b91bc6ec | |||
| e3c3b5d9a5 | |||
| edaf1d8c0b | |||
| 3d97503604 | |||
| e9e2ec9d9e | |||
| 320dc22775 | |||
| 759f8236f1 | |||
| 51017c4789 | |||
| 9fafba1f67 | |||
| 1bb3f828fe | |||
| 76618b8ffe | |||
| b0accd6320 | |||
| 186c4cc944 | |||
| 36b3def4df | |||
| bff662b2bb | |||
| 6a830fd09e | |||
| 53738530d9 | |||
| 2008d08da2 | |||
| f1a229a2b2 | |||
| 8163c1574f | |||
| 61bc0ee372 | |||
| dd34bf3df9 | |||
| 36614abf6a | |||
| 96cc41dcde | |||
| b2d2877df9 | |||
| d051f3f73b | |||
| 90bb86cec1 | |||
| e9e0e0be8f | |||
| 82e6b1edea | |||
| bea5c4dfd6 | |||
| a3751e733b | |||
| 88cae232da | |||
| 3861ade296 | |||
| 20401b1e4f | |||
| a5920b81da | |||
| 5a1bddf043 | |||
| c24367f987 | |||
| 0ccfdbfc21 | |||
| c30cd6999b | |||
| e5b37014d0 | |||
| 96ae6855ac | |||
| 22014421b1 | |||
| ccebe7ecf3 | |||
| 7557a84a7d | |||
| 712774d585 | |||
| ef98a333ca | |||
|   | 7727ce662e | ||
|   | b841184cb2 | ||
|   | 528b3091c6 | ||
|   | ffb4f4ba98 | ||
|   | 64fe174eba | ||
|   | dc955770b3 | ||
|   | 004760e16a | ||
| bb1f0fbdc0 | |||
|   | f879bf8965 | ||
|   | 7e93c77b9a | ||
| 8832d21deb | |||
| 189ceeb7e7 | |||
| 9c6b20fea3 | |||
| 9a514cc3ca | |||
|   | 4f3899f6c6 | ||
|   | 0efd3bdfa9 | ||
|   | f5d07a597f | ||
|   | c48893ded2 | ||
|   | 781f6de35a | 
							
								
								
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								LICENSE
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| BSD 2-Clause License | BSD 2-Clause License | ||||||
|  |  | ||||||
| Copyright (c) 2017, Cromnix GNU/Linux | Copyright (c) 2018-2021, Artix Linux | ||||||
| All rights reserved. | All rights reserved. | ||||||
|  |  | ||||||
| Redistribution and use in source and binary forms, with or without | Redistribution and use in source and binary forms, with or without | ||||||
|   | |||||||
							
								
								
									
										144
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										144
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,13 +1,23 @@ | |||||||
| Version=0.1 | VERSION = 0.11.2 | ||||||
|  |  | ||||||
|  | PKG = live-services | ||||||
|  | TOOLS = artools | ||||||
|  |  | ||||||
| PREFIX = /usr/local |  | ||||||
| SYSCONFDIR = /etc | SYSCONFDIR = /etc | ||||||
|  | PREFIX ?= /usr | ||||||
|  | BINDIR = $(PREFIX)/bin | ||||||
|  | LIBDIR = $(PREFIX)/lib | ||||||
|  | DATADIR = $(PREFIX)/share | ||||||
|  | SYSUSERSDIR = $(PREFIX)/lib/sysusers.d | ||||||
|  | LIVEUSER ?= artix | ||||||
|  |  | ||||||
|  | FMODE = -m0644 | ||||||
|  | DMODE = -dm0755 | ||||||
|  | BMODE = -m0755 | ||||||
|  |  | ||||||
| BIN = \ | BIN = \ | ||||||
| 	bin/artix-live | 	bin/artix-live | ||||||
|  |  | ||||||
| LIBS = $(wildcard lib/*.sh) |  | ||||||
|  |  | ||||||
| SHARED = \ | SHARED = \ | ||||||
| 	$(wildcard data/*.map) \ | 	$(wildcard data/*.map) \ | ||||||
| 	data/live.conf | 	data/live.conf | ||||||
| @@ -17,67 +27,111 @@ RC = \ | |||||||
| 	data/rc/pacman-init \ | 	data/rc/pacman-init \ | ||||||
| 	data/rc/artix-live | 	data/rc/artix-live | ||||||
|  |  | ||||||
| GRUB_DEFAULT = \ | RUNIT_SVD = \ | ||||||
| 	data/grub2-portable-efi | 	data/runit/live | ||||||
|  |  | ||||||
| GRUB_D = \ | RUNIT_SV = \ | ||||||
| 	data/99_zzz-portable-efi | 	data/runit/pacman-init.run | ||||||
|  |  | ||||||
| all: $(BIN) $(RC) $(XBIN) ${GRUB_D} | S6_LIVE = \ | ||||||
|  | 	data/s6/artix-live/up \ | ||||||
|  | 	data/s6/artix-live/type | ||||||
|  |  | ||||||
| edit = sed -e "s|@datadir[@]|$(DESTDIR)$(PREFIX)/share/artools|g" \ | S6_PI = \ | ||||||
| 	-e "s|@sysconfdir[@]|$(DESTDIR)$(SYSCONFDIR)/artools|g" \ | 	data/s6/pacman-init/type \ | ||||||
| 	-e "s|@libdir[@]|$(DESTDIR)$(PREFIX)/lib/artools|g" | 	data/s6/pacman-init/up \ | ||||||
|  | 	data/s6/pacman-init/down | ||||||
|  |  | ||||||
| %: %.in Makefile | S6_BUNDLE = \ | ||||||
|  | 	data/s6/live/type \ | ||||||
|  | 	data/s6/live/contents | ||||||
|  |  | ||||||
|  | 66_LIVE = \ | ||||||
|  | 	data/66/artix-live | ||||||
|  |  | ||||||
|  | 66_PI = \ | ||||||
|  | 	data/66/pacman-init | ||||||
|  |  | ||||||
|  | XDG = $(wildcard data/*.desktop) | ||||||
|  |  | ||||||
|  | XBIN = bin/desktop-items | ||||||
|  |  | ||||||
|  | SYSUSERS = \ | ||||||
|  | 	data/sysusers | ||||||
|  |  | ||||||
|  | RM = rm -f | ||||||
|  | M4 = m4 -P | ||||||
|  | CHMODAW = chmod a-w | ||||||
|  | CHMODX = chmod +x | ||||||
|  |  | ||||||
|  | all: $(BIN) $(SYSUSERS) $(XBIN) $(RC) $(RUNIT_SVD) $(S6_PI) $(S6_LIVE) | ||||||
|  |  | ||||||
|  | EDIT = sed -e "s|@datadir[@]|$(DATADIR)|g" \ | ||||||
|  | 	-e "s|@sysconfdir[@]|$(SYSCONFDIR)|g" \ | ||||||
|  | 	-e "s|@bindir[@]|$(BINDIR)|g" \ | ||||||
|  | 	-e "s|@libdir[@]|$(LIBDIR)|g" \ | ||||||
|  | 	-e "s|@live[@]|$(LIVEUSER)|g" | ||||||
|  |  | ||||||
|  | %: %.in Makefile lib/util-live.sh | ||||||
| 	@echo "GEN $@" | 	@echo "GEN $@" | ||||||
| 	@$(RM) "$@" | 	@$(RM) "$@" | ||||||
| 	@m4 -P $@.in | $(edit) >$@ | 	@{ echo -n 'm4_changequote([[[,]]])'; cat $@.in; } | $(M4) | $(EDIT) >$@ | ||||||
| 	@chmod a-w "$@" | 	@$(CHMODAW) "$@" | ||||||
| 	@chmod +x "$@" | 	@$(CHMODX) "$@" | ||||||
|  | 	@bash -O extglob -n "$@" | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	rm -f $(BIN) $(RC) ${GRUB_D} | 	$(RM) $(BIN) $(SYSUSERS) $(XBIN) $(RC) $(RUNIT_SVD) $(S6_PI) $(S6_LIVE) | ||||||
|  |  | ||||||
| install_base: | install_base: | ||||||
| 	install -dm0755 $(DESTDIR)$(PREFIX)/bin | 	install $(DMODE) $(DESTDIR)$(BINDIR) | ||||||
| 	install -m0755 ${BIN} $(DESTDIR)$(PREFIX)/bin | 	install $(BMODE) $(BIN) $(DESTDIR)$(BINDIR) | ||||||
|  |  | ||||||
| 	install -dm0755 $(DESTDIR)$(PREFIX)/lib/artools | 	install $(DMODE) $(DESTDIR)$(SYSUSERSDIR) | ||||||
| 	install -m0644 ${LIBS} $(DESTDIR)$(PREFIX)/lib/artools | 	install $(FMODE) $(SYSUSERS) $(DESTDIR)$(SYSUSERSDIR)/live-artix.conf | ||||||
|  |  | ||||||
| 	install -dm0755 $(DESTDIR)$(PREFIX)/share/artools | 	install $(DMODE) $(DESTDIR)$(DATADIR)/$(TOOLS) | ||||||
| 	install -m0644 ${SHARED} $(DESTDIR)$(PREFIX)/share/artools | 	install $(FMODE) $(SHARED) $(DESTDIR)$(DATADIR)/$(TOOLS) | ||||||
|  |  | ||||||
| install_rc: | install_rc: | ||||||
| 	install -dm0755 $(DESTDIR)$(SYSCONFDIR)/init.d | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/init.d | ||||||
| 	install -m0755 ${RC} $(DESTDIR)$(SYSCONFDIR)/init.d | 	install $(BMODE) $(RC) $(DESTDIR)$(SYSCONFDIR)/init.d | ||||||
|  |  | ||||||
| install_portable_efi: | install_runit: | ||||||
| 	install -dm0755 $(DESTDIR)$(SYSCONFDIR)/default | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/rc/sysinit | ||||||
| 	install -m0755 $(GRUB_DEFAULT) $(DESTDIR)$(SYSCONFDIR)/default | 	install $(DMODE) $(DESTDIR)$(LIBDIR)/rc/sv.d | ||||||
|  |  | ||||||
| 	install -dm0755 $(DESTDIR)$(SYSCONFDIR)/grub.d | 	install $(BMODE) $(RUNIT_SVD) $(DESTDIR)$(LIBDIR)/rc/sv.d | ||||||
| 	install -m0755 $(GRUB_D) $(DESTDIR)$(SYSCONFDIR)/grub.d | 	ln -sf $(LIBDIR)/rc/sv.d/live $(DESTDIR)$(SYSCONFDIR)/rc/sysinit/98-live | ||||||
|  |  | ||||||
| uninstall_base: | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/runit/sv/pacman-init | ||||||
| 	for f in ${BIN}; do rm -f $(DESTDIR)$(PREFIX)/bin/$$f; done | 	install $(BMODE) $(RUNIT_SV) $(DESTDIR)$(SYSCONFDIR)/runit/sv/pacman-init/run | ||||||
| 	for f in ${SHARED}; do rm -f $(DESTDIR)$(PREFIX)/share/artools/$$f; done |  | ||||||
| 	for f in ${LIBS}; do rm -f $(DESTDIR)$(PREFIX)/lib/artools/$$f; done |  | ||||||
|  |  | ||||||
| uninstall_portable_efi: | install_s6: | ||||||
| 	for f in ${GRUB_DEFAULT}; do rm -f $(DESTDIR)$(SYSCONFDIR)/default/$$f; done | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/s6/sv | ||||||
| 	for f in ${GRUB_D}; do rm -f $(DESTDIR)$(SYSCONFDIR)/grub.d/$$f; done |  | ||||||
|  |  | ||||||
| uninstall_rc: | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/pacman-init | ||||||
| 	for f in ${RC}; do rm -f $(DESTDIR)$(SYSCONFDIR)/init.d/$$f; done | 	install $(BMODE) $(S6_PI) $(DESTDIR)$(SYSCONFDIR)/s6/sv/pacman-init/ | ||||||
|  |  | ||||||
| install: install_base install_rc install_portable_efi | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/artix-live | ||||||
|  | 	install $(BMODE) $(S6_LIVE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/artix-live/ | ||||||
|  |  | ||||||
| uninstall: uninstall_base uninstall_rc uninstall_portable_efi | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/live | ||||||
|  | 	install $(BMODE) $(S6_BUNDLE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/live/ | ||||||
|  |  | ||||||
| dist: | install_66: | ||||||
| 	git archive --format=tar --prefix=live-services-$(Version)/ $(Version) | gzip -9 > live-services-$(Version).tar.gz | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/66/service | ||||||
| 	gpg --detach-sign --use-agent live-services-$(Version).tar.gz |  | ||||||
|  |  | ||||||
| .PHONY: all clean install uninstall dist | 	install $(FMODE) $(66_LIVE) $(DESTDIR)$(SYSCONFDIR)/66/service/artix-live | ||||||
|  | 	install $(FMODE) $(66_PI) $(DESTDIR)$(SYSCONFDIR)/66/service/pacman-init | ||||||
|  |  | ||||||
|  | install_xdg: | ||||||
|  | 	install -dm0755 $(DESTDIR)$(PREFIX)/bin | ||||||
|  | 	install -m0755 ${XBIN} $(DESTDIR)$(PREFIX)/bin | ||||||
|  |  | ||||||
|  | 	install -dm0755 $(DESTDIR)$(SYSCONFDIR)/skel/.config/autostart | ||||||
|  | 	install -m0755 ${XDG} $(DESTDIR)$(SYSCONFDIR)/skel/.config/autostart | ||||||
|  |  | ||||||
|  | install: install_base install_rc install_runit install_s6 install_xdg | ||||||
|  |  | ||||||
|  | .PHONY: install | ||||||
|   | |||||||
| @@ -1,58 +1,23 @@ | |||||||
| #!/bin/sh | #!/bin/bash | ||||||
|  |  | ||||||
|  | m4_include(lib/util-live.sh) | ||||||
|  |  | ||||||
| LIBDIR='@libdir@' |  | ||||||
| DATADIR='@datadir@' |  | ||||||
| SYSCONFDIR='@sysconfdir@' |  | ||||||
| LOGFILE='/var/log/artix-live.log' | LOGFILE='/var/log/artix-live.log' | ||||||
|  |  | ||||||
| export LC_MESSAGES=C |  | ||||||
| export LANG=C |  | ||||||
|  |  | ||||||
| livetimer=$(date +%s%3N) |  | ||||||
|  |  | ||||||
| [[ -r ${LIBDIR}/util-live.sh ]] && source ${LIBDIR}/util-live.sh |  | ||||||
|  |  | ||||||
| load_live_config "${SYSCONFDIR}/live.conf" || load_live_config "${DATADIR}/live.conf" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) |  | ||||||
| detect_desktop_env |  | ||||||
| echo "Detected ${default_desktop_executable} ${default_desktop_file}: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) |  | ||||||
| CONSOLEFONT="$(kernel_cmdline vconsole.font)" | CONSOLEFONT="$(kernel_cmdline vconsole.font)" | ||||||
| CONSOLEMAP="$(kernel_cmdline vconsole.font.map)" | CONSOLEMAP="$(kernel_cmdline vconsole.font.map)" | ||||||
| arch=$(uname -m) | #echo "Got consolefont ${CONSOLEFONT} and consolemap ${CONSOLEMAP}" >> "${LOGFILE}" | ||||||
| echo "Got consolefont and arch $arch: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| # Activate swap |  | ||||||
| livetimer=$(get_timer_ms) |  | ||||||
| configure_swap | configure_swap | ||||||
| echo "Activated swap and added to fstab: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) |  | ||||||
| configure_language | configure_language | ||||||
| echo "Finished localization: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) |  | ||||||
| configure_user | configure_user | ||||||
| echo "Created user ${username} with password ${password}: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) | detect_desktop_env | ||||||
| configure_sudoers_d |  | ||||||
| echo "Configured sudoers: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) | configure_accountsservice | ||||||
| configure_machine_id |  | ||||||
| echo "Configured machine-id: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) |  | ||||||
| configure_accountsservice "${username}" |  | ||||||
| echo "Configured accountsservice: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) |  | ||||||
| configure_displaymanager | configure_displaymanager | ||||||
| echo "Configured displaymanager: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| livetimer=$(get_timer_ms) | configure_branding | ||||||
| configure_user_root / |  | ||||||
| echo "Configured root user: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|   | |||||||
							
								
								
									
										37
									
								
								bin/desktop-items.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								bin/desktop-items.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | #!/bin/sh | ||||||
|  |  | ||||||
|  | # Ensure the user directories are created, some DEs (MATE) | ||||||
|  | # create them after autostart scripts are run | ||||||
|  | xdg-user-dirs-update --force | ||||||
|  |  | ||||||
|  | xdg=$(xdg-user-dir DESKTOP) | ||||||
|  | src=@datadir@/applications | ||||||
|  |  | ||||||
|  | # if [[ -f $src/org.kde.konversation.desktop ]]; then | ||||||
|  | #     install -m644 $src/org.kde.konversation.desktop \ | ||||||
|  | #     $xdg/org.kde.konversation.desktop | ||||||
|  | # fi | ||||||
|  |  | ||||||
|  | if [[ -f @bindir@/calamares ]]; then | ||||||
|  |     cp -f $src/calamares.desktop "$xdg/" | ||||||
|  |     sed -i s/Icon.*=calamares/Icon=artixlinux-logo/g "$xdg"/calamares.desktop | ||||||
|  |     chmod +x "$xdg/calamares.desktop" | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | docs=@datadir@/doc/artix | ||||||
|  |  | ||||||
|  | for f in {Configuration,Troubleshooting}.pdf; do | ||||||
|  |     ln -s $docs/$f "$xdg"/$f | ||||||
|  | done | ||||||
|  |  | ||||||
|  | if [[ -d /run/openrc ]]; then | ||||||
|  |     ln -s $docs/OpenRC.pdf "$xdg"/OpenRC.pdf | ||||||
|  | elif [[ -d /run/runit ]]; then | ||||||
|  |     ln -s $docs/Runit.pdf "$xdg"/Runit.pdf | ||||||
|  | elif [[ -d /run/66 ]]; then | ||||||
|  |     ln -s $docs/Suite66.pdf "$xdg"/Suite66.pdf | ||||||
|  | else | ||||||
|  |     ln -s $docs/S6.pdf "$xdg"/S6.pdf | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | echo "live session details: /var/log/artix-live.log" > "$xdg"/README.txt | ||||||
							
								
								
									
										8
									
								
								data/66/artix-live
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										8
									
								
								data/66/artix-live
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,8 @@ | |||||||
|  | [main] | ||||||
|  | @type = oneshot | ||||||
|  | @version = 0.0.1 | ||||||
|  | @description = "artix-live service" | ||||||
|  | @user = ( root ) | ||||||
|  |  | ||||||
|  | [start] | ||||||
|  | @execute = (artix-live) | ||||||
							
								
								
									
										14
									
								
								data/66/pacman-init
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								data/66/pacman-init
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | [main] | ||||||
|  | @type = oneshot | ||||||
|  | @description = "pacman init service" | ||||||
|  | @version = 0.0.2 | ||||||
|  | @user = ( root ) | ||||||
|  | @extdepends = ( haveged ) | ||||||
|  |  | ||||||
|  | [start] | ||||||
|  | @execute = ( | ||||||
|  | foreground { mkdir -p /etc/pacman.d/gnupg } | ||||||
|  | foreground { mount -t tmpfs -o size=10M,mode=0755 tmpfs /etc/pacman.d/gnupg } | ||||||
|  | fdmove -c 2 1 | ||||||
|  | foreground { pacman-key --init } | ||||||
|  | foreground { pacman-key --populate artix } ) | ||||||
| @@ -1,49 +0,0 @@ | |||||||
| #!/bin/sh |  | ||||||
|  |  | ||||||
| # grub-mkconfig helper script. |  | ||||||
| # |  | ||||||
| # Copyright © 2014 Niall Walsh <niallwalsh@celtux.org> |  | ||||||
| # |  | ||||||
| # This program is free software; you can redistribute it and/or |  | ||||||
| # modify it under the terms of the GNU General Public License |  | ||||||
| # as published by the Free Software Foundation; either version 2 |  | ||||||
| # of the License, or (at your option) any later version. |  | ||||||
| # |  | ||||||
| # This program is distributed in the hope that it will be useful, |  | ||||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
| # GNU General Public License for more details. |  | ||||||
|  |  | ||||||
| set -e |  | ||||||
|  |  | ||||||
| AT_EFI_STANDALONE="" |  | ||||||
| AT_EFI_PORTABLE_PATH="/boot/efi/EFI/BOOT" |  | ||||||
|  |  | ||||||
| # override tool behaviour through /etc/default/grub2-fll-standalone |  | ||||||
| if [ -r /etc/default/grub2-portable-efi ]; then |  | ||||||
| 	. /etc/default/grub2-portable-efi |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| patt='[[:space:]]-o[[:space:]]\+/boot/grub/grub.cfg' |  | ||||||
| # do nothing if disabled or grub-mkconfig is generating /boot/grub/grub.cfg |  | ||||||
| ( [ "${AT_EFI_STANDALONE}" != "disable" ] && \ |  | ||||||
| 	ps x | grep 'grub-mkconfig[[:space:]]' | grep -q -e "${patt}[[:space:]]" -e "${patt}$" ) || exit |  | ||||||
|  |  | ||||||
| beeb="${AT_EFI_PORTABLE_PATH}" |  | ||||||
| if [ -e "${beeb}" ]; then |  | ||||||
| 	# do not do anything to a beeb we didn't create |  | ||||||
| 	[ ! -e "${beeb}/fullstory" ] && exit |  | ||||||
| else |  | ||||||
| 	# create beeb and mark it as ours |  | ||||||
| 	mkdir -p "${beeb}" |  | ||||||
| 	touch "${beeb}/fullstory" |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| for platform in i386-efi x86_64-efi ; do |  | ||||||
| 	filename="bootx64" |  | ||||||
| 	[ "${platform}" = "i386-efi" ] && filename="bootia32" |  | ||||||
| 	[ -e /usr/lib/grub/${platform} ] && grub-mkstandalone \ |  | ||||||
| 		-o ${beeb}/${filename}.efi --compress=xz  -O ${platform} \ |  | ||||||
| 		/boot/grub/grub.cfg=/boot/grub/grub.cfg.new 2>&1 > /dev/null |  | ||||||
| done |  | ||||||
|  |  | ||||||
| @@ -4,15 +4,15 @@ jwm:jwm | |||||||
| i3:i3 | i3:i3 | ||||||
| fluxbox:startfluxbox | fluxbox:startfluxbox | ||||||
| pekwm:pekwm | pekwm:pekwm | ||||||
| plasma:startkde |  | ||||||
| gnome:gnome-session |  | ||||||
| xfce:startxfce4 |  | ||||||
| cinnamon:cinnamon-session-cinnamon |  | ||||||
| mate:mate-session |  | ||||||
| enlightenment:enlightenment_start | enlightenment:enlightenment_start | ||||||
|  | Lumina-DE:start-lumina-desktop | ||||||
| LXDE:lxsession | LXDE:lxsession | ||||||
|  | plasma:startplasma-x11 | ||||||
| lxqt:lxqt-session | lxqt:lxqt-session | ||||||
| pantheon:pantheon-session | pantheon:pantheon-session | ||||||
| budgie-desktop:budgie-desktop | budgie-desktop:budgie-desktop | ||||||
| deepin:startdde | deepin:startdde | ||||||
| Lumina-DE:start-lumina-desktop | mate:mate-session | ||||||
|  | cinnamon:cinnamon-session-cinnamon | ||||||
|  | xfce:startxfce4 | ||||||
|  | gnome:gnome-session | ||||||
|   | |||||||
| @@ -1,15 +0,0 @@ | |||||||
| # Defaults for grub2-portable-efi update-grub helper |  | ||||||
| # sourced by grub2's update-grub |  | ||||||
| # installed at /etc/default/grub2-portable-efi by the maintainer scripts |  | ||||||
|  |  | ||||||
| # |  | ||||||
| # This is a POSIX shell fragment |  | ||||||
| # |  | ||||||
|  |  | ||||||
| # specify is this should be disabled (set to "disable") |  | ||||||
| # default: |  | ||||||
| #AT_EFI_STANDALONE="" |  | ||||||
|  |  | ||||||
| # specify where to install the portable efi |  | ||||||
| # default: /boot/efi/EFI/BOOT |  | ||||||
| #AT_EFI_PORTABLE_PATH="/boot/efi/EFI/BOOT" |  | ||||||
| @@ -1,20 +1,7 @@ | |||||||
| # live session configuration | # live session configuration | ||||||
|  |  | ||||||
| # autologin | # autologin | ||||||
| autologin=true | AUTOLOGIN=true | ||||||
|  |  | ||||||
| # live username |  | ||||||
| username=artix |  | ||||||
|  |  | ||||||
| # live password | # live password | ||||||
| password=artix | PASSWORD=artix | ||||||
|  |  | ||||||
| # live group membership |  | ||||||
| addgroups='video,power,disk,storage,optical,network,lp,scanner,wheel' |  | ||||||
|  |  | ||||||
| # default_desktop_file |  | ||||||
| default_desktop_file=lxqt |  | ||||||
|  |  | ||||||
| # default_desktop_executable |  | ||||||
| default_desktop_executable=lxqt-session |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| #!/usr/bin/openrc-run | #!/usr/bin/openrc-run | ||||||
| # Copyright 2015 artoo (artoo@cromnix.org) | # Copyright 2019 artoo (artoo@artixlinux.org) | ||||||
| # Distributed under the terms of the GNU General Public License v2 | # Distributed under the terms of the GNU General Public License v2 | ||||||
|  |  | ||||||
| target_dir=/etc/pacman.d/gnupg | target_dir=/etc/pacman.d/gnupg | ||||||
|   | |||||||
| @@ -12,6 +12,6 @@ depend() { | |||||||
| start() { | start() { | ||||||
| 	ebegin "Running pacman initialization" | 	ebegin "Running pacman initialization" | ||||||
| 	/usr/bin/pacman-key --init &> /dev/null | 	/usr/bin/pacman-key --init &> /dev/null | ||||||
| 	/usr/bin/pacman-key --populate archlinux artix &> /dev/null | 	/usr/bin/pacman-key --populate artix &> /dev/null | ||||||
| 	eend $? | 	eend $? | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										15
									
								
								data/runit/live.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								data/runit/live.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,15 @@ | |||||||
|  | #!/bin/bash | ||||||
|  |  | ||||||
|  | . @libdir@/rc/functions | ||||||
|  |  | ||||||
|  | case "$1" in | ||||||
|  |     start) | ||||||
|  |         stat_busy "Initializing artix live system" | ||||||
|  |         artix-live #|| stat_die | ||||||
|  |         add_daemon live | ||||||
|  |         stat_done | ||||||
|  |         ;; | ||||||
|  |     *) | ||||||
|  |         echo "usage: $0 {start}" | ||||||
|  |         ;; | ||||||
|  | esac | ||||||
							
								
								
									
										5
									
								
								data/runit/pacman-init.run
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								data/runit/pacman-init.run
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | |||||||
|  | #!/bin/sh | ||||||
|  | mount -t tmpfs -o size=10M,mode=0755 tmpfs /etc/pacman.d/gnupg | ||||||
|  | pacman-key --init 1>&2 | ||||||
|  | pacman-key --populate artix 1>&2 | ||||||
|  | exec chpst -b pacman-init pause | ||||||
							
								
								
									
										1
									
								
								data/s6/artix-live/type.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								data/s6/artix-live/type.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | oneshot | ||||||
							
								
								
									
										2
									
								
								data/s6/artix-live/up.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								data/s6/artix-live/up.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | #!@bindir@/execlineb -P | ||||||
|  | exec @bindir@/artix-live | ||||||
							
								
								
									
										2
									
								
								data/s6/live/contents
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								data/s6/live/contents
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | artix-live | ||||||
|  | pacman-init | ||||||
							
								
								
									
										1
									
								
								data/s6/live/type
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								data/s6/live/type
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | bundle | ||||||
							
								
								
									
										2
									
								
								data/s6/pacman-init/down.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								data/s6/pacman-init/down.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | #!@bindir@/execlineb -P | ||||||
|  | umount -l /etc/pacman.d/gnupg | ||||||
							
								
								
									
										1
									
								
								data/s6/pacman-init/type.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								data/s6/pacman-init/type.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | oneshot | ||||||
							
								
								
									
										6
									
								
								data/s6/pacman-init/up.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								data/s6/pacman-init/up.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,6 @@ | |||||||
|  | #!@bindir@/execlineb -P | ||||||
|  | foreground { mkdir -p /etc/pacman.d/gnupg } | ||||||
|  | foreground { mount -t tmpfs -o size=10M,mode=0755 tmpfs /etc/pacman.d/gnupg } | ||||||
|  | fdmove -c 2 1 | ||||||
|  | foreground { pacman-key --init } | ||||||
|  | foreground { pacman-key --populate artix } | ||||||
							
								
								
									
										12
									
								
								data/sysusers.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								data/sysusers.in
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | |||||||
|  | # artix live user | ||||||
|  | u @live@ 1000 - /home/@live@ /bin/bash | ||||||
|  |  | ||||||
|  | m @live@ video | ||||||
|  | m @live@ power | ||||||
|  | m @live@ cdrom | ||||||
|  | m @live@ network | ||||||
|  | m @live@ lp | ||||||
|  | m @live@ scanner | ||||||
|  | m @live@ wheel | ||||||
|  | m @live@ log | ||||||
|  | m @live@ users | ||||||
							
								
								
									
										429
									
								
								lib/util-live.sh
									
									
									
									
									
								
							
							
						
						
									
										429
									
								
								lib/util-live.sh
									
									
									
									
									
								
							| @@ -1,300 +1,259 @@ | |||||||
| #!/bin/bash | #!/hint/bash | ||||||
| # |  | ||||||
| # This program is free software; you can redistribute it and/or modify | export LC_MESSAGES=C | ||||||
| # it under the terms of the GNU General Public License as published by | export LANG=C | ||||||
| # the Free Software Foundation; version 2 of the License. |  | ||||||
| # | # {{{ functions | ||||||
| # This program is distributed in the hope that it will be useful, |  | ||||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of |  | ||||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the |  | ||||||
| # GNU General Public License for more details. |  | ||||||
|  |  | ||||||
| kernel_cmdline(){ | kernel_cmdline(){ | ||||||
| 	for param in $(cat /proc/cmdline); do |     for param in $(cat /proc/cmdline); do | ||||||
| 		case "${param}" in |         case "${param}" in | ||||||
| 			$1=*) echo "${param##*=}"; return 0 ;; |             $1=*) echo "${param##*=}"; return 0 ;; | ||||||
| 			$1) return 0 ;; |             "$1") return 0 ;; | ||||||
| 			*) continue ;; |             *) continue ;; | ||||||
| 		esac |         esac | ||||||
| 	done |     done | ||||||
| 	[ -n "${2}" ] && echo "${2}" |     [ -n "${2}" ] && echo "${2}" | ||||||
| 	return 1 |     return 1 | ||||||
| } | } | ||||||
|  |  | ||||||
| get_lang(){ | get_lang(){ | ||||||
| 	echo $(kernel_cmdline lang) |     kernel_cmdline lang | ||||||
| } | } | ||||||
|  |  | ||||||
| get_keytable(){ | get_keytable(){ | ||||||
| 	echo $(kernel_cmdline keytable) |     kernel_cmdline keytable | ||||||
| } | } | ||||||
|  |  | ||||||
| get_tz(){ | get_tz(){ | ||||||
| 	echo $(kernel_cmdline tz) |     kernel_cmdline tz | ||||||
| } |  | ||||||
|  |  | ||||||
| get_timer_ms(){ |  | ||||||
| 	echo $(date +%s%3N) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # $1: start timer |  | ||||||
| elapsed_time_ms(){ |  | ||||||
| 	echo $(echo $1 $(get_timer_ms) | awk '{ printf "%0.3f",($2-$1)/1000 }') |  | ||||||
| } |  | ||||||
|  |  | ||||||
| load_live_config(){ |  | ||||||
|  |  | ||||||
| 	[[ -f $1 ]] || return 1 |  | ||||||
|  |  | ||||||
| 	live_conf="$1" |  | ||||||
|  |  | ||||||
| 	[[ -r ${live_conf} ]] && source ${live_conf} |  | ||||||
|  |  | ||||||
| 	[[ -z ${autologin} ]] && autologin=true |  | ||||||
|  |  | ||||||
| 	[[ -z ${username} ]] && username="cromnix" |  | ||||||
|  |  | ||||||
| 	[[ -z ${password} ]] && password="cromnix" |  | ||||||
|  |  | ||||||
| 	[[ -z ${addgroups} ]] && addgroups="" |  | ||||||
|  |  | ||||||
| 	echo "Loaded ${live_conf}: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" |  | ||||||
|  |  | ||||||
| 	return 0 |  | ||||||
| } | } | ||||||
|  |  | ||||||
| is_valid_de(){ | is_valid_de(){ | ||||||
| 	if [[ ${default_desktop_executable} != "none" ]] && \ |     if [[ ${DEFAULT_DESKTOP_EXECUTABLE} != "none" ]] && \ | ||||||
| 	[[ ${default_desktop_file} != "none" ]]; then |     [[ ${DEFAULT_DESKTOP_FILE} != "none" ]]; then | ||||||
| 		return 0 |         return 0 | ||||||
| 	else |     fi | ||||||
| 		return 1 |     return 1 | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| load_desktop_map(){ |  | ||||||
|     local _space="s| ||g" _clean=':a;N;$!ba;s/\n/ /g' _com_rm="s|#.*||g" \ |  | ||||||
|         file=${DATADIR}/desktop.map |  | ||||||
|     local desktop_map=$(sed "$_com_rm" "$file" \ |  | ||||||
|             | sed "$_space" \ |  | ||||||
|             | sed "$_clean") |  | ||||||
|     echo ${desktop_map} |  | ||||||
| } | } | ||||||
|  |  | ||||||
| detect_desktop_env(){ | detect_desktop_env(){ | ||||||
|     local xs=/usr/share/xsessions ex=/usr/bin key val map=( $(load_desktop_map) ) |     local key val map | ||||||
|     default_desktop_file="none" |     map="${DATADIR}"/artools/desktop.map | ||||||
|     default_desktop_executable="none" |     DEFAULT_DESKTOP_FILE="none" | ||||||
|     for item in "${map[@]}";do |     DEFAULT_DESKTOP_EXECUTABLE="none" | ||||||
|  |     while read -r item; do | ||||||
|         key=${item%:*} |         key=${item%:*} | ||||||
|         val=${item#*:} |         val=${item#*:} | ||||||
|         if [[ -f $xs/$key.desktop ]] && [[ -f $ex/$val ]];then |         if [[ -f "${DATADIR}"/xsessions/$key.desktop ]] && [[ -f ${BINDIR}/$val ]];then | ||||||
|             default_desktop_file="$key" |             DEFAULT_DESKTOP_FILE="$key" | ||||||
|             default_desktop_executable="$val" |             DEFAULT_DESKTOP_EXECUTABLE="$val" | ||||||
|         fi |         fi | ||||||
|     done |     done < "$map" | ||||||
|  |     echo "Detected ${DEFAULT_DESKTOP_EXECUTABLE} ${DEFAULT_DESKTOP_FILE}" >> "${LOGFILE}" | ||||||
| } | } | ||||||
|  |  | ||||||
| configure_accountsservice(){ | configure_accountsservice(){ | ||||||
| 	local path=/var/lib/AccountsService/users |     local path=/var/lib/AccountsService/users user="${1:-${LIVEUSER}}" | ||||||
| 	if [ -d "${path}" ] ; then |     if [ -d "${path}" ] ; then | ||||||
| 		echo "[User]" > ${path}/$1 |         echo "[User]" > ${path}/"$user" | ||||||
| 		echo "XSession=${default_desktop_file}" >> ${path}/$1 |         echo "XSession=${DEFAULT_DESKTOP_FILE}" >> ${path}/"$user" | ||||||
| 		if [[ -f "/var/lib/AccountsService/icons/$1.png" ]];then |         if [[ -f "/var/lib/AccountsService/icons/$user.png" ]];then | ||||||
| 			echo "Icon=/var/lib/AccountsService/icons/$1.png" >> ${path}/$1 |             echo "Icon=/var/lib/AccountsService/icons/$user.png" >> ${path}/"$user" | ||||||
| 		fi |         fi | ||||||
| 	fi |     fi | ||||||
|  |     echo "Configured accountsservice" >> "${LOGFILE}" | ||||||
| } | } | ||||||
|  |  | ||||||
|  set_lightdm_greeter(){ |  set_lightdm_greeter(){ | ||||||
| 	local greeters=$(ls /usr/share/xgreeters/*greeter.desktop) name |     local name | ||||||
| 	for g in ${greeters[@]};do |     for g in "${DATADIR}"/xgreeters/*.desktop;do | ||||||
| 		name=${g##*/} |         name=${g##*/} | ||||||
| 		name=${name%%.*} |         name=${name%%.*} | ||||||
| 		case ${name} in |         case ${name} in | ||||||
| 			lightdm-gtk-greeter) break ;; |             lightdm-gtk-greeter) break ;; | ||||||
| 			lightdm-*-greeter) |             lightdm-*-greeter) | ||||||
| 				sed -i -e "s/^.*greeter-session=.*/greeter-session=${name}/" /etc/lightdm/lightdm.conf |                 sed -e "s/^.*greeter-session=.*/greeter-session=${name}/" \ | ||||||
| 			;; |                     -i /etc/lightdm/lightdm.conf | ||||||
| 		esac |             ;; | ||||||
| 	done |         esac | ||||||
|  } |     done | ||||||
|  |  | ||||||
|  set_lightdm_vt(){ |  | ||||||
| 	sed -i -e 's/^.*minimum-vt=.*/minimum-vt=7/' /etc/lightdm/lightdm.conf |  | ||||||
|  } |  } | ||||||
|  |  | ||||||
| configure_displaymanager(){ | configure_displaymanager(){ | ||||||
| 	# Try to detect desktop environment |     # Try to detect desktop environment | ||||||
| 	# Configure display manager |     # Configure display manager | ||||||
| 	if [[ -f /usr/bin/lightdm ]];then |  | ||||||
| 		groupadd -r autologin |  | ||||||
| 		set_lightdm_vt |  | ||||||
| 		set_lightdm_greeter |  | ||||||
| 		if $(is_valid_de); then |  | ||||||
| 			sed -i -e "s/^.*user-session=.*/user-session=$default_desktop_file/" /etc/lightdm/lightdm.conf |  | ||||||
| 		fi |  | ||||||
| 		if ${autologin};then |  | ||||||
| 			gpasswd -a ${username} autologin &> /dev/null |  | ||||||
| 			sed -i -e "s/^.*autologin-user=.*/autologin-user=${username}/" /etc/lightdm/lightdm.conf |  | ||||||
| 			sed -i -e "s/^.*autologin-user-timeout=.*/autologin-user-timeout=0/" /etc/lightdm/lightdm.conf |  | ||||||
| 			sed -i -e "s/^.*pam-autologin-service=.*/pam-autologin-service=lightdm-autologin/" /etc/lightdm/lightdm.conf |  | ||||||
| 		fi |  | ||||||
| 	elif [[ -f /usr/bin/gdm ]];then |  | ||||||
| 		configure_accountsservice "gdm" |  | ||||||
| 		if ${autologin};then |  | ||||||
| 			sed -i -e "s/\[daemon\]/\[daemon\]\nAutomaticLogin=${username}\nAutomaticLoginEnable=True/" /etc/gdm/custom.conf |  | ||||||
| 		fi |  | ||||||
| 	elif [[ -f /usr/bin/mdm ]];then |  | ||||||
| 		if $(is_valid_de); then |  | ||||||
| 			sed -i "s|default.desktop|$default_desktop_file.desktop|g" /etc/mdm/custom.conf |  | ||||||
| 		fi |  | ||||||
| 	elif [[ -f /usr/bin/sddm ]];then |  | ||||||
| 		if $(is_valid_de); then |  | ||||||
| 			sed -i -e "s|^Session=.*|Session=$default_desktop_file.desktop|" /etc/sddm.conf |  | ||||||
| 		fi |  | ||||||
| 		if ${autologin};then |  | ||||||
| 			sed -i -e "s|^User=.*|User=${username}|" /etc/sddm.conf |  | ||||||
| 		fi |  | ||||||
| 	elif [[ -f /usr/bin/lxdm ]];then |  | ||||||
| 		if $(is_valid_de); then |  | ||||||
| 			sed -i -e "s|^.*session=.*|session=/usr/bin/$default_desktop_executable|" /etc/lxdm/lxdm.conf |  | ||||||
| 		fi |  | ||||||
| 		if ${autologin};then |  | ||||||
| 			sed -i -e "s/^.*autologin=.*/autologin=${username}/" /etc/lxdm/lxdm.conf |  | ||||||
| 		fi |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| gen_pw(){ |     if [[ -f "${BINDIR}"/lightdm ]];then | ||||||
| 	echo $(perl -e 'print crypt($ARGV[0], "password")' ${password}) |         groupadd -r autologin | ||||||
| } |         gpasswd -a "${LIVEUSER}" autologin &> /dev/null | ||||||
|  |         set_lightdm_greeter | ||||||
| configure_user(){ |         if is_valid_de; then | ||||||
| 	# set up user and password |             sed -e "s/^.*user-session=.*/user-session=$DEFAULT_DESKTOP_FILE/" \ | ||||||
| 	if [[ -n ${password} ]];then |                 -e 's/^.*minimum-vt=.*/minimum-vt=7/' \ | ||||||
| 		useradd -m -G ${addgroups} -p $(gen_pw) -s /bin/bash ${username} |                 -i /etc/lightdm/lightdm.conf | ||||||
| 	else |         fi | ||||||
| 		useradd -m -G ${addgroups} -s /bin/bash ${username} |         ${AUTOLOGIN} && sed -e "s/^.*autologin-user=.*/autologin-user=${LIVEUSER}/" \ | ||||||
| 	fi |                 -e "s/^.*autologin-user-timeout=.*/autologin-user-timeout=0/" \ | ||||||
|  |                 -e "s/^.*pam-autologin-service=.*/pam-autologin-service=lightdm-autologin/" \ | ||||||
|  |                 -i /etc/lightdm/lightdm.conf | ||||||
|  |     elif [[ -f "${BINDIR}"/gdm ]];then | ||||||
|  |         configure_accountsservice "gdm" | ||||||
|  |         ${AUTOLOGIN} && sed -e "s/\[daemon\]/\[daemon\]\nAutomaticLogin=${LIVEUSER}\nAutomaticLoginEnable=True/" \ | ||||||
|  |                 -i /etc/gdm/custom.conf | ||||||
|  |     elif [[ -f "${BINDIR}"/sddm ]];then | ||||||
|  |         if is_valid_de; then | ||||||
|  |             sed -e "s|^Session=.*|Session=$DEFAULT_DESKTOP_FILE.desktop|" \ | ||||||
|  |                 -i /etc/sddm.conf | ||||||
|  |         fi | ||||||
|  |         ${AUTOLOGIN} && sed -e "s|^User=.*|User=${LIVEUSER}|" \ | ||||||
|  |                 -i /etc/sddm.conf | ||||||
|  |     elif [[ -f "${BINDIR}"/lxdm ]];then | ||||||
|  |         if is_valid_de; then | ||||||
|  |             sed -e "s|^.*session=.*|session=${BINDIR}/${DEFAULT_DESKTOP_EXECUTABLE}|" \ | ||||||
|  |                 -i /etc/lxdm/lxdm.conf | ||||||
|  |         fi | ||||||
|  |         ${AUTOLOGIN} && sed -e "s/^.*autologin=.*/autologin=${LIVEUSER}/" \ | ||||||
|  |                 -i /etc/lxdm/lxdm.conf | ||||||
|  |     fi | ||||||
|  |     echo "Configured displaymanager" >> "${LOGFILE}" | ||||||
| } | } | ||||||
|  |  | ||||||
| find_legacy_keymap(){ | find_legacy_keymap(){ | ||||||
| 	local file="${DATADIR}/kbd-model.map" |     local file="${DATADIR}/artools/kbd-model.map" kt="$1" | ||||||
| 	while read -r line || [[ -n $line ]]; do |     while read -r line || [[ -n $line ]]; do | ||||||
| 		if [[ -z $line ]] || [[ $line == \#* ]]; then |         if [[ -z $line ]] || [[ $line == \#* ]]; then | ||||||
| 			continue |             continue | ||||||
| 		fi |         fi | ||||||
|  |  | ||||||
| 		mapping=( $line ); # parses columns |         local mapping=( "$line" ); # parses columns | ||||||
| 		if [[ ${#mapping[@]} != 5 ]]; then |         if [[ ${#mapping[@]} != 5 ]]; then | ||||||
| 			continue |             continue | ||||||
| 		fi |         fi | ||||||
|  |  | ||||||
| 		if  [[ "${keytable}" != "${mapping[0]}" ]]; then |         if  [[ "$kt" != "${mapping[0]}" ]]; then | ||||||
| 			continue |             continue | ||||||
| 		fi |         fi | ||||||
|  |  | ||||||
| 		if [[ "${mapping[3]}" = "-" ]]; then |         if [[ "${mapping[3]}" == "-" ]]; then | ||||||
| 			mapping[3]="" |             mapping[3]="" | ||||||
| 		fi |         fi | ||||||
|  |  | ||||||
| 		X11_LAYOUT=${mapping[1]} |         X11_LAYOUT=${mapping[1]} | ||||||
| 		X11_MODEL=${mapping[2]} |         X11_MODEL=${mapping[2]} | ||||||
| 		X11_VARIANT=${mapping[3]} |         X11_VARIANT=${mapping[3]} | ||||||
| 		x11_OPTIONS=${mapping[4]} |         X11_OPTIONS=${mapping[4]} | ||||||
| 	done < $file |     done < $file | ||||||
| } | } | ||||||
|  |  | ||||||
| write_x11_config(){ | write_x11_config(){ | ||||||
| 	# find a x11 layout that matches the keymap |     # find a x11 layout that matches the keymap | ||||||
| 	# in isolinux if you select a keyboard layout and a language that doesnt match this layout, |     # in isolinux if you select a keyboard layout and a language that doesnt match this layout, | ||||||
| 	# it will provide the correct keymap, but not kblayout value |     # it will provide the correct keymap, but not kblayout value | ||||||
| 	local X11_LAYOUT= |     local X11_LAYOUT= | ||||||
| 	local X11_MODEL="pc105" |     local X11_MODEL="pc105" | ||||||
| 	local X11_VARIANT="" |     local X11_VARIANT="" | ||||||
| 	local X11_OPTIONS="terminate:ctrl_alt_bksp" |     local X11_OPTIONS="terminate:ctrl_alt_bksp" | ||||||
|  |     local kt="$1" | ||||||
|  |  | ||||||
| 	find_legacy_keymap |     find_legacy_keymap "$kt" | ||||||
|  |  | ||||||
| 	# layout not found, use KBLAYOUT |     # layout not found, use KBLAYOUT | ||||||
| 	if [[ -z "$X11_LAYOUT" ]]; then |     if [[ -z "$X11_LAYOUT" ]]; then | ||||||
| 		X11_LAYOUT="${keytable}" |         X11_LAYOUT="$kt" | ||||||
| 	fi |     fi | ||||||
|  |  | ||||||
| 	# create X11 keyboard layout config |     # create X11 keyboard layout config | ||||||
| 	mkdir -p "/etc/X11/xorg.conf.d" |     mkdir -p "/etc/X11/xorg.conf.d" | ||||||
|  |  | ||||||
| 	local XORGKBLAYOUT="/etc/X11/xorg.conf.d/00-keyboard.conf" |     local XORGKBLAYOUT="/etc/X11/xorg.conf.d/00-keyboard.conf" | ||||||
|  |  | ||||||
| 	echo "" >> "$XORGKBLAYOUT" |     echo "Section \"InputClass\"" > "$XORGKBLAYOUT" | ||||||
| 	echo "Section \"InputClass\"" > "$XORGKBLAYOUT" |     { | ||||||
| 	echo " Identifier \"system-keyboard\"" >> "$XORGKBLAYOUT" |     echo " Identifier \"system-keyboard\"" | ||||||
| 	echo " MatchIsKeyboard \"on\"" >> "$XORGKBLAYOUT" |     echo " MatchIsKeyboard \"on\"" | ||||||
| 	echo " Option \"XkbLayout\" \"$X11_LAYOUT\"" >> "$XORGKBLAYOUT" |     echo " Option \"XkbLayout\" \"$X11_LAYOUT\"" | ||||||
| 	echo " Option \"XkbModel\" \"$X11_MODEL\"" >> "$XORGKBLAYOUT" |     echo " Option \"XkbModel\" \"$X11_MODEL\"" | ||||||
| 	echo " Option \"XkbVariant\" \"$X11_VARIANT\"" >> "$XORGKBLAYOUT" |     echo " Option \"XkbVariant\" \"$X11_VARIANT\"" | ||||||
| 	echo " Option \"XkbOptions\" \"$X11_OPTIONS\"" >> "$XORGKBLAYOUT" |     echo " Option \"XkbOptions\" \"$X11_OPTIONS\"" | ||||||
| 	echo "EndSection" >> "$XORGKBLAYOUT" |     echo "EndSection" | ||||||
|  |     } >> "$XORGKBLAYOUT" | ||||||
| } | } | ||||||
|  |  | ||||||
| configure_language(){ | configure_language(){ | ||||||
|     # hack to be able to set the locale on bootup |     # hack to be able to set the locale on bootup | ||||||
|     local lang=$(get_lang) |     local lang keytable timezone | ||||||
|  |     lang=$(get_lang) | ||||||
|     keytable=$(get_keytable) |     keytable=$(get_keytable) | ||||||
|     local timezone=$(get_tz) |     timezone=$(get_tz) | ||||||
|     # Fallback |  | ||||||
| #     [[ -z "${lang}" ]] && lang="en_US" |  | ||||||
| #     [[ -z "${keytable}" ]] && keytable="us" |  | ||||||
| #     [[ -z "${timezone}" ]] && timezone="Etc/UTC" |  | ||||||
|  |  | ||||||
|     sed -e "s/#${lang}.UTF-8/${lang}.UTF-8/" -i /etc/locale.gen |     sed -e "s/#${lang}.UTF-8/${lang}.UTF-8/" -i /etc/locale.gen | ||||||
|  |  | ||||||
|     # 	echo "LANG=${lang}.UTF-8" >> /etc/environment |  | ||||||
|  |  | ||||||
|     if [[ -d /run/openrc ]]; then |  | ||||||
|         sed -i "s/keymap=.*/keymap=\"${keytable}\"/" /etc/conf.d/keymaps |  | ||||||
|     fi |  | ||||||
|     echo "KEYMAP=${keytable}" > /etc/vconsole.conf |     echo "KEYMAP=${keytable}" > /etc/vconsole.conf | ||||||
|     echo "LANG=${lang}.UTF-8" > /etc/locale.conf |     echo "LANG=${lang}.UTF-8" > /etc/locale.conf | ||||||
|     ln -sf /usr/share/zoneinfo/${timezone} /etc/localtime |     ln -sf "${DATADIR}"/zoneinfo/"${timezone}" /etc/localtime | ||||||
|  |  | ||||||
|     write_x11_config |     write_x11_config "${keytable}" | ||||||
|  |  | ||||||
|     loadkeys "${keytable}" |     loadkeys "${keytable}" | ||||||
|  |  | ||||||
|     locale-gen ${lang} |     locale-gen "${lang}" | ||||||
|     echo "Configured language: ${lang}" >> "${LOGFILE}" |     { | ||||||
|     echo "Configured keymap: ${keytable}" >> "${LOGFILE}" |     echo "Configured language: ${lang}" | ||||||
|     echo "Configured timezone: ${timezone}" >> "${LOGFILE}" |     echo "Configured keymap: ${keytable}" | ||||||
| } |     echo "Configured timezone: ${timezone}" | ||||||
|  |     echo "Finished localization" | ||||||
| configure_machine_id(){ |     } >> "${LOGFILE}" | ||||||
| 	if [ -e "/etc/machine-id" ] ; then |  | ||||||
| 		# delete existing machine-id |  | ||||||
| 		echo "Deleting existing machine-id ..." >> "${LOGFILE}" |  | ||||||
| 		rm /etc/machine-id |  | ||||||
| 	fi |  | ||||||
| 	# set unique machine-id |  | ||||||
| 	echo "Setting machine-id ..." >> "${LOGFILE}" |  | ||||||
| 	dbus-uuidgen --ensure=/etc/machine-id |  | ||||||
| 	ln -sf /etc/machine-id /var/lib/dbus/machine-id |  | ||||||
| } |  | ||||||
|  |  | ||||||
| configure_sudoers_d(){ |  | ||||||
| 	echo "%wheel  ALL=(ALL) NOPASSWD: ALL" > /etc/sudoers.d/g_wheel |  | ||||||
| 	echo "root ALL=(ALL) ALL"  > /etc/sudoers.d/u_root |  | ||||||
| } | } | ||||||
|  |  | ||||||
| configure_swap(){ | configure_swap(){ | ||||||
| 	local swapdev="$(fdisk -l 2>/dev/null | grep swap | cut -d' ' -f1)" |     local swapdev | ||||||
| 	if [ -e "${swapdev}" ]; then |     swapdev="$(fdisk -l 2>/dev/null | grep swap | cut -d' ' -f1)" | ||||||
| 		swapon ${swapdev} |     if [ -e "${swapdev}" ]; then | ||||||
| 	fi |         swapon "${swapdev}" | ||||||
|  |     fi | ||||||
|  |     echo "Activated swap and added to fstab" >> "${LOGFILE}" | ||||||
| } | } | ||||||
|  |  | ||||||
| configure_user_root(){ | configure_branding(){ | ||||||
| 	# set up root password |     if [[ -f "${BINDIR}"/neofetch ]]; then | ||||||
| 	echo "root:${password}" | chroot $1 chpasswd |         neofetch >| /etc/issue | ||||||
| 	cp /etc/skel/.{bash_profile,bashrc,bash_logout} /root/ |         echo "Configured branding" >> "${LOGFILE}" | ||||||
|  |     fi | ||||||
| } | } | ||||||
|  |  | ||||||
|  | configure_user(){ | ||||||
|  |     echo "root:${PASSWORD}" | chroot / chpasswd | ||||||
|  |     cp /etc/skel/.{bash_profile,bashrc,bash_logout} /root/ | ||||||
|  |  | ||||||
|  |     mkdir /home/${LIVEUSER} | ||||||
|  |     chown ${LIVEUSER}:${LIVEUSER} /home/${LIVEUSER} | ||||||
|  |     echo "${LIVEUSER}:${PASSWORD}" | chroot / chpasswd | ||||||
|  |     cp -r /etc/skel/.[^.]* /home/${LIVEUSER} | ||||||
|  |     chown -R ${LIVEUSER}:${LIVEUSER} /home/${LIVEUSER} | ||||||
|  |     echo "Configured live user ${LIVEUSER} with password ${PASSWORD}" >> "${LOGFILE}" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | # }}} | ||||||
|  |  | ||||||
|  |  | ||||||
|  | load_live_config(){ | ||||||
|  |  | ||||||
|  |     [[ -f $1 ]] || return 1 | ||||||
|  |  | ||||||
|  |     local live_conf="$1" | ||||||
|  |  | ||||||
|  |     [[ -r "${live_conf}" ]] && source "${live_conf}" | ||||||
|  |  | ||||||
|  |     AUTOLOGIN=${AUTOLOGIN:-true} | ||||||
|  |  | ||||||
|  |     PASSWORD=${PASSWORD:-artix} | ||||||
|  |  | ||||||
|  |     return 0 | ||||||
|  | } | ||||||
|  |  | ||||||
|  | load_live_config "@sysconfdir@/artools/live.conf" || load_live_config "@datadir@/artools/live.conf" | ||||||
|  |  | ||||||
|  | LIVEUSER=@live@ | ||||||
|  | DATADIR=@datadir@ | ||||||
|  | BINDIR=@bindir@ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user