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.
101 lines
2.3 KiB
101 lines
2.3 KiB
# Copyright 1999-2021 Gentoo Authors
|
|
# Distributed under the terms of the GNU General Public License v2
|
|
|
|
EAPI=7
|
|
|
|
inherit autotools bash-completion-r1
|
|
|
|
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="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
|
|
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
|
|
"${FILESDIR}"/${PN}-1.0.0-bash-completion-configure.patch
|
|
)
|
|
|
|
src_prepare() {
|
|
default
|
|
eautoreconf
|
|
}
|
|
|
|
src_configure() {
|
|
local myargs=(
|
|
--with-bash-completion-dir=$(get_bashcompdir)
|
|
$(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
|
|
}
|