Gentoo Archives: gentoo-commits

From: Michael Orlitzky <mjo@g.o>
To: gentoo-commits@l.g.o
Subject: [gentoo-commits] repo/gentoo:master commit in: mail-filter/spamassassin/
Date: Tue, 18 Sep 2018 02:47:43
Message-Id: 1537238605.0dbbc52674fccc8c21209fe42b9e66790369901f.mjo@gentoo
1 commit: 0dbbc52674fccc8c21209fe42b9e66790369901f
2 Author: Michael Orlitzky <mjo <AT> gentoo <DOT> org>
3 AuthorDate: Tue Sep 18 02:05:09 2018 +0000
4 Commit: Michael Orlitzky <mjo <AT> gentoo <DOT> org>
5 CommitDate: Tue Sep 18 02:43:25 2018 +0000
6 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0dbbc526
7
8 mail-filter/spamassassin: new version 3.4.2.
9
10 This new version incorporates a ton of fixes that have piled on top of
11 v3.4.1 over the past few years. As a result, we are able to drop all
12 of our PATCHES in the new ebuild. The new version also addresses four
13 security vulnerabilities:
14
15 * CVE-2016-1238
16 * CVE-2017-15705
17 * CVE-2018-11780
18 * CVE-2018-11781
19
20 Sadly, there is a new failure in the test suite (upstream bug 7622) so
21 I've added RESTRICT=test for now.
22
23 Stabilization of this version should already be fast-tracked for the
24 security issues mentioned above, but just in case, the release notes
25 have the following to say:
26
27 If you do not update to 3.4.2, you will be stuck at the last ruleset
28 with SHA-1 signatures in the near future.
29
30 Bug: https://bugs.gentoo.org/666348
31 Bug: https://bz.apache.org/SpamAssassin/show_bug.cgi?id=7622
32 Package-Manager: Portage-2.3.40, Repoman-2.3.9
33
34 mail-filter/spamassassin/Manifest | 1 +
35 mail-filter/spamassassin/spamassassin-3.4.2.ebuild | 242 +++++++++++++++++++++
36 2 files changed, 243 insertions(+)
37
38 diff --git a/mail-filter/spamassassin/Manifest b/mail-filter/spamassassin/Manifest
39 index d2d417e002f..6b7489e6f21 100644
40 --- a/mail-filter/spamassassin/Manifest
41 +++ b/mail-filter/spamassassin/Manifest
42 @@ -1 +1,2 @@
43 DIST Mail-SpamAssassin-3.4.1.tar.bz2 2710985 BLAKE2B f85b0ed2bae783bc6dfa39df36589a6cb90e6c657efcff1fa094f952847e4bcb24aa232b6689804bb1170204ae1d33216ed9bde207d7a7a6863410d8f847c391 SHA512 91d50e2ce6520e3e1c7bc66da133a0815be34ced15e26b6e6c17af5a03d5c62f41d8086f25f65084d6634497148cf5439977d7d4a44d7c3e307535beac6629af
44 +DIST Mail-SpamAssassin-3.4.2.tar.bz2 2700016 BLAKE2B a29b4cfce5e578c07ec54b2224191917dc45bcefff071f674c572fc905f1d6324827bcc21c338546bdea11140fc20474a16314218e2fd4fa685965b0e0078df8 SHA512 fe3d9d1d7b9fed3063549afd071066729f1f4d998be91ded1e5afc29bb37c7a298dc5f8f99a282b75435d317b5b5072a81393134ccfe059a73d953e26a9c3885
45
46 diff --git a/mail-filter/spamassassin/spamassassin-3.4.2.ebuild b/mail-filter/spamassassin/spamassassin-3.4.2.ebuild
47 new file mode 100644
48 index 00000000000..340edb07078
49 --- /dev/null
50 +++ b/mail-filter/spamassassin/spamassassin-3.4.2.ebuild
51 @@ -0,0 +1,242 @@
52 +# Copyright 1999-2018 Gentoo Foundation
53 +# Distributed under the terms of the GNU General Public License v2
54 +
55 +EAPI=6
56 +
57 +inherit perl-functions systemd toolchain-funcs user
58 +
59 +MY_P="Mail-SpamAssassin-${PV//_/-}"
60 +S="${WORKDIR}/${MY_P}"
61 +DESCRIPTION="An extensible mail filter which can identify and tag spam"
62 +HOMEPAGE="https://spamassassin.apache.org/"
63 +SRC_URI="mirror://apache/spamassassin/source/${MY_P}.tar.bz2"
64 +
65 +LICENSE="Apache-2.0 GPL-2"
66 +SLOT="0"
67 +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~x86-fbsd ~amd64-linux ~x86-linux ~x86-macos"
68 +IUSE="berkdb cron ipv6 ldap libressl mysql postgres qmail sqlite ssl test"
69 +
70 +# Upstream bug 7622.
71 +RESTRICT=test
72 +
73 +# The Makefile.PL script checks for dependencies, but only fails if a
74 +# required (i.e. not optional) dependency is missing. We therefore
75 +# require most of the optional modules only at runtime.
76 +REQDEPEND="dev-lang/perl:=
77 + dev-perl/HTML-Parser
78 + dev-perl/Net-DNS
79 + dev-perl/NetAddr-IP
80 + virtual/perl-Archive-Tar
81 + virtual/perl-Digest-SHA
82 + virtual/perl-IO-Zlib
83 + virtual/perl-Time-HiRes
84 + ssl? (
85 + !libressl? ( dev-libs/openssl:0= )
86 + libressl? ( dev-libs/libressl )
87 + )"
88 +
89 +# SpamAssassin doesn't use libwww-perl except as a fallback for when
90 +# curl/wget are missing, so we depend on one of those instead. Some
91 +# mirrors use https, so we need those utilities to support SSL.
92 +#
93 +# re2c is needed to compile the rules (sa-compile).
94 +#
95 +# We still need the old Digest-SHA1 because razor2 has not been ported
96 +# to Digest-SHA.
97 +OPTDEPEND="app-crypt/gnupg
98 + dev-perl/Digest-SHA1
99 + dev-perl/Encode-Detect
100 + dev-perl/Geo-IP
101 + dev-perl/HTTP-Date
102 + dev-perl/Mail-DKIM
103 + dev-perl/Mail-SPF
104 + dev-perl/Net-Patricia
105 + dev-perl/Net-CIDR-Lite
106 + dev-util/re2c
107 + || ( net-misc/wget[ssl] net-misc/curl[ssl] )
108 + virtual/perl-MIME-Base64
109 + virtual/perl-Pod-Parser
110 + berkdb? ( virtual/perl-DB_File )
111 + ipv6? ( dev-perl/IO-Socket-INET6 )
112 + ldap? ( dev-perl/perl-ldap )
113 + mysql? (
114 + dev-perl/DBI
115 + dev-perl/DBD-mysql
116 + )
117 + postgres? (
118 + dev-perl/DBI
119 + dev-perl/DBD-Pg
120 + )
121 + sqlite? (
122 + dev-perl/DBI
123 + dev-perl/DBD-SQLite
124 + )
125 + ssl? ( dev-perl/IO-Socket-SSL )"
126 +
127 +DEPEND="${REQDEPEND}
128 + test? (
129 + ${OPTDEPEND}
130 + virtual/perl-Test-Harness
131 + )"
132 +RDEPEND="${REQDEPEND} ${OPTDEPEND}"
133 +
134 +src_prepare() {
135 + default
136 +
137 + # The sa_compile test does some weird stuff like hopping around in
138 + # the directory tree and calling "make" to create a dist tarball
139 + # from ${S}. It fails, and is more trouble than it's worth...
140 + perl_rm_files t/sa_compile.t || die 'failed to remove sa_compile test'
141 +
142 + # The spamc tests (which need the networked spamd daemon) fail for
143 + # irrelevant reasons. It's too hard to disable them (unlike the
144 + # spamd tests themselves -- see src_test), so use a crude
145 + # workaround.
146 + perl_rm_files t/spamc_*.t || die 'failed to remove spamc tests'
147 +}
148 +
149 +src_configure() {
150 + # This is how and where the perl-module eclass disables the
151 + # MakeMaker interactive prompt.
152 + export PERL_MM_USE_DEFAULT=1
153 +
154 + # Set SYSCONFDIR explicitly so we can't get bitten by bug 48205 again
155 + # (just to be sure, nobody knows how it could happen in the first place).
156 + #
157 + # We also set the path to the perl executable explictly. This will be
158 + # used to create the initial shebang line in the scripts (bug 62276).
159 + perl Makefile.PL \
160 + PREFIX="${EPREFIX}/usr" \
161 + INSTALLDIRS=vendor \
162 + SYSCONFDIR="${EPREFIX}/etc" \
163 + DATADIR="${EPREFIX}/usr/share/spamassassin" \
164 + PERL_BIN="${EPREFIX}/usr/bin/perl" \
165 + ENABLE_SSL="$(usex ssl)" \
166 + DESTDIR="${D}" \
167 + || die 'failed to create a Makefile using Makefile.PL'
168 +
169 + # Now configure spamc.
170 + emake CC="$(tc-getCC)" LDFLAGS="${LDFLAGS}" spamc/Makefile
171 +}
172 +
173 +src_compile() {
174 + emake
175 + use qmail && emake spamc/qmail-spamc
176 +}
177 +
178 +src_install () {
179 + emake install
180 + einstalldocs
181 +
182 + # Create the stub dir used by sa-update and friends
183 + keepdir /var/lib/spamassassin
184 +
185 + # Move spamd to sbin where it belongs.
186 + dodir /usr/sbin
187 + mv "${ED}"/usr/bin/spamd "${ED}"/usr/sbin/spamd || die "move spamd failed"
188 +
189 + if use qmail; then
190 + dobin spamc/qmail-spamc
191 + fi
192 +
193 + dosym mail/spamassassin /etc/spamassassin
194 +
195 + # Disable plugin by default
196 + sed -i -e 's/^loadplugin/\#loadplugin/g' \
197 + "${ED}/etc/mail/spamassassin/init.pre" \
198 + || die "failed to disable plugins by default"
199 +
200 + # Add the init and config scripts.
201 + newinitd "${FILESDIR}/3.4.1-spamd.init-r3" spamd
202 + newconfd "${FILESDIR}/3.4.1-spamd.conf-r1" spamd
203 +
204 + systemd_newunit "${FILESDIR}/${PN}.service-r4" "${PN}.service"
205 + systemd_install_serviced "${FILESDIR}/${PN}.service.conf-r2" \
206 + "${PN}.service"
207 +
208 + use postgres && dodoc sql/*_pg.sql
209 + use mysql && dodoc sql/*_mysql.sql
210 +
211 + dodoc NOTICE TRADEMARK CREDITS UPGRADE USAGE sql/README.bayes \
212 + sql/README.awl procmailrc.example sample-nonspam.txt \
213 + sample-spam.txt spamd/PROTOCOL spamd/README.vpopmail \
214 + spamd-apache2/README.apache
215 +
216 + # Rename some files so that they don't clash with others.
217 + newdoc spamd/README README.spamd
218 + newdoc sql/README README.sql
219 + newdoc ldap/README README.ldap
220 +
221 + if use qmail; then
222 + dodoc spamc/README.qmail
223 + fi
224 +
225 + insinto /etc/mail/spamassassin/
226 + insopts -m0400
227 + newins "${FILESDIR}"/secrets.cf secrets.cf.example
228 +
229 + # Create the directory where sa-update stores its GPG key (if you
230 + # choose to import one). If this directory does not exist, the
231 + # import will fail. This is bug 396307. We expect that the import
232 + # will be performed as root, and making the directory accessible
233 + # only to root prevents a warning on the command-line.
234 + diropts -m0700
235 + dodir /etc/mail/spamassassin/sa-update-keys
236 +
237 + if use cron; then
238 + # Install the cron job if they want it.
239 + exeinto /etc/cron.daily
240 + newexe "${FILESDIR}/update-spamassassin-rules.cron" \
241 + update-spamassassin-rules
242 + fi
243 +
244 + # Remove perllocal.pod to avoid file collisions (bug #603338).
245 + perl_delete_localpod || die "failed to remove perllocal.pod"
246 +
247 + # The perl-module eclass calls three other functions to clean
248 + # up in src_install. The first fixes references to ${D} in the
249 + # packlist, and is useful to us, too. The other two functions,
250 + # perl_delete_emptybsdir and perl_remove_temppath, don't seem
251 + # to be needed: there are no empty directories, *.bs files, or
252 + # ${D} paths remaining in our installed image.
253 + perl_fix_packlist || die "failed to fix paths in packlist"
254 +}
255 +
256 +src_test() {
257 + # Trick the test suite into skipping the spamd tests. Setting
258 + # SPAMD_HOST to a non-localhost value causes SKIP_SPAMD_TESTS to be
259 + # set in SATest.pm.
260 + export SPAMD_HOST=disabled
261 + default
262 +}
263 +
264 +pkg_preinst() {
265 + # The spamd daemon runs as this user. Use a real home directory so
266 + # that it can hold SA configuration.
267 + enewuser spamd -1 -1 /home/spamd
268 +}
269 +
270 +pkg_postinst() {
271 + elog
272 + elog 'No rules are installed by default. You will need to run sa-update'
273 + elog 'at least once, and most likely configure SpamAssassin before it'
274 + elog 'will work.'
275 +
276 + if ! use cron; then
277 + elog
278 + elog 'You should consider a cron job for sa-update. One is provided'
279 + elog 'for daily updates if you enable the "cron" USE flag.'
280 + fi
281 + elog
282 + elog 'Configuration and update help can be found on the wiki:'
283 + elog
284 + elog ' https://wiki.gentoo.org/wiki/SpamAssassin'
285 + elog
286 +
287 + ewarn 'If this version of SpamAssassin causes permissions issues'
288 + ewarn 'with your user configurations or bayes databases, then you'
289 + ewarn 'may need to set SPAMD_RUN_AS_ROOT=true in your OpenRC service'
290 + ewarn 'configuration file, or remove the --username and --groupname'
291 + ewarn 'flags from the SPAMD_OPTS variable in your systemd service'
292 + ewarn 'configuration file.'
293 +}