website/integrations/security/vaultwarden/index.md
Vaultwarden is an alternative server implementation of the Bitwarden Client API, written in Rust and compatible with official Bitwarden clients, perfect for self-hosted deployment where running the official resource-heavy service might not be ideal.
The following placeholders are used in this guide:
vaultwarden.company is the FQDN of the Vaultwarden installation.authentik.company is the FQDN of the authentik installation.:::info This documentation lists only the settings that you need to change from their default values. Be aware that any changes other than those explicitly mentioned in this guide could cause issues accessing your application. :::
To support the integration of Vaultwarden with authentik, you need to create an application/provider pair in authentik.
Vaultwarden either requires the email scope to return a true value for whether the email address is verified, or no value at all. As of authentik 2025.10 the default behavior is to return email_verified: False, so a custom scope mapping is required for Vaultwarden to allow authentication.
Log in to authentik as an administrator and open the authentik Admin interface.
Navigate to Customization > Property Mappings and click Create.
Select type: select Scope Mapping.
Configure the Scope Mapping: Provide a descriptive name (e.g. Vaultwarden Email Scope), and an optional description.
emailreturn {
"email": request.user.email,
"email_verified": True
}
Click Finish to save the property mapping.
Log in to authentik as an administrator and open the authentik Admin interface.
Navigate to Applications > Applications and click Create with Provider to create an application and provider pair. (Alternatively you can first create a provider separately, then create the application and connect it with the provider.)
Strict redirect URI to https://vaultwarden.company/identity/connect/oidc-signin.offline_access scope mapping is available by adding authentik default OAuth Mapping: OpenID 'offline_access' to the selected scopes.authentik default OAuth Mapping: OpenID 'email' scope, and add the custom scope mapping you created above.Click Submit to save the new application and provider.
To configure Vaultwarden to use authentik, add the following environment variables to your Vaultwarden deployment:
SSO_ENABLED=true
SSO_AUTHORITY=https://authentik.company/application/o/<application_slug>/
SSO_CLIENT_ID=<client_id>
SSO_CLIENT_SECRET=<client_secret>
SSO_SCOPES=email profile offline_access
SSO_ALLOW_UNKNOWN_EMAIL_VERIFICATION=false
SSO_CLIENT_CACHE_EXPIRATION=0
SSO_ONLY=false # Set to true to disable email+master password login and require SSO
SSO_SIGNUPS_MATCH_EMAIL=true # Match first SSO login to existing account by email
Then restart Vaultwarden to apply the changes.
To verify the integration of authentik with Vaultwarden, log out of Vaultwarden, then on the login page enter a verified email and click Use single sign-on.