blob: 03463f95f56f404f28b9f726b05de3f68eb3b81a [file] [log] [blame]
Patrick Williamsf1e5d692016-03-30 15:21:19 -05001# Copyright (C) 2015 Intel Corporation
2# Released under the MIT license (see COPYING.MIT for the terms)
3
Patrick Williamsc0f7c042017-02-23 20:41:17 -06004SUMMARY = "Makes public keys of the signing keys available"
Patrick Williamsf1e5d692016-03-30 15:21:19 -05005LICENSE = "MIT"
Patrick Williamsf1e5d692016-03-30 15:21:19 -05006
Patrick Williamsd8c66bc2016-06-20 12:57:21 -05007
8inherit allarch deploy
Patrick Williamsf1e5d692016-03-30 15:21:19 -05009
10EXCLUDE_FROM_WORLD = "1"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050011INHIBIT_DEFAULT_DEPS = "1"
Patrick Williamsf1e5d692016-03-30 15:21:19 -050012
Patrick Williamsc0f7c042017-02-23 20:41:17 -060013SYSROOT_DIRS += "${sysconfdir}/pki"
14
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050015PACKAGES =+ "${PN}-ipk ${PN}-rpm ${PN}-packagefeed"
Patrick Williamsf1e5d692016-03-30 15:21:19 -050016
Patrick Williams213cb262021-08-07 19:21:33 -050017FILES:${PN}-rpm = "${sysconfdir}/pki/rpm-gpg"
18FILES:${PN}-ipk = "${sysconfdir}/pki/ipk-gpg"
19FILES:${PN}-packagefeed = "${sysconfdir}/pki/packagefeed-gpg"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050020
21python do_get_public_keys () {
22 from oe.gpg_sign import get_signer
23
Brad Bishop6e60e8b2018-02-01 10:27:11 -050024 if d.getVar("RPM_SIGN_PACKAGES"):
Patrick Williamsf1e5d692016-03-30 15:21:19 -050025 # Export public key of the rpm signing key
Brad Bishop6e60e8b2018-02-01 10:27:11 -050026 signer = get_signer(d, d.getVar('RPM_GPG_BACKEND'))
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050027 signer.export_pubkey(os.path.join(d.expand('${B}'), 'rpm-key'),
Brad Bishop6e60e8b2018-02-01 10:27:11 -050028 d.getVar('RPM_GPG_NAME'))
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050029
Brad Bishop6e60e8b2018-02-01 10:27:11 -050030 if d.getVar("IPK_SIGN_PACKAGES"):
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050031 # Export public key of the ipk signing key
Brad Bishop6e60e8b2018-02-01 10:27:11 -050032 signer = get_signer(d, d.getVar('IPK_GPG_BACKEND'))
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050033 signer.export_pubkey(os.path.join(d.expand('${B}'), 'ipk-key'),
Brad Bishop6e60e8b2018-02-01 10:27:11 -050034 d.getVar('IPK_GPG_NAME'))
Patrick Williamsf1e5d692016-03-30 15:21:19 -050035
Brad Bishop6e60e8b2018-02-01 10:27:11 -050036 if d.getVar('PACKAGE_FEED_SIGN') == '1':
Patrick Williamsf1e5d692016-03-30 15:21:19 -050037 # Export public key of the feed signing key
Brad Bishop6e60e8b2018-02-01 10:27:11 -050038 signer = get_signer(d, d.getVar('PACKAGE_FEED_GPG_BACKEND'))
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050039 signer.export_pubkey(os.path.join(d.expand('${B}'), 'pf-key'),
Brad Bishop6e60e8b2018-02-01 10:27:11 -050040 d.getVar('PACKAGE_FEED_GPG_NAME'))
Patrick Williamsf1e5d692016-03-30 15:21:19 -050041}
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050042do_get_public_keys[cleandirs] = "${B}"
43addtask get_public_keys before do_install
Brad Bishop316dfdd2018-06-25 12:45:53 -040044do_get_public_keys[depends] += "gnupg-native:do_populate_sysroot"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050045
46do_install () {
47 if [ -f "${B}/rpm-key" ]; then
Brad Bishopd7bf8c12018-02-25 22:55:05 -050048 install -D -m 0644 "${B}/rpm-key" "${D}${sysconfdir}/pki/rpm-gpg/RPM-GPG-KEY-${DISTRO}-${DISTRO_CODENAME}"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050049 fi
50 if [ -f "${B}/ipk-key" ]; then
Brad Bishopd7bf8c12018-02-25 22:55:05 -050051 install -D -m 0644 "${B}/ipk-key" "${D}${sysconfdir}/pki/ipk-gpg/IPK-GPG-KEY-${DISTRO}-${DISTRO_CODENAME}"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050052 fi
53 if [ -f "${B}/pf-key" ]; then
Brad Bishopd7bf8c12018-02-25 22:55:05 -050054 install -D -m 0644 "${B}/pf-key" "${D}${sysconfdir}/pki/packagefeed-gpg/PACKAGEFEED-GPG-KEY-${DISTRO}-${DISTRO_CODENAME}"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050055 fi
56}
57
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050058do_deploy () {
59 if [ -f "${B}/rpm-key" ]; then
Brad Bishopd7bf8c12018-02-25 22:55:05 -050060 install -D -m 0644 "${B}/rpm-key" "${DEPLOYDIR}/RPM-GPG-KEY-${DISTRO}-${DISTRO_CODENAME}"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050061 fi
62 if [ -f "${B}/ipk-key" ]; then
Brad Bishopd7bf8c12018-02-25 22:55:05 -050063 install -D -m 0644 "${B}/ipk-key" "${DEPLOYDIR}/IPK-GPG-KEY-${DISTRO}-${DISTRO_CODENAME}"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050064 fi
65 if [ -f "${B}/pf-key" ]; then
Brad Bishopd7bf8c12018-02-25 22:55:05 -050066 install -D -m 0644 "${B}/pf-key" "${DEPLOYDIR}/PACKAGEFEED-GPG-KEY-${DISTRO}-${DISTRO_CODENAME}"
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050067 fi
68}
69do_deploy[sstate-outputdirs] = "${DEPLOY_DIR_RPM}"
Brad Bishop316dfdd2018-06-25 12:45:53 -040070# clear stamp-extra-info since MACHINE_ARCH is normally put there by
71# deploy.bbclass
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050072do_deploy[stamp-extra-info] = ""
73addtask deploy after do_get_public_keys
Brad Bishopd7bf8c12018-02-25 22:55:05 -050074
75# Delete unnecessary tasks. In particular, "do_unpack" _must_ be deleted because
76# it cleans ${B} and will wipe any keys exported by do_get_public_keys.
77deltask do_fetch
78deltask do_unpack
79deltask do_patch
80deltask do_configure
81deltask do_compile