1
0
forked from artix/alpm-hooks

70 Commits

Author SHA1 Message Date
89b170310d remove live check from openrc-user-hook 2025-03-08 16:51:06 +01:00
4937e1ee11 Merge pull request 'add openrc-user-hook' (#27) from openrc-user-sv into master
Reviewed-on: artix/alpm-hooks#27
2025-03-08 16:30:54 +01:00
b6e6922998 add openrc-user-hook 2025-03-08 16:28:30 +01:00
48b9a2a9ec openrc (#26)
Reviewed-on: artix/alpm-hooks#26
2025-03-06 22:44:30 +00:00
e14878b49c artix-service: use dinitctl for disable and enable ops 2024-06-03 07:42:36 +07:00
31f3dda786 openrc: readd binfmt hook 2024-05-05 19:36:55 +02:00
09ef3fc619 Merge pull request 'unify binfmt into a single implementation' (#25) from binfmt into master
Reviewed-on: artix/alpm-hooks#25
2024-05-05 17:46:14 +02:00
9442565f14 unify binfmt into a single implementation
Since binfmt now lives in artix-groups, all the inits can use the same,
simplified hook.
2024-05-05 09:50:02 -05:00
c17eb2ad37 wrapper: fix quote to run 2024-01-07 22:06:00 +01:00
70445d2177 wrapper: remove script name from help 2024-01-05 00:35:32 +01:00
5d3cd01ffe wrapper: drop printf 2024-01-04 23:31:00 +01:00
fccd8fcdd9 bash (#24)
Reviewed-on: artix/alpm-hooks#24
2024-01-04 20:08:21 +01:00
0126b86bf7 wrapper: fix runit enable/disable 2024-01-04 03:50:49 +01:00
1487bf4089 makefile: install wrapper in /bin 2024-01-02 02:52:50 +01:00
cf66dd76c5 wrapper: add artix-service 2024-01-02 02:44:31 +01:00
d68ed909c4 actually fix runit test 2023-11-10 18:50:35 +07:00
Qontinuum
3ada9e391e Fix Runit commands 2023-11-07 20:06:01 +01:00
3d142ebda7 add artix-svc wrapper 2023-11-07 17:30:58 +01:00
7a5877342a Merge pull request 's6: change early getty to tty12' (#22) from s6-early-getty into master
Reviewed-on: artix/alpm-hooks#22
2023-11-07 17:14:15 +01:00
6a1c2c55d9 s6: change early getty to tty12
Some things do actually use tty7, so tty12 is better as a backup getty.
2023-11-06 20:00:53 -06:00
09bc2d021b run udevadm trigger with -c change 2023-09-27 15:40:33 +02:00
8396101929 adopt esysusers & tmpfiles 2023-08-29 02:25:43 +02:00
1344532759 adopt etmpfiles & esysusers binaries 2023-08-18 18:46:07 +02:00
4ace40eddd udev: use separate udevadm settle call 2023-05-03 10:20:29 +02:00
6a9ac65e53 udev: update hook script; not sure this change will work with future eudev release 2023-03-03 16:17:46 +01:00
c36cea5240 base: remove suite66 support 2022-07-19 22:54:41 +02:00
57bcc7fee2 s6: remove scripts; deloyed with new s6-contrib 2022-05-24 21:33:26 +02:00
Qontinuum
da1975c606 Small changes on runit hooks (#20)
Co-authored-by: qontinuum <qontinuum@artixlinux.org>
Reviewed-on: artix/alpm-hooks#20
Co-authored-by: Qontinuum <qontinuum@artixlinux.org>
Co-committed-by: Qontinuum <qontinuum@artixlinux.org>
2022-05-22 12:51:18 +02:00
8ee6788925 s6: fix the help hook (#19)
Reviewed-on: artix/alpm-hooks#19
Co-authored-by: artoo <artoo@artixlinux.org>
Co-committed-by: artoo <artoo@artixlinux.org>
2022-04-10 21:59:06 +02:00
fda8182527 s6-db-reload refactor into case/esac 2022-04-10 13:23:24 -05:00
ca121a8621 s6-db-reload: improve print messages
Print the name of the new database and only show the suggestion about
deletion if -r isn't used.
2022-04-10 13:05:23 -05:00
c375c45283 s6-db-reload: add -h/--help argument 2022-04-10 13:05:23 -05:00
7ba882813a s6-db-reload: add -r/--remove argument
This removes all old databases.
2022-04-10 13:05:23 -05:00
f97c7d3041 s6-service: fix help 2022-04-10 18:49:53 +02:00
5090413f28 s6-db-reload: read a convfile on upgrades
This file is provided by s6-scripts. In most cases it is blank (does
nothing), but sometimes certain script updates will need special
instructions so they can write it here. The instructions are always a
one-time operation so the file is cleared afterwards.
2022-04-10 11:44:29 -05:00
315cb334f1 s6: remove s6-pre-remove.hook
Can cause less than desirable behavior and isn't truly needed.
2022-04-10 11:18:49 -05:00
b9d94c232e Merge pull request 's6' (#16) from s6 into master
Reviewed-on: artix/alpm-hooks#16
2022-04-10 16:55:53 +02:00
d0f03bc2c7 s6-db-reload: adopt new cmd name; use nanosecs 2022-04-10 15:46:47 +02:00
a71fa724f6 s6-service: drop echo 2022-04-10 14:46:02 +02:00
0bf78e4885 s6: rename scripts 2022-04-10 13:33:10 +02:00
c9a6659ec8 s6-rc-db-update: fix new line 2022-04-10 13:20:30 +02:00
3d909a640a s6-rc-db-update: kill echo 2022-04-10 13:18:18 +02:00
42a9f1a5ba s6-rc-bundle-update: remove s6-db-reload usage
The hook should call this at the end.
2022-04-09 17:17:17 -05:00
2b823adf5c s6-rc-bundle-update: rewrite and undeprecate
This is tool is now updated for touching/deleting files as per s6-rc.
2022-04-08 14:38:09 -05:00
0d93c640ec s6-rc-bundle-update: improve deprecation message
s6-db-reload is going to be the new way to handle this.
2022-01-24 10:05:49 -06:00
48aee2b67d s6-rc-bundle-update: print deprecation message
Instead of using this tool, users should use the new way of touching
files in a contents.d directory. Print a deprecation warning anytime
someone uses this.
2022-01-23 19:28:38 -06:00
f47aa4a061 s6-rc-db-update-hook: make saving bundles optional
This hook has some complicated logic for preserving bundle contents in
live bundles (i.e a bundle added by s6-rc-bundle) after a database
update. It works OK, but this interface is being moved away from and
instead users should touch files in the appropriate contents.d
directory. Because of how the bundle preservation logic in this hook
works, it would lead to cases where removing a file in contents.d and
then updating the database would preserve the service in the bundle
(despite the user's obvious intention to remove the service from the
bundle). This is not really feasible to fix. Instead,
s6-rc-db-update-hook will read /etc/s6/config/s6-rc-db-update.conf. If
it has a single line containing "true" in it (this will be the default
for now in s6-base in order to not break things), then the bundle
preservation logic is still executed. A user can easily turn this off by
simply changing it to be false (this will be the default sometime in the
future).
2022-01-23 19:21:39 -06:00
8f970e6b6a Revert live alpm hook commits
It was decided that this logic would be better served in the
live-services source. This reverts the previous 3 commits completely.
2022-01-20 19:37:57 -06:00
10f0b56b79 live: add to makefile 2022-01-20 16:43:19 -06:00
a8a445f2e6 liveservices-hook: Add 66-specific setup
Signed-off-by: strajder <strajder@artixlinux.org>
2022-01-20 23:30:09 +01:00
bc2867b1cd add alpm-hook for live services
Only s6 and suite66 actually need to use this.
2022-01-20 16:20:49 -06:00
29cd296aa4 dinit: make it possible to install dinit in conjunction with openrc, etc. 2021-11-13 08:57:14 +07:00
185c4b2e51 dinit: fix dinit hookscripts 2021-11-04 21:12:20 +07:00
d2362e98e5 fix dinit hook places 2021-11-04 18:29:14 +07:00
4e4451be73 Merge pull request 'dinit: initial support' (#11) from konimex/alpm-hooks:master into master
Reviewed-on: artix/alpm-hooks#11
2021-11-04 12:20:38 +01:00
948388bb18 dinit: initial support 2021-11-04 14:30:35 +07:00
a2164ac051 s6-rc-db-update-hook: rename usersv to adminsv
Thinking about it some more, usersv is actually a bad name. That implies
local users on the machine which is not correct. These directories are
for adminstrators and are owned by root. Instead, call them adminsv
which makes more sense.
2021-09-21 09:38:48 -05:00
32cfa84a93 s6-rc-db-update-hook: rename to fallbacksv
This name should make it clearer that this directory is only ever used
as an emergency fallback. Alter the printed messages a little bit as
well.
2021-09-20 14:33:01 -05:00
27263a58e8 s6-rc-hook: fix service shutdown behavior
It turns out that old logic caused all services and bundles to always
shutdown. The s6-rc -a list grep always returns some nonzero string.
Thus, the conditional is always true and we always try to shutdown
anything that's removed. This has the side effect of causing any moved
bundles to automatically shutdown as well which is never desirable (only
services that go away for good should shut down). Instead of using -n,
we should check for ! $active which is equivalent to checking if $active
= "". This is what is actually returned by that grep if the sv name is
not in the s6-rc -a list.
2021-09-19 22:10:49 -05:00
09bcac3bbb s6-rc-db-update-hook: support custom user sv path
Finally got around to working on this. Some users in #artix and #s6
correctly pointed out that Artix's s6 implementation is heavily
dependent on s6-rc-bundle and is not very friendly about letting users
edit and make their own services. Specifically, the default bundle and
its contents are commonly overwritten on every s6-scripts update. This
adds some groundwork to splitting the s6-rc database compilation into
multiple directories. ${USERSVPATH} is the path for custom user service
files. The default bundle will live here along with anything else not
installed by the user. ${BACKUPSVPATH} is strictly for emergency usage
when the compilation fails. These are not to be altered by users.
2021-09-19 20:56:11 -05:00
c7db8b46ab s6-rc-update-hook: remove tabs
A couple of tabs snuck in here. Replace them with spaces. Also make that
printf one line (it's not that long).
2021-09-19 17:47:30 -05:00
54b6a8d842 makefile: don't install empty dir for sysusers & tmpfiles 2021-08-29 01:01:45 +02:00
41274292e4 udev: remove commented line 2021-07-24 19:29:53 +02:00
10c5644890 Merge pull request 's6-rc-db-update-hook and s6-rc-bundle-update improvements' (#10) from s6-rc-db-update-posix into master
Reviewed-on: artix/alpm-hooks#10
2021-07-18 20:05:52 +02:00
022c5887a5 s6-rc-bundle-update: make error messages prettier
Just add some single quotes to make things nicer. The main change is the
extra if that ensures that there isn't an extra space at the beginning
of CONTENTS.
2021-07-18 12:15:07 -05:00
capezotte
b74274ec84 s6-rc-db-update: optimize the main update loop
s6-rc-bundle-update must do at least one loop to update an existing
bundle. In the main update loop, s6-rc-bundle-update is called several
times which means we do several loops here. However, s6-rc-bundle-update
is designed to be able to handle any arbitrary number of arguments as
needed. In this case, just call it once after we finishing populating
new_contents. This should save a massive amount of time when executing
the script.
2021-07-18 10:28:03 -05:00
9142373219 s6-rc-db-update-hook: reindex loop variables
Start from "i" instead of "j" since it's more natural. The original "i"
got removed at some point during the rewrite. Just shift all the
variables up one letter basically.
2021-07-17 22:28:17 -05:00
capezotte
88147c78b3 s6-rc-db-update-hook: remove arrays and make posix 2021-07-17 22:28:08 -05:00
a88c0c6036 s6-rc-db-update-hook: make database update atomic
Technically, this has been wrong for a while (no bad side effects seem
to have been reported at least). The original version of this script did
do atomic updates but it got lost in a recent-ish rewrite. According to
skarnet documentation, the updated symlink to the newly compiled
database should be made atomically. The standard ln utilty does not do
that and actually forbids this. We could use s6-ln (it is packaged), but
artix is a GNU distro so it's better not to incur any additional
dependencies. The correct way to fix this is to simply use && mv -f as
per the skarnet documentation.
2021-07-17 20:16:24 -05:00
720d72ac7d s6-rc-db-update-hook: quote ${SVDIRS}
Shellcheck complained about this one and it should be okay to quote.
Note that we do want word splitting for $new_contents though so ignore
shellcheck there.
2021-07-17 20:14:43 -05:00
39 changed files with 291 additions and 495 deletions

View File

@@ -2,6 +2,7 @@ PREFIX ?= /usr
ALPMDIR = $(PREFIX)/share/libalpm
SCRIPTSDIR = $(ALPMDIR)/scripts
HOOKSDIR = $(ALPMDIR)/hooks
BINDIR = $(PREFIX)/bin
OPENRCSCRIPTS = $(wildcard openrc/scripts/*)
OPENRCHOOKS = $(wildcard openrc/hooks/*)
@@ -16,18 +17,16 @@ RUNITHOOKS = $(wildcard runit/hooks/*)
S6SCRIPTS = $(wildcard s6/scripts/*)
S6HOOKS = $(wildcard s6/hooks/*)
S6EXTRA = s6/s6-rc-bundle-update
S6CRONIEHOOKS = $(wildcard s6/cronie-hooks/*)
S6DBUSHOOKS = $(wildcard s6/dbus-hooks/*)
S6ATDHOOKS = $(wildcard s6/atd-hooks/*)
SUITE66SCRIPTS = $(wildcard suite66/scripts/*)
SUITE66HOOKS = $(wildcard suite66/hooks/*)
DINITSCRIPTS = $(wildcard dinit/scripts/*)
DINITHOOKS = $(wildcard dinit/hooks/*)
SUITE66CRONIEHOOKS = $(wildcard suite66/cronie-hooks/*)
SUITE66DBUSHOOKS = $(wildcard suite66/dbus-hooks/*)
SUITE66ATDHOOKS = $(wildcard suite66/atd-hooks/*)
DINITCRONIEHOOKS = $(wildcard dinit/cronie-hooks/*)
DINITDBUSHOOKS = $(wildcard dinit/dbus-hooks/*)
DINITATDHOOKS = $(wildcard dinit/atd-hooks/*)
UDEVSCRIPTS = $(wildcard udev/scripts/*)
UDEVHOOKS = $(wildcard udev/hooks/*)
@@ -35,9 +34,11 @@ UDEVHOOKS = $(wildcard udev/hooks/*)
BASESCRIPTS = $(wildcard base/scripts/*)
BASEHOOKS = $(wildcard base/hooks/*)
TMPFILESHOOKS = $(wildcard tmpfiles/hooks/*)
TMPFILESHOOKS = $(wildcard etmpfiles/hooks/*)
SYSUSERSHOOKS = $(wildcard sysusers/hooks/*)
SYSUSERSHOOKS = $(wildcard esysusers/hooks/*)
WRAPPER = $(wildcard wrapper/*)
DMODE = -dm0755
MODE = -m0644
@@ -50,10 +51,6 @@ install_common:
install_hook_common:
install $(DMODE) $(DESTDIR)$(HOOKSDIR)
install_s6_extra:
install $(DMODE) $(DESTDIR)$(PREFIX)/bin
install $(EMODE) $(S6EXTRA) $(DESTDIR)$(PREFIX)/bin
install_base: install_common
install $(EMODE) $(BASESCRIPTS) $(DESTDIR)$(SCRIPTSDIR)
install $(MODE) $(BASEHOOKS) $(DESTDIR)$(HOOKSDIR)
@@ -62,10 +59,10 @@ install_udev: install_common
install $(EMODE) $(UDEVSCRIPTS) $(DESTDIR)$(SCRIPTSDIR)
install $(MODE) $(UDEVHOOKS) $(DESTDIR)$(HOOKSDIR)
install_tmpfiles: install_common
install_tmpfiles: install_hook_common
install $(MODE) $(TMPFILESHOOKS) $(DESTDIR)$(HOOKSDIR)
install_sysusers: install_common
install_sysusers: install_hook_common
install $(MODE) $(SYSUSERSHOOKS) $(DESTDIR)$(HOOKSDIR)
install_openrc: install_common
@@ -76,13 +73,13 @@ install_runit: install_common
install $(EMODE) $(RUNITSCRIPTS) $(DESTDIR)$(SCRIPTSDIR)
install $(MODE) $(RUNITHOOKS) $(DESTDIR)$(HOOKSDIR)
install_s6: install_common install_s6_extra
install_s6: install_common
install $(EMODE) $(S6SCRIPTS) $(DESTDIR)$(SCRIPTSDIR)
install $(MODE) $(S6HOOKS) $(DESTDIR)$(HOOKSDIR)
install_suite66: install_common
install $(EMODE) $(SUITE66SCRIPTS) $(DESTDIR)$(SCRIPTSDIR)
install $(MODE) $(SUITE66HOOKS) $(DESTDIR)$(HOOKSDIR)
install_dinit: install_common
install $(EMODE) $(DINITSCRIPTS) $(DESTDIR)$(SCRIPTSDIR)
install $(MODE) $(DINITHOOKS) $(DESTDIR)$(HOOKSDIR)
install_openrc_cronie: install_hook_common
install $(MODE) $(OPENRCCRONIEHOOKS) $(DESTDIR)$(HOOKSDIR)
@@ -102,13 +99,17 @@ install_s6_at: install_hook_common
install_s6_dbus: install_hook_common
install $(MODE) $(S6DBUSHOOKS) $(DESTDIR)$(HOOKSDIR)
install_suite66_cronie: install_hook_common
install $(MODE) $(SUITE66CRONIEHOOKS) $(DESTDIR)$(HOOKSDIR)
install_dinit_cronie: install_hook_common
install $(MODE) $(DINITCRONIEHOOKS) $(DESTDIR)$(HOOKSDIR)
install_suite66_dbus: install_hook_common
install $(MODE) $(SUITE66DBUSHOOKS) $(DESTDIR)$(HOOKSDIR)
install_dinit_at: install_hook_common
install $(MODE) $(DINITATDHOOKS) $(DESTDIR)$(HOOKSDIR)
install_suite66_at: install_hook_common
install $(MODE) $(SUITE66ATDHOOKS) $(DESTDIR)$(HOOKSDIR)
install_dinit_dbus: install_hook_common
install $(MODE) $(DINITDBUSHOOKS) $(DESTDIR)$(HOOKSDIR)
.PHONY: install install_base install_s6 install_openrc install_runit install_suite66
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

View File

@@ -7,5 +7,5 @@ Target = usr/lib/binfmt.d/*.conf
[Action]
Description = Registering binary formats...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-hook binfmt
Exec = /usr/lib/artix/binfmt.sh
NeedsTargets

View File

@@ -5,7 +5,7 @@ Type = Path
Target = usr/bin/openrc-init
Target = usr/bin/runit-init
Target = usr/bin/s6-init
Target = usr/bin/suite66-init
Target = usr/bin/dinit-init
[Action]
Description = Setting init symlink ...

View File

@@ -11,7 +11,7 @@ init_conf(){
}
init_detect(){
artix_inits="openrc-init runit-init s6-init suite66-init"
artix_inits="openrc-init runit-init s6-init dinit-init"
for supported in ${artix_inits}; do
bin=/usr/bin/"$supported"
if [ -f "$bin" ];then
@@ -33,7 +33,7 @@ init_detect(){
s6_init_remake(){
# we need to ensure that s6-linux-init-maker is run on every machine
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
cp -a /tmp/current/bin /usr
rm -rf /tmp/current/{bin,scripts}

View File

@@ -6,4 +6,4 @@ Target = glibc
[Action]
Description = Restarting atd for libc upgrade...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-hook longrun_restart atd
Exec = /usr/share/libalpm/scripts/dinit-hook restart atd

View File

@@ -6,4 +6,4 @@ Target = glibc
[Action]
Description = Restarting cronie for libc upgrade...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-hook longrun_restart cronie
Exec = /usr/share/libalpm/scripts/dinit-hook restart cronie

View File

@@ -10,4 +10,4 @@ Target = usr/share/dbus-1/system-services/*.service
[Action]
Description = Reloading system bus configuration...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-hook dbus_reload
Exec = /usr/share/libalpm/scripts/dinit-hook dbus_reload

View File

@@ -8,5 +8,5 @@ Target = usr/lib/sysctl.d/*.conf
[Action]
Description = Applying kernel sysctl settings...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-hook sysctl
Exec = /usr/share/libalpm/scripts/dinit-hook sysctl
NeedsTargets

View File

@@ -0,0 +1,11 @@
[Trigger]
Type = Path
Operation = Install
Operation = Upgrade
Target = etc/dinit.d/*
[Action]
Description = Displaying dinit service help ...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/dinit-hook add
NeedsTargets

View File

@@ -0,0 +1,10 @@
[Trigger]
Type = Path
Operation = Remove
Target = etc/dunit.d/*
[Action]
Description = Displaying dinit service help ...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/dinit-hook del
NeedsTargets

58
dinit/scripts/dinit-hook Normal file
View File

@@ -0,0 +1,58 @@
#!/bin/sh -e
dinit_live() {
if [ ! -S /run/dinitctl ]; then
echo >&2 " Skipped: Current root is not booted."
exit 0
fi
}
svc_help(){
echo " ==> Start/stop/restart a service:"
echo " dinitctl <start/stop/restart> <service>"
}
svc_add_help(){
echo " ==> Add a service:"
echo " dinitctl enable <service>"
svc_help
}
svc_del_help(){
echo " ==> Remove a service:"
echo " dinitctl disable <service>"
svc_help
}
each_conf() {
while read -r f; do
"$@" "/$f"
done
}
reload_dbus() {
dbus-send --print-reply --system --type=method_call \
--dest=org.freedesktop.DBus \
/ org.freedesktop.DBus.ReloadConfig > /dev/null
}
restart_service() {
if dinitctl list | grep -qF "[[+] ] $1"; then
dinitctl restart "$1"
fi
}
op="$1"; shift
case $op in
sysctl) dinit_live; each_conf /usr/bin/sysctl -q -p ;;
dbus_reload) dinit_live; reload_dbus ;;
# For use by other packages
reload) dinit_live; /usr/bin/dinitctl reload "$@"; /usr/bin/dinitctl restart "$@" ;;
restart) dinit_live; restart_service "$1" ;;
add) svc_add_help ;;
del) svc_del_help ;;
*) echo >&2 " Invalid operation '$op'"; exit 1 ;;
esac
exit 0

View File

@@ -7,4 +7,4 @@ Target = usr/lib/sysusers.d/*.conf
[Action]
Description = Creating system user accounts...
When = PostTransaction
Exec = /usr/bin/sysusers
Exec = /usr/bin/esysusers

View File

@@ -7,4 +7,4 @@ Target = usr/lib/tmpfiles.d/*.conf
[Action]
Description = Creating temporary files...
When = PostTransaction
Exec = /usr/bin/tmpfiles --create
Exec = /usr/bin/etmpfiles --create

View File

@@ -0,0 +1,11 @@
[Trigger]
Type = Path
Operation = Install
Operation = Upgrade
Target = etc/user/init.d/*
[Action]
Description = Configuring openrc user ...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/openrc-user-hook create
NeedsTargets

View File

@@ -33,11 +33,11 @@ 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 ;;
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 ;;
# For use by other packages
reload) openrc_live; /usr/bin/rc-service "$@" reload ;;
add) svc_add_help ;;
del) svc_del_help ;;
*) echo >&2 " Invalid operation '$op'"; exit 1 ;;

View File

@@ -0,0 +1,50 @@
#!/bin/sh -e
openrc_live() {
if [ ! -f /run/openrc/softlevel ]; then
echo >&2 " Skipped: Current root is not booted."
exit 0
fi
}
svc_help(){
echo " ==> Start/stop/restart a service:"
echo " rc-service -U <service> <start/stop/restart>"
}
svc_add_help(){
echo " ==> Add a user service to runlevel:"
echo " rc-update -U add <service> <runlevel>"
svc_help
}
svc_del_help(){
echo " ==> Remove a user service from runlevel:"
echo " rc-update -U del <service> <runlevel>"
svc_help
}
create_user_symlinks() {
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
}
op="$1"; shift
case $op in
create) create_user_symlinks ;;
add) svc_add_help ;;
del) svc_del_help ;;
*) echo >&2 " Invalid operation '$op'"; exit 1 ;;
esac
exit 0

View File

@@ -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

View File

@@ -1,7 +1,6 @@
[Trigger]
Type = Path
Operation = Install
Operation = Upgrade
Target = etc/runit/sv/*
[Action]

View File

@@ -14,13 +14,13 @@ svc_help(){
svc_add_help(){
echo " ==> Add a service:"
echo " ln -s /etc/runit/sv/<service> /run/runit/service/"
echo " ln -s ../../sv/<service> /run/runit/service/"
svc_help
}
svc_del_help(){
echo " ==> Remove a service:"
echo " rm /run/runit/service/<service>"
echo " unlink /run/runit/service/<service>"
svc_help
}
@@ -34,7 +34,6 @@ op="$1"; shift
case $op in
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
reload) runit_live; /usr/bin/sv "$@" reload ;;
add) svc_add_help ;;

View File

@@ -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

View File

@@ -1,10 +0,0 @@
[Trigger]
Type = Path
Operation = Remove
Target = etc/s6/sv/*
[Action]
Description = Shutting down services ...
When = PreTransaction
Exec = /usr/share/libalpm/scripts/s6-rc-hook shutdown_sv
NeedsTargets

View File

@@ -8,4 +8,4 @@ Target = etc/s6/sv/*
[Action]
Description = Updating s6-rc database...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/s6-rc-db-update-hook
Exec = /usr/bin/s6-db-reload

View File

@@ -1,166 +0,0 @@
#!/bin/sh
# {{{ functions
db_action() {
s6-rc-db -c "${DATABASE}" "$@"
}
bundle_action() {
s6-rc-bundle -c "${DATABASE}" "$@"
}
db_err_msg() {
echo "${CMD_UPD}: fatal: unable to take lock on ${DATABASE} Permission denied"
exit 1
}
bundle_err_msg() {
echo "${BUNDLE} is not an existing bundle. Create it with ${CMD}."
exit 1
}
bundle_entry_err_msg() {
name="$1"
echo "$name does not exist in bundle ${BUNDLE}!"
exit 1
}
bundle_add_err_msg() {
echo "Error when trying to add ${CONTENTS}!"
}
cmd_help() {
echo "${CMD_UPD} help"
echo "${CMD_UPD} add bundlename contents..."
echo "${CMD_UPD} delete bundlename contents..."
echo "${CMD_UPD} list bundlename"
}
bundle_action_check() {
pos="$1"
num="$2"
if [ "$pos" -lt "$num" ]; then
echo "${HELP_MSG}"
exit 1
fi
isbundle=$(db_action type "${BUNDLE}" 2> /dev/null)
if [ "$?" = 111 ]; then
db_err_msg
fi
if [ "$isbundle" != "bundle" ]; then
bundle_err_msg
fi
}
bundle_to_backup() {
backup=$(db_action contents "${BUNDLE}")
for entry in ${CONTENTS}; do
isbundle=$(db_action type "$entry" 2> /dev/null)
entrycontents=$entry
if [ "$isbundle" = "bundle" ]; then
entrycontents=$(db_action contents "$entry")
fi
for srv in $entrycontents; do
if ! echo $backup | grep -w "$srv" > /dev/null; then
bundle_entry_err_msg "$entry"
else
oldupdated=""
for oldsrv in $backup; do
if [ "$oldsrv" != "$srv" ]; then
oldupdated="${oldupdated} $oldsrv"
fi
done
backup=$oldupdated
fi
done
done
echo "$backup"
}
cmd_add() {
pos="$1"
bundle_action_check "$pos" 3
old="$(db_action contents "${BUNDLE}")"
bundle_action delete "${BUNDLE}"
if ! bundle_action add "${BUNDLE}" $old ${CONTENTS}; then
bundle_add_err_msg
bundle_action add "${BUNDLE}" $old
fi
}
cmd_delete() {
pos="$1"
bundle_action_check "$pos" 3
old="$(bundle_to_backup)"
if [ "$?" = 1 ]; then
echo $old
exit 1
fi
bundle_action delete "${BUNDLE}"
bundle_action add "${BUNDLE}" $old
}
cmd_list() {
pos="$1"
bundle_action_check "$pos" 2
db_action contents "${BUNDLE}"
}
# }}}
BUNDLE=""
COMMAND=""
CONTENTS=""
DATABASE="/run/s6-rc/compiled"
CMD="s6-rc-bundle"
CMD_UPD="${CMD}-update"
HELP_MSG="${CMD_UPD}: usage: ${CMD_UPD} [ -c compiled ] command... (use ${CMD_UPD} help for more information)"
c_arg=false
for arg in "$@"; do
if [ "$c_arg" = true ]; then
DATABASE=$arg
c_arg=false
continue
fi
if [ "$arg" = "-c" ]; then
c_arg=true
continue
fi
if [ "${COMMAND}" = "" ]; then
COMMAND=$arg
continue
fi
if [ "${BUNDLE}" = "" ]; then
BUNDLE=$arg
continue
fi
CONTENTS="${CONTENTS} $arg"
done
case "${COMMAND}" in
help) cmd_help ;;
add) cmd_add "$#" ;;
delete) cmd_delete "$#" ;;
list) cmd_list "$#" ;;
*) echo "${HELP_MSG}" ;;
esac

View File

@@ -1,122 +0,0 @@
#!/bin/bash
# {{{ functions
db_action() {
s6-rc-db -c "${DBPATH}" "$@"
}
a_newbundle() {
for j in $new_bundles; do
if [ "$j" = "$1" ]; then
return 0
fi
done
return 1
}
service_exists() {
for k in $all_services; do
if [ "$k" = "$1" ]; then
return 0
fi
done
return 1
}
in_newbundle() {
bundle_contents=$(db_action contents "$1")
for l in $bundle_contents; do
if [ "$l" = "$2" ]; then
return 0
fi
done
return 1
}
# }}}
# main
RCPATH='/etc/s6/rc'
DBPATH="${RCPATH}/compiled"
SVPATH='/etc/s6/sv'
SVDIRS='/run/s6-rc/servicedirs'
TIMESTAMP=$(date +%s)
if [ -e "${DBPATH}" ]; then
old_bundles="$(db_action list bundles)"
len=0
for bundle in $old_bundles; do
contents[$len]=$(db_action contents "$bundle")
len=$(( len + 1 ))
done
fi
if ! s6-rc-compile "${DBPATH}"-"${TIMESTAMP}" "${SVPATH}"; then
echo "Error compiling database."
echo "Please double check the ${SVPATH} directories. Exiting."
exit 1
fi
if [ -e "/run/s6-rc" ]; then
for dir in ${SVDIRS}/*; do
if [ -e "${dir}/down" ]; then
s6-svc -x "${dir}"
fi
done
s6-rc-update "${DBPATH}"-"${TIMESTAMP}"
fi
if [ -d "${DBPATH}" ]; then
ln -sf "${DBPATH}"-"${TIMESTAMP}" "${DBPATH}"/compiled
mv -f "${DBPATH}"/compiled "${RCPATH}"
else
ln -sf "${DBPATH}"-"${TIMESTAMP}" "${DBPATH}"
fi
new_bundles=$(db_action list bundles)
all_services=$(db_action list all)
if [ -n "$old_bundles" ]; then
len=0
for m in $old_bundles; do
old_contents=${contents[$len]}
a_newbundle "$m"
ret=$?
for n in $old_contents; do
service_exists "$n"
ret2=$?
if [ $ret -eq 1 ]; then
if [ $ret2 -eq 0 ]; then
new_contents="$new_contents $n"
fi
else
if [ $ret2 -eq 0 ]; then
in_newbundle "$m" "$n"
ret3=$?
if [ $ret3 -eq 1 ]; then
s6-rc-bundle-update -c "${DBPATH}" add "$m" "$n"
fi
fi
fi
done
if [ -n "$new_contents" ]; then
s6-rc-bundle -c "${DBPATH}" add "$m" $new_contents
fi
new_contents=""
len=$(( len + 1 ))
done
fi
echo "==> Switched to a new database."
echo " Remove any old unwanted/unneeded database directories in ${RCPATH}."

View File

@@ -10,17 +10,19 @@ s6_live() {
svc_help(){
echo " ==> Start/stop a service:"
echo " s6-rc -u/-d change <service>"
echo " ==> Recompile the service database:"
echo " s6-db-reload <args>"
}
svc_add_help(){
echo " ==> Add a service:"
echo " s6-rc-bundle-update add default <service>"
echo " s6-service add default <service>"
svc_help
}
svc_del_help(){
echo " ==> Remove a service:"
echo " s6-rc-bundle-update delete default <service>"
echo " s6-service delete default <service>"
svc_help
}
@@ -30,18 +32,6 @@ reload_dbus() {
/ org.freedesktop.DBus.ReloadConfig > /dev/null
}
shutdown_service() {
while read -r dir; do
if [ -d "$dir" ] && [ "$dir" != "etc/s6/sv/" ]; then
sv=$(basename "$dir")
active=$(s6-rc -a list | grep -Fx "$sv" || true)
if [ -n $active ]; then
s6-rc -d change "$sv"
fi
fi
done
}
restart_service() {
if [ -e /run/s6-rc/servicedirs/"$1" ]; then
s6-svc -r /run/s6-rc/servicedirs/"$1"
@@ -61,13 +51,11 @@ op="$1"; shift
case $op in
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 ;;
# For use by other packages
add) svc_add_help ;;
del) svc_del_help ;;
longrun_restart) s6_live; restart_service "$1" ;;
shutdown_sv) s6_live; shutdown_service ;;
*) echo >&2 " Invalid operation '$op'"; exit 1 ;;
esac

View File

@@ -1,11 +0,0 @@
[Trigger]
Type = Path
Operation = Install
Operation = Upgrade
Target = etc/66/service/*
[Action]
Description = Displaying 66 service help ...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-hook add
NeedsTargets

View File

@@ -1,10 +0,0 @@
[Trigger]
Type = Path
Operation = Remove
Target = etc/66/service/*
[Action]
Description = Displaying 66 service help ...
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-hook del
NeedsTargets

View File

@@ -1,10 +0,0 @@
[Trigger]
Operation = Upgrade
Type = Package
Target = suite66-scripts
Target = 66
[Action]
Description = Updating boot tree module
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-bootmodule

View File

@@ -1,10 +0,0 @@
[Trigger]
Operation = Install
Type = Package
Target = suite66-base
Target = 66
[Action]
Description = Creating initial boot and default tree
When = PostTransaction
Exec = /usr/share/libalpm/scripts/66-postinstall

View File

@@ -1,2 +0,0 @@
#!/usr/bin/sh
66-enable -t boot -F boot@system

View File

@@ -1,54 +0,0 @@
#!/bin/sh -e
suite66_live() {
if [ ! -d /run/dbus ]; then
echo >&2 " Skipped: 66 is not running."
exit 0
fi
}
svc_help(){
echo " ==> Start/stop a service:"
echo " 66-start <service>"
echo " 66-stop <service>"
}
svc_add_help(){
echo " ==> Add a service:"
echo " 66-enable <service>"
svc_help
}
svc_del_help(){
echo " ==> Remove a service:"
echo " 66-disable <service>"
svc_help
}
reload_dbus() {
dbus-send --print-reply --system --type=method_call \
--dest=org.freedesktop.DBus \
/ org.freedesktop.DBus.ReloadConfig > /dev/null
}
each_conf() {
while read -r f; do
"$@" "/$f"
done
}
op="$1"; shift
sv="$2"
case $op in
sysctl) suite66_live; each_conf /usr/bin/sysctl -q -p ;;
binfmt) suite66_live; /etc/66/script/binfmt.sh ;;
dbus_reload) suite66_live; reload_dbus ;;
# For use by other packages
add) svc_add_help ;;
del) svc_del_help ;;
longrun_restart) suite66_live; 66-svctl -r "$1" ;;
*) echo >&2 " Invalid operation '$op'"; exit 1 ;;
esac
exit 0

View File

@@ -1,9 +0,0 @@
#!/usr/bin/sh
if [ ! -d /var/lib/66/system/boot ]; then
66-tree -n boot
66-enable -t boot -F boot@system
fi
if [ ! -d /var/lib/66/system/default ]; then
66-tree -ncE default
fi

View File

@@ -1,19 +1,28 @@
#!/bin/sh -e
udevd_live() {
if [ ! -d /run/udev ]; then
echo >&2 " Skipped: Device manager is not running."
exit 0
fi
if [ ! -d /run/udev ]; then
echo >&2 " Skipped: Device manager is not running."
exit 0
fi
}
op="$1"; shift
case "$op" in
#hwdb) /usr/bin/udev-hwdb --usr update ;;
hwdb) /usr/bin/udevadm hwdb --update ;;
udev-reload) udevd_live; /usr/bin/udevadm control --reload ;;
*) echo >&2 " Invalid operation '$op'"; exit 1 ;;
hwdb)
/usr/bin/udev-hwdb --usr update
;;
udev-reload)
udevd_live
/usr/bin/udevadm control --reload
/usr/bin/udevadm trigger -c change
/usr/bin/udevadm settle
;;
*)
echo >&2 " Invalid operation '$op'"
exit 1
;;
esac
exit 0

86
wrapper/artix-service Normal file
View 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