nixpkgs/pkgs/by-name/gn/gnome-keyring/package.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

109 lines
2.5 KiB
Nix
Raw Normal View History

2021-03-26 20:04:58 +00:00
{ lib
, stdenv
, fetchurl
, pkg-config
, dbus
, libgcrypt
, pam
, python3
2021-03-26 20:04:58 +00:00
, glib
, libxslt
, gettext
, gcr
, libcap_ng
, libselinux
, p11-kit
, openssh
, wrapGAppsHook3
2021-03-26 20:04:58 +00:00
, docbook-xsl-nons
, docbook_xml_dtd_43
, gnome
, useWrappedDaemon ? true
2021-03-26 20:04:58 +00:00
}:
stdenv.mkDerivation rec {
pname = "gnome-keyring";
version = "46.1";
2021-03-26 20:04:58 +00:00
outputs = [ "out" "dev" ];
src = fetchurl {
2021-03-26 20:04:58 +00:00
url = "mirror://gnome/sources/gnome-keyring/${lib.versions.major version}/${pname}-${version}.tar.xz";
hash = "sha256-sdOukTL/L4s/JaGQeQiSlo49Cs+VKkh+QPZEqFUM4/Y=";
};
2021-03-26 20:04:58 +00:00
nativeBuildInputs = [
pkg-config
gettext
libxslt
docbook-xsl-nons
docbook_xml_dtd_43
wrapGAppsHook3
];
2018-08-09 23:04:52 +00:00
buildInputs = [
2021-03-26 20:04:58 +00:00
glib
libgcrypt
pam
openssh
libcap_ng
libselinux
gcr
p11-kit
];
nativeCheckInputs = [ dbus python3 ];
configureFlags = [
"--with-pkcs11-config=${placeholder "out"}/etc/pkcs11/" # installation directories
"--with-pkcs11-modules=${placeholder "out"}/lib/pkcs11/"
# gnome-keyring doesn't build with ssh-agent by default anymore, we need to
# switch to using gcr https://github.com/NixOS/nixpkgs/issues/140824
"--enable-ssh-agent"
# cross compilation requires these paths to be explicitly declared:
"LIBGCRYPT_CONFIG=${lib.getExe' (lib.getDev libgcrypt) "libgcrypt-config"}"
"SSH_ADD=${lib.getExe' openssh "ssh-add"}"
"SSH_AGENT=${lib.getExe' openssh "ssh-agent"}"
];
# Tends to fail non-deterministically.
# - https://github.com/NixOS/nixpkgs/issues/55293
# - https://github.com/NixOS/nixpkgs/issues/51121
doCheck = false;
2021-03-26 20:04:58 +00:00
postPatch = ''
patchShebangs build
'';
2018-08-08 18:25:45 +00:00
checkPhase = ''
export HOME=$(mktemp -d)
dbus-run-session \
2022-11-21 02:03:50 +00:00
--config-file=${dbus}/share/dbus-1/session.conf \
make check
'';
# Use wrapped gnome-keyring-daemon with cap_ipc_lock=ep
postFixup = lib.optionalString useWrappedDaemon ''
files=($out/etc/xdg/autostart/* $out/share/dbus-1/services/*)
for file in ''${files[*]}; do
substituteInPlace $file \
--replace "$out/bin/gnome-keyring-daemon" "/run/wrappers/bin/gnome-keyring-daemon"
done
'';
2018-08-09 23:04:52 +00:00
passthru = {
updateScript = gnome.updateScript {
2018-08-09 23:04:52 +00:00
packageName = "gnome-keyring";
};
};
meta = with lib; {
description = "Collection of components in GNOME that store secrets, passwords, keys, certificates and make them available to applications";
homepage = "https://gitlab.gnome.org/GNOME/gnome-keyring";
license = licenses.gpl2;
maintainers = teams.gnome.members;
platforms = platforms.linux;
};
}