summaryrefslogtreecommitdiffstats
path: root/system/install-service.sh.in
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-07-24 09:54:23 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-07-24 09:54:44 +0000
commit836b47cb7e99a977c5a23b059ca1d0b5065d310e (patch)
tree1604da8f482d02effa033c94a84be42bc0c848c3 /system/install-service.sh.in
parentReleasing debian version 1.44.3-2. (diff)
downloadnetdata-836b47cb7e99a977c5a23b059ca1d0b5065d310e.tar.xz
netdata-836b47cb7e99a977c5a23b059ca1d0b5065d310e.zip
Merging upstream version 1.46.3.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'system/install-service.sh.in')
-rwxr-xr-xsystem/install-service.sh.in63
1 files changed, 62 insertions, 1 deletions
diff --git a/system/install-service.sh.in b/system/install-service.sh.in
index cdd1bf52f..0ed4fa1bb 100755
--- a/system/install-service.sh.in
+++ b/system/install-service.sh.in
@@ -29,7 +29,7 @@ DUMP_CMDS=0
ENABLE="auto"
EXPORT_CMDS=0
INSTALL=1
-LINUX_INIT_TYPES="systemd openrc lsb initd runit"
+LINUX_INIT_TYPES="systemd openrc lsb initd runit dinit"
PLATFORM="$(uname -s)"
SHOW_SVC_TYPE=0
SVC_SOURCE="@libsysdir_POST@"
@@ -563,6 +563,65 @@ runit_cmds() {
}
# =====================================================================
+# dinit support functions
+
+_check_dinit() {
+ # if /etc/dinit.d does not exist, it’s not dinit
+ [ ! -d /etc/dinit.d ] && echo "NO" && return 0
+
+ # if PID 1 is dinit, it’s dinit
+ [ "$(basename "$(readlink /proc/1/exe)" 2> /dev/null)" = "dinit" ] && echo "YES" && return 0
+
+ # if /run/dinitctl exists and is a socket, it’s dinit
+ [ -S /run/dinitctl ] && echo "YES" && return 0
+
+ # if the dinitctl command exists despite getting to this point, it’s dinit, but not booted as such
+ [ -n "$(command -v dinitctl 2>/dev/null || true)" ] && echo "OFFLINE" && return 0
+
+ echo "NO" && return 0
+}
+
+check_dinit() {
+ if [ -z "${IS_DINIT}" ]; then
+ IS_DINIT="$(_check_dinit)"
+ fi
+
+ echo "${IS_DINIT}"
+}
+
+_run_dinitctl() {
+ opts=''
+
+ if [ "$(check_dinit)" = "OFFLINE" ]; then
+ opts="-o"
+ fi
+
+ # shellcheck disable=SC2086
+ dinitctl ${opts} "${@}"
+}
+
+enable_dinit() {
+ _run_dinitctl enable netdata
+}
+
+enable_dinit() {
+ _run_dinitctl disable netdata
+}
+
+install_dinit_service() {
+ install_generic_service dinit/netdata "dinit" /etc/dinit.d enable_dinit disable_dinit
+}
+
+dinit_cmds() {
+ if [ "$(check_dinit)" = "YES" ]; then
+ NETDATA_START_CMD='dinitctl start netdata'
+ NETDATA_STOP_CMD='dinitct stop netdata'
+ else # Not booted using dinit, use external defaults by not providing commands.
+ warning "Detected dinit, but the system is not booted using dinit. Unable to provide commands to start or stop Netdata using the service manager."
+ fi
+}
+
+# =====================================================================
# WSL support functions
_check_wsl() {
@@ -630,6 +689,8 @@ install_darwin_service() {
exit 4
fi
+ launchctl unload /Library/LaunchDaemons/com.github.netdata.plist 2>/dev/null
+
if ! launchctl load /Library/LaunchDaemons/com.github.netdata.plist; then
error "Failed to load plist file."
exit 4