55fa570046
Don't add the testing "webcam" device, which is unexpected to see when querying what devices fwupd believes exist :). Won't change behavior for anyone defining the blacklistPlugin option already, but doesn't seem worth making more complicated.
124 lines
4.4 KiB
Nix
124 lines
4.4 KiB
Nix
{ stdenv, fetchurl, gtk-doc, pkgconfig, gobject-introspection, intltool
|
||
, libgudev, polkit, libxmlb, gusb, sqlite, libarchive, glib-networking
|
||
, libsoup, help2man, gpgme, libxslt, elfutils, libsmbios, efivar, glibcLocales
|
||
, gnu-efi, libyaml, valgrind, meson, libuuid, colord, docbook_xml_dtd_43, docbook_xsl
|
||
, ninja, gcab, gnutls, python3, wrapGAppsHook, json-glib, bash-completion
|
||
, shared-mime-info, umockdev, vala, makeFontsConf, freefont_ttf
|
||
, cairo, freetype, fontconfig, pango
|
||
}:
|
||
let
|
||
# Updating? Keep $out/etc synchronized with passthru.filesInstalledToEtc
|
||
version = "1.2.3";
|
||
python = python3.withPackages (p: with p; [ pygobject3 pycairo pillow ]);
|
||
installedTestsPython = python3.withPackages (p: with p; [ pygobject3 requests ]);
|
||
|
||
fontsConf = makeFontsConf {
|
||
fontDirectories = [ freefont_ttf ];
|
||
};
|
||
in stdenv.mkDerivation {
|
||
name = "fwupd-${version}";
|
||
src = fetchurl {
|
||
url = "https://people.freedesktop.org/~hughsient/releases/fwupd-${version}.tar.xz";
|
||
sha256 = "11qpgincndahq96rbm2kgcy9kw5n9cmbbilsrqcqcyk7mvv464sl";
|
||
};
|
||
|
||
outputs = [ "out" "dev" "devdoc" "man" "installedTests" ];
|
||
|
||
nativeBuildInputs = [
|
||
meson ninja gtk-doc pkgconfig gobject-introspection intltool glibcLocales shared-mime-info
|
||
valgrind gcab docbook_xml_dtd_43 docbook_xsl help2man libxslt python wrapGAppsHook vala
|
||
];
|
||
buildInputs = [
|
||
polkit libxmlb gusb sqlite libarchive libsoup elfutils libsmbios gnu-efi libyaml
|
||
libgudev colord gpgme libuuid gnutls glib-networking efivar json-glib umockdev
|
||
bash-completion cairo freetype fontconfig pango
|
||
];
|
||
|
||
LC_ALL = "en_US.UTF-8"; # For po/make-images
|
||
|
||
patches = [
|
||
./fix-paths.patch
|
||
./add-option-for-installation-sysconfdir.patch
|
||
];
|
||
|
||
postPatch = ''
|
||
# needs a different set of modules than po/make-images
|
||
escapedInterpreterLine=$(echo "${installedTestsPython}/bin/python3" | sed 's|\\|\\\\|g')
|
||
sed -i -e "1 s|.*|#\!$escapedInterpreterLine|" data/installed-tests/hardware.py
|
||
|
||
patchShebangs .
|
||
substituteInPlace data/installed-tests/fwupdmgr.test.in --subst-var-by installedtestsdir "$installedTests/share/installed-tests/fwupd"
|
||
'';
|
||
|
||
# /etc/os-release not available in sandbox
|
||
# doCheck = true;
|
||
|
||
preFixup = ''
|
||
gappsWrapperArgs+=(--prefix XDG_DATA_DIRS : "${shared-mime-info}/share")
|
||
'';
|
||
|
||
mesonFlags = [
|
||
"-Dplugin_dummy=true"
|
||
"-Dudevdir=lib/udev"
|
||
"-Dsystemdunitdir=lib/systemd/system"
|
||
"-Defi-libdir=${gnu-efi}/lib"
|
||
"-Defi-ldsdir=${gnu-efi}/lib"
|
||
"-Defi-includedir=${gnu-efi}/include/efi"
|
||
"--localstatedir=/var"
|
||
"--sysconfdir=/etc"
|
||
"-Dsysconfdir_install=${placeholder "out"}/etc"
|
||
];
|
||
|
||
# TODO: We need to be able to override the directory flags from meson setup hook
|
||
# better – declaring them multiple times might become an error.
|
||
preConfigure = ''
|
||
mesonFlagsArray+=("--libexecdir=$out/libexec")
|
||
'';
|
||
|
||
postInstall = ''
|
||
moveToOutput share/installed-tests "$installedTests"
|
||
wrapProgram $installedTests/share/installed-tests/fwupd/hardware.py \
|
||
--prefix GI_TYPELIB_PATH : "$out/lib/girepository-1.0:${libsoup}/lib/girepository-1.0"
|
||
'';
|
||
|
||
FONTCONFIG_FILE = fontsConf; # Fontconfig error: Cannot load default config file
|
||
|
||
# TODO: wrapGAppsHook wraps efi capsule even though it is not elf
|
||
dontWrapGApps = true;
|
||
# so we need to wrap the executables manually
|
||
postFixup = ''
|
||
find -L "$out/bin" "$out/libexec" -type f -executable -print0 \
|
||
| while IFS= read -r -d ''' file; do
|
||
if [[ "''${file}" != *.efi ]]; then
|
||
echo "Wrapping program ''${file}"
|
||
wrapProgram "''${file}" "''${gappsWrapperArgs[@]}"
|
||
fi
|
||
done
|
||
'';
|
||
|
||
# /etc/fwupd/uefi.conf is created by the services.hardware.fwupd NixOS module
|
||
passthru = {
|
||
filesInstalledToEtc = [
|
||
"fwupd/remotes.d/fwupd.conf"
|
||
"fwupd/remotes.d/lvfs-testing.conf"
|
||
"fwupd/remotes.d/lvfs.conf"
|
||
"fwupd/remotes.d/vendor.conf"
|
||
"fwupd/remotes.d/fwupd-tests.conf"
|
||
"pki/fwupd/GPG-KEY-Hughski-Limited"
|
||
"pki/fwupd/GPG-KEY-Linux-Foundation-Firmware"
|
||
"pki/fwupd/GPG-KEY-Linux-Vendor-Firmware-Service"
|
||
"pki/fwupd/LVFS-CA.pem"
|
||
"pki/fwupd-metadata/GPG-KEY-Linux-Foundation-Metadata"
|
||
"pki/fwupd-metadata/GPG-KEY-Linux-Vendor-Firmware-Service"
|
||
"pki/fwupd-metadata/LVFS-CA.pem"
|
||
];
|
||
};
|
||
|
||
meta = with stdenv.lib; {
|
||
homepage = https://fwupd.org/;
|
||
maintainers = with maintainers; [];
|
||
license = [ licenses.gpl2 ];
|
||
platforms = platforms.linux;
|
||
};
|
||
}
|