Files
Vaultwarden/root/etc/init.d/vaultwarden
Cantibra 3180255caa
All checks were successful
Vaultwarden / Vaultwarden [arm64] (push) Successful in 59s
Vaultwarden / Vaultwarden [amd64] (push) Successful in 51s
Inital Commit
2025-10-26 21:11:06 +01:00

83 lines
2.4 KiB
Bash

#!/bin/sh
### BEGIN INIT INFO
# Provides: vaultwarden
# Required-Start: $local_fs $network $remote_fs
# Required-Stop: $local_fs $network $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Vaultwarden Server
# Description: Alternative implementation of the Bitwarden server API
# written in Rust and compatible with upstream Bitwarden
# clients.
### END INIT INFO
NAME='vaultwarden'
DESC='Vaultwarden Server'
USER='vaultwarden'
GROUP='vaultwarden'
PIDFOLDER="/run/vaultwarden"
PIDFILE="${PIDFOLDER}/vaultwarden.pid"
DAEMON='/usr/sbin/vaultwarden'
DAEMON_CONFIG='/etc/vaultwarden/vaultwarden.conf'
set -e
[ -f "${DAEMON_CONFIG}" ]
. "${DAEMON_CONFIG}"
. '/lib/lsb/init-functions'
[ -x "${DAEMON}" ]
case "${1}" in
start)
/usr/bin/install --directory --group="${GROUP}" ---mode='0755' --owner="${USER}" "${PIDFOLDER}"
log_daemon_msg "Starting ${DESC}" "${NAME}"
if /usr/sbin/start-stop-daemon --quiet \
--start \
--oknodo \
--make-pidfile \
--pidfile "${PIDFILE}" \
--user "${USER}" \
--group "${GROUP}" \
--exec "${DAEMON}"; then
log_end_msg 0
else
log_end_msg 1
/usr/bin/test -f "${PIDFILE}" && \
/usr/bin/rm --force "${PIDFILE}"
fi
;;
stop)
log_daemon_msg "Stopping ${DESC}" "${NAME}"
if /usr/sbin/start-stop-daemon --quiet \
--stop \
--oknodo \
--retry 30 \
--remove-pidfile \
--pidfile "${PIDFILE}" \
--user "${USER}" \
--group "${GROUP}" \
--exec "${DAEMON}"; then
/usr/bin/test -f "${PIDFILE}" && \
/usr/bin/rm --force "${PIDFILE}"
log_end_msg 0
else
log_end_msg 1
fi
;;
restart)
"${0}" stop
"${0}" start
;;
status)
status_of_proc -p "${PIDFILE}" "${DAEMON}" "${NAME}" && \
exit 0 || \
exit "${?}"
;;
*)
echo "Usage: /etc/init.d/${NAME} {start|stop|restart|status}" >&2
exit 1
;;
esac