forked from artix/alpm-hooks
		
	Compare commits
	
		
			6 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| c9518dae35 | |||
| 51cf1104bd | |||
| 89b170310d | |||
| 4937e1ee11 | |||
| b6e6922998 | |||
| 48b9a2a9ec | 
| @@ -4,6 +4,6 @@ Operation = Upgrade | ||||
| Target = openrc | ||||
|  | ||||
| [Action] | ||||
| Description = Reexecuting init ... | ||||
| Description = Configuring user service & reexecuting init ... | ||||
| When = PostTransaction | ||||
| 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_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() { | ||||
|   while read -r f; do | ||||
|     "$@" "/$f" | ||||
| @@ -33,13 +64,15 @@ each_conf() { | ||||
| op="$1"; shift | ||||
|  | ||||
| case $op in | ||||
|   sysctl)   openrc_live; each_conf /usr/bin/sysctl -q -p ;; | ||||
|   binfmt)   openrc_live; each_conf /usr/lib/openrc/sh/binfmt.sh ;; | ||||
|   reexec) openrc_live; /usr/bin/openrc-shutdown -R ;; | ||||
|     # For use by other packages | ||||
|   reload)        openrc_live; /usr/bin/rc-service "$@" reload ;; | ||||
|   sysctl) openrc_live; each_conf /usr/bin/sysctl -q -p ;; | ||||
|   binfmt) openrc_live; each_conf /usr/lib/openrc/sh/binfmt.sh ;; | ||||
|   reexec) svc_user_ln; openrc_live; /usr/bin/openrc-shutdown -R ;; | ||||
|   # For use by other packages | ||||
|   reload) openrc_live; /usr/bin/rc-service "$@" reload ;; | ||||
|   add) svc_add_help ;; | ||||
|   del) svc_del_help ;; | ||||
|   uadd) svc_user_add_help ;; | ||||
|   udel) svc_user_del_help ;; | ||||
|   *) echo >&2 "  Invalid operation '$op'"; exit 1 ;; | ||||
| esac | ||||
|  | ||||
|   | ||||
| @@ -22,8 +22,6 @@ cmds_dinit() { | ||||
| } | ||||
|  | ||||
| cmds_runit() { | ||||
|     mkdir -p /run/runit | ||||
|     ln -s /etc/runit/runsvdir/current /run/runit/service 2>/dev/null | ||||
|     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/" | ||||
| @@ -86,5 +84,3 @@ case "${ACTION}" in | ||||
|     help) usage; exit 0 ;; | ||||
|     *) usage; exit 1 ;; | ||||
| esac | ||||
|  | ||||
| [ ${INIT} == s6 ] && s6-db-reload | ||||
|   | ||||
		Reference in New Issue
	
	Block a user