finallycoffee.services.vaultwarden
ansible role
Vaultwarden is an unofficial (not associated with Bitwarden) bitwarden API compatible
server backend, formally called bitwarden_rs
, written in rust.
This ansible role can deploy and configure vaultwarden
, and supports removing
itself using vaultwarden_state: absent
(Warning: It does not ask for confirmation,
and will remove all user data when instructed to remove it).
Configuration
To use this role, the following variables need to be populated:
vaultwarden_config_domain
- always. Changing this will lead to two-factor not working for two-factor methods registered in the past.vaultwarden_config_admin_token
- ifvaultwarden_config_disable_admin_token
isfalse
.
Setting other configuration values for vaultwarden can be done using role-provided flattened keys in the
vaultwarden_config_*
namespace (see defaults/main/config.yml
for available variables),
or by setting the configuration directly in the same structure as the config.json
would be in vaultwarden_config
.
Configure mailing by first enabling SMTP using vaultwarden_config_enable_smtp: true
,
then configure your email server like this:
vaultwarden_config:
smtp_host: "mail.example.com"
smtp_explicit_tls: true
smtp_port: 465
smtp_from: "noreply+vaultwarden@example.com"
smtp_from_name: "'Example.com Vaultwarden instance' <noreply+vaultwarden@example.com>"
smtp_username: vaultwarden@example.com
smtp_password: i_hope_i_will_be_a_strong_one!
helo_name: "{{ vaultwarden_config_domain }}"
2FA via email
To enable email-based two-factor-authentication, set vaultwarden_config_enable_email_2fa: true
and optionally set the following configuration:
vaultwarden_config:
email_token_size: 8
email_expiration_time: 300 # 300 seconds = 5min
email_attempts_limit: 3
Feature flags
To enable more authentication methods, toggles are provided in
vaultwarden_config_enable_*
.
It is genereally recommended to simply keep unused methods off.
Per default, 'Sends' are allowed.