2020-04-24 23:36:52 +00:00
|
|
|
{ stdenv, lib, fetchFromGitHub, substituteAll
|
2021-02-05 17:12:51 +00:00
|
|
|
, pkg-config, autoreconfHook, autoconf-archive, makeWrapper, patchelf
|
2022-04-27 09:35:20 +00:00
|
|
|
, tpm2-tss, tpm2-tools, opensc, openssl, sqlite, python3, glibc, libyaml
|
2020-04-24 23:36:52 +00:00
|
|
|
, abrmdSupport ? true, tpm2-abrmd ? null
|
2023-11-16 04:20:00 +00:00
|
|
|
, fapiSupport ? true
|
2020-04-24 23:36:52 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
|
|
|
pname = "tpm2-pkcs11";
|
2023-11-16 04:20:00 +00:00
|
|
|
version = "1.9.0";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "tpm2-software";
|
|
|
|
repo = pname;
|
|
|
|
rev = version;
|
2023-11-16 04:20:00 +00:00
|
|
|
sha256 = "sha256-SoHtgZRIYNJg4/w1MIocZAM26mkrM+UOQ+RKCh6nwCk=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
2023-11-16 04:20:00 +00:00
|
|
|
patches = [
|
|
|
|
./version.patch
|
|
|
|
./graceful-fapi-fail.patch
|
|
|
|
];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# 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 = ''
|
2023-11-16 04:20:00 +00:00
|
|
|
echo ${version} > VERSION
|
2020-04-24 23:36:52 +00:00
|
|
|
./bootstrap
|
|
|
|
'';
|
|
|
|
|
2023-11-16 04:20:00 +00:00
|
|
|
configureFlags = lib.optionals (!fapiSupport) [
|
|
|
|
# Note: this will be renamed to with-fapi in next release.
|
|
|
|
"--enable-fapi=no"
|
|
|
|
];
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
nativeBuildInputs = [
|
2021-02-05 17:12:51 +00:00
|
|
|
pkg-config autoreconfHook autoconf-archive makeWrapper patchelf
|
2020-04-24 23:36:52 +00:00
|
|
|
];
|
|
|
|
buildInputs = [
|
|
|
|
tpm2-tss tpm2-tools opensc openssl sqlite libyaml
|
2022-08-12 12:06:08 +00:00
|
|
|
(python3.withPackages (ps: with ps; [ packaging pyyaml cryptography pyasn1-modules tpm2-pytss ]))
|
2020-04-24 23:36:52 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
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 = "A PKCS#11 interface for TPM2 hardware";
|
|
|
|
homepage = "https://github.com/tpm2-software/tpm2-pkcs11";
|
|
|
|
license = licenses.bsd2;
|
|
|
|
platforms = platforms.linux;
|
2020-11-03 02:18:15 +00:00
|
|
|
maintainers = with maintainers; [ matthiasbeyer ];
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
}
|