2020-03-22 15:13:34 +00:00
|
|
|
use std::env;
|
2021-03-31 20:18:35 +00:00
|
|
|
use std::process::Command;
|
2018-12-29 23:04:22 +00:00
|
|
|
|
2021-03-31 20:18:35 +00:00
|
|
|
fn main() {
|
2020-08-18 15:15:44 +00:00
|
|
|
// This allow using #[cfg(sqlite)] instead of #[cfg(feature = "sqlite")], which helps when trying to add them through macros
|
|
|
|
#[cfg(feature = "sqlite")]
|
|
|
|
println!("cargo:rustc-cfg=sqlite");
|
|
|
|
#[cfg(feature = "mysql")]
|
|
|
|
println!("cargo:rustc-cfg=mysql");
|
|
|
|
#[cfg(feature = "postgresql")]
|
|
|
|
println!("cargo:rustc-cfg=postgresql");
|
2022-12-03 17:25:59 +00:00
|
|
|
#[cfg(feature = "query_logger")]
|
|
|
|
println!("cargo:rustc-cfg=query_logger");
|
2019-07-09 15:26:34 +00:00
|
|
|
|
2019-09-12 20:12:22 +00:00
|
|
|
#[cfg(not(any(feature = "sqlite", feature = "mysql", feature = "postgresql")))]
|
2021-03-31 20:18:35 +00:00
|
|
|
compile_error!(
|
|
|
|
"You need to enable one DB backend. To build with previous defaults do: cargo build --features sqlite"
|
|
|
|
);
|
|
|
|
|
2024-06-20 07:35:52 +00:00
|
|
|
// Use check-cfg to let cargo know which cfg's we define,
|
|
|
|
// and avoid warnings when they are used in the code.
|
|
|
|
println!("cargo::rustc-check-cfg=cfg(sqlite)");
|
|
|
|
println!("cargo::rustc-check-cfg=cfg(mysql)");
|
|
|
|
println!("cargo::rustc-check-cfg=cfg(postgresql)");
|
|
|
|
println!("cargo::rustc-check-cfg=cfg(query_logger)");
|
|
|
|
|
2023-12-09 22:04:33 +00:00
|
|
|
// Rerun when these paths are changed.
|
|
|
|
// Someone could have checked-out a tag or specific commit, but no other files changed.
|
|
|
|
println!("cargo:rerun-if-changed=.git");
|
|
|
|
println!("cargo:rerun-if-changed=.git/HEAD");
|
|
|
|
println!("cargo:rerun-if-changed=.git/index");
|
|
|
|
println!("cargo:rerun-if-changed=.git/refs/tags");
|
|
|
|
|
2022-12-03 17:25:59 +00:00
|
|
|
#[cfg(all(not(debug_assertions), feature = "query_logger"))]
|
2023-10-05 17:08:26 +00:00
|
|
|
compile_error!("Query Logging is only allowed during development, it is not intended for production usage!");
|
2022-12-03 17:25:59 +00:00
|
|
|
|
2022-01-23 22:40:59 +00:00
|
|
|
// Support $BWRS_VERSION for legacy compatibility, but default to $VW_VERSION.
|
|
|
|
// If neither exist, read from git.
|
|
|
|
let maybe_vaultwarden_version =
|
|
|
|
env::var("VW_VERSION").or_else(|_| env::var("BWRS_VERSION")).or_else(|_| version_from_git_info());
|
|
|
|
|
|
|
|
if let Ok(version) = maybe_vaultwarden_version {
|
2022-12-03 17:25:59 +00:00
|
|
|
println!("cargo:rustc-env=VW_VERSION={version}");
|
|
|
|
println!("cargo:rustc-env=CARGO_PKG_VERSION={version}");
|
2020-03-22 15:13:34 +00:00
|
|
|
}
|
2018-12-29 23:04:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn run(args: &[&str]) -> Result<String, std::io::Error> {
|
|
|
|
let out = Command::new(args[0]).args(&args[1..]).output()?;
|
2019-02-10 14:46:51 +00:00
|
|
|
if !out.status.success() {
|
|
|
|
use std::io::{Error, ErrorKind};
|
|
|
|
return Err(Error::new(ErrorKind::Other, "Command not successful"));
|
|
|
|
}
|
2018-12-29 23:04:22 +00:00
|
|
|
Ok(String::from_utf8(out.stdout).unwrap().trim().to_string())
|
|
|
|
}
|
|
|
|
|
|
|
|
/// This method reads info from Git, namely tags, branch, and revision
|
2022-01-23 22:40:59 +00:00
|
|
|
/// To access these values, use:
|
2024-02-08 21:16:29 +00:00
|
|
|
/// - `env!("GIT_EXACT_TAG")`
|
|
|
|
/// - `env!("GIT_LAST_TAG")`
|
|
|
|
/// - `env!("GIT_BRANCH")`
|
|
|
|
/// - `env!("GIT_REV")`
|
|
|
|
/// - `env!("VW_VERSION")`
|
2022-01-23 22:40:59 +00:00
|
|
|
fn version_from_git_info() -> Result<String, std::io::Error> {
|
2018-12-29 23:04:22 +00:00
|
|
|
// The exact tag for the current commit, can be empty when
|
|
|
|
// the current commit doesn't have an associated tag
|
2019-02-10 14:46:51 +00:00
|
|
|
let exact_tag = run(&["git", "describe", "--abbrev=0", "--tags", "--exact-match"]).ok();
|
|
|
|
if let Some(ref exact) = exact_tag {
|
2022-12-03 17:25:59 +00:00
|
|
|
println!("cargo:rustc-env=GIT_EXACT_TAG={exact}");
|
2019-02-10 14:46:51 +00:00
|
|
|
}
|
2018-12-29 23:04:22 +00:00
|
|
|
|
|
|
|
// The last available tag, equal to exact_tag when
|
|
|
|
// the current commit is tagged
|
|
|
|
let last_tag = run(&["git", "describe", "--abbrev=0", "--tags"])?;
|
2022-12-03 17:25:59 +00:00
|
|
|
println!("cargo:rustc-env=GIT_LAST_TAG={last_tag}");
|
2018-12-29 23:04:22 +00:00
|
|
|
|
|
|
|
// The current branch name
|
|
|
|
let branch = run(&["git", "rev-parse", "--abbrev-ref", "HEAD"])?;
|
2022-12-03 17:25:59 +00:00
|
|
|
println!("cargo:rustc-env=GIT_BRANCH={branch}");
|
2018-12-29 23:04:22 +00:00
|
|
|
|
|
|
|
// The current git commit hash
|
|
|
|
let rev = run(&["git", "rev-parse", "HEAD"])?;
|
2019-02-10 14:46:51 +00:00
|
|
|
let rev_short = rev.get(..8).unwrap_or_default();
|
2022-12-03 17:25:59 +00:00
|
|
|
println!("cargo:rustc-env=GIT_REV={rev_short}");
|
2018-12-29 23:04:22 +00:00
|
|
|
|
2019-02-10 14:46:51 +00:00
|
|
|
// Combined version
|
2022-01-23 22:40:59 +00:00
|
|
|
if let Some(exact) = exact_tag {
|
|
|
|
Ok(exact)
|
2023-07-04 22:08:52 +00:00
|
|
|
} else if &branch != "main" && &branch != "master" && &branch != "HEAD" {
|
2022-12-03 17:25:59 +00:00
|
|
|
Ok(format!("{last_tag}-{rev_short} ({branch})"))
|
2019-02-10 14:46:51 +00:00
|
|
|
} else {
|
2022-12-03 17:25:59 +00:00
|
|
|
Ok(format!("{last_tag}-{rev_short}"))
|
2022-01-23 22:40:59 +00:00
|
|
|
}
|
2018-12-29 23:04:22 +00:00
|
|
|
}
|