blob: 857afa1bb764ab461c30743d008e2d547d0a3d9c [file] [log] [blame]
# Copyright 2014 The Chromium OS Authors. All rights reserved.
# Distributed under the terms of the GNU General Public License v2
EAPI=7
CROS_WORKON_COMMIT="5fc770072f3c76a5fff2f346ec832ddc44970226"
CROS_WORKON_TREE=("52a8a8b6d3bbca5e90d4761aa308a5541d52b1bb" "e2d4b5c2a34733c2112e0a9a8d0a2171f90ec316" "5956de9997bc0735d9aeff6edc4d0098fb571b9b" "989d840598227b15d78525d5f92c806011a9c158" "8d228c8e702aebee142bcbf0763a15786eb5b3bb" "e3bf102d9535965e9911dc352202c6927e8f5514" "20ed8021024637e492670d20fa5969a2ad75e4b6" "e7dba8c91c1f3257c34d4a7ffff0ea2537aeb6bb")
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 attestation chaps libhwsec metrics tpm_manager trunks .gn"
PLATFORM_SUBDIR="attestation"
inherit cros-workon libchrome platform user
DESCRIPTION="Attestation service for Chromium OS"
HOMEPAGE="https://chromium.googlesource.com/chromiumos/platform2/+/master/attestation/"
LICENSE="Apache-2.0"
KEYWORDS="*"
IUSE="test tpm tpm2"
REQUIRED_USE="tpm2? ( !tpm )"
RDEPEND="
tpm? (
app-crypt/trousers:=
)
tpm2? (
chromeos-base/trunks:=
)
chromeos-base/chaps:=
chromeos-base/system_api:=[fuzzer?]
>=chromeos-base/metrics-0.0.1-r3152:=
chromeos-base/minijail:=
chromeos-base/tpm_manager:=
"
DEPEND="
${RDEPEND}
test? ( chromeos-base/libhwsec:= )
chromeos-base/vboot_reference:=
tpm2? (
chromeos-base/trunks:=[test?]
chromeos-base/chromeos-ec-headers:=
)
"
pkg_preinst() {
# Create user and group for attestation.
enewuser "attestation"
enewgroup "attestation"
# Create group for /mnt/stateful_partition/unencrypted/preserve.
enewgroup "preserve"
}
src_install() {
insinto /etc/dbus-1/system.d
doins server/org.chromium.Attestation.conf
insinto /etc/init
doins server/attestationd.conf
dosbin "${OUT}"/attestationd
dobin "${OUT}"/attestation_client
insinto /usr/share/policy
newins server/attestationd-seccomp-${ARCH}.policy attestationd-seccomp.policy
insinto /etc/dbus-1/system.d
doins pca_agent/server/org.chromium.PcaAgent.conf
insinto /etc/init
doins pca_agent/server/pca_agentd.conf
dosbin "${OUT}"/pca_agentd
dobin "${OUT}"/pca_agent_client
dolib.so "${OUT}"/lib/libattestation.so
insinto /usr/include/attestation/client
doins client/dbus_proxy.h
insinto /usr/include/attestation/common
doins common/attestation_interface.h
doins common/print_attestation_ca_proto.h
doins common/print_interface_proto.h
doins common/print_keystore_proto.h
# Install the generated dbus-binding for fake pca agent.
# It does no harm to install the header even for non-test image build.
insinto /usr/include/attestation/pca-agent/dbus_adaptors
doins "${OUT}"/gen/include/attestation/pca-agent/dbus_adaptors/org.chromium.PcaAgent.h
insinto /usr/share/policy
newins "pca_agent/server/pca_agentd-seccomp-${ARCH}.policy" pca_agentd-seccomp.policy
}
platform_pkg_test() {
local tests=(
attestation_testrunner
)
local test_bin
for test_bin in "${tests[@]}"; do
platform_test "run" "${OUT}/${test_bin}"
done
}