69 lines
1.9 KiB
Nix
69 lines
1.9 KiB
Nix
{ lib, stdenv, fetchFromGitHub, cmake, pkg-config, zip, gettext, perl
|
|
, wxGTK30, libXext, libXi, libXt, libXtst, xercesc
|
|
, qrencode, libuuid, libyubikey, yubikey-personalization
|
|
, curl, openssl, file
|
|
}:
|
|
|
|
stdenv.mkDerivation rec {
|
|
pname = "pwsafe";
|
|
version = "3.56.0";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = pname;
|
|
repo = pname;
|
|
rev = version;
|
|
sha256 = "sha256-ZLX/3cs1cdia5+32QEwE6q3V0uFNkkmiIGboKW6Xej8=";
|
|
};
|
|
|
|
nativeBuildInputs = [
|
|
cmake gettext perl pkg-config zip
|
|
];
|
|
buildInputs = [
|
|
libXext libXi libXt libXtst wxGTK30
|
|
curl qrencode libuuid openssl xercesc
|
|
libyubikey yubikey-personalization
|
|
file
|
|
];
|
|
|
|
cmakeFlags = [
|
|
"-DNO_GTEST=ON"
|
|
"-DCMAKE_CXX_FLAGS=-I${yubikey-personalization}/include/ykpers-1"
|
|
];
|
|
|
|
postPatch = ''
|
|
# Fix perl scripts used during the build.
|
|
for f in `find . -type f -name '*.pl'`; do
|
|
patchShebangs $f
|
|
done
|
|
|
|
# Fix hard coded paths.
|
|
for f in `grep -Rl /usr/share/ src`; do
|
|
substituteInPlace $f --replace /usr/share/ $out/share/
|
|
done
|
|
|
|
# Fix hard coded zip path.
|
|
substituteInPlace help/Makefile.linux --replace /usr/bin/zip ${zip}/bin/zip
|
|
|
|
for f in `grep -Rl /usr/bin/ .`; do
|
|
substituteInPlace $f --replace /usr/bin/ ""
|
|
done
|
|
'';
|
|
|
|
installFlags = [ "PREFIX=${placeholder "out"}" ];
|
|
|
|
meta = with lib; {
|
|
description = "A password database utility";
|
|
longDescription = ''
|
|
Password Safe is a password database utility. Like many other
|
|
such products, commercial and otherwise, it stores your
|
|
passwords in an encrypted file, allowing you to remember only
|
|
one password (the "safe combination"), instead of all the
|
|
username/password combinations that you use.
|
|
'';
|
|
homepage = "https://pwsafe.org/";
|
|
maintainers = with maintainers; [ c0bw3b pjones ];
|
|
platforms = platforms.linux;
|
|
license = licenses.artistic2;
|
|
};
|
|
}
|