You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
58 lines
1.4 KiB
58 lines
1.4 KiB
#!/usr/bin/env bash |
|
set -e |
|
|
|
OUTPUT_DIR="../." |
|
if [ $# -gt 0 ] |
|
then |
|
OUTPUT_DIR=$1 |
|
fi |
|
|
|
COREVERSION="latest" |
|
if [ $# -gt 1 ] |
|
then |
|
COREVERSION=$2 |
|
fi |
|
|
|
WEBVERSION="latest" |
|
if [ $# -gt 2 ] |
|
then |
|
WEBVERSION=$3 |
|
fi |
|
|
|
OS="lin" |
|
if [ "$(uname)" == "Darwin" ] |
|
then |
|
OS="mac" |
|
fi |
|
|
|
mkdir -p $OUTPUT_DIR |
|
|
|
LETS_ENCRYPT="n" |
|
read -p "(!) Enter the domain name for your bitwarden instance (ex. bitwarden.company.com): " DOMAIN |
|
|
|
if [ "$DOMAIN" == "" ] |
|
then |
|
DOMAIN="localhost" |
|
fi |
|
|
|
if [ "$DOMAIN" != "localhost" ] |
|
then |
|
read -p "(!) Do you want to use Let's Encrypt to generate a free SSL certificate? (y/n): " LETS_ENCRYPT |
|
|
|
if [ "$LETS_ENCRYPT" == "y" ] |
|
then |
|
read -p "(!) Enter your email address (Let's Encrypt will send you certificate expiration reminders): " EMAIL |
|
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 \ |
|
certonly --standalone --noninteractive --agree-tos --preferred-challenges http --email $EMAIL -d $DOMAIN \ |
|
--logs-dir /etc/letsencrypt/logs |
|
fi |
|
fi |
|
|
|
docker pull bitwarden/setup:$COREVERSION |
|
docker run -it --rm --name setup -v $OUTPUT_DIR:/bitwarden bitwarden/setup:$COREVERSION \ |
|
dotnet Setup.dll -install 1 -domain $DOMAIN -letsencrypt $LETS_ENCRYPT -os $OS -corev $COREVERSION -webv $WEBVERSION |
|
|
|
echo "" |
|
echo "Setup complete"
|
|
|