blob: aaa01d0c345037c099c62ed63c8f4cc8dd5aef9f [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 Williamsd8c66bc2016-06-20 12:57:21 -050017FILES_${PN}-rpm = "${sysconfdir}/pki/rpm-gpg"
18FILES_${PN}-ipk = "${sysconfdir}/pki/ipk-gpg"
19FILES_${PN}-packagefeed = "${sysconfdir}/pki/packagefeed-gpg"
20
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
44
45do_install () {
46 if [ -f "${B}/rpm-key" ]; then
47 install -D -m 0644 "${B}/rpm-key" "${D}${sysconfdir}/pki/rpm-gpg/RPM-GPG-KEY-${DISTRO_VERSION}"
48 fi
49 if [ -f "${B}/ipk-key" ]; then
50 install -D -m 0644 "${B}/ipk-key" "${D}${sysconfdir}/pki/ipk-gpg/IPK-GPG-KEY-${DISTRO_VERSION}"
51 fi
52 if [ -f "${B}/pf-key" ]; then
53 install -D -m 0644 "${B}/pf-key" "${D}${sysconfdir}/pki/packagefeed-gpg/PACKAGEFEED-GPG-KEY-${DISTRO_VERSION}"
54 fi
55}
56
Patrick Williamsd8c66bc2016-06-20 12:57:21 -050057do_deploy () {
58 if [ -f "${B}/rpm-key" ]; then
59 install -D -m 0644 "${B}/rpm-key" "${DEPLOYDIR}/RPM-GPG-KEY-${DISTRO_VERSION}"
60 fi
61 if [ -f "${B}/ipk-key" ]; then
62 install -D -m 0644 "${B}/ipk-key" "${DEPLOYDIR}/IPK-GPG-KEY-${DISTRO_VERSION}"
63 fi
64 if [ -f "${B}/pf-key" ]; then
65 install -D -m 0644 "${B}/pf-key" "${DEPLOYDIR}/PACKAGEFEED-GPG-KEY-${DISTRO_VERSION}"
66 fi
67}
68do_deploy[sstate-outputdirs] = "${DEPLOY_DIR_RPM}"
69# cleandirs should possibly be in deploy.bbclass but we need it
70do_deploy[cleandirs] = "${DEPLOYDIR}"
71# clear stamp-extra-info since MACHINE is normally put there by deploy.bbclass
72do_deploy[stamp-extra-info] = ""
73addtask deploy after do_get_public_keys