blob: 6629777c02b05a01f0690e995a2e747186fbcbf4 [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="6f9011123f3656c45bb34148673aa110a22326b3"
CROS_WORKON_TREE=("791c6808b4f4f5f1c484108d66ff958d65f8f1e3" "a9ed3579a46a08a64f1ac9d96a1faaa6e15720b9" "81dfbbc1756a3b4224b447e7bf10a916d97c4f66" "1a305e65cfaf27dd42734a37eda080d40b377d6c" "e7dba8c91c1f3257c34d4a7ffff0ea2537aeb6bb")
CROS_WORKON_LOCALNAME="platform2"
CROS_WORKON_PROJECT="chromiumos/platform2"
CROS_WORKON_DESTDIR="${S}/platform2"
CROS_WORKON_INCREMENTAL_BUILD=1
# TODO(crbug.com/809389): Avoid directly including headers from other packages.
CROS_WORKON_SUBTREE="common-mk cryptohome libhwsec secure_erase_file .gn"
PLATFORM_NATIVE_TEST="yes"
PLATFORM_SUBDIR="cryptohome"
inherit tmpfiles cros-workon platform systemd udev user
DESCRIPTION="Encrypted home directories for Chromium OS"
HOMEPAGE="https://chromium.googlesource.com/chromiumos/platform2/+/master/cryptohome/"
SRC_URI=""
LICENSE="BSD-Google"
SLOT="0/0"
KEYWORDS="*"
IUSE="-cert_provision +device_mapper -direncription_allow_v2 -direncryption
double_extend_pcr_issue +downloads_bind_mount fuzzer
generated_cros_config generic_tpm2 kernel-5_10 kernel-5_4 kernel-upstream
lvm_stateful_partition mount_oop pinweaver selinux slow_mount systemd
test tpm tpm2 tpm2_simulator unibuild uprev-4-to-5
user_session_isolation +vault_legacy_mount vtpm_proxy"
REQUIRED_USE="
device_mapper
tpm2? ( !tpm )
"
COMMON_DEPEND="
!chromeos-base/chromeos-cryptohome
tpm? (
app-crypt/trousers:=
)
fuzzer? (
app-crypt/trousers:=
)
tpm2? (
chromeos-base/trunks:=
)
selinux? (
sys-libs/libselinux:=
)
chromeos-base/attestation:=
chromeos-base/biod_proxy:=
chromeos-base/bootlockbox-client:=
chromeos-base/cbor:=
chromeos-base/chaps:=
chromeos-base/chromeos-config-tools:=
chromeos-base/libhwsec:=
>=chromeos-base/metrics-0.0.1-r3152:=
chromeos-base/secure-erase-file:=
chromeos-base/tpm_manager:=
dev-libs/dbus-glib:=
dev-libs/flatbuffers:=
dev-libs/glib:=
dev-libs/openssl:=
dev-libs/protobuf:=
sys-apps/flashmap:=
sys-apps/keyutils:=
sys-apps/rootdev:=
sys-fs/e2fsprogs:=
sys-fs/ecryptfs-utils:=
sys-fs/lvm2:=
unibuild? (
!generated_cros_config? ( chromeos-base/chromeos-config )
generated_cros_config? ( chromeos-base/chromeos-config-bsp:= )
)
"
RDEPEND="${COMMON_DEPEND}"
DEPEND="${COMMON_DEPEND}
tpm2? ( chromeos-base/trunks:=[test?] )
chromeos-base/attestation-client:=
chromeos-base/cryptohome-client:=
chromeos-base/power_manager-client:=
chromeos-base/protofiles:=
chromeos-base/system_api:=[fuzzer?]
chromeos-base/tpm_manager-client:=
chromeos-base/vboot_reference:=
chromeos-base/libhwsec:=
"
src_install() {
pushd "${OUT}" >/dev/null
dosbin cryptohomed cryptohome cryptohome-proxy cryptohome-path homedirs_initializer \
lockbox-cache tpm-manager
dosbin cryptohome-namespace-mounter
dosbin mount-encrypted
dosbin encrypted-reboot-vault
if use tpm2; then
dosbin bootlockboxd bootlockboxtool
fi
if use cert_provision; then
dolib.so lib/libcert_provision.so
dosbin cert_provision_client
fi
popd >/dev/null
insinto /etc/dbus-1/system.d
doins etc/Cryptohome.conf
doins etc/org.chromium.UserDataAuth.conf
if use tpm2; then
doins etc/BootLockbox.conf
fi
if use direncription_allow_v2 && ( (use !kernel-5_4 && use !kernel-5_10 && use !kernel-upstream) || use uprev-4-to-5); then
die "direncription_allow_v2 is enabled where it shouldn't be. Do you need to change the board overlay? Note, uprev boards should have it disabled!"
fi
if use !direncription_allow_v2 && (use kernel-5_4 || use kernel-5_10 || use kernel-upstream) && use !uprev-4-to-5; then
die "direncription_allow_v2 is not enabled where it should be. Do you need to change the board overlay? Note, uprev boards should have it disabled!"
fi
# Install init scripts
if use systemd; then
if use tpm2; then
sed 's/tcsd.service/attestationd.service/' \
init/cryptohomed.service \
> "${T}/cryptohomed.service"
systemd_dounit "${T}/cryptohomed.service"
else
systemd_dounit init/cryptohomed.service
fi
systemd_dounit init/mount-encrypted.service
systemd_dounit init/lockbox-cache.service
systemd_enable_service boot-services.target cryptohomed.service
systemd_enable_service system-services.target mount-encrypted.service
systemd_enable_service ui.target lockbox-cache.service
else
insinto /etc/init
doins init/cryptohomed-client.conf
doins init/cryptohomed.conf
doins init/cryptohome-proxy.conf
doins init/init-homedirs.conf
doins init/mount-encrypted.conf
doins init/send-mount-encrypted-metrics.conf
if use tpm2_simulator && ! use vtpm_proxy; then
newins init/lockbox-cache.conf.tpm2_simulator lockbox-cache.conf
else
doins init/lockbox-cache.conf
fi
if use tpm2; then
insinto /usr/share/policy
newins bootlockbox/seccomp/bootlockboxd-seccomp-${ARCH}.policy \
bootlockboxd-seccomp.policy
insinto /etc/init
doins bootlockbox/bootlockboxd.conf
else
sed -i '/env DISTRIBUTED_MODE_FLAG=/s:=.*:="--attestation_mode=dbus":' \
"${D}/etc/init/cryptohomed.conf" ||
die "Can't activate distributed mode in cryptohomed.conf"
fi
if use direncryption; then
sed -i '/env DIRENCRYPTION_FLAG=/s:=.*:="--direncryption":' \
"${D}/etc/init/cryptohomed.conf" ||
die "Can't replace direncryption flag in cryptohomed.conf"
fi
if use !vault_legacy_mount; then
sed -i '/env NO_LEGACY_MOUNT_FLAG=/s:=.*:="--nolegacymount":' \
"${D}/etc/init/cryptohomed.conf" ||
die "Can't replace nolegacymount flag in cryptohomed.conf"
fi
if use !downloads_bind_mount; then
sed -i '/env NO_DOWNLOAD_BINDMOUNT_FLAG=/s:=.*:="--no_downloads_bind_mount":' \
"${D}/etc/init/cryptohomed.conf" ||
die "Can't replace no_downloads_bind_mount flag in cryptohomed.conf"
fi
if use direncription_allow_v2; then
sed -i '/env FSCRYPT_V2_FLAG=/s:=.*:="--fscrypt_v2":' \
"${D}/etc/init/cryptohomed.conf" ||
die "Can't replace fscrypt_v2 flag in cryptohomed.conf"
fi
fi
exeinto /usr/share/cros/init
if use tpm2_simulator && ! use vtpm_proxy; then
newexe init/lockbox-cache.sh.tpm2_simulator lockbox-cache.sh
else
doexe init/lockbox-cache.sh
fi
if use cert_provision; then
insinto /usr/include/cryptohome
doins cert_provision.h
fi
# Install seccomp policy for cryptohome-proxy
insinto /usr/share/policy
newins "seccomp/cryptohome-proxy-${ARCH}.policy" cryptohome-proxy.policy
dotmpfiles tmpfiles.d/cryptohome.conf
platform_fuzzer_install "${S}"/OWNERS \
"${OUT}"/cryptohome_cryptolib_rsa_oaep_decrypt_fuzzer \
fuzzers/data/*
platform_fuzzer_install "${S}"/OWNERS \
"${OUT}"/cryptohome_cryptolib_blob_to_hex_fuzzer
platform_fuzzer_install "${S}"/OWNERS \
"${OUT}"/cryptohome_tpm1_cmk_migration_parser_fuzzer \
fuzzers/data/*
}
pkg_preinst() {
enewuser "bootlockboxd"
enewgroup "bootlockboxd"
enewuser "cryptohome"
enewgroup "cryptohome"
}
platform_pkg_test() {
platform_test "run" "${OUT}/cryptohome_testrunner"
platform_test "run" "${OUT}/mount_encrypted_unittests"
if use tpm2; then
platform_test "run" "${OUT}/boot_lockbox_unittests"
fi
}