You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gentoo-overlay/sys-apps/usbguard/usbguard-1.0.0-r1.ebuild

100 lines
2.3 KiB

# Copyright 1999-2021 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=7
inherit autotools
DESCRIPTION="Daemon protecting your computer against BadUSB"
HOMEPAGE="https://github.com/USBGuard/usbguard"
SRC_URI="https://github.com/USBGuard/usbguard/releases/download/${P}/${P}.tar.gz"
LICENSE="GPL-2+"
SLOT="0/1" # due to libusbguard.so.<1>.0.0
KEYWORDS="~amd64 ~x86"
IUSE="bash-completion dbus ldap policykit static-libs systemd test umockdev"
REQUIRED_USE="policykit? ( dbus )"
# https://github.com/USBGuard/usbguard/issues/449
# https://bugs.gentoo.org/769692
REQUIRED_USE+=" test? ( static-libs )"
CDEPEND="
<dev-libs/pegtl-3
>=dev-libs/libsodium-0.4.5:=
>=dev-libs/protobuf-2.5.0:=
>=sys-cluster/libqb-0.16.0:=
sys-devel/gcc:*[cxx]
>=sys-libs/libcap-ng-0.7.0
>=sys-libs/libseccomp-2.0.0
>=sys-process/audit-2.7.7
bash-completion? ( >=app-shells/bash-completion-2.0 )
dbus? (
dev-libs/glib:2
sys-apps/dbus
policykit? ( sys-auth/polkit[introspection] )
)
ldap? ( net-nds/openldap )
systemd? ( sys-apps/systemd )
umockdev? ( dev-util/umockdev )
"
RDEPEND="${CDEPEND}
virtual/udev
"
DEPEND="${CDEPEND}
app-text/asciidoc
dev-cpp/catch:1
dbus? (
dev-libs/libxml2
dev-libs/libxslt
dev-util/gdbus-codegen
)
"
RESTRICT="!test? ( test )"
PATCHES=(
"${FILESDIR}"/${PN}-1.0.0-pthreads-link.patch
)
src_prepare() {
default
eautoreconf
}
src_configure() {
local myargs=(
$(use_with dbus)
$(use_with ldap)
$(use_with policykit polkit)
$(use_enable static-libs static)
$(use_enable systemd)
$(use_enable umockdev)
)
econf "${myargs[@]}"
}
src_install() {
default
keepdir /var/lib/log/usbguard
newinitd "${FILESDIR}"/${PN}-0.7.6-usbguard.openrc usbguard
use dbus && newinitd "${FILESDIR}"/${PN}-0.7.6-usbguard-dbus.openrc usbguard-dbus
}
pkg_postinst() {
ewarn
ewarn 'BEFORE STARTING USBGUARD please be sure to create/generate'
ewarn ' a rules file at /etc/usbguard/rules.conf'
ewarn ' so that you do not'
ewarn ' GET LOCKED OUT'
ewarn " of this system (\"$(hostname)\")."
ewarn
ewarn 'This command may be of help:'
ewarn ' sudo sh -c "usbguard generate-policy > /etc/usbguard/rules.conf"'
ewarn
}