1
0
mirror of https://github.com/bitwarden/server.git synced 2025-01-01 18:37:35 +01:00
bitwarden-server/util/MsSql/entrypoint.sh

60 lines
1.5 KiB
Bash
Raw Normal View History

2018-03-28 03:14:52 +02:00
#!/bin/bash
2018-04-16 21:30:07 +02:00
# Setup
GROUPNAME="bitwarden"
2018-03-28 04:57:30 +02:00
USERNAME="bitwarden"
2018-04-16 21:30:07 +02:00
LUID=${LOCAL_UID:-0}
LGID=${LOCAL_GID:-0}
2018-04-16 21:30:07 +02:00
# Step down from host root to well-known nobody/nogroup user
2018-03-28 04:57:30 +02:00
if [ $LUID -eq 0 ]
2018-04-16 21:30:07 +02:00
then
LUID=65534
2018-04-16 21:30:07 +02:00
fi
if [ $LGID -eq 0 ]
2018-03-28 04:57:30 +02:00
then
LGID=65534
2018-03-28 04:57:30 +02:00
fi
# Create user and group
2018-04-16 21:30:07 +02:00
groupadd -o -g $LGID $GROUPNAME >/dev/null 2>&1 ||
groupmod -o -g $LGID $GROUPNAME >/dev/null 2>&1
useradd -o -u $LUID -g $GROUPNAME -s /bin/false $USERNAME >/dev/null 2>&1 ||
usermod -o -u $LUID -g $GROUPNAME -s /bin/false $USERNAME >/dev/null 2>&1
mkhomedir_helper $USERNAME
2018-04-03 03:11:32 +02:00
# Read the SA_PASSWORD value from a file for swarm environments.
# See https://github.com/Microsoft/mssql-docker/issues/326
2019-04-15 04:46:11 +02:00
if [ ! -z "$SA_PASSWORD" ] && [ ! -z "$SA_PASSWORD_FILE" ]
then
echo "Provided both SA_PASSWORD and SA_PASSWORD_FILE environment variables. Please only use one."
exit 1
fi
2019-04-15 04:46:11 +02:00
if [ ! -z "$SA_PASSWORD_FILE" ]
then
# It should be exported, so it is available to the env command below.
export SA_PASSWORD=$(cat $SA_PASSWORD_FILE)
fi
2018-04-16 21:30:07 +02:00
# The rest...
2018-09-05 17:47:57 +02:00
# ref: https://stackoverflow.com/a/38850273
touch /var/log/cron.log /etc/crontab /etc/cron.*/*
2018-04-16 21:30:07 +02:00
chown $USERNAME:$GROUPNAME /var/log/cron.log
2018-03-27 20:55:33 +02:00
mkdir -p /etc/bitwarden/mssql/backups
2018-04-16 21:30:07 +02:00
chown -R $USERNAME:$GROUPNAME /etc/bitwarden
2018-03-27 20:55:33 +02:00
mkdir -p /var/opt/mssql/data
2018-04-16 21:30:07 +02:00
chown -R $USERNAME:$GROUPNAME /var/opt/mssql
chown $USERNAME:$GROUPNAME /backup-db.sh
chown $USERNAME:$GROUPNAME /backup-db.sql
2018-03-27 20:55:33 +02:00
# Sounds like gosu keeps env when switching, but of course cron does not
env > /etc/environment
2017-08-21 16:58:00 +02:00
cron
2018-03-27 03:38:32 +02:00
exec gosu $USERNAME:$GROUPNAME /opt/mssql/bin/sqlservr