blob: b42b7b414bdbd498910bbc7531f73b62f12d0146 [file] [log] [blame]
Andrew Geisslerf1e44062021-04-15 15:52:46 -05001SUMMARY = "Platform AbstRaction for SECurity Daemon"
2HOMEPAGE = "https://github.com/parallaxsecond/parsec"
3LICENSE = "Apache-2.0"
Patrick Williams8e7b46e2023-05-01 14:19:06 -05004LIC_FILES_CHKSUM = "file://LICENSE;md5=3b83ef96387f14655fc854ddc3c6bd57"
Andrew Geisslerf1e44062021-04-15 15:52:46 -05005
Patrick Williams8e7b46e2023-05-01 14:19:06 -05006inherit cargo pkgconfig cargo-update-recipe-crates
7
8DEPENDS += "clang-native"
Andrew Geisslerf1e44062021-04-15 15:52:46 -05009
10SRC_URI += "crate://crates.io/parsec-service/${PV} \
11 file://parsec_init \
12 file://systemd.patch \
13 file://parsec-tmpfiles.conf \
14"
Patrick Williams8e7b46e2023-05-01 14:19:06 -050015SRC_URI[parsec-service-1.2.0.sha256sum] = "f58e7ba859c22cc1904dc8298b1a7d94ee1ba3b4d4808f28e4cc0c96ddb149c9"
16
Patrick Williamsb542dec2023-06-09 01:26:37 -050017B = "${CARGO_VENDORING_DIRECTORY}/${BP}"
Andrew Geisslerf1e44062021-04-15 15:52:46 -050018
Patrick Williams03907ee2022-05-01 06:28:52 -050019PACKAGECONFIG ??= "PKCS11 MBED-CRYPTO"
Andrew Geissler9aee5002022-03-30 16:27:02 +000020have_TPM = "${@bb.utils.contains('DISTRO_FEATURES', 'tpm2', 'TPM', '', d)}"
21PACKAGECONFIG:append = " ${@bb.utils.contains('BBFILE_COLLECTIONS', 'tpm-layer', '${have_TPM}', '', d)}"
22
Andrew Geisslerd5838332022-05-27 11:33:10 -050023PACKAGECONFIG[ALL] = "all-providers cryptoki/generate-bindings tss-esapi/generate-bindings,,tpm2-tss libts,tpm2-tss libtss2-tcti-device libts"
24PACKAGECONFIG[TPM] = "tpm-provider tss-esapi/generate-bindings,,tpm2-tss,tpm2-tss libtss2-tcti-device"
Patrick Williams53961c22022-01-20 11:06:23 -060025PACKAGECONFIG[PKCS11] = "pkcs11-provider cryptoki/generate-bindings,"
Patrick Williams93c203f2021-10-06 16:15:23 -050026PACKAGECONFIG[MBED-CRYPTO] = "mbed-crypto-provider,"
27PACKAGECONFIG[CRYPTOAUTHLIB] = "cryptoauthlib-provider,"
28PACKAGECONFIG[TS] = "trusted-service-provider,,libts,libts"
29
Patrick Williams53961c22022-01-20 11:06:23 -060030PARSEC_FEATURES = "${@d.getVar('PACKAGECONFIG_CONFARGS',True).strip().replace(' ', ',')}"
31CARGO_BUILD_FLAGS += " --features ${PARSEC_FEATURES}"
Andrew Geisslerf1e44062021-04-15 15:52:46 -050032
Andrew Geisslerd5838332022-05-27 11:33:10 -050033export BINDGEN_EXTRA_CLANG_ARGS
34target = "${@d.getVar('TARGET_SYS',True).replace('-', ' ')}"
35BINDGEN_EXTRA_CLANG_ARGS = "${@bb.utils.contains('target', 'arm', \
36 '--sysroot=${WORKDIR}/recipe-sysroot -I${WORKDIR}/recipe-sysroot/usr/include -mfloat-abi=hard', \
37 '--sysroot=${WORKDIR}/recipe-sysroot -I${WORKDIR}/recipe-sysroot/usr/include', \
38 d)}"
39
Patrick Williams03907ee2022-05-01 06:28:52 -050040inherit systemd
Patrick Williams213cb262021-08-07 19:21:33 -050041SYSTEMD_SERVICE:${PN} = "parsec.service"
Andrew Geisslerf1e44062021-04-15 15:52:46 -050042
43inherit update-rc.d
44INITSCRIPT_NAME = "parsec"
45
46# A local file can be defined in build/local.conf
47# The file should also be included into SRC_URI then
48PARSEC_CONFIG ?= "${S}/config.toml"
49
Andrew Geisslerd5838332022-05-27 11:33:10 -050050do_install () {
Andrew Geisslerf1e44062021-04-15 15:52:46 -050051 # Binaries
52 install -d -m 700 -o parsec -g parsec "${D}${libexecdir}/parsec"
Patrick Williams92b42cb2022-09-03 06:53:57 -050053 install -m 700 -o parsec -g parsec "${B}/target/${CARGO_TARGET_SUBDIR}/parsec" ${D}${libexecdir}/parsec/parsec
Andrew Geisslerf1e44062021-04-15 15:52:46 -050054
55 # Config file
56 install -d -m 700 -o parsec -g parsec "${D}${sysconfdir}/parsec"
57 install -m 400 -o parsec -g parsec "${PARSEC_CONFIG}" ${D}${sysconfdir}/parsec/config.toml
58
Andrew Geisslerf1e44062021-04-15 15:52:46 -050059 if ${@bb.utils.contains('DISTRO_FEATURES', 'systemd', 'true', 'false', d)}; then
60 install -d ${D}${systemd_unitdir}/system
61 install -m 644 ${S}/systemd-daemon/parsec.service ${D}${systemd_unitdir}/system
62
63 install -d ${D}${libdir}/tmpfiles.d
64 install -m 644 ${WORKDIR}/parsec-tmpfiles.conf ${D}${libdir}/tmpfiles.d
65 fi
66
67 if ${@bb.utils.contains('DISTRO_FEATURES', 'sysvinit', 'true', 'false', d)}; then
68 install -d ${D}${sysconfdir}/init.d
69 install -m 755 ${WORKDIR}/parsec_init ${D}${sysconfdir}/init.d/parsec
Andrew Geisslerd5838332022-05-27 11:33:10 -050070 # Data dir
71 install -d -m 700 -o parsec -g parsec "${D}${localstatedir}/lib/parsec"
Andrew Geisslerf1e44062021-04-15 15:52:46 -050072 fi
73}
74
75inherit useradd
76USERADD_PACKAGES = "${PN}"
Patrick Williams213cb262021-08-07 19:21:33 -050077GROUPADD_PARAM:${PN} = "-r parsec"
Patrick Williams92b42cb2022-09-03 06:53:57 -050078USERADD_PARAM:${PN} = "-r -g parsec -s /bin/false -d ${localstatedir}/lib/parsec parsec"
79GROUPMEMS_PARAM:${PN} = "${@bb.utils.contains('PACKAGECONFIG_CONFARGS', 'tpm-provider', '-a parsec -g tss ;', '', d)}"
80GROUPMEMS_PARAM:${PN} += "${@bb.utils.contains('PACKAGECONFIG_CONFARGS', 'trusted-service-provider', '-a parsec -g teeclnt', '', d)}"
Andrew Geisslerf1e44062021-04-15 15:52:46 -050081
Patrick Williams213cb262021-08-07 19:21:33 -050082FILES:${PN} += " \
Andrew Geisslerf1e44062021-04-15 15:52:46 -050083 ${sysconfdir}/parsec/config.toml \
84 ${libexecdir}/parsec/parsec \
85 ${systemd_unitdir}/system/parsec.service \
Andrew Geisslerf1e44062021-04-15 15:52:46 -050086 ${libdir}/tmpfiles.d/parsec-tmpfiles.conf \
87 ${sysconfdir}/init.d/parsec \
88"
89
Patrick Williams8e7b46e2023-05-01 14:19:06 -050090require parsec-service-crates.inc
Patrick Williams2390b1b2022-11-03 13:47:49 -050091
Patrick Williams8e7b46e2023-05-01 14:19:06 -050092# The QA check has been temporarily disabled. An issue has been created
93# upstream to fix this.
Patrick Williams2390b1b2022-11-03 13:47:49 -050094# https://github.com/parallaxsecond/parsec/issues/645
95INSANE_SKIP:${PN}-dbg += "buildpaths"
Patrick Williams8e7b46e2023-05-01 14:19:06 -050096