# Copyright 1999-2016 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Id$ EAPI=6 inherit toolchain-funcs systemd MY_P=Mail-SpamAssassin-${PV//_/-} S=${WORKDIR}/${MY_P} DESCRIPTION="An extensible mail filter which can identify and tag spam" HOMEPAGE="http://spamassassin.apache.org/" SRC_URI="mirror://apache/spamassassin/source/${MY_P}.tar.bz2" LICENSE="Apache-2.0 GPL-2" SLOT="0" KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~x86-fbsd ~amd64-linux ~x86-linux ~x86-macos" IUSE="+bayes berkdb cron ipv6 ldap libressl mysql postgres qmail sqlite ssl test" # You can do without a database unless you need the Bayes features. REQUIRED_USE="bayes? ( || ( berkdb mysql postgres sqlite ) )" # SpamAssassin doesn't use libwww-perl except as a fallback for when # curl/wget are missing, so we depend on one of those instead. Some # mirrors use https, so we need those utilities to support SSL. # # re2c is needed to compile the rules (sa-compile). # DEPEND="app-crypt/gnupg dev-lang/perl dev-perl/Digest-SHA1 dev-perl/Encode-Detect dev-perl/Geo-IP dev-perl/HTML-Parser dev-perl/HTTP-Date dev-perl/Mail-DKIM dev-perl/Mail-SPF dev-perl/Net-DNS dev-perl/Net-Patricia dev-perl/NetAddr-IP dev-util/re2c || ( net-misc/wget[ssl] net-misc/curl[ssl] ) virtual/perl-Archive-Tar virtual/perl-IO-Zlib virtual/perl-MIME-Base64 virtual/perl-Pod-Parser virtual/perl-Time-HiRes berkdb? ( virtual/perl-DB_File ) ipv6? ( dev-perl/IO-Socket-INET6 ) ldap? ( dev-perl/perl-ldap ) mysql? ( dev-perl/DBI dev-perl/DBD-mysql ) postgres? ( dev-perl/DBI dev-perl/DBD-Pg ) sqlite? ( dev-perl/DBI dev-perl/DBD-SQLite ) ssl? ( dev-perl/IO-Socket-SSL !libressl? ( dev-libs/openssl:0 ) libressl? ( dev-libs/libressl ) )" RDEPEND="${DEPEND}" # Some spamd tests fail, and it looks like the whole suite eventually # hangs. RESTRICT=test PATCHES=( "${FILESDIR}/spamassassin-3.4.1-bug_7199.patch" "${FILESDIR}/spamassassin-3.4.1-bug_7223.patch" "${FILESDIR}/spamassassin-3.4.1-bug_7231.patch" "${FILESDIR}/spamassassin-3.4.1-bug_7265.patch" ) src_configure() { # spamc can be built with ssl support. local use_ssl="no" if use ssl; then use_ssl="yes" fi # Set SYSCONFDIR explicitly so we can't get bitten by bug 48205 again # (just to be sure, nobody knows how it could happen in the first place). # # We also set the path to the perl executable explictly. This will be # used to create the initial shebang line in the scripts (bug 62276). perl Makefile.PL \ PREFIX="${EPREFIX}/usr" \ INSTALLDIRS=vendor \ SYSCONFDIR="${EPREFIX}/etc" \ DATADIR="${EPREFIX}/usr/share/spamassassin" \ PERL_BIN="${EPREFIX}/usr/bin/perl" \ ENABLE_SSL="${use_ssl}" \ DESTDIR="${D}" \ || die "Unable to build!" # Now configure spamc. emake CC="$(tc-getCC)" LDFLAGS="${LDFLAGS}" spamc/Makefile } src_compile() { PERL_MM_USE_DEFAULT=1 emake if use qmail; then emake spamc/qmail-spamc fi } src_install () { emake install einstalldocs # Create the stub dir used by sa-update and friends keepdir /var/lib/spamassassin # Move spamd to sbin where it belongs. dodir /usr/sbin mv "${ED}"/usr/bin/spamd "${ED}"/usr/sbin/spamd || die "move spamd failed" if use qmail; then dobin spamc/qmail-spamc fi ln -s mail/spamassassin "${ED}"/etc/spamassassin || die # Disable plugin by default sed -i -e 's/^loadplugin/\#loadplugin/g' \ "${ED}"/etc/mail/spamassassin/init.pre \ || die "failed to disable plugins by default" # Add the init and config scripts. newinitd "${FILESDIR}"/3.4.1-spamd.init spamd newconfd "${FILESDIR}"/3.4.1-spamd.conf spamd systemd_newunit "${FILESDIR}"/${PN}.service-r1 ${PN}.service systemd_install_serviced "${FILESDIR}"/${PN}.service.conf # The sed statements in the following conditionals alter the init # script to depend (or not) on the database being running before # spamd is started. The sed commands either enable the dependency, # or delete the line entirely. if use postgres; then sed -i -e 's:@USEPOSTGRES@::' "${ED}/etc/init.d/spamd" || die dodoc sql/*_pg.sql else sed -i -e '/@USEPOSTGRES@/d' "${ED}/etc/init.d/spamd" || die fi if use mysql; then sed -i -e 's:@USEMYSQL@::' "${ED}/etc/init.d/spamd" || die dodoc sql/*_mysql.sql else sed -i -e '/@USEMYSQL@/d' "${ED}/etc/init.d/spamd" || die fi dodoc NOTICE TRADEMARK CREDITS UPGRADE USAGE sql/README.bayes \ sql/README.awl procmailrc.example sample-nonspam.txt \ sample-spam.txt spamd/PROTOCOL spamd/README.vpopmail \ spamd-apache2/README.apache # Rename some files so that they don't clash with others. newdoc spamd/README README.spamd newdoc sql/README README.sql newdoc ldap/README README.ldap if use qmail; then dodoc spamc/README.qmail fi insinto /etc/mail/spamassassin/ insopts -m0400 newins "${FILESDIR}"/secrets.cf secrets.cf.example # Create the directory where sa-update stores its GPG key (if you # choose to import one). If this directory does not exist, the # import will fail. This is bug 396307. We expect that the import # will be performed as root, and making the directory accessible # only to root prevents a warning on the command-line. diropts -m0700 dodir /etc/mail/spamassassin/sa-update-keys if use cron; then # Install the cron job if they want it. exeinto /etc/cron.daily newexe "${FILESDIR}/update-spamassassin-rules.cron" \ update-spamassassin-rules fi } pkg_postinst() { elog elog 'No rules are installed by default. You will need to run sa-update' elog 'at least once, and most likely configure SpamAssassin before it' elog 'will work.' if ! use cron; then elog elog 'You should consider a cron job for sa-update. One is provided' elog 'for daily updates if you enable the "cron" USE flag.' fi elog elog 'Configuration and update help can be found on the wiki:' elog elog ' https://wiki.gentoo.org/wiki/SpamAssassin' elog }