Compare commits
	
		
			42 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 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 | 
							
								
								
									
										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-2019, 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 | ||||||
|   | |||||||
							
								
								
									
										95
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										95
									
								
								Makefile
									
									
									
									
									
								
							| @@ -1,29 +1,23 @@ | |||||||
| VERSION = 0.5 | VERSION = 0.10 | ||||||
|  |  | ||||||
| PKG = live-services | PKG = live-services | ||||||
| TOOLS = artools | TOOLS = artools | ||||||
|  |  | ||||||
| SYSCONFDIR = /etc | SYSCONFDIR = /etc | ||||||
| ifdef PREFIX | PREFIX ?= /usr | ||||||
| PREFIX = /usr/local |  | ||||||
| endif |  | ||||||
| BINDIR = $(PREFIX)/bin | BINDIR = $(PREFIX)/bin | ||||||
| LIBDIR = $(PREFIX)/lib | LIBDIR = $(PREFIX)/lib | ||||||
| DATADIR = $(PREFIX)/share | DATADIR = $(PREFIX)/share | ||||||
|  | SYSUSERSDIR = $(PREFIX)/lib/sysusers.d | ||||||
|  | LIVEUSER ?= artix | ||||||
|  |  | ||||||
| FMODE = -m0644 | FMODE = -m0644 | ||||||
| DMODE = -dm0755 | DMODE = -dm0755 | ||||||
| BMODE = -m0755 | BMODE = -m0755 | ||||||
| RM = rm -f |  | ||||||
| M4 = m4 -P |  | ||||||
| CHAW = chmod a-w |  | ||||||
| CHX = chmod +x |  | ||||||
|  |  | ||||||
| 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 | ||||||
| @@ -39,38 +33,62 @@ RUNIT_SVD = \ | |||||||
| RUNIT_SV = \ | RUNIT_SV = \ | ||||||
| 	data/runit/pacman-init.run | 	data/runit/pacman-init.run | ||||||
|  |  | ||||||
| GRUB_DEFAULT = \ | S6_LIVE = \ | ||||||
| 	data/grub2-portable-efi | 	data/s6/artix-live/up \ | ||||||
|  | 	data/s6/artix-live/type | ||||||
|  |  | ||||||
| GRUB_D = \ | S6_PI = \ | ||||||
| 	data/99_zzz-portable-efi | 	data/s6/pacman-init/type \ | ||||||
|  | 	data/s6/pacman-init/up \ | ||||||
|  | 	data/s6/pacman-init/down | ||||||
|  |  | ||||||
|  | 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) | XDG = $(wildcard data/*.desktop) | ||||||
|  |  | ||||||
| XBIN = bin/desktop-items | XBIN = bin/desktop-items | ||||||
|  |  | ||||||
| all: $(BIN) $(RC) $(RUNIT_SV) $(XBIN) $(GRUB_D) | SYSUSERS = \ | ||||||
|  | 	data/sysusers | ||||||
|  |  | ||||||
| EDIT = sed -e "s|@datadir[@]|$(DATADIR)/$(TOOLS)|g" \ | RM = rm -f | ||||||
| 	-e "s|@sysconfdir[@]|$(SYSCONFDIR)/$(TOOLS)|g" \ | M4 = m4 -P | ||||||
| 	-e "s|@libdir[@]|$(LIBDIR)/$(TOOLS)|g" | CHMODAW = chmod a-w | ||||||
|  | CHMODX = chmod +x | ||||||
|  |  | ||||||
| %: %.in Makefile | 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) $@.in | $(EDIT) >$@ | 	@{ echo -n 'm4_changequote([[[,]]])'; cat $@.in; } | $(M4) | $(EDIT) >$@ | ||||||
| 	@$(CHAW) "$@" | 	@$(CHMODAW) "$@" | ||||||
| 	@$(CHX) "$@" | 	@$(CHMODX) "$@" | ||||||
|  | 	@bash -O extglob -n "$@" | ||||||
|  |  | ||||||
| clean: | clean: | ||||||
| 	$(RM) $(BIN) $(RC) $(GRUB_D) | 	$(RM) $(BIN) $(SYSUSERS) $(XBIN) $(RC) $(RUNIT_SVD) $(S6_PI) $(S6_LIVE) | ||||||
|  |  | ||||||
| install_base: | install_base: | ||||||
| 	install $(DMODE) $(DESTDIR)$(BINDIR) | 	install $(DMODE) $(DESTDIR)$(BINDIR) | ||||||
| 	install $(BMODE) $(BIN) $(DESTDIR)$(BINDIR) | 	install $(BMODE) $(BIN) $(DESTDIR)$(BINDIR) | ||||||
|  |  | ||||||
| 	install $(DMODE) $(DESTDIR)$(LIBDIR)/$(TOOLS) | 	install $(DMODE) $(DESTDIR)$(SYSUSERSDIR) | ||||||
| 	install $(FMODE) $(LIBS) $(DESTDIR)$(LIBDIR)/$(TOOLS) | 	install $(FMODE) $(SYSUSERS) $(DESTDIR)$(SYSUSERSDIR)/live-artix.conf | ||||||
|  |  | ||||||
| 	install $(DMODE) $(DESTDIR)$(DATADIR)/$(TOOLS) | 	install $(DMODE) $(DESTDIR)$(DATADIR)/$(TOOLS) | ||||||
| 	install $(FMODE) $(SHARED) $(DESTDIR)$(DATADIR)/$(TOOLS) | 	install $(FMODE) $(SHARED) $(DESTDIR)$(DATADIR)/$(TOOLS) | ||||||
| @@ -83,18 +101,29 @@ install_runit: | |||||||
| 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/rc/sysinit | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/rc/sysinit | ||||||
| 	install $(DMODE) $(DESTDIR)$(LIBDIR)/rc/sv.d | 	install $(DMODE) $(DESTDIR)$(LIBDIR)/rc/sv.d | ||||||
|  |  | ||||||
| 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/runit/sv/pacman-init |  | ||||||
| 	install $(BMODE) $(RUNIT_SVD) $(DESTDIR)$(LIBDIR)/rc/sv.d | 	install $(BMODE) $(RUNIT_SVD) $(DESTDIR)$(LIBDIR)/rc/sv.d | ||||||
| 	ln -sf $(LIBDIR)/rc/sv.d/live $(DESTDIR)$(SYSCONFDIR)/rc/sysinit/98-live | 	ln -sf $(LIBDIR)/rc/sv.d/live $(DESTDIR)$(SYSCONFDIR)/rc/sysinit/98-live | ||||||
|  |  | ||||||
|  | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/runit/sv/pacman-init | ||||||
| 	install $(BMODE) $(RUNIT_SV) $(DESTDIR)$(SYSCONFDIR)/runit/sv/pacman-init/run | 	install $(BMODE) $(RUNIT_SV) $(DESTDIR)$(SYSCONFDIR)/runit/sv/pacman-init/run | ||||||
|  |  | ||||||
| install_portable_efi: | install_s6: | ||||||
| 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/default | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/s6/sv | ||||||
| 	install $(BMODE) $(GRUB_DEFAULT) $(DESTDIR)$(SYSCONFDIR)/default |  | ||||||
|  |  | ||||||
| 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/grub.d | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/pacman-init | ||||||
| 	install $(BMODE) $(GRUB_D) $(DESTDIR)$(SYSCONFDIR)/grub.d | 	install $(BMODE) $(S6_PI) $(DESTDIR)$(SYSCONFDIR)/s6/sv/pacman-init/ | ||||||
|  |  | ||||||
|  | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/artix-live | ||||||
|  | 	install $(BMODE) $(S6_LIVE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/artix-live/ | ||||||
|  |  | ||||||
|  | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/live | ||||||
|  | 	install $(BMODE) $(S6_BUNDLE) $(DESTDIR)$(SYSCONFDIR)/s6/sv/live/ | ||||||
|  |  | ||||||
|  | install_66: | ||||||
|  | 	install $(DMODE) $(DESTDIR)$(SYSCONFDIR)/66/service | ||||||
|  |  | ||||||
|  | 	install $(FMODE) $(66_LIVE) $(DESTDIR)$(SYSCONFDIR)/66/service/artix-live | ||||||
|  | 	install $(FMODE) $(66_PI) $(DESTDIR)$(SYSCONFDIR)/66/service/pacman-init | ||||||
|  |  | ||||||
| install_xdg: | install_xdg: | ||||||
| 	install -dm0755 $(DESTDIR)$(PREFIX)/bin | 	install -dm0755 $(DESTDIR)$(PREFIX)/bin | ||||||
| @@ -103,6 +132,6 @@ install_xdg: | |||||||
| 	install -dm0755 $(DESTDIR)$(SYSCONFDIR)/skel/.config/autostart | 	install -dm0755 $(DESTDIR)$(SYSCONFDIR)/skel/.config/autostart | ||||||
| 	install -m0755 ${XDG} $(DESTDIR)$(SYSCONFDIR)/skel/.config/autostart | 	install -m0755 ${XDG} $(DESTDIR)$(SYSCONFDIR)/skel/.config/autostart | ||||||
|  |  | ||||||
| install: install_base install_rc install_portable_efi install_xdg | install: install_base install_rc install_runit install_s6 install_xdg | ||||||
|  |  | ||||||
| .PHONY: all clean install uninstall dist | .PHONY: install | ||||||
|   | |||||||
| @@ -1,50 +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_accountsservice "${username}" |  | ||||||
| echo "Configured accountsservice: $(elapsed_time_ms ${livetimer})ms" >> "${LOGFILE}" | configure_accountsservice | ||||||
|  |  | ||||||
| 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}" |  | ||||||
|   | |||||||
| @@ -1,26 +1,35 @@ | |||||||
| #!/bin/sh | #!/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) | xdg=$(xdg-user-dir DESKTOP) | ||||||
| src=/usr/share/applications | src=@datadir@/applications | ||||||
|  |  | ||||||
| if [[ -f $src/org.kde.konversation.desktop ]]; then | # if [[ -f $src/org.kde.konversation.desktop ]]; then | ||||||
|     install -Dm755 $src/org.kde.konversation.desktop \ | #     install -m644 $src/org.kde.konversation.desktop \ | ||||||
|     $xdg/konversation-artix-help.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 | fi | ||||||
|  |  | ||||||
| if [[ -f /usr/bin/calamares ]]; then | docs=@datadir@/doc/artix | ||||||
|     install -Dm755 $src/calamares.desktop \ |  | ||||||
|     $xdg/calamares.desktop |  | ||||||
| fi |  | ||||||
|  |  | ||||||
| docs=/usr/share/doc/artix | for f in {Configuration,Troubleshooting}.pdf; do | ||||||
|  |     ln -s $docs/$f "$xdg"/$f | ||||||
| for f in {Configuration,Installation,Migration,Troubleshooting}.pdf;do |  | ||||||
|     ln -s $docs/$f $xdg/$f |  | ||||||
| done | done | ||||||
|  |  | ||||||
| if [[ -d /run/openrc ]]; then | if [[ -d /run/openrc ]]; then | ||||||
|     ln -s $docs/OpenRC.pdf $xdg/OpenRC.pdf |     ln -s $docs/OpenRC.pdf "$xdg"/OpenRC.pdf | ||||||
|  | elif [[ -d /run/runit ]]; then | ||||||
|  |     ln -s $docs/Runit.pdf "$xdg"/Runit.pdf | ||||||
| else | else | ||||||
|     ln -s $docs/Runit.pdf $xdg/Runit.pdf |     ln -s $docs/S6.pdf "$xdg"/S6.pdf | ||||||
| fi | 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 $? | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| #!/bin/bash | #!/bin/bash | ||||||
| 
 | 
 | ||||||
| . /usr/lib/rc/functions | . @libdir@/rc/functions | ||||||
| 
 | 
 | ||||||
| case "$1" in | case "$1" in | ||||||
|     start) |     start) | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| #!/bin/sh | #!/bin/sh | ||||||
| mount -t tmpfs -o size=10M,mode=0755 tmpfs /etc/pacman.d/gnupg | mount -t tmpfs -o size=10M,mode=0755 tmpfs /etc/pacman.d/gnupg | ||||||
| pacman-key --init 1>&2 | pacman-key --init 1>&2 | ||||||
| pacman-key --populate archlinux artix 1>&2 | pacman-key --populate artix 1>&2 | ||||||
| exec chpst -b pacman-init pause | 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 | ||||||
							
								
								
									
										288
									
								
								lib/util-live.sh
									
									
									
									
									
								
							
							
						
						
									
										288
									
								
								lib/util-live.sh
									
									
									
									
									
								
							| @@ -1,19 +1,15 @@ | |||||||
| #!/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 | ||||||
| @@ -22,185 +18,131 @@ kernel_cmdline(){ | |||||||
| } | } | ||||||
|  |  | ||||||
| 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_cal_mode(){ |  | ||||||
|     echo $(kernel_cmdline netinstall) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| 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="artix" |  | ||||||
|  |  | ||||||
|     [[ -z ${password} ]] && password="artix" |  | ||||||
|  |  | ||||||
|     [[ -z ${addgroups} ]] && addgroups="video,power,storage,optical,network,lp,scanner,wheel,users,audio" |  | ||||||
|  |  | ||||||
|     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 |  | ||||||
|         return 1 |  | ||||||
|     fi |     fi | ||||||
| } |     return 1 | ||||||
|  |  | ||||||
| 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 |         esac | ||||||
|     done |     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 |  | ||||||
|  |     if [[ -f "${BINDIR}"/lightdm ]];then | ||||||
|         groupadd -r autologin |         groupadd -r autologin | ||||||
|         set_lightdm_vt |         gpasswd -a "${LIVEUSER}" autologin &> /dev/null | ||||||
|         set_lightdm_greeter |         set_lightdm_greeter | ||||||
|         if $(is_valid_de); then |         if is_valid_de; then | ||||||
|                 sed -i -e "s/^.*user-session=.*/user-session=$default_desktop_file/" /etc/lightdm/lightdm.conf |             sed -e "s/^.*user-session=.*/user-session=$DEFAULT_DESKTOP_FILE/" \ | ||||||
|  |                 -e 's/^.*minimum-vt=.*/minimum-vt=7/' \ | ||||||
|  |                 -i /etc/lightdm/lightdm.conf | ||||||
|         fi |         fi | ||||||
|         if ${autologin};then |         ${AUTOLOGIN} && sed -e "s/^.*autologin-user=.*/autologin-user=${LIVEUSER}/" \ | ||||||
|             gpasswd -a ${username} autologin &> /dev/null |                 -e "s/^.*autologin-user-timeout=.*/autologin-user-timeout=0/" \ | ||||||
|             sed -i -e "s/^.*autologin-user=.*/autologin-user=${username}/" /etc/lightdm/lightdm.conf |                 -e "s/^.*pam-autologin-service=.*/pam-autologin-service=lightdm-autologin/" \ | ||||||
|             sed -i -e "s/^.*autologin-user-timeout=.*/autologin-user-timeout=0/" /etc/lightdm/lightdm.conf |                 -i /etc/lightdm/lightdm.conf | ||||||
|             sed -i -e "s/^.*pam-autologin-service=.*/pam-autologin-service=lightdm-autologin/" /etc/lightdm/lightdm.conf |     elif [[ -f "${BINDIR}"/gdm ]];then | ||||||
|         fi |  | ||||||
|     elif [[ -f /usr/bin/gdm ]];then |  | ||||||
|         configure_accountsservice "gdm" |         configure_accountsservice "gdm" | ||||||
|         if ${autologin};then |         ${AUTOLOGIN} && sed -e "s/\[daemon\]/\[daemon\]\nAutomaticLogin=${LIVEUSER}\nAutomaticLoginEnable=True/" \ | ||||||
|             sed -i -e "s/\[daemon\]/\[daemon\]\nAutomaticLogin=${username}\nAutomaticLoginEnable=True/" /etc/gdm/custom.conf |                 -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 |         fi | ||||||
|     elif [[ -f /usr/bin/sddm ]];then |         ${AUTOLOGIN} && sed -e "s|^User=.*|User=${LIVEUSER}|" \ | ||||||
|         if $(is_valid_de); then |                 -i /etc/sddm.conf | ||||||
|             sed -i -e "s|^Session=.*|Session=$default_desktop_file.desktop|" /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 |         fi | ||||||
|         if ${autologin};then |         ${AUTOLOGIN} && sed -e "s/^.*autologin=.*/autologin=${LIVEUSER}/" \ | ||||||
|             sed -i -e "s|^User=.*|User=${username}|" /etc/sddm.conf |                 -i /etc/lxdm/lxdm.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(){ |  | ||||||
|     echo $(perl -e 'print crypt($ARGV[0], "password")' ${password}) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| configure_user(){ |  | ||||||
|     # set up user and password |  | ||||||
|     if [[ -n ${password} ]];then |  | ||||||
|             useradd -m -G ${addgroups} -p $(gen_pw) -s /bin/bash ${username} |  | ||||||
|     else |  | ||||||
|             useradd -m -G ${addgroups} -s /bin/bash ${username} |  | ||||||
|     fi |     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 | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -212,12 +154,13 @@ write_x11_config(){ | |||||||
|     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 | ||||||
| @@ -225,57 +168,92 @@ write_x11_config(){ | |||||||
|  |  | ||||||
|     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 " MatchIsKeyboard \"on\"" >> "$XORGKBLAYOUT" |     echo " Identifier \"system-keyboard\"" | ||||||
|     echo " Option \"XkbLayout\" \"$X11_LAYOUT\"" >> "$XORGKBLAYOUT" |     echo " MatchIsKeyboard \"on\"" | ||||||
|     echo " Option \"XkbModel\" \"$X11_MODEL\"" >> "$XORGKBLAYOUT" |     echo " Option \"XkbLayout\" \"$X11_LAYOUT\"" | ||||||
|     echo " Option \"XkbVariant\" \"$X11_VARIANT\"" >> "$XORGKBLAYOUT" |     echo " Option \"XkbModel\" \"$X11_MODEL\"" | ||||||
|     echo " Option \"XkbOptions\" \"$X11_OPTIONS\"" >> "$XORGKBLAYOUT" |     echo " Option \"XkbVariant\" \"$X11_VARIANT\"" | ||||||
|     echo "EndSection" >> "$XORGKBLAYOUT" |     echo " Option \"XkbOptions\" \"$X11_OPTIONS\"" | ||||||
|  |     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" | ||||||
|  |     } >> "${LOGFILE}" | ||||||
| } | } | ||||||
|  |  | ||||||
| configure_swap(){ | configure_swap(){ | ||||||
|     local swapdev="$(fdisk -l 2>/dev/null | grep swap | cut -d' ' -f1)" |     local swapdev | ||||||
|  |     swapdev="$(fdisk -l 2>/dev/null | grep swap | cut -d' ' -f1)" | ||||||
|     if [ -e "${swapdev}" ]; then |     if [ -e "${swapdev}" ]; then | ||||||
|         swapon ${swapdev} |         swapon "${swapdev}" | ||||||
|  |     fi | ||||||
|  |     echo "Activated swap and added to fstab" >> "${LOGFILE}" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | configure_branding(){ | ||||||
|  |     if [[ -f "${BINDIR}"/neofetch ]]; then | ||||||
|  |         neofetch >| /etc/issue | ||||||
|  |         echo "Configured branding" >> "${LOGFILE}" | ||||||
|     fi |     fi | ||||||
| } | } | ||||||
|  |  | ||||||
| configure_user_root(){ | configure_user(){ | ||||||
|     # set up root password |     echo "root:${PASSWORD}" | chroot / chpasswd | ||||||
|     echo "root:${password}" | chroot $1 chpasswd |  | ||||||
|     cp /etc/skel/.{bash_profile,bashrc,bash_logout} /root/ |     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