nixpkgs-suyu/pkgs/os-specific/linux/usbguard/default.nix

92 lines
2 KiB
Nix
Raw Normal View History

2021-01-15 18:26:47 +01:00
{ stdenv
, lib
, fetchFromGitHub
, autoreconfHook
2021-01-21 23:12:29 +01:00
, installShellFiles
2021-01-16 23:15:52 +01:00
, nixosTests
2021-01-15 18:26:47 +01:00
, asciidoc
, pkg-config
2021-01-15 18:26:47 +01:00
, libxslt
, libxml2
, docbook_xml_dtd_45
, docbook_xsl
, dbus-glib
, libcap_ng
, libqb
, libseccomp
, polkit
, protobuf
, audit
, libgcrypt
, libsodium
}:
assert libgcrypt != null -> libsodium == null;
stdenv.mkDerivation rec {
2021-01-15 18:26:47 +01:00
version = "1.0.0";
pname = "usbguard";
2021-01-15 18:26:47 +01:00
src = fetchFromGitHub {
owner = "USBGuard";
repo = pname;
rev = "usbguard-${version}";
sha256 = "sha256-CPuBQmDOpXWn0jPo4HRyDCZUpDy5NmbvUHxXoVbMd/I=";
fetchSubmodules = true;
};
nativeBuildInputs = [
2021-01-15 18:26:47 +01:00
autoreconfHook
2021-01-21 23:12:29 +01:00
installShellFiles
asciidoc
pkg-config
libxslt # xsltproc
libxml2 # xmllint
docbook_xml_dtd_45
docbook_xsl
];
buildInputs = [
dbus-glib
libcap_ng
libqb
libseccomp
polkit
protobuf
2018-02-27 19:07:43 +01:00
audit
]
++ (lib.optional (libgcrypt != null) libgcrypt)
++ (lib.optional (libsodium != null) libsodium);
configureFlags = [
"--with-bundled-catch"
"--with-bundled-pegtl"
"--with-dbus"
"--with-polkit"
]
++ (lib.optional (libgcrypt != null) "--with-crypto-library=gcrypt")
++ (lib.optional (libsodium != null) "--with-crypto-library=sodium");
enableParallelBuilding = true;
2021-01-21 23:12:29 +01:00
postInstall = ''
installShellCompletion --bash --name usbguard.bash scripts/bash_completion/usbguard
installShellCompletion --zsh --name _usbguard scripts/usbguard-zsh-completion
'';
2021-01-16 23:15:52 +01:00
passthru.tests = nixosTests.usbguard;
2021-01-15 18:26:47 +01:00
meta = with lib; {
description = "The USBGuard software framework helps to protect your computer against BadUSB";
2021-01-15 18:26:47 +01:00
longDescription = ''
USBGuard is a software framework for implementing USB device authorization
policies (what kind of USB devices are authorized) as well as method of
use policies (how a USB device may interact with the system). Simply put,
it is a USB device whitelisting tool.
'';
2018-02-27 19:07:43 +01:00
homepage = "https://usbguard.github.io/";
license = licenses.gpl2Plus;
maintainers = [ maintainers.tnias ];
};
}