depot/third_party/nixpkgs/pkgs/by-name/tp/tpm2-pkcs11/package.nix

125 lines
2.5 KiB
Nix

{
stdenv,
lib,
fetchFromGitHub,
substituteAll,
pkg-config,
autoreconfHook,
autoconf-archive,
makeWrapper,
patchelf,
tpm2-tss,
tpm2-tools,
opensc,
openssl,
sqlite,
python3,
glibc,
libyaml,
abrmdSupport ? true,
tpm2-abrmd ? null,
fapiSupport ? true,
}:
stdenv.mkDerivation rec {
pname = "tpm2-pkcs11";
version = "1.9.0";
src = fetchFromGitHub {
owner = "tpm2-software";
repo = pname;
rev = version;
sha256 = "sha256-SoHtgZRIYNJg4/w1MIocZAM26mkrM+UOQ+RKCh6nwCk=";
};
patches = [
./version.patch
./graceful-fapi-fail.patch
];
# The preConfigure phase doesn't seem to be working here
# ./bootstrap MUST be executed as the first step, before all
# of the autoreconfHook stuff
postPatch = ''
echo ${version} > VERSION
./bootstrap
'';
configureFlags = lib.optionals (!fapiSupport) [
# Note: this will be renamed to with-fapi in next release.
"--enable-fapi=no"
];
nativeBuildInputs = [
pkg-config
autoreconfHook
autoconf-archive
makeWrapper
patchelf
];
buildInputs = [
tpm2-tss
tpm2-tools
opensc
openssl
sqlite
libyaml
(python3.withPackages (
ps: with ps; [
packaging
pyyaml
cryptography
pyasn1-modules
tpm2-pytss
]
))
];
outputs = [
"out"
"bin"
"dev"
];
dontStrip = true;
dontPatchELF = true;
# To be able to use the userspace resource manager, the RUNPATH must
# explicitly include the tpm2-abrmd shared libraries.
preFixup =
let
rpath = lib.makeLibraryPath (
(lib.optional abrmdSupport tpm2-abrmd)
++ [
tpm2-tss
sqlite
openssl
glibc
libyaml
]
);
in
''
patchelf \
--set-rpath ${rpath} \
${lib.optionalString abrmdSupport "--add-needed ${lib.makeLibraryPath [ tpm2-abrmd ]}/libtss2-tcti-tabrmd.so"} \
--add-needed ${lib.makeLibraryPath [ tpm2-tss ]}/libtss2-tcti-device.so \
$out/lib/libtpm2_pkcs11.so.0.0.0
'';
postInstall = ''
mkdir -p $bin/bin/ $bin/share/tpm2_pkcs11/
mv ./tools/* $bin/share/tpm2_pkcs11/
makeWrapper $bin/share/tpm2_pkcs11/tpm2_ptool.py $bin/bin/tpm2_ptool \
--prefix PATH : ${lib.makeBinPath [ tpm2-tools ]}
'';
meta = with lib; {
description = "PKCS#11 interface for TPM2 hardware";
homepage = "https://github.com/tpm2-software/tpm2-pkcs11";
license = licenses.bsd2;
platforms = platforms.linux;
maintainers = [ ];
mainProgram = "tpm2_ptool";
};
}