You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

85 lines
2.2 KiB
Bash

#!/bin/sh
ACTION=${1}
shift 1
do_install() {
local http_port=`uci get vaultwarden.@main[0].http_port 2>/dev/null`
local notify_port=`uci get vaultwarden.@main[0].notify_port 2>/dev/null`
local image_name=`uci get vaultwarden.@main[0].image_name 2>/dev/null`
local config=`uci get vaultwarden.@main[0].config_path 2>/dev/null`
local admin_token=`uci get vaultwarden.@main[0].admin_token 2>/dev/null`
local signup_allowed=`uci get vaultwarden.@main[0].signup_allowed 2>/dev/null`
[ -z "$image_name" ] && image_name="vaultwarden/server:latest"
echo "docker pull ${image_name}"
docker pull ${image_name}
docker rm -f vaultwarden
if [ -z "$config" ]; then
echo "config path is empty!"
exit 1
fi
[ -z "$http_port" ] && http_port=8002
local cmd="docker run --restart=unless-stopped -d \
--dns=172.17.0.1 \
-p $http_port:80 \
-v \"$config:/data\""
[ -z "$notify_port" ] || cmd="$cmd -e \"-e WEBSOCKET_ENABLED=true\" -p $notify_port:3012"
[ -z "$admin_token" ] || cmd="$cmd -e \"ADMIN_TOKEN=$admin_token\""
if [ "$signup_allowed" = "1" ]; then
cmd="$cmd -e \"SIGNUPS_ALLOWED=true\""
else
cmd="$cmd -e \"SIGNUPS_ALLOWED=false\""
fi
local tz="`uci get system.@system[0].zonename`"
[ -z "$tz" ] || cmd="$cmd -e TZ=$tz"
cmd="$cmd -v /mnt:/mnt"
mountpoint -q /mnt && cmd="$cmd:rslave"
cmd="$cmd --name vaultwarden \"$image_name\""
echo "$cmd"
eval "$cmd"
}
usage() {
echo "usage: $0 sub-command"
echo "where sub-command is one of:"
echo " install Install the vaultwarden"
echo " upgrade Upgrade the vaultwarden"
echo " rm/start/stop/restart Remove/Start/Stop/Restart the vaultwarden"
echo " status Vaultwarden status"
echo " port Vaultwarden port"
}
case ${ACTION} in
"install")
do_install
;;
"upgrade")
do_install
;;
"rm")
docker rm -f vaultwarden
;;
"start" | "stop" | "restart")
docker ${ACTION} vaultwarden
;;
"status")
docker ps --all -f 'name=vaultwarden' --format '{{.State}}'
;;
"port")
http_port=`uci get vaultwarden.@main[0].http_port 2>/dev/null`
echo $http_port
;;
*)
usage
exit 1
;;
esac