nixpkgs-suyu/pkgs/tools/security/vaultwarden/default.nix

48 lines
1.4 KiB
Nix
Raw Normal View History

{ lib, stdenv, rustPlatform, fetchFromGitHub, fetchurl, nixosTests
2021-01-17 04:51:22 +01:00
, pkg-config, openssl
2021-05-11 16:40:37 +02:00
, libiconv, Security, CoreServices
2020-01-27 16:16:42 +01:00
, dbBackend ? "sqlite", libmysqlclient, postgresql }:
2019-04-23 21:25:46 +02:00
2020-01-27 16:16:42 +01:00
let
featuresFlag = "--features ${dbBackend}";
in rustPlatform.buildRustPackage rec {
pname = "vaultwarden";
version = "1.22.1";
2019-04-23 21:25:46 +02:00
src = fetchFromGitHub {
owner = "dani-garcia";
repo = pname;
rev = version;
sha256 = "sha256-aXbnNO3mTAgE1yNx7YVDo1vPpO8ACZpBGHQ633fNZ3k=";
2019-04-23 21:25:46 +02:00
};
cargoSha256 = "sha256-SFzq3OU0a0s3zlEzUkqGdZb/knYafqDamLy4ghH4i8I=";
2021-01-17 04:51:22 +01:00
nativeBuildInputs = [ pkg-config ];
2021-01-15 10:19:50 +01:00
buildInputs = with lib; [ openssl ]
2021-05-11 16:40:37 +02:00
++ optionals stdenv.isDarwin [ libiconv Security CoreServices ]
2020-01-27 16:16:42 +01:00
++ optional (dbBackend == "mysql") libmysqlclient
++ optional (dbBackend == "postgresql") postgresql;
2019-04-23 21:25:46 +02:00
RUSTC_BOOTSTRAP = 1;
2020-01-27 16:16:42 +01:00
cargoBuildFlags = [ featuresFlag ];
checkPhase = ''
runHook preCheck
echo "Running cargo cargo test ${featuresFlag} -- ''${checkFlags} ''${checkFlagsArray+''${checkFlagsArray[@]}}"
cargo test ${featuresFlag} -- ''${checkFlags} ''${checkFlagsArray+"''${checkFlagsArray[@]}"}
runHook postCheck
'';
2019-04-23 21:25:46 +02:00
passthru.tests = nixosTests.vaultwarden;
2020-06-06 12:55:50 +02:00
meta = with lib; {
2020-01-27 16:16:42 +01:00
description = "Unofficial Bitwarden compatible server written in Rust";
homepage = "https://github.com/dani-garcia/vaultwarden";
license = licenses.gpl3Only;
2019-04-23 21:25:46 +02:00
maintainers = with maintainers; [ msteen ];
};
}