1
0
mirror of https://github.com/bitwarden/server.git synced 2025-01-18 21:11:21 +01:00
bitwarden-server/scripts/run.sh

257 lines
6.5 KiB
Bash
Raw Normal View History

2017-08-23 22:15:42 +02:00
#!/usr/bin/env bash
set -e
# Setup
CYAN='\033[0;36m'
NC='\033[0m' # No Color
2017-08-23 22:15:42 +02:00
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
OUTPUT_DIR=".."
2017-08-23 22:51:36 +02:00
if [ $# -gt 1 ]
2017-08-23 22:15:42 +02:00
then
OUTPUT_DIR=$2
fi
2017-11-09 04:24:23 +01:00
COREVERSION="latest"
2017-08-24 02:05:53 +02:00
if [ $# -gt 2 ]
2017-08-23 22:15:42 +02:00
then
2017-11-09 04:24:23 +01:00
COREVERSION=$3
2017-08-23 22:15:42 +02:00
fi
2017-11-09 04:24:23 +01:00
WEBVERSION="latest"
if [ $# -gt 3 ]
then
WEBVERSION=$4
fi
OS="lin"
[ "$(uname)" == "Darwin" ] && OS="mac"
ENV_DIR="$OUTPUT_DIR/env"
DOCKER_DIR="$OUTPUT_DIR/docker"
2018-05-31 19:49:41 +02:00
# Initialize UID/GID which will be used to run services from within containers
if ! grep -q "^LOCAL_UID=" $ENV_DIR/uid.env 2>/dev/null || ! grep -q "^LOCAL_GID=" $ENV_DIR/uid.env 2>/dev/null
2017-08-23 22:15:42 +02:00
then
LUID="LOCAL_UID=`id -u $USER`"
[ "$LUID" == "LOCAL_UID=0" ] && LUID="LOCAL_UID=65534"
LGID="LOCAL_GID=`id -g $USER`"
[ "$LGID" == "LOCAL_GID=0" ] && LGID="LOCAL_GID=65534"
mkdir -p $ENV_DIR
echo $LUID >$ENV_DIR/uid.env
echo $LGID >>$ENV_DIR/uid.env
2017-08-23 22:15:42 +02:00
fi
# Functions
function install() {
LETS_ENCRYPT="n"
echo -e -n "${CYAN}(!)${NC} Enter the domain name for your Bitwarden instance (ex. bitwarden.example.com): "
read DOMAIN
echo ""
if [ "$DOMAIN" == "" ]
then
DOMAIN="localhost"
fi
if [ "$DOMAIN" != "localhost" ]
then
echo -e -n "${CYAN}(!)${NC} Do you want to use Let's Encrypt to generate a free SSL certificate? (y/n): "
read LETS_ENCRYPT
echo ""
if [ "$LETS_ENCRYPT" == "y" ]
then
echo -e -n "${CYAN}(!)${NC} Enter your email address (Let's Encrypt will send you certificate expiration reminders): "
read EMAIL
echo ""
mkdir -p $OUTPUT_DIR/letsencrypt
docker pull certbot/certbot
docker run -it --rm --name certbot -p 80:80 -v $OUTPUT_DIR/letsencrypt:/etc/letsencrypt/ certbot/certbot \
2018-05-31 19:49:41 +02:00
certonly --standalone --noninteractive --agree-tos --preferred-challenges http \
--email $EMAIL -d $DOMAIN --logs-dir /etc/letsencrypt/logs
fi
fi
pullSetup
2018-05-31 19:49:41 +02:00
docker run -it --rm --name setup -v $OUTPUT_DIR:/bitwarden \
--env-file $ENV_DIR/uid.env bitwarden/setup:$COREVERSION \
dotnet Setup.dll -install 1 -domain $DOMAIN -letsencrypt $LETS_ENCRYPT -os $OS \
-corev $COREVERSION -webv $WEBVERSION
}
2017-08-23 22:15:42 +02:00
function dockerComposeUp() {
2018-08-31 15:16:14 +02:00
dockerComposeFiles
dockerComposeVolumes
2018-08-31 15:16:14 +02:00
docker-compose up -d
2017-08-23 22:15:42 +02:00
}
function dockerComposeDown() {
2018-08-31 15:16:14 +02:00
dockerComposeFiles
docker-compose down
2017-08-23 22:15:42 +02:00
}
2017-08-27 04:36:25 +02:00
function dockerComposePull() {
2018-08-31 15:16:14 +02:00
dockerComposeFiles
docker-compose pull
}
function dockerComposeFiles() {
2018-02-20 17:15:16 +01:00
if [ -f "${DOCKER_DIR}/docker-compose.override.yml" ]
then
2018-08-31 15:16:14 +02:00
export COMPOSE_FILE="$DOCKER_DIR/docker-compose.yml:$DOCKER_DIR/docker-compose.override.yml"
else
2018-08-31 15:16:14 +02:00
export COMPOSE_FILE="$DOCKER_DIR/docker-compose.yml"
fi
2018-11-09 03:32:23 +01:00
export COMPOSE_HTTP_TIMEOUT="300"
2017-08-27 04:36:25 +02:00
}
function dockerComposeVolumes() {
createDir "core"
createDir "core/attachments"
createDir "logs"
createDir "logs/admin"
createDir "logs/api"
createDir "logs/events"
createDir "logs/icons"
createDir "logs/identity"
createDir "logs/mssql"
createDir "logs/nginx"
createDir "logs/notifications"
2020-09-14 19:08:43 +02:00
createDir "logs/sso"
createDir "logs/portal"
createDir "mssql/backups"
createDir "mssql/data"
}
function createDir() {
if [ ! -d "${OUTPUT_DIR}/$1" ]
then
echo "Creating directory $OUTPUT_DIR/$1"
mkdir -p $OUTPUT_DIR/$1
fi
}
2017-08-23 22:15:42 +02:00
function dockerPrune() {
2018-11-07 15:51:16 +01:00
docker image prune --all --force --filter="label=com.bitwarden.product=bitwarden" \
--filter="label!=com.bitwarden.project=setup"
2017-08-23 22:15:42 +02:00
}
function updateLetsEncrypt() {
2017-11-09 04:24:23 +01:00
if [ -d "${OUTPUT_DIR}/letsencrypt/live" ]
2017-08-23 22:15:42 +02:00
then
2017-08-27 04:54:10 +02:00
docker pull certbot/certbot
2018-03-27 20:55:33 +02:00
docker run -i --rm --name certbot -p 443:443 -p 80:80 \
-v $OUTPUT_DIR/letsencrypt:/etc/letsencrypt/ certbot/certbot \
2017-08-23 22:15:42 +02:00
renew --logs-dir /etc/letsencrypt/logs
fi
}
2020-06-17 15:12:01 +02:00
function forceUpdateLetsEncrypt() {
if [ -d "${OUTPUT_DIR}/letsencrypt/live" ]
then
docker pull certbot/certbot
docker run -i --rm --name certbot -p 443:443 -p 80:80 \
-v $OUTPUT_DIR/letsencrypt:/etc/letsencrypt/ certbot/certbot \
renew --logs-dir /etc/letsencrypt/logs --force-renew
fi
2020-06-17 15:05:35 +02:00
}
2017-08-23 22:15:42 +02:00
function updateDatabase() {
2017-10-25 23:21:35 +02:00
pullSetup
dockerComposeFiles
MSSQL_ID=$(docker-compose ps -q mssql)
docker run -i --rm --name setup --network container:$MSSQL_ID \
-v $OUTPUT_DIR:/bitwarden --env-file $ENV_DIR/uid.env bitwarden/setup:$COREVERSION \
dotnet Setup.dll -update 1 -db 1 -os $OS -corev $COREVERSION -webv $WEBVERSION
2017-08-23 22:15:42 +02:00
echo "Database update complete"
}
2017-10-25 23:21:35 +02:00
function update() {
2018-08-30 22:25:33 +02:00
if [ "$1" == "withpull" ]
then
pullSetup
fi
docker run -i --rm --name setup -v $OUTPUT_DIR:/bitwarden \
--env-file $ENV_DIR/uid.env bitwarden/setup:$COREVERSION \
dotnet Setup.dll -update 1 -os $OS -corev $COREVERSION -webv $WEBVERSION
2017-10-25 23:21:35 +02:00
}
2017-08-24 17:16:01 +02:00
function printEnvironment() {
2017-10-25 23:21:35 +02:00
pullSetup
docker run -i --rm --name setup -v $OUTPUT_DIR:/bitwarden \
--env-file $ENV_DIR/uid.env bitwarden/setup:$COREVERSION \
dotnet Setup.dll -printenv 1 -os $OS -corev $COREVERSION -webv $WEBVERSION
2017-08-24 17:16:01 +02:00
}
2017-10-25 23:21:35 +02:00
function restart() {
2017-08-23 22:15:42 +02:00
dockerComposeDown
2017-08-27 04:36:25 +02:00
dockerComposePull
2017-08-23 22:15:42 +02:00
updateLetsEncrypt
dockerComposeUp
2017-08-24 17:16:01 +02:00
printEnvironment
2017-10-25 23:21:35 +02:00
}
2020-06-17 15:12:01 +02:00
function certRestart() {
2020-06-17 15:05:35 +02:00
dockerComposeDown
dockerComposePull
2020-06-17 15:12:01 +02:00
forceUpdateLetsEncrypt
2020-06-17 15:05:35 +02:00
dockerComposeUp
printEnvironment
}
2017-10-25 23:21:35 +02:00
function pullSetup() {
2017-11-09 04:24:23 +01:00
docker pull bitwarden/setup:$COREVERSION
2017-10-25 23:21:35 +02:00
}
# Commands
if [ "$1" == "install" ]
then
install
elif [ "$1" == "start" -o "$1" == "restart" ]
2017-10-25 23:21:35 +02:00
then
restart
2017-08-27 04:36:25 +02:00
elif [ "$1" == "pull" ]
then
dockerComposePull
2017-08-23 22:15:42 +02:00
elif [ "$1" == "stop" ]
then
dockerComposeDown
2020-06-17 15:05:35 +02:00
elif [ "$1" == "renewcert" ]
then
2020-06-17 15:12:01 +02:00
certRestart
elif [ "$1" == "updateconf" ]
then
dockerComposeDown
update withpull
2017-08-23 22:42:39 +02:00
elif [ "$1" == "updatedb" ]
2017-08-23 22:15:42 +02:00
then
updateDatabase
2017-10-25 23:21:35 +02:00
elif [ "$1" == "update" ]
then
2020-06-01 23:35:57 +02:00
dockerComposeFiles
CORE_ID=$(docker-compose ps -q admin)
WEB_ID=$(docker-compose ps -q web)
if docker inspect --format='{{.Config.Image}}:' $CORE_ID | grep -F ":$COREVERSION:" | grep -q ":[0-9.]*:$" &&
docker inspect --format='{{.Config.Image}}:' $WEB_ID | grep -F ":$WEBVERSION:" | grep -q ":[0-9.]*:$"
then
echo "Update not needed"
exit
fi
2017-10-25 23:21:35 +02:00
dockerComposeDown
2018-08-30 22:25:33 +02:00
update withpull
2017-10-25 23:21:35 +02:00
restart
dockerPrune
2018-03-11 05:53:21 +01:00
echo "Pausing 60 seconds for database to come online. Please wait..."
sleep 60
2017-10-25 23:21:35 +02:00
updateDatabase
2018-08-30 22:25:33 +02:00
elif [ "$1" == "rebuild" ]
then
dockerComposeDown
update nopull
2017-08-23 22:15:42 +02:00
fi