This repository helps to host your own Vaultwarden instance on your server or a raspberry-pi.
Before you begin, ensure you have the following prerequisites:
- Docker installed and configured on your server.
- Docker Compose installed.
- Traefik-Proxy installed.
- A registered domain name.
Copy this repository to your server.
git clone https://github.com/erkenes/docker-vaultwarden-server.git /docker/vaultwarden
Navigate to the repository directory:
cd /docker/vaultwarden
Copy the .env
file.
cp .env.example .env
Start the containers with
docker-compose up -d
In the docker-compose.yml file the admin-token is disabled. If this setting is disabled you are not able to open the
admin page (yourhost.local/admin
).
By default, anyone who can access your instance can register for a new account. To disable this, set the
SIGNUPS_ALLOWED
env variable to false.
You can restrict registration to email addresses from certain domains by setting SIGNUPS_DOMAINS_WHITELIST
accordingly.
Require email verification to finish the registration.
Require new device emails. When a user logs in an email is required to be sent.
Even when registration is disabled (SIGNUPS_ALLOWED
), organization administrators or owners can invite users to join
organization.
Activated the admin page. This page allows server administrators to view all the registered users and to delete them. It also shows inviting new users, even when registration is disabled.
If you have another method to authenticate the admin page then you can set the DISABLE_ADMIN_TOKEN
variable to true.
The domain of your vaultwarden instance (should be the same as VIRTUAL_HOST
).
This is required for U2F and FIDO2 WebAuthn authentication.
You need a YUBICO_CLIENT_ID
and YUBICO_SECRET_KEY
to allow authentication with a Yubikey.
If YUBICO_SERVER
is not set the default YubiCloud servers are used.
SMTP_HOST
: The host server of the mail serverSMTP_FROM
: the mail address which should be used for sending mailsSMTP_FROM_NAME
: the name which should be used for sending mailsSMTP_PORT
: the port of the smtp serverSMTP_SECURITY
: the protocol that should be used (default: starttls, options: force_tls, off, starttls)SMTP_USERNAME
: the username of the smtp userSMTP_PASSWORD
: the password of the smtp userSMTP_EMBED_IMAGES
: embed images as email attachments
This requires to set the DOMAIN
variable.
Usually, password hints are sent by email. But as vaultwarden is made with small or personal deployment in mind, hints are also available from the password hint page, so you don't have to configure an email service.
Controls whether users can change their email. This setting applies globally to all users.
LOG_LEVEL
: options are: "trace", "debug", "info", "warn", "error" or "off". NOTE: Using the log level "warn" or "error" still allows Fail2Ban to work properly.USE_SYSLOG
EXTENDED_LOGGING
To enable the push notifications you have to get a Hosting Installation id and Key from here.
PUSH_ENABLED=true
PUSH_INSTALLATION_ID=CHANGEME
PUSH_INSTALLATION_KEY=CHANGEME
To use "European Data" Region set these variables (default):
PUSH_RELAY_URI=https://push.bitwarden.eu
PUSH_IDENTITY_URI=https://identity.bitwarden.eu
if you want to use the "US Data" region use these instead:
PUSH_RELAY_URI=https://push.bitwarden.com
PUSH_IDENTITY_URI=https://identity.bitwarden.com
Controls whether users are allowed to create Bitwarden Sends.
Controls whether users can enable emergency access to their accounts.