blob: b451c1b3ddbefe8ef6b17607b1ade387e39d53f7 [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="f35f2919309cf11b0ddd9deb24a6b145d40d9254"
CROS_WORKON_TREE=("a625767bb59509159091f2ab0b71f8b9b4b2e353" "3e8ec46db7a894d8f90bf457f66dbe4e3efad0e1" "b8893a9e8fdf8b402519c4496addb087f21fbe50" "fb2b8277318fb7e7eff84f5c7669a46bf60f19f5" "b1c7898d3f42051cbba6426c62b35476a8de5b72" "4a0dedab080195bdc122d2289118df4af3ddca2c" "2acba33c99f07fa000bb44a4df3a65a8fe313bb1" "97266a4772907835fdab5d56b3ca24ed9c1c7a0e" "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 libhwsec-foundation 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="generic_tpm2 test tpm tpm_dynamic tpm2"
REQUIRED_USE="
tpm_dynamic? ( tpm tpm2 )
!tpm_dynamic? ( ?? ( tpm tpm2 ) )
"
RDEPEND="
tpm? (
app-crypt/trousers:=
)
tpm2? (
chromeos-base/trunks:=
)
chromeos-base/chaps:=
chromeos-base/libhwsec-foundation:=
chromeos-base/system_api:=[fuzzer?]
>=chromeos-base/metrics-0.0.1-r3152:=
chromeos-base/minijail:=
chromeos-base/tpm_manager:=
chromeos-base/attestation-client
"
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() {
platform_install
insinto /usr/include/attestation/common
doins common/attestation_interface.h
doins "${OUT}"/gen/attestation/common/print_attestation_ca_proto.h
doins "${OUT}"/gen/attestation/common/print_interface_proto.h
doins "${OUT}"/gen/attestation/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
}
platform_pkg_test() {
platform test_all
}