- 
          
- 
                Notifications
    You must be signed in to change notification settings 
- Fork 2.3k
Building binary
If you don't want to build the binary yourself, you can look if bitwarden_rs was already packaged for your Linux distribution.
- 
Rust nightly(strongly recommended to use rustup)
- On a Debian based distro some general packages to make sure building should go fine install the following: build-essential,git
- 
OpenSSL(should be available in path, install through your system's package manager or use the prebuilt binaries)
 On a Debian based distro, you need to installpkgconfigandlibssl-dev
- For the SQlite3 backend on a Debian based distro you need to install libsqlite3-dev
- For the MySQL backend on a Debian based distro you need to install libmariadb-dev-compatandlibmariadb-dev
- For the PostgreSQL on a Debian based distro you need to install libpq-devandpkgconfig
- 
NodeJS(only when compiling the web-vault, install through your system's package manager, use the prebuilt binaries) or nodesource binary distribution Note: web-vault currently uses a package base (e.g. node-sass <v4.12) which requires NodeJS v11
# Compile with all backends and run
cargo run --features sqlite,mysql,postgresql --release
# or just compile with all backends (binary located in target/release/bitwarden_rs)
cargo build --features sqlite,mysql,postgresql --release# Compile with sqlite backend and run
cargo run --features sqlite --release
# or just compile with sqlite (binary located in target/release/bitwarden_rs)
cargo build --features sqlite --release# Compile with mysql backend and run
cargo run --features mysql --release
# or just compile with mysql (binary located in target/release/bitwarden_rs)
cargo build --features mysql --release# Compile with postgresql backend and run
cargo run --features postgresql --release
# or just compile with postgresql (binary located in target/release/bitwarden_rs)
cargo build --features postgresql --releaseWhen run, the server is accessible in http://localhost:8000.
Note: A previous issue meant that compilation could fail with a segfault due to an incompatibility between the Rust compiler and LLVM. As a work around an older version of the compiler could be used, e.g. cargo +nightly-2019-08-27 build --features yourbackend --release
A compiled version of the web vault can be downloaded from dani-garcia/bw_web_builds.
If you prefer to compile it manually, follow these steps:
Note: building the Vault needs ~1.5GB of RAM. On systems like a RaspberryPI with 1GB or less, please enable swapping or build it on a more powerful machine and copy the directory from there. This much memory is only needed for building it, running bitwarden_rs with vault needs only about 10MB of RAM.
- Clone the git repository at bitwarden/web and checkout the latest release tag (e.g. v2.1.1):
# clone the repository
git clone https://github.com/bitwarden/web.git web-vault
cd web-vault
# switch to the latest tag
git checkout "$(git tag --sort=v:refname | tail -n1)"- Download the patch file from dani-garcia/bw_web_builds and copy it to the web-vaultfolder. To choose the version to use, assuming the web vault is versionvX.Y.Z:- If there is a patch with version vX.Y.Z, use that one
- Otherwise, pick the one with the largest version that is still smaller than vX.Y.Z
 
- If there is a patch with version 
- Apply the patch
# In the 'web-vault' directory
git apply vX.Y.Z.patch- Then, build the Vault:
npm run sub:init
npm install
npm run distNote: You might be asked to run npm audit fix to fix vulnerability. This will automatically try to upgrade packages to newer version, which might not be compatible and break web-vault functionality``` Use it at your own risk, if you know what you are doing.
Finally copy the contents of the build folder into the destination folder:
- If you run with cargo run --release, it'sbitwarden_rs/web-vault.
- If you run the compiled binary directly, it's next to the binary, in bitwarden_rs/target/release/web-vault.
The available configuration options are documented in the default .env file, and they can be modified by uncommenting the desired options in that file or by setting their respective environment variables. See the Configuration section of this wiki for the main configuration options available.
Note: the environment variables override the values set in the .env file.
Install diesel-cli with cargo:
cargo install diesel_cli --no-default-features --features sqlite-bundledMake sure that the correct path to the database is in the .env file.
If you want to modify the schemas, create a new migration with:
diesel migration generate <name>
Modify the *.sql files, making sure that any changes are reverted in the down.sql file.
Apply the migrations and save the generated schemas as follows:
diesel migration redo
# This step should be done automatically when using diesel-cli > 1.3.0
# diesel print-schema > src/db/sqlite/schema.rsRefer to using the MySQL backend if you want to migrate from SQLite.
Refer to using the PostgreSQL backend if you want to migrate from SQLite.
- Which container image to use
- Starting a container
- Using Docker Compose
- Using Podman
- Updating the vaultwarden image
- Overview
- Enabling admin page
- SMTP configuration
- Disable registration of new users
- Disable invitations
- Enabling WebSocket notifications
- Enabling Mobile Client push notification
- Enabling SSO support using OpenId Connect
- Other configuration
- Using the MariaDB (MySQL) Backend
- Using the PostgreSQL Backend
- Running without WAL enabled
- Migrating from MariaDB (MySQL) to SQLite
- Hardening Guide
- Password hint display
- Enabling U2F and FIDO2 WebAuthn authentication
- Enabling YubiKey OTP authentication
- Fail2Ban Setup
- Fail2Ban + ModSecurity + Traefik + Docker
- Translating the email templates
- Translating admin page
- Customize Vaultwarden CSS
- Using custom website icons
- Disabling or overriding the Vault interface hosting
- Building binary
- Building your own docker image
- Git hooks
- Differences from the upstream API implementation