2020-04-09 22:52:11 +00:00
|
|
|
# Bitwarden_rs in docker
|
|
|
|
|
|
|
|
###### guide by example
|
|
|
|
|
2020-04-16 22:05:54 +00:00
|
|
|
![logo](https://i.imgur.com/tT3FQLJ.png)
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Purpose
|
2020-04-09 22:52:11 +00:00
|
|
|
|
|
|
|
Password manager. RS version is simpler and lighter than the official bitwarden.
|
|
|
|
|
|
|
|
* [Official site](https://bitwarden.com/)
|
|
|
|
* [Github](https://github.com/dani-garcia/bitwarden_rs)
|
2020-04-10 09:55:22 +00:00
|
|
|
* [DockerHub](https://hub.docker.com/r/bitwardenrs/server)
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Files and directory structure
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-25 22:44:34 +00:00
|
|
|
```
|
|
|
|
/home
|
|
|
|
└── ~
|
|
|
|
└── docker
|
|
|
|
└── bitwarden
|
|
|
|
├── 🗁 bitwarden-data
|
|
|
|
├── 🗋 .env
|
|
|
|
├── 🗋 docker-compose.yml
|
|
|
|
└── 🗋 bitwarden-backup-script.sh
|
|
|
|
```
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# docker-compose
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-25 22:44:34 +00:00
|
|
|
[Documentation](https://github.com/dani-garcia/bitwarden_rs/wiki/Using-Docker-Compose) on compose.
|
|
|
|
|
|
|
|
`docker-compose.yml`
|
|
|
|
|
|
|
|
```yml
|
|
|
|
version: "3"
|
|
|
|
services:
|
|
|
|
|
|
|
|
bitwarden:
|
|
|
|
image: bitwardenrs/server
|
|
|
|
container_name: bitwarden
|
|
|
|
hostname: bitwarden
|
|
|
|
restart: unless-stopped
|
|
|
|
env_file: .env
|
|
|
|
volumes:
|
|
|
|
- ./bitwarden-data/:/data/
|
|
|
|
|
|
|
|
networks:
|
|
|
|
default:
|
|
|
|
external:
|
|
|
|
name: $DEFAULT_NETWORK
|
|
|
|
```
|
|
|
|
|
|
|
|
`.env`
|
2020-04-25 22:45:46 +00:00
|
|
|
```bash
|
2020-04-25 22:44:34 +00:00
|
|
|
# GENERAL
|
|
|
|
MY_DOMAIN=blabla.org
|
|
|
|
DEFAULT_NETWORK=caddy_net
|
|
|
|
TZ=Europe/Prague
|
|
|
|
|
|
|
|
# BITWARDEN
|
|
|
|
ADMIN_TOKEN=YdLo1TM4MYEQ948GOVZ29IF4fABSrZMpk9
|
|
|
|
SIGNUPS_ALLOWED=false
|
|
|
|
WEBSOCKET_ENABLED=true
|
|
|
|
|
|
|
|
# USING SENDGRID FOR SENDING EMAILS
|
|
|
|
DOMAIN=https://passwd.blabla.org
|
|
|
|
SMTP_SSL=true
|
|
|
|
SMTP_EXPLICIT_TLS=true
|
|
|
|
SMTP_HOST=smtp.sendgrid.net
|
|
|
|
SMTP_PORT=465
|
|
|
|
SMTP_USERNAME=apikey
|
|
|
|
SMTP_PASSWORD=SG.MOQQegA3bgfodRN4IG2Wqwe.s23Ld4odqhOQQegf4466A4
|
|
|
|
SMTP_FROM=admin@blabla.org
|
|
|
|
```
|
|
|
|
|
|
|
|
**All containers must be on the same network**.</br>
|
|
|
|
If one does not exist yet: `docker network create caddy_net`
|
2020-04-16 22:05:54 +00:00
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Reverse proxy
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-25 22:44:34 +00:00
|
|
|
Caddy v2 is used, details [here.](https://github.com/DoTheEvo/Caddy-v2-docker-example-setup)</br>
|
|
|
|
Bitwarden_rs documentation has a [section on reverse proxy.](https://github.com/dani-garcia/bitwarden_rs/wiki/Proxy-examples)
|
|
|
|
|
|
|
|
`Caddyfile`
|
|
|
|
```
|
|
|
|
passwd.{$MY_DOMAIN} {
|
|
|
|
header / {
|
|
|
|
X-XSS-Protection "1; mode=block"
|
|
|
|
X-Frame-Options "DENY"
|
|
|
|
X-Robots-Tag "none"
|
|
|
|
-Server
|
|
|
|
}
|
|
|
|
encode gzip
|
|
|
|
reverse_proxy /notifications/hub/negotiate bitwarden:80
|
|
|
|
reverse_proxy /notifications/hub bitwarden:3012
|
|
|
|
reverse_proxy bitwarden:80
|
|
|
|
}
|
|
|
|
```
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Forward port 3012 TCP on your router
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 07:50:11 +00:00
|
|
|
[WebSocket](https://youtu.be/2Nt-ZrNP22A) protocol is used for notifications,
|
|
|
|
so that all web based clients can immediatly sync when a change happens on server.
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 21:30:48 +00:00
|
|
|
* Enviromental variable `WEBSOCKET_ENABLED=true` needs to be set.</br>
|
|
|
|
* Reverse proxy needs to route `/notifications/hub` to port 3012.</br>
|
|
|
|
* Router needs to **forward port 3012** to docker host,
|
2020-04-24 07:50:11 +00:00
|
|
|
same as port 80 and 443 are forwarded.
|
|
|
|
|
|
|
|
To test if websocket works, have the desktop app open
|
|
|
|
and make changes through browser extension, or through the website.
|
|
|
|
Changes should immediatly appear in the desktop app. If it is not working,
|
|
|
|
you need to manually sync for changes to appear.
|
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Extra info
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 07:50:11 +00:00
|
|
|
**bitwarden can be managed** at `<url>/admin` and entering `ADMIN_TOKEN`
|
|
|
|
set in the `.env` file. Especially if signups are disabled it is the only way
|
|
|
|
to invite users.
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 22:00:54 +00:00
|
|
|
**push notifications**
|
|
|
|
|
2020-04-16 22:05:54 +00:00
|
|
|
---
|
|
|
|
|
2020-04-09 22:52:11 +00:00
|
|
|
![interface-pic](https://i.imgur.com/5LxEUsA.png)
|
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Update
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-10 09:55:22 +00:00
|
|
|
* [watchtower](https://github.com/DoTheEvo/selfhosted-apps-docker/tree/master/watchtower) updates the image automaticly
|
2020-04-09 22:52:11 +00:00
|
|
|
|
|
|
|
* manual image update</br>
|
|
|
|
`docker-compose pull`</br>
|
|
|
|
`docker-compose up -d`</br>
|
|
|
|
`docker image prune`
|
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Backup and restore
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-25 22:44:34 +00:00
|
|
|
* **backup** using [BorgBackup setup](https://github.com/DoTheEvo/selfhosted-apps-docker/tree/master/borg_backup)
|
2020-04-10 09:55:22 +00:00
|
|
|
that makes daily snapshot of the entire directory
|
2020-04-09 22:52:11 +00:00
|
|
|
|
|
|
|
* **restore**</br>
|
|
|
|
down the bitwarden container `docker-compose down`</br>
|
|
|
|
delete the entire bitwarden directory</br>
|
|
|
|
from the backup copy back the bitwarden directortory</br>
|
|
|
|
start the container `docker-compose up -d`
|
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Backup of just user data
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-24 22:00:54 +00:00
|
|
|
User-data daily export using the [official procedure.](https://github.com/dani-garcia/bitwarden_rs/wiki/Backing-up-your-vault)</br>
|
2020-04-24 21:30:48 +00:00
|
|
|
For bitwarden_rs it means sqlite database dump and backing up `attachments` directory.</br>
|
2020-04-24 22:00:54 +00:00
|
|
|
|
2020-04-25 22:44:34 +00:00
|
|
|
Daily run of [BorgBackup](https://github.com/DoTheEvo/selfhosted-apps-docker/tree/master/borg_backup)
|
2020-04-24 22:00:54 +00:00
|
|
|
takes care of backing up the directory.
|
|
|
|
So only database dump is needed.
|
|
|
|
The created backup sqlite3 file is overwriten on every run of the script,
|
2020-04-25 22:44:34 +00:00
|
|
|
but that's ok since BorgBackup is making daily snapshots.
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-10 09:55:22 +00:00
|
|
|
* **create a backup script**</br>
|
2020-04-09 22:52:11 +00:00
|
|
|
placed inside `bitwarden` directory on the host
|
|
|
|
|
2020-04-10 09:55:22 +00:00
|
|
|
`bitwarden-backup-script.sh`
|
2020-04-09 22:52:11 +00:00
|
|
|
```
|
2020-04-10 09:55:22 +00:00
|
|
|
#!/bin/bash
|
2020-04-09 22:52:11 +00:00
|
|
|
|
|
|
|
# CREATE SQLITE BACKUP
|
2020-04-10 09:55:22 +00:00
|
|
|
docker container exec bitwarden sqlite3 /data/db.sqlite3 ".backup '/data/BACKUP.bitwarden.db.sqlite3'"
|
2020-04-09 22:52:11 +00:00
|
|
|
```
|
|
|
|
|
2020-04-10 10:08:25 +00:00
|
|
|
the script must be **executabe** - `chmod +x bitwarden-backup-script.sh`
|
2020-04-09 22:52:11 +00:00
|
|
|
|
|
|
|
* **cronjob** on the host</br>
|
|
|
|
`crontab -e` - add new cron job</br>
|
|
|
|
`0 2 * * * /home/bastard/docker/bitwarden/bitwarden-backup-script.sh` - run it [at 02:00](https://crontab.guru/#0_2_*_*_*)</br>
|
|
|
|
`crontab -l` - list cronjobs
|
|
|
|
|
2020-04-24 21:33:34 +00:00
|
|
|
# Restore the user data
|
2020-04-09 22:52:11 +00:00
|
|
|
|
2020-04-10 09:55:22 +00:00
|
|
|
Assuming clean start.
|
|
|
|
|
|
|
|
* start the bitwarden container: `docker-compose up -d`
|
|
|
|
* let it run so it creates its file structure
|
|
|
|
* down the container `docker-compose down`
|
|
|
|
* in `bitwarden/bitwarden-data/`</br>
|
2020-04-10 10:08:25 +00:00
|
|
|
replace `db.sqlite3` with the backup one `BACKUP.bitwarden.db.sqlite3`</br>
|
2020-04-25 22:44:34 +00:00
|
|
|
replace `attachments` directory with the one from the BorgBackup repository
|
2020-04-10 09:55:22 +00:00
|
|
|
* start the container `docker-compose up -d`
|
2020-04-09 22:52:11 +00:00
|
|
|
|