2017-08-07 17:24:16 +02:00
|
|
|
param (
|
2017-08-21 14:49:44 +02:00
|
|
|
[string]$outputDir = "../."
|
2017-08-07 17:24:16 +02:00
|
|
|
)
|
|
|
|
|
2017-08-08 21:48:45 +02:00
|
|
|
if(!(Test-Path -Path $outputDir )){
|
2017-08-21 17:24:39 +02:00
|
|
|
New-Item -ItemType directory -Path $outputDir | Out-Null
|
2017-08-08 21:48:45 +02:00
|
|
|
}
|
|
|
|
|
2017-08-08 20:35:31 +02:00
|
|
|
docker --version
|
2017-08-11 21:05:50 +02:00
|
|
|
echo ""
|
2017-08-08 20:35:31 +02:00
|
|
|
|
2017-08-21 17:21:40 +02:00
|
|
|
[string]$letsEncrypt = "n"
|
2017-08-11 20:43:46 +02:00
|
|
|
[string]$domain = $( Read-Host "(!) Enter the domain name for your bitwarden instance (ex. bitwarden.company.com)" )
|
2017-08-08 21:48:45 +02:00
|
|
|
|
2017-08-21 17:21:40 +02:00
|
|
|
if($domain -ne "localhost") {
|
|
|
|
$letsEncrypt = $( Read-Host "(!) Do you want to use Let's Encrypt to generate a free SSL certificate? (y/n)" )
|
|
|
|
|
|
|
|
if($letsEncrypt -eq "y") {
|
|
|
|
[string]$email = $( Read-Host "(!) Enter your email address (Let's Encrypt will send you certificate expiration reminders)" )
|
|
|
|
|
|
|
|
$letsEncryptPath = "${outputDir}/letsencrypt/live/${domain}"
|
|
|
|
if(!(Test-Path -Path $letsEncryptPath )){
|
2017-08-21 17:24:39 +02:00
|
|
|
New-Item -ItemType directory -Path $letsEncryptPath | Out-Null
|
2017-08-21 17:21:40 +02:00
|
|
|
}
|
|
|
|
docker run -it --rm --name certbot -p 80:80 -v $outputDir/letsencrypt:/etc/letsencrypt/ certbot/certbot `
|
|
|
|
certonly --standalone --noninteractive --agree-tos --preferred-challenges http --email $email -d $domain
|
2017-08-08 21:48:45 +02:00
|
|
|
}
|
2017-08-08 20:35:31 +02:00
|
|
|
}
|
2017-08-07 17:24:16 +02:00
|
|
|
|
2017-08-19 15:36:03 +02:00
|
|
|
docker run -it --rm --name setup -v ${outputDir}:/bitwarden bitwarden/setup `
|
|
|
|
dotnet Setup.dll -install 1 -domain ${domain} -letsencrypt ${letsEncrypt}
|
2017-08-07 17:24:16 +02:00
|
|
|
|
2017-08-07 22:31:00 +02:00
|
|
|
echo "Setup complete"
|