blob: ff49bc966b3991e993b70f740930c2f5e29e13a8 [file] [log] [blame]
# Copyright 2018 The ChromiumOS Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=7
CROS_WORKON_COMMIT="8b6e11a069e490c761cdab7ab3ff59434806cd9c"
CROS_WORKON_TREE=("41d899585b7a07ea908a0cca2944a7b8a4d13655" "faa5b8036561b66b5b9d79ea1af8a95927a0ae0f" "9e9c3d918778bd1e5e6c837254e83b19fb2a8f4d" "f91b6afd5f2ae04ee9a2c19109a3a4a36f7659e6")
CROS_WORKON_INCREMENTAL_BUILD=1
CROS_WORKON_LOCALNAME="platform2"
CROS_WORKON_PROJECT="chromiumos/platform2"
CROS_WORKON_OUTOFTREE_BUILD=1
# TODO(crbug.com/809389): Avoid directly including headers from other packages.
CROS_WORKON_SUBTREE="common-mk metrics usb_bouncer .gn"
PLATFORM_SUBDIR="usb_bouncer"
inherit tmpfiles cros-workon platform user cros-fuzzer cros-sanitizers
DESCRIPTION="Manage the usbguard whitelist"
HOMEPAGE="https://chromium.googlesource.com/chromiumos/platform2/+/HEAD/usb_bouncer/"
LICENSE="BSD-Google"
SLOT="0/0"
KEYWORDS="*"
IUSE="fuzzer"
COMMON_DEPEND="
fuzzer? ( dev-libs/libprotobuf-mutator:= )
>=chromeos-base/metrics-0.0.1-r3152:=
chromeos-base/minijail:=
dev-libs/openssl:0=
dev-libs/re2:=
sys-apps/usbguard:=
sys-libs/libcap:=
"
RDEPEND="${COMMON_DEPEND}"
DEPEND="${COMMON_DEPEND}
chromeos-base/session_manager-client:="
BDEPEND="
chromeos-base/minijail
dev-libs/protobuf
"
src_install() {
platform_src_install
insinto /lib/udev/rules.d
doins "${S}/40-usb-bouncer.rules"
dotmpfiles tmpfiles.d/*.conf
cd "${OUT}" || die
dosbin usb_bouncer
insinto /etc/dbus-1/system.d
doins "${S}/UsbBouncer.conf"
insinto /usr/share/policy
newins "${S}/seccomp/usb_bouncer-seccomp-${ARCH}.policy" usb_bouncer-seccomp.policy
insinto /etc/init
doins "${S}"/init/usb_bouncer.conf
local daemon_store="/etc/daemon-store/usb_bouncer"
dodir "${daemon_store}"
fperms 0700 "${daemon_store}"
fowners usb_bouncer:usb_bouncer "${daemon_store}"
local f="${OUT}/usb_bouncer_fuzzer"
local fuzzer_component_id="1048474"
fuzzer_install "${S}/OWNERS" "${f}" \
--comp "${fuzzer_component_id}"
}
platform_pkg_test() {
platform_test "run" "${OUT}/run_tests"
}
pkg_setup() {
enewuser usb_bouncer
enewgroup usb_bouncer
cros-workon_pkg_setup
}