2018-02-09 19:00:55 -05:00
|
|
|
[package]
|
2021-04-27 17:18:32 -04:00
|
|
|
name = "vaultwarden"
|
2018-08-21 16:21:54 -04:00
|
|
|
version = "1.0.0"
|
2018-02-09 19:00:55 -05:00
|
|
|
authors = ["Daniel García <dani-garcia@users.noreply.github.com>"]
|
2021-11-05 14:18:54 -04:00
|
|
|
edition = "2021"
|
2024-02-08 16:16:29 -05:00
|
|
|
rust-version = "1.74.0"
|
2021-09-22 14:26:48 -04:00
|
|
|
resolver = "2"
|
2018-02-09 19:00:55 -05:00
|
|
|
|
2021-04-27 17:18:32 -04:00
|
|
|
repository = "https://github.com/dani-garcia/vaultwarden"
|
2018-12-29 18:04:22 -05:00
|
|
|
readme = "README.md"
|
2022-06-16 09:13:10 -04:00
|
|
|
license = "AGPL-3.0-only"
|
2018-12-29 18:04:22 -05:00
|
|
|
publish = false
|
|
|
|
build = "build.rs"
|
|
|
|
|
2018-12-06 14:35:25 -05:00
|
|
|
[features]
|
2021-11-07 12:53:39 -05:00
|
|
|
# default = ["sqlite"]
|
2019-03-29 15:27:20 -04:00
|
|
|
# Empty to keep compatibility, prefer to set USE_SYSLOG=true
|
|
|
|
enable_syslog = []
|
2019-05-27 16:58:52 -04:00
|
|
|
mysql = ["diesel/mysql", "diesel_migrations/mysql"]
|
2020-01-18 14:09:52 -05:00
|
|
|
postgresql = ["diesel/postgres", "diesel_migrations/postgres"]
|
2019-05-27 17:31:56 -04:00
|
|
|
sqlite = ["diesel/sqlite", "diesel_migrations/sqlite", "libsqlite3-sys"]
|
2020-09-25 17:23:13 -04:00
|
|
|
# Enable to use a vendored and statically linked openssl
|
|
|
|
vendored_openssl = ["openssl/vendored"]
|
2022-03-20 13:51:24 -04:00
|
|
|
# Enable MiMalloc memory allocator to replace the default malloc
|
|
|
|
# This can improve performance for Alpine builds
|
|
|
|
enable_mimalloc = ["mimalloc"]
|
2022-12-03 12:25:59 -05:00
|
|
|
# This is a development dependency, and should only be used during development!
|
|
|
|
# It enables the usage of the diesel_logger crate, which is able to output the generated queries.
|
|
|
|
# You also need to set an env variable `QUERY_LOGGER=1` to fully activate this so you do not have to re-compile
|
|
|
|
# if you want to turn off the logging for a specific run.
|
|
|
|
query_logger = ["diesel_logger"]
|
2018-12-06 14:35:25 -05:00
|
|
|
|
2020-07-14 17:44:01 -04:00
|
|
|
# Enable unstable features, requires nightly
|
2020-09-11 17:52:20 -04:00
|
|
|
# Currently only used to enable rusts official ip support
|
2020-07-14 17:44:01 -04:00
|
|
|
unstable = []
|
|
|
|
|
2019-04-02 16:35:22 -04:00
|
|
|
[target."cfg(not(windows))".dependencies]
|
2022-02-07 16:26:22 -05:00
|
|
|
# Logging
|
2023-04-30 11:18:12 -04:00
|
|
|
syslog = "6.1.0"
|
2019-04-02 16:35:22 -04:00
|
|
|
|
2018-02-09 19:00:55 -05:00
|
|
|
[dependencies]
|
2022-02-07 16:26:22 -05:00
|
|
|
# Logging
|
2023-08-28 10:48:42 -04:00
|
|
|
log = "0.4.20"
|
2023-09-22 11:03:41 -04:00
|
|
|
fern = { version = "0.6.2", features = ["syslog-6", "reopen-1"] }
|
2023-10-22 18:18:38 -04:00
|
|
|
tracing = { version = "0.1.40", features = ["log"] } # Needed to have lettre and webauthn-rs trace logging to work
|
2022-05-04 15:13:05 -04:00
|
|
|
|
2022-02-07 16:26:22 -05:00
|
|
|
# A `dotenv` implementation for Rust
|
2023-03-22 16:30:07 -04:00
|
|
|
dotenvy = { version = "0.15.7", default-features = false }
|
2021-05-16 09:29:13 -04:00
|
|
|
|
2022-02-07 16:26:22 -05:00
|
|
|
# Lazy initialization
|
2023-12-09 17:04:33 -05:00
|
|
|
once_cell = "1.19.0"
|
2018-02-09 19:00:55 -05:00
|
|
|
|
2022-02-07 16:26:22 -05:00
|
|
|
# Numerical libraries
|
2024-02-08 16:16:29 -05:00
|
|
|
num-traits = "0.2.18"
|
|
|
|
num-derive = "0.4.2"
|
2024-01-26 20:43:26 -05:00
|
|
|
bigdecimal = "0.4.2"
|
2022-02-07 16:26:22 -05:00
|
|
|
|
|
|
|
# Web framework
|
2023-12-04 14:26:11 -05:00
|
|
|
rocket = { version = "0.5.0", features = ["tls", "json"], default-features = false }
|
|
|
|
rocket_ws = { version ="0.1.0" }
|
2018-08-30 11:43:46 -04:00
|
|
|
|
2022-02-07 16:26:22 -05:00
|
|
|
# WebSockets libraries
|
2023-11-15 04:41:14 -05:00
|
|
|
tokio-tungstenite = "0.20.1"
|
2023-06-11 12:11:09 -04:00
|
|
|
rmpv = "1.0.1" # MessagePack library
|
2023-02-08 11:13:14 -05:00
|
|
|
|
|
|
|
# Concurrent HashMap used for WebSocket messaging and favicons
|
2023-08-28 10:48:42 -04:00
|
|
|
dashmap = "5.5.3"
|
2018-08-30 11:43:46 -04:00
|
|
|
|
2022-02-07 16:26:22 -05:00
|
|
|
# Async futures
|
2024-01-01 09:41:54 -05:00
|
|
|
futures = "0.3.30"
|
2024-02-02 12:30:54 -05:00
|
|
|
tokio = { version = "1.36.0", features = ["rt-multi-thread", "fs", "io-util", "parking_lot", "time", "signal"] }
|
2018-08-30 11:43:46 -04:00
|
|
|
|
2018-02-09 19:00:55 -05:00
|
|
|
# A generic serialization/deserialization framework
|
2024-02-02 12:30:54 -05:00
|
|
|
serde = { version = "1.0.196", features = ["derive"] }
|
|
|
|
serde_json = "1.0.113"
|
2018-12-06 14:35:25 -05:00
|
|
|
|
2018-02-09 19:00:55 -05:00
|
|
|
# A safe, extensible ORM and Query builder
|
2024-01-26 20:43:26 -05:00
|
|
|
diesel = { version = "2.1.4", features = ["chrono", "r2d2", "numeric"] }
|
2023-05-26 08:53:13 -04:00
|
|
|
diesel_migrations = "2.1.0"
|
2023-06-04 16:14:51 -04:00
|
|
|
diesel_logger = { version = "0.3.0", optional = true }
|
2019-05-26 17:02:41 -04:00
|
|
|
|
2023-02-08 11:13:14 -05:00
|
|
|
# Bundled/Static SQLite
|
2023-11-15 04:41:14 -05:00
|
|
|
libsqlite3-sys = { version = "0.27.0", features = ["bundled"], optional = true }
|
2018-05-07 15:33:54 -04:00
|
|
|
|
2020-08-22 19:07:53 -04:00
|
|
|
# Crypto-related libraries
|
2022-06-04 09:13:10 -04:00
|
|
|
rand = { version = "0.8.5", features = ["small_rng"] }
|
Several small fixes for open issues (#4143)
* Fix BWDC when re-run with cleared cache
Using the BWDC with a cleared cache caused invited users to be converted
to accepted users.
The problem was a wrong check for the `restore` function.
Fixes #4114
* Remove useless variable
During some refactoring this seems to be overlooked.
This variable gets filled but isn't used at all afterwards.
Fixes #4105
* Check some `.git` paths to force a rebuild
When a checked-out repo switches to a specific tag, and that tag does
not have anything else changed in the files except the tag, it could
happen that the build process doesn't see any changes, while it could be
that the version string needs to be different.
This commit ensures that if some specific paths are changed within the
.git directory, cargo will be triggered to rebuild.
Fixes #4087
* Do not delete dir on file delete
Previously during a `delete_file` check we also tried to delete the
parent directory and ignored all errors, like not being empty for
example.
Since this function is called `delete_file` and does not mention
anything in regards to a directory i have removed that code and it will
now only delete the file and leave the rest as-is.
If this somehow is still needed or wanted, which i do not think we want,
then we should create a new function.
Fixes #4081
* Fix healthcheck when using an ENV file
If someone is using a `.env` file or configured the `ENV_FILE` variable
to use that as it's configuration, this was missed by the healthcheck.
So, `DOMAIN` and `ROCKET_TLS` were not seen, and not used in these cases.
This commit fixes this by checking for this file and if it exists, then
it will load those variables first.
Fixes #4112
* Add missing route
While there was a function and a derive, this endpoint wasn't part of
the routes. Since Bitwarden does have this endpoint ill add the route
instead of deleting it.
Fixes #4076
Fixes #4144
* Update crates to update the openssl crate
Because of a bug in the openssl-sys crate we pinned the version to an
older version. This issue has been fixed and was released 2 days ago.
This commit updates the openssl crates including others.
This should also fix the issues with building Vaultwarden using newer
versions of LibreSSL.
Fixes #4051
2023-12-08 19:21:14 -05:00
|
|
|
ring = "0.17.7"
|
2018-02-09 19:00:55 -05:00
|
|
|
|
|
|
|
# UUID generation
|
2024-01-26 14:19:53 -05:00
|
|
|
uuid = { version = "1.7.0", features = ["v4"] }
|
2018-02-09 19:00:55 -05:00
|
|
|
|
2020-07-08 00:30:18 -04:00
|
|
|
# Date and time libraries
|
2024-01-26 14:19:53 -05:00
|
|
|
chrono = { version = "0.4.33", features = ["clock", "serde"], default-features = false }
|
2024-01-01 09:41:54 -05:00
|
|
|
chrono-tz = "0.8.5"
|
2024-02-08 16:16:29 -05:00
|
|
|
time = "0.3.34"
|
2018-02-09 19:00:55 -05:00
|
|
|
|
2021-04-02 23:16:49 -04:00
|
|
|
# Job scheduler
|
2023-02-08 11:13:14 -05:00
|
|
|
job_scheduler_ng = "2.0.4"
|
2021-04-02 23:16:49 -04:00
|
|
|
|
2022-02-07 16:26:22 -05:00
|
|
|
# Data encoding library Hex/Base32/Base64
|
2023-12-04 14:26:11 -05:00
|
|
|
data-encoding = "2.5.0"
|
2018-02-09 19:00:55 -05:00
|
|
|
|
|
|
|
# JWT library
|
2023-12-04 14:26:11 -05:00
|
|
|
jsonwebtoken = "9.2.0"
|
2018-02-09 19:00:55 -05:00
|
|
|
|
2022-02-07 16:26:22 -05:00
|
|
|
# TOTP library
|
2023-11-15 04:41:14 -05:00
|
|
|
totp-lite = "2.0.1"
|
2018-07-12 15:46:50 -04:00
|
|
|
|
2018-11-15 20:34:17 -05:00
|
|
|
# Yubico Library
|
2022-05-11 16:03:07 -04:00
|
|
|
yubico = { version = "0.11.0", features = ["online-tokio"], default-features = false }
|
2018-11-15 20:34:17 -05:00
|
|
|
|
2022-03-27 11:25:04 -04:00
|
|
|
# WebAuthn libraries
|
2022-02-07 16:26:22 -05:00
|
|
|
webauthn-rs = "0.3.2"
|
2018-02-09 19:00:55 -05:00
|
|
|
|
2023-02-08 11:13:14 -05:00
|
|
|
# Handling of URL's for WebAuthn and favicons
|
2023-12-04 14:26:11 -05:00
|
|
|
url = "2.5.0"
|
2018-07-12 15:46:50 -04:00
|
|
|
|
2023-02-08 11:13:14 -05:00
|
|
|
# Email libraries
|
2024-02-02 12:30:54 -05:00
|
|
|
lettre = { version = "0.11.4", features = ["smtp-transport", "sendmail-transport", "builder", "serde", "tokio1-native-tls", "hostname", "tracing", "tokio1"], default-features = false }
|
2023-12-04 14:26:11 -05:00
|
|
|
percent-encoding = "2.3.1" # URL encoding library used for URL's in the emails
|
2022-11-04 07:56:02 -04:00
|
|
|
email_address = "0.2.4"
|
2018-08-15 02:32:19 -04:00
|
|
|
|
2023-02-08 11:13:14 -05:00
|
|
|
# HTML Template library
|
2024-02-02 12:30:54 -05:00
|
|
|
handlebars = { version = "5.1.0", features = ["dir_source"] }
|
2019-01-12 19:39:29 -05:00
|
|
|
|
2023-02-08 11:13:14 -05:00
|
|
|
# HTTP client (Used for favicons, version check, DUO and HIBP API)
|
2024-02-02 12:30:54 -05:00
|
|
|
reqwest = { version = "0.11.24", features = ["stream", "json", "gzip", "brotli", "socks", "cookies", "trust-dns", "native-tls-alpn"] }
|
2022-02-07 16:26:22 -05:00
|
|
|
|
2023-02-08 11:13:14 -05:00
|
|
|
# Favicon extraction libraries
|
2023-06-11 12:11:09 -04:00
|
|
|
html5gum = "0.5.7"
|
2024-01-26 14:19:53 -05:00
|
|
|
regex = { version = "1.10.3", features = ["std", "perf", "unicode-perl"], default-features = false }
|
2023-12-04 14:26:11 -05:00
|
|
|
data-url = "0.3.1"
|
2023-10-22 18:18:38 -04:00
|
|
|
bytes = "1.5.0"
|
2023-02-08 11:13:14 -05:00
|
|
|
|
|
|
|
# Cache function results (Used for version check and favicon fetching)
|
2024-01-26 14:19:53 -05:00
|
|
|
cached = { version = "0.48.1", features = ["async"] }
|
2022-02-07 16:26:22 -05:00
|
|
|
|
|
|
|
# Used for custom short lived cookie jar during favicon extraction
|
2024-02-02 12:30:54 -05:00
|
|
|
cookie = "0.17.0"
|
|
|
|
cookie_store = "0.20.0"
|
2019-01-27 09:39:19 -05:00
|
|
|
|
2023-02-08 11:13:14 -05:00
|
|
|
# Used by U2F, JWT and PostgreSQL
|
2024-01-26 14:19:53 -05:00
|
|
|
openssl = "0.10.63"
|
2019-09-12 16:12:22 -04:00
|
|
|
|
2020-03-02 14:57:06 -05:00
|
|
|
# CLI argument parsing
|
2022-06-04 13:16:36 -04:00
|
|
|
pico-args = "0.5.0"
|
2020-03-02 14:57:06 -05:00
|
|
|
|
2020-08-18 11:15:44 -04:00
|
|
|
# Macro ident concatenation
|
2023-06-11 12:11:09 -04:00
|
|
|
paste = "1.0.14"
|
|
|
|
governor = "0.6.0"
|
2020-08-18 11:15:44 -04:00
|
|
|
|
2022-11-07 11:13:34 -05:00
|
|
|
# Check client versions for specific features.
|
2024-01-12 14:44:37 -05:00
|
|
|
semver = "1.0.21"
|
2022-11-07 11:13:34 -05:00
|
|
|
|
2022-03-20 13:51:24 -04:00
|
|
|
# Allow overriding the default memory allocator
|
|
|
|
# Mainly used for the musl builds, since the default musl malloc is very slow
|
2023-10-22 18:18:38 -04:00
|
|
|
mimalloc = { version = "0.1.39", features = ["secure"], default-features = false, optional = true }
|
2024-01-26 14:19:53 -05:00
|
|
|
which = "6.0.0"
|
2022-03-20 13:51:24 -04:00
|
|
|
|
2023-02-28 17:09:51 -05:00
|
|
|
# Argon2 library with support for the PHC format
|
2024-01-26 14:19:53 -05:00
|
|
|
argon2 = "0.5.3"
|
2023-02-28 17:09:51 -05:00
|
|
|
|
|
|
|
# Reading a password from the cli for generating the Argon2id ADMIN_TOKEN
|
2023-11-15 04:41:14 -05:00
|
|
|
rpassword = "7.3.1"
|
2023-03-30 11:18:59 -04:00
|
|
|
|
2023-10-22 18:18:38 -04:00
|
|
|
|
2022-02-22 14:48:00 -05:00
|
|
|
# Strip debuginfo from the release builds
|
2023-12-04 14:26:11 -05:00
|
|
|
# The symbols are the provide better panic traces
|
|
|
|
# Also enable fat LTO and use 1 codegen unit for optimizations
|
2022-02-22 14:48:00 -05:00
|
|
|
[profile.release]
|
|
|
|
strip = "debuginfo"
|
2023-12-04 14:26:11 -05:00
|
|
|
lto = "fat"
|
|
|
|
codegen-units = 1
|
2023-02-28 17:09:51 -05:00
|
|
|
|
2023-03-04 13:18:38 -05:00
|
|
|
|
|
|
|
# A little bit of a speedup
|
|
|
|
[profile.dev]
|
|
|
|
split-debuginfo = "unpacked"
|
2023-10-22 18:18:38 -04:00
|
|
|
|
|
|
|
# Always build argon2 using opt-level 3
|
|
|
|
# This is a huge speed improvement during testing
|
|
|
|
[profile.dev.package.argon2]
|
|
|
|
opt-level = 3
|
2023-12-18 15:46:53 -05:00
|
|
|
|
|
|
|
# Optimize for size
|
|
|
|
[profile.release-micro]
|
|
|
|
inherits = "release"
|
|
|
|
opt-level = "z"
|
|
|
|
strip = "symbols"
|
|
|
|
lto = "fat"
|
|
|
|
codegen-units = 1
|
|
|
|
panic = "abort"
|
2024-02-08 16:16:29 -05:00
|
|
|
|
|
|
|
# Profile for systems with low resources
|
|
|
|
# It will use less resources during build
|
|
|
|
[profile.release-low]
|
|
|
|
inherits = "release"
|
|
|
|
strip = "symbols"
|
|
|
|
lto = "thin"
|
2024-02-10 07:04:08 -05:00
|
|
|
codegen-units = 16
|
2024-02-08 16:16:29 -05:00
|
|
|
|
|
|
|
# Linting config
|
|
|
|
[lints.rust]
|
|
|
|
# Forbid
|
|
|
|
unsafe_code = "forbid"
|
|
|
|
non_ascii_idents = "forbid"
|
|
|
|
|
|
|
|
# Deny
|
|
|
|
future_incompatible = "deny"
|
|
|
|
noop_method_call = "deny"
|
|
|
|
pointer_structural_match = "deny"
|
|
|
|
rust_2018_idioms = "deny"
|
|
|
|
rust_2021_compatibility = "deny"
|
|
|
|
trivial_casts = "deny"
|
|
|
|
trivial_numeric_casts = "deny"
|
|
|
|
unused = "deny"
|
|
|
|
unused_import_braces = "deny"
|
|
|
|
unused_lifetimes = "deny"
|
|
|
|
deprecated_in_future = "deny"
|
|
|
|
|
|
|
|
[lints.clippy]
|
|
|
|
# Allow
|
|
|
|
# We need this since Rust v1.76+, since it has some bugs
|
|
|
|
# https://github.com/rust-lang/rust-clippy/issues/12016
|
|
|
|
blocks_in_conditions = "allow"
|
|
|
|
|
|
|
|
# Deny
|
|
|
|
cast_lossless = "deny"
|
|
|
|
clone_on_ref_ptr = "deny"
|
|
|
|
equatable_if_let = "deny"
|
|
|
|
float_cmp_const = "deny"
|
|
|
|
inefficient_to_string = "deny"
|
|
|
|
iter_on_empty_collections = "deny"
|
|
|
|
iter_on_single_items = "deny"
|
|
|
|
linkedlist = "deny"
|
|
|
|
macro_use_imports = "deny"
|
|
|
|
manual_assert = "deny"
|
|
|
|
manual_instant_elapsed = "deny"
|
|
|
|
manual_string_new = "deny"
|
|
|
|
match_wildcard_for_single_variants = "deny"
|
|
|
|
mem_forget = "deny"
|
|
|
|
needless_lifetimes = "deny"
|
|
|
|
string_add_assign = "deny"
|
|
|
|
string_to_string = "deny"
|
|
|
|
unnecessary_join = "deny"
|
|
|
|
unnecessary_self_imports = "deny"
|
|
|
|
unused_async = "deny"
|
|
|
|
verbose_file_reads = "deny"
|
|
|
|
zero_sized_map_values = "deny"
|