base-files: fix enabled for services with only STOP
authorKarel Kočí <karel.koci@nic.cz>
Mon, 7 Jun 2021 17:25:06 +0000 (19:25 +0200)
committerPaul Spooren <mail@aparcar.org>
Tue, 22 Jun 2021 19:45:27 +0000 (09:45 -1000)
There are services that have only STOP value set. They are executed only
on shutdown and it is common to use them for system cleanup. There is
one such service shipped directly with base-files, it is 'umount'. Those
work the same way as those with START but enabled does not report them
as enabled although it should have as they can be enabled and disabled
as any other service.

This also changes check from check for executable to check for symbolic
link. The implementation depends on those being links to service file
and it is much cleaner and direct to check for them being links.

Signed-off-by: Karel Kočí <karel.koci@nic.cz>
package/base-files/files/etc/rc.common

index f39b69464eac98f92012ecc6f1566531049081b6..5dcbf5138d532fe2a874d3fd9b19601454b8cd8d 100755 (executable)
@@ -55,7 +55,12 @@ enable() {
 
 enabled() {
        name="$(basename "${initscript}")"
-       [ -x "$IPKG_INSTROOT/etc/rc.d/S${START}${name##S[0-9][0-9]}" ]
+       name="${name##[SK][0-9][0-9]}"
+       {
+               [ -z "${START:-}" ] || [ -L "$IPKG_INSTROOT/etc/rc.d/S${START}$name" ]
+       } && {
+               [ -z "${STOP:-}" ] || [ -L "$IPKG_INSTROOT/etc/rc.d/K${STOP}$name" ]
+       }
 }
 
 depends() {