Gentoo Archives: gentoo-commits

From: Sam James <sam@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: app-crypt/gnupg/
Date: Thu, 01 Sep 2022 21:49:23
Message-Id: 1662068950.d97a3080b57cfa7cc913b295744678ab44b686a9.sam@gentoo
1 commit: d97a3080b57cfa7cc913b295744678ab44b686a9
2 Author: Sam James <sam <AT> gentoo <DOT> org>
3 AuthorDate: Thu Sep 1 21:03:43 2022 +0000
4 Commit: Sam James <sam <AT> gentoo <DOT> org>
5 CommitDate: Thu Sep 1 21:49:10 2022 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=d97a3080
7
8 app-crypt/gnupg: add 2.2.38
9
10 Signed-off-by: Sam James <sam <AT> gentoo.org>
11
12 app-crypt/gnupg/Manifest | 2 +
13 app-crypt/gnupg/gnupg-2.2.38.ebuild | 159 ++++++++++++++++++++++++++++++++++++
14 2 files changed, 161 insertions(+)
15
16 diff --git a/app-crypt/gnupg/Manifest b/app-crypt/gnupg/Manifest
17 index f069d19f182d..292c8c4c6144 100644
18 --- a/app-crypt/gnupg/Manifest
19 +++ b/app-crypt/gnupg/Manifest
20 @@ -4,6 +4,8 @@ DIST gnupg-2.2.36.tar.bz2 7273805 BLAKE2B 82f26f48380632ddffedacb5e7cff653aec7be
21 DIST gnupg-2.2.36.tar.bz2.sig 119 BLAKE2B ad6dc03c34f6c0d13080ef0bdea2db152c12ea4f129783ba1b0b7f237965b8eeec22b2e79fcf42657dafdd20cae558d781b07378bed78386979a0b4c4ef4a49b SHA512 4ad3f9041aa1fbffaab3cc4aa0df038a67dc8eb200492cdd96259dcf1e0005cb39d6e6245280f1a2a8d4db9f686381e2b0f5bb80c412edbdbcb3fc11dca044c5
22 DIST gnupg-2.2.37.tar.bz2 7285172 BLAKE2B 40606f996aea3d26e28989466861bf486b8bf95e38d23377c0745b85f4817988f794fa07cbb1d5b8b7ae1da3c8bd5fcee5fabb1998b2fc1aa0b0e3ea4351575b SHA512 b56c47002948fd28fc9d5c23b46f5522e4210ed61c17f491c3b3fab5fab8893da33b1f8ff55a3bbef6367ff92b10c141c1f24d8350c37a0e756d2bdfbe86d7be
23 DIST gnupg-2.2.37.tar.bz2.sig 119 BLAKE2B b5166f574a35223eeadf056d6bc3e8bcbd02fad766713afba28e20d4d431fcf123b5566527274923fede092c1e48efefd32b825644583f016bf3db119af03209 SHA512 8a1c34a5cd6afa3a263669922bc43217274f796634dc14b54558e1361f5e38680c6897e402a5289ccbe08c91efa3647bccd741fa09f3259174b8dabf86ecbc6f
24 +DIST gnupg-2.2.38.tar.bz2 7290509 BLAKE2B 249fd6502a1607d1881fd97e4a97a1a3557da26929b67424bafcf29b5ef1588c9295347c5be497a8485dd61755bfe40b4f0232e0f1f67d2517c69613c6080da1 SHA512 30483492e27c31db114c29e22eae1b9c54db9f02ade491f443a7748b42825fa3e52545286316b99217aed0b0af29f67ccecca2399c76554a086bcd49b35ad3e5
25 +DIST gnupg-2.2.38.tar.bz2.sig 119 BLAKE2B 9e7257a7326ccf107eff1f93b92f7e79ab31a2e58c12d4085a2106528c822df1737a127923c62a05fa199fa1d1e0ac900726808870d059871be6ab178849369e SHA512 e00ec552e1347ab26d37ad7830f599aa51e7620e9780250480192f83c67e319bf2d26f7198f49c553204ab96461c0a4aea1fa6ae57c83a91681f98c2596a9ab6
26 DIST gnupg-2.3.6.tar.bz2 7604761 BLAKE2B 6cbc749156c50b6633c126cde621271c6c9682a04efea51fbc5a2e92ee56493e8348814391ee0c337adcb4de4dd23293b9592db78998626905038c859ac4af6e SHA512 4540e8d2be836b491918f4987ba301a73fcdc4539b1f9abf6112a74c2d39c0e5dc3f17511212bac1dd7fd0594feecd91f95ecf78d4b2c1e70e818342a1802b85
27 DIST gnupg-2.3.6.tar.bz2.sig 119 BLAKE2B c7d4cdc81580b8b1e56c7bc83236d65c9d2c1bab2d210d14a0d3c58f635d656c9b449ef9596b9601027cb891bd437cc8f2a63eb3c17742c288531511984fba7f SHA512 85d155f9809c8d0f38723d8622c085e421531c016d19fcce2ae34dc9a4aeac0bc1895f7a094ee9cdf69a15b426fb0d72ee53319fe0a05665c92caa0e950c1797
28 DIST gnupg-2.3.7.tar.bz2 7599853 BLAKE2B 3e9e33c8357222f42cc0e2af538e9f1f1f0453f35d790aaadf47ce9df24229efa91457b6014b34f19084448a3a6603c82e7d07714b89a68c6a84a08af6fa0e02 SHA512 c7fe169050ef17051cdaac9ad476e7ea792483baad1208fc359d568fa9e138d920ecaa2cd9cae73b20f5472a7d8ca6540a62062ff7a06055cc656b0eb4b917b9
29
30 diff --git a/app-crypt/gnupg/gnupg-2.2.38.ebuild b/app-crypt/gnupg/gnupg-2.2.38.ebuild
31 new file mode 100644
32 index 000000000000..fcc6d9e01c03
33 --- /dev/null
34 +++ b/app-crypt/gnupg/gnupg-2.2.38.ebuild
35 @@ -0,0 +1,159 @@
36 +# Copyright 1999-2022 Gentoo Authors
37 +# Distributed under the terms of the GNU General Public License v2
38 +
39 +EAPI=8
40 +
41 +VERIFY_SIG_OPENPGP_KEY_PATH="${BROOT}"/usr/share/openpgp-keys/gnupg.asc
42 +inherit flag-o-matic systemd toolchain-funcs verify-sig
43 +
44 +MY_P="${P/_/-}"
45 +
46 +DESCRIPTION="The GNU Privacy Guard, a GPL OpenPGP implementation"
47 +HOMEPAGE="https://gnupg.org/"
48 +SRC_URI="mirror://gnupg/gnupg/${MY_P}.tar.bz2"
49 +SRC_URI+=" verify-sig? ( mirror://gnupg/gnupg/${P}.tar.bz2.sig )"
50 +S="${WORKDIR}/${MY_P}"
51 +
52 +LICENSE="GPL-3"
53 +SLOT="0"
54 +KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86 ~x64-cygwin ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
55 +IUSE="bzip2 doc ldap nls readline selinux +smartcard ssl test tofu tools usb user-socket wks-server"
56 +RESTRICT="!test? ( test )"
57 +
58 +# Existence of executables is checked during configuration.
59 +# Note: On each bump, update dep bounds on each version from configure.ac!
60 +DEPEND=">=dev-libs/libassuan-2.5.0
61 + >=dev-libs/libgcrypt-1.8.0:=
62 + >=dev-libs/libgpg-error-1.29
63 + >=dev-libs/libksba-1.3.5
64 + >=dev-libs/npth-1.2
65 + >=net-misc/curl-7.10
66 + sys-libs/zlib
67 + bzip2? ( app-arch/bzip2 )
68 + ldap? ( net-nds/openldap:= )
69 + readline? ( sys-libs/readline:0= )
70 + smartcard? ( usb? ( virtual/libusb:1 ) )
71 + ssl? ( >=net-libs/gnutls-3.0:0= )
72 + tofu? ( >=dev-db/sqlite-3.7 )"
73 +
74 +RDEPEND="${DEPEND}
75 + app-crypt/pinentry
76 + nls? ( virtual/libintl )
77 + selinux? ( sec-policy/selinux-gpg )
78 + wks-server? ( virtual/mta )"
79 +
80 +BDEPEND="virtual/pkgconfig
81 + doc? ( sys-apps/texinfo )
82 + nls? ( sys-devel/gettext )
83 + verify-sig? ( sec-keys/openpgp-keys-gnupg )"
84 +
85 +DOCS=(
86 + ChangeLog NEWS README THANKS TODO VERSION
87 + doc/FAQ doc/DETAILS doc/HACKING doc/TRANSLATE doc/OpenPGP doc/KEYSERVER
88 +)
89 +
90 +PATCHES=(
91 + "${FILESDIR}"/${PN}-2.1.20-gpgscm-Use-shorter-socket-path-lengts-to-improve-tes.patch
92 +)
93 +
94 +src_prepare() {
95 + default
96 +
97 + # Inject SSH_AUTH_SOCK into user's sessions after enabling gpg-agent-ssh.socket in systemctl --user mode,
98 + # idea borrowed from libdbus, see
99 + # https://gitlab.freedesktop.org/dbus/dbus/-/blob/master/bus/systemd-user/dbus.socket.in#L6
100 + #
101 + # This cannot be upstreamed, as it requires determining the exact prefix of 'systemctl',
102 + # which in turn requires discovery in Autoconf, something that upstream deeply resents.
103 + sed -e "/DirectoryMode=/a ExecStartPost=-${EPREFIX}/bin/systemctl --user set-environment SSH_AUTH_SOCK=%t/gnupg/S.gpg-agent.ssh" \
104 + -i doc/examples/systemd-user/gpg-agent-ssh.socket || die
105 +}
106 +
107 +src_configure() {
108 + local myconf=(
109 + $(use_enable bzip2)
110 + $(use_enable nls)
111 + $(use_enable smartcard scdaemon)
112 + $(use_enable ssl gnutls)
113 + $(use_enable test all-tests)
114 + $(use_enable test tests)
115 + $(use_enable tofu)
116 + $(use smartcard && use_enable usb ccid-driver || echo '--disable-ccid-driver')
117 + $(use_enable wks-server wks-tools)
118 + $(use_with ldap)
119 + $(use_with readline)
120 + --with-mailprog=/usr/libexec/sendmail
121 + --disable-ntbtls
122 + --enable-gpg
123 + --enable-gpgsm
124 + --enable-large-secmem
125 +
126 + CC_FOR_BUILD="$(tc-getBUILD_CC)"
127 + GPG_ERROR_CONFIG="${ESYSROOT}/usr/bin/${CHOST}-gpg-error-config"
128 + KSBA_CONFIG="${ESYSROOT}/usr/bin/ksba-config"
129 + LIBASSUAN_CONFIG="${ESYSROOT}/usr/bin/libassuan-config"
130 + LIBGCRYPT_CONFIG="${ESYSROOT}/usr/bin/${CHOST}-libgcrypt-config"
131 + NPTH_CONFIG="${ESYSROOT}/usr/bin/npth-config"
132 +
133 + $("${S}/configure" --help | grep -o -- '--without-.*-prefix')
134 + )
135 +
136 + if use prefix && use usb; then
137 + # bug #649598
138 + append-cppflags -I"${EPREFIX}/usr/include/libusb-1.0"
139 + fi
140 +
141 + # bug #663142
142 + if use user-socket; then
143 + myconf+=( --enable-run-gnupg-user-socket )
144 + fi
145 +
146 + # glib fails and picks up clang's internal stdint.h causing weird errors
147 + tc-is-clang && export gl_cv_absolute_stdint_h="${ESYSROOT}"/usr/include/stdint.h
148 +
149 + # Hardcode mailprog to /usr/libexec/sendmail even if it does not exist.
150 + # As of GnuPG 2.3, the mailprog substitution is used for the binary called
151 + # by wks-client & wks-server; and if it's autodetected but not not exist at
152 + # build time, then then 'gpg-wks-client --send' functionality will not
153 + # work. This has an unwanted side-effect in stage3 builds: there was a
154 + # [R]DEPEND on virtual/mta, which also brought in virtual/logger, bloating
155 + # the build where the install guide previously make the user chose the
156 + # logger & mta early in the install.
157 +
158 + econf "${myconf[@]}"
159 +}
160 +
161 +src_compile() {
162 + default
163 +
164 + use doc && emake -C doc html
165 +}
166 +
167 +src_test() {
168 + # bug #638574
169 + use tofu && export TESTFLAGS=--parallel
170 +
171 + default
172 +}
173 +
174 +src_install() {
175 + default
176 +
177 + use tools &&
178 + dobin \
179 + tools/{convert-from-106,gpg-check-pattern} \
180 + tools/{gpg-zip,gpgconf,gpgsplit,lspgpot,mail-signed-keys} \
181 + tools/make-dns-cert
182 +
183 + dosym gpg /usr/bin/gpg2
184 + dosym gpgv /usr/bin/gpgv2
185 + echo ".so man1/gpg.1" > "${ED}"/usr/share/man/man1/gpg2.1 || die
186 + echo ".so man1/gpgv.1" > "${ED}"/usr/share/man/man1/gpgv2.1 || die
187 +
188 + dodir /etc/env.d
189 + echo "CONFIG_PROTECT=/usr/share/gnupg/qualified.txt" >> "${ED}"/etc/env.d/30gnupg || die
190 +
191 + use doc && dodoc doc/gnupg.html/* doc/*.png
192 +
193 + systemd_douserunit doc/examples/systemd-user/*.{service,socket}
194 +}