forked from artix/alpm-hooks
		
	Compare commits
	
		
			23 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| c9518dae35 | |||
| 51cf1104bd | |||
| 89b170310d | |||
| 4937e1ee11 | |||
| b6e6922998 | |||
| 48b9a2a9ec | |||
| e14878b49c | |||
| 31f3dda786 | |||
| 09ef3fc619 | |||
| 9442565f14 | |||
| c17eb2ad37 | |||
| 70445d2177 | |||
| 5d3cd01ffe | |||
| fccd8fcdd9 | |||
| 0126b86bf7 | |||
| 1487bf4089 | |||
| cf66dd76c5 | |||
| d68ed909c4 | |||
|   | 3ada9e391e | ||
| 3d142ebda7 | |||
| 7a5877342a | |||
| 6a1c2c55d9 | |||
| 09bc2d021b | 
							
								
								
									
										9
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								Makefile
									
									
									
									
									
								
							| @@ -2,6 +2,7 @@ PREFIX ?= /usr | |||||||
| ALPMDIR = $(PREFIX)/share/libalpm | ALPMDIR = $(PREFIX)/share/libalpm | ||||||
| SCRIPTSDIR = $(ALPMDIR)/scripts | SCRIPTSDIR = $(ALPMDIR)/scripts | ||||||
| HOOKSDIR = $(ALPMDIR)/hooks | HOOKSDIR = $(ALPMDIR)/hooks | ||||||
|  | BINDIR = $(PREFIX)/bin | ||||||
|  |  | ||||||
| OPENRCSCRIPTS = $(wildcard openrc/scripts/*) | OPENRCSCRIPTS = $(wildcard openrc/scripts/*) | ||||||
| OPENRCHOOKS = $(wildcard openrc/hooks/*) | OPENRCHOOKS = $(wildcard openrc/hooks/*) | ||||||
| @@ -37,6 +38,8 @@ TMPFILESHOOKS = $(wildcard etmpfiles/hooks/*) | |||||||
|  |  | ||||||
| SYSUSERSHOOKS = $(wildcard esysusers/hooks/*) | SYSUSERSHOOKS = $(wildcard esysusers/hooks/*) | ||||||
|  |  | ||||||
|  | WRAPPER = $(wildcard wrapper/*) | ||||||
|  |  | ||||||
| DMODE = -dm0755 | DMODE = -dm0755 | ||||||
| MODE = -m0644 | MODE = -m0644 | ||||||
| EMODE = -m0755 | EMODE = -m0755 | ||||||
| @@ -105,4 +108,8 @@ install_dinit_at: install_hook_common | |||||||
| install_dinit_dbus: install_hook_common | install_dinit_dbus: install_hook_common | ||||||
| 	install $(MODE) $(DINITDBUSHOOKS) $(DESTDIR)$(HOOKSDIR) | 	install $(MODE) $(DINITDBUSHOOKS) $(DESTDIR)$(HOOKSDIR) | ||||||
|  |  | ||||||
| .PHONY: install install_base install_s6 install_openrc install_runit install_dinit | install_wrapper: | ||||||
|  | 	install $(DMODE) $(DESTDIR)$(BINDIR) | ||||||
|  | 	install $(EMODE) $(WRAPPER) $(DESTDIR)$(BINDIR) | ||||||
|  |  | ||||||
|  | .PHONY: install install_base install_s6 install_openrc install_runit install_dinit install_wrapper | ||||||
|   | |||||||
| @@ -7,5 +7,5 @@ Target = usr/lib/binfmt.d/*.conf | |||||||
| [Action] | [Action] | ||||||
| Description = Registering binary formats... | Description = Registering binary formats... | ||||||
| When = PostTransaction | When = PostTransaction | ||||||
| Exec = /usr/share/libalpm/scripts/dinit-hook binfmt | Exec = /usr/lib/artix/binfmt.sh | ||||||
| NeedsTargets | NeedsTargets | ||||||
| @@ -33,7 +33,7 @@ init_detect(){ | |||||||
| s6_init_remake(){ | s6_init_remake(){ | ||||||
|     # we need to ensure that s6-linux-init-maker is run on every machine |     # we need to ensure that s6-linux-init-maker is run on every machine | ||||||
|     rm -rf /tmp/current |     rm -rf /tmp/current | ||||||
|     s6-linux-init-maker -1 -G "/usr/bin/agetty -L -8 tty7 115200" -c /etc/s6/current /tmp/current |     s6-linux-init-maker -1 -G "/usr/bin/agetty -L -8 tty12 115200" -c /etc/s6/current /tmp/current | ||||||
|     mv /tmp/current/bin/init /tmp/current/bin/s6-init |     mv /tmp/current/bin/init /tmp/current/bin/s6-init | ||||||
|     cp -a /tmp/current/bin /usr |     cp -a /tmp/current/bin /usr | ||||||
|     rm -rf /tmp/current/{bin,scripts} |     rm -rf /tmp/current/{bin,scripts} | ||||||
|   | |||||||
| @@ -46,7 +46,6 @@ op="$1"; shift | |||||||
|  |  | ||||||
| case $op in | case $op in | ||||||
|   sysctl)   dinit_live; each_conf /usr/bin/sysctl -q -p ;; |   sysctl)   dinit_live; each_conf /usr/bin/sysctl -q -p ;; | ||||||
|   binfmt)   dinit_live; /usr/bin/dinitctl restart binfmt ;; |  | ||||||
|   dbus_reload) dinit_live; reload_dbus ;; |   dbus_reload) dinit_live; reload_dbus ;; | ||||||
|     # For use by other packages |     # For use by other packages | ||||||
|   reload)   dinit_live; /usr/bin/dinitctl reload "$@"; /usr/bin/dinitctl restart "$@" ;; |   reload)   dinit_live; /usr/bin/dinitctl reload "$@"; /usr/bin/dinitctl restart "$@" ;; | ||||||
|   | |||||||
| @@ -4,6 +4,6 @@ Operation = Upgrade | |||||||
| Target = openrc | Target = openrc | ||||||
|  |  | ||||||
| [Action] | [Action] | ||||||
| Description = Reexecuting init ... | Description = Configuring user service & reexecuting init ... | ||||||
| When = PostTransaction | When = PostTransaction | ||||||
| Exec = /usr/share/libalpm/scripts/openrc-hook reexec | Exec = /usr/share/libalpm/scripts/openrc-hook reexec | ||||||
|   | |||||||
							
								
								
									
										11
									
								
								openrc/hooks/openrc-user-install.hook
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								openrc/hooks/openrc-user-install.hook
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | |||||||
|  | [Trigger] | ||||||
|  | Type = Path | ||||||
|  | Operation = Install | ||||||
|  | Operation = Upgrade | ||||||
|  | Target = etc/user/init.d/* | ||||||
|  |  | ||||||
|  | [Action] | ||||||
|  | Description = Displaying openrc user service help ... | ||||||
|  | When = PostTransaction | ||||||
|  | Exec = /usr/share/libalpm/scripts/openrc-hook uadd | ||||||
|  | NeedsTargets | ||||||
							
								
								
									
										10
									
								
								openrc/hooks/openrc-user-remove.hook
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								openrc/hooks/openrc-user-remove.hook
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | |||||||
|  | [Trigger] | ||||||
|  | Type = Path | ||||||
|  | Operation = Remove | ||||||
|  | Target = etc/user/init.d/* | ||||||
|  |  | ||||||
|  | [Action] | ||||||
|  | Description = Displaying openrc user service help ... | ||||||
|  | When = PostTransaction | ||||||
|  | Exec = /usr/share/libalpm/scripts/openrc-hook udel | ||||||
|  | NeedsTargets | ||||||
| @@ -24,6 +24,37 @@ svc_del_help(){ | |||||||
|     svc_help |     svc_help | ||||||
| } | } | ||||||
|  |  | ||||||
|  | svc_user_help(){ | ||||||
|  |     echo "	==> Start/stop/restart a service:" | ||||||
|  |     echo "	rc-service -U <service> <start/stop/restart>" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | svc_user_add_help(){ | ||||||
|  |     echo "	==> Add a user service to runlevel:" | ||||||
|  |     echo "	rc-update -U add <service> <runlevel>" | ||||||
|  |     svc_user_help | ||||||
|  | } | ||||||
|  |  | ||||||
|  | svc_user_del_help(){ | ||||||
|  |     echo "	==> Remove a user service from runlevel:" | ||||||
|  |     echo "	rc-update -U del <service> <runlevel>" | ||||||
|  |     svc_user_help | ||||||
|  | } | ||||||
|  |  | ||||||
|  | svc_user_ln() { | ||||||
|  |     umin=$(grep "^UID_MIN" /etc/login.defs) | ||||||
|  |     umax=$(grep "^UID_MAX" /etc/login.defs) | ||||||
|  |     users=$(awk -F':' -v "min=${umin##UID_MIN}" -v "max=${umax##UID_MAX}" \ | ||||||
|  |         '{ if ( $3 >= min && $3 <= max ) print $0 }' /etc/passwd \ | ||||||
|  |             | cut -d: -f1) | ||||||
|  |  | ||||||
|  |     for u in $users; do | ||||||
|  |         if [ ! -e /etc/init.d/user.$u ]; then | ||||||
|  |             ln -sv /etc/init.d/user /etc/init.d/user.$u | ||||||
|  |         fi | ||||||
|  |     done | ||||||
|  | } | ||||||
|  |  | ||||||
| each_conf() { | each_conf() { | ||||||
|   while read -r f; do |   while read -r f; do | ||||||
|     "$@" "/$f" |     "$@" "/$f" | ||||||
| @@ -33,13 +64,15 @@ each_conf() { | |||||||
| op="$1"; shift | op="$1"; shift | ||||||
|  |  | ||||||
| case $op in | case $op in | ||||||
|   sysctl)   openrc_live; each_conf /usr/bin/sysctl -q -p ;; |   sysctl) openrc_live; each_conf /usr/bin/sysctl -q -p ;; | ||||||
|   binfmt)   openrc_live; each_conf /usr/lib/openrc/sh/binfmt.sh ;; |   binfmt) openrc_live; each_conf /usr/lib/openrc/sh/binfmt.sh ;; | ||||||
|   reexec) openrc_live; /usr/bin/openrc-shutdown -R ;; |   reexec) svc_user_ln; openrc_live; /usr/bin/openrc-shutdown -R ;; | ||||||
|     # For use by other packages |   # For use by other packages | ||||||
|   reload)        openrc_live; /usr/bin/rc-service "$@" reload ;; |   reload) openrc_live; /usr/bin/rc-service "$@" reload ;; | ||||||
|   add) svc_add_help ;; |   add) svc_add_help ;; | ||||||
|   del) svc_del_help ;; |   del) svc_del_help ;; | ||||||
|  |   uadd) svc_user_add_help ;; | ||||||
|  |   udel) svc_user_del_help ;; | ||||||
|   *) echo >&2 "  Invalid operation '$op'"; exit 1 ;; |   *) echo >&2 "  Invalid operation '$op'"; exit 1 ;; | ||||||
| esac | esac | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,11 +0,0 @@ | |||||||
| [Trigger] |  | ||||||
| Type = Path |  | ||||||
| Operation = Install |  | ||||||
| Operation = Upgrade |  | ||||||
| Target = usr/lib/binfmt.d/*.conf |  | ||||||
|  |  | ||||||
| [Action] |  | ||||||
| Description = Registering binary formats... |  | ||||||
| When = PostTransaction |  | ||||||
| Exec = /usr/share/libalpm/scripts/runit-hook binfmt |  | ||||||
| NeedsTargets |  | ||||||
| @@ -34,7 +34,6 @@ op="$1"; shift | |||||||
|  |  | ||||||
| case $op in | case $op in | ||||||
|   sysctl)   runit_live; each_conf /usr/bin/sysctl -q -p ;; |   sysctl)   runit_live; each_conf /usr/bin/sysctl -q -p ;; | ||||||
|   binfmt)   runit_live; each_conf /usr/lib/rc/sv.d/binfmt once ;; |  | ||||||
|     # For use by other packages |     # For use by other packages | ||||||
|   reload)   runit_live; /usr/bin/sv "$@" reload ;; |   reload)   runit_live; /usr/bin/sv "$@" reload ;; | ||||||
|   add)      svc_add_help ;; |   add)      svc_add_help ;; | ||||||
|   | |||||||
| @@ -1,11 +0,0 @@ | |||||||
| [Trigger] |  | ||||||
| Type = Path |  | ||||||
| Operation = Install |  | ||||||
| Operation = Upgrade |  | ||||||
| Target = usr/lib/binfmt.d/*.conf |  | ||||||
|  |  | ||||||
| [Action] |  | ||||||
| Description = Registering binary formats... |  | ||||||
| When = PostTransaction |  | ||||||
| Exec = /usr/share/libalpm/scripts/s6-rc-hook binfmt |  | ||||||
| NeedsTargets |  | ||||||
| @@ -51,7 +51,6 @@ op="$1"; shift | |||||||
|  |  | ||||||
| case $op in | case $op in | ||||||
|   sysctl)   s6_live; each_conf /usr/bin/sysctl -q -p ;; |   sysctl)   s6_live; each_conf /usr/bin/sysctl -q -p ;; | ||||||
|   binfmt)   s6_live; sh /etc/s6/sv/binfmt/shell_up ;; |  | ||||||
|   dbus_reload) s6_live; reload_dbus ;; |   dbus_reload) s6_live; reload_dbus ;; | ||||||
|     # For use by other packages |     # For use by other packages | ||||||
|   add)      svc_add_help ;; |   add)      svc_add_help ;; | ||||||
|   | |||||||
| @@ -16,7 +16,7 @@ case "$op" in | |||||||
|     udev-reload) |     udev-reload) | ||||||
|         udevd_live |         udevd_live | ||||||
|         /usr/bin/udevadm control --reload |         /usr/bin/udevadm control --reload | ||||||
|         /usr/bin/udevadm trigger |         /usr/bin/udevadm trigger -c change | ||||||
|         /usr/bin/udevadm settle |         /usr/bin/udevadm settle | ||||||
|     ;; |     ;; | ||||||
|     *) |     *) | ||||||
|   | |||||||
							
								
								
									
										86
									
								
								wrapper/artix-service
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								wrapper/artix-service
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,86 @@ | |||||||
|  | #!/bin/bash | ||||||
|  |  | ||||||
|  | cmds_openrc() { | ||||||
|  |     COMMANDS[enable]="rc-update add ${SV} default" | ||||||
|  |     COMMANDS[disable]="rc-update del ${SV} default" | ||||||
|  |     COMMANDS[start]="rc-service ${SV} start" | ||||||
|  |     COMMANDS[stop]="rc-service ${SV} stop" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | cmds_s6() { | ||||||
|  |     COMMANDS[start]="s6-rc -u change ${SV}" | ||||||
|  |     COMMANDS[stop]="s6-rc -d change ${SV}" | ||||||
|  |     COMMANDS[enable]="s6-service add default ${SV}" | ||||||
|  |     COMMANDS[disable]="s6-service del default ${SV}" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | cmds_dinit() { | ||||||
|  |     COMMANDS[start]="dinitctl start ${SV}" | ||||||
|  |     COMMANDS[stop]="dinitctl stop ${SV}" | ||||||
|  |     COMMANDS[enable]="dinitctl -o enable ${SV}" | ||||||
|  |     COMMANDS[disable]="dinitctl -o disable ${SV}" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | cmds_runit() { | ||||||
|  |     COMMANDS[start]="runsv /etc/runit/sv/${SV}" | ||||||
|  |     COMMANDS[stop]="sv stop /etc/runit/sv/${SV}" | ||||||
|  |     COMMANDS[enable]="ln -s /etc/runit/sv/${SV} /run/runit/service/" | ||||||
|  |     COMMANDS[disable]="rm /run/runit/service/${SV}" | ||||||
|  | } | ||||||
|  |  | ||||||
|  | is_live() { | ||||||
|  |     if [[ ! -d /run/openrc && "${INIT}" == "openrc" ]]; then | ||||||
|  |         echo >&2 "  Skipped: ${INIT} is not running." | ||||||
|  |         exit 0 | ||||||
|  |     elif [[ ! -d /run/s6-rc && "${INIT}" == "s6" ]]; then | ||||||
|  |         echo >&2 "  Skipped: ${INIT} is not running." | ||||||
|  |         exit 0 | ||||||
|  |     elif [[ ! -S /run/dinitctl && "${INIT}" == "dinit" ]]; then | ||||||
|  |         echo >&2 "  Skipped: ${INIT} is not running." | ||||||
|  |         exit 0 | ||||||
|  |     elif [[ ! -d /run/runit && "${INIT}" == "runit" ]]; then | ||||||
|  |         echo >&2 "  Skipped: ${INIT} is not running." | ||||||
|  |         exit 0 | ||||||
|  |     fi | ||||||
|  | } | ||||||
|  |  | ||||||
|  | detect() { | ||||||
|  |     for i in "${SUPPORTED[@]}"; do | ||||||
|  |         if [[ -f /usr/bin/"$i"-init ]]; then | ||||||
|  |             INIT="$i" | ||||||
|  |             cmds_"${INIT}" | ||||||
|  |         fi | ||||||
|  |     done | ||||||
|  | } | ||||||
|  |  | ||||||
|  | usage() { | ||||||
|  |     cat <<EOF | ||||||
|  | usage: ${0##*/} [action] [service] | ||||||
|  |  | ||||||
|  |   actions: | ||||||
|  |     enable | ||||||
|  |     disable | ||||||
|  |     start | ||||||
|  |     stop | ||||||
|  | EOF | ||||||
|  | } | ||||||
|  |  | ||||||
|  | readonly SUPPORTED=(openrc s6 dinit runit) | ||||||
|  | declare -A COMMANDS | ||||||
|  |  | ||||||
|  | INIT= | ||||||
|  | ACTION="$1" | ||||||
|  | SV="$2" | ||||||
|  |  | ||||||
|  | if [[ -z "${SV}" ]]; then | ||||||
|  |     usage; exit 1 | ||||||
|  | fi | ||||||
|  |  | ||||||
|  | detect | ||||||
|  |  | ||||||
|  | case "${ACTION}" in | ||||||
|  |     start|stop)   is_live; ${COMMANDS["${ACTION}"]} ;; | ||||||
|  |     enable|disable) ${COMMANDS["${ACTION}"]} ;; | ||||||
|  |     help) usage; exit 0 ;; | ||||||
|  |     *) usage; exit 1 ;; | ||||||
|  | esac | ||||||
		Reference in New Issue
	
	Block a user