diff options
author | Conrad Kostecki <conikost@gentoo.org> | 2021-07-10 00:05:44 +0200 |
---|---|---|
committer | Conrad Kostecki <conikost@gentoo.org> | 2021-07-10 00:36:32 +0200 |
commit | 1916dc504837114a2fcd018363632edac9a9b0e8 (patch) | |
tree | 0d8d4b6009e017cc773bb7b8c100bc8b820c19e0 /mail-mta/nullmailer | |
parent | acct-user/nullmail: add user (88) for mail-mta/nullmailer (diff) | |
download | gentoo-1916dc504837114a2fcd018363632edac9a9b0e8.tar.gz gentoo-1916dc504837114a2fcd018363632edac9a9b0e8.tar.bz2 gentoo-1916dc504837114a2fcd018363632edac9a9b0e8.zip |
mail-mta/nullmailer: migrate to GLEP 81
Closes: https://bugs.gentoo.org/781320
Package-Manager: Portage-3.0.20, Repoman-3.0.3
Signed-off-by: Conrad Kostecki <conikost@gentoo.org>
Diffstat (limited to 'mail-mta/nullmailer')
-rw-r--r-- | mail-mta/nullmailer/nullmailer-2.2-r2.ebuild | 157 |
1 files changed, 157 insertions, 0 deletions
diff --git a/mail-mta/nullmailer/nullmailer-2.2-r2.ebuild b/mail-mta/nullmailer/nullmailer-2.2-r2.ebuild new file mode 100644 index 000000000000..3ea8f8fe0a92 --- /dev/null +++ b/mail-mta/nullmailer/nullmailer-2.2-r2.ebuild @@ -0,0 +1,157 @@ +# Copyright 1999-2021 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=7 + +inherit autotools flag-o-matic multilib systemd + +DESCRIPTION="Simple relay-only local mail transport agent" +HOMEPAGE="http://untroubled.org/nullmailer/ https://github.com/bruceg/nullmailer" +SRC_URI="http://untroubled.org/${PN}/archive/${P}.tar.gz" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="amd64 ~arm ~arm64 ppc x86 ~x64-cygwin" +IUSE="ssl test" +RESTRICT="!test? ( test )" + +BDEPEND=" + acct-group/nullmail + acct-user/nullmail +" + +DEPEND=" + ssl? ( net-libs/gnutls:0= ) + test? ( sys-apps/ucspi-tcp[ipv6] sys-process/daemontools ) +" +RDEPEND=" + ${BDEPEND} + virtual/logger + sys-apps/shadow + ssl? ( net-libs/gnutls:0= ) + !mail-mta/courier + !mail-mta/esmtp + !mail-mta/exim + !mail-mta/mini-qmail + !mail-mta/msmtp[mta(+)] + !mail-mta/netqmail + !mail-mta/opensmtpd[mta(+)] + !mail-mta/postfix + !mail-mta/qmail-ldap + !mail-mta/sendmail + !mail-mta/ssmtp[mta(+)] +" + +PATCHES=( + "${FILESDIR}/${P}-fix-test-racecondition.patch" + "${FILESDIR}/${P}-disable-dns-using-test.patch" + "${FILESDIR}/${P}-disable-smtp-auth-tests.patch" + "${FILESDIR}/${P}-c++11.patch" +) + +src_prepare() { + default + sed -i.orig \ + -e '/\$(localstatedir)\/trigger/d' \ + "${S}"/Makefile.am || die + sed \ + -e "s:^AC_PROG_RANLIB:AC_CHECK_TOOL(AR, ar, false)\nAC_PROG_RANLIB:g" \ + -i configure.ac || die + sed -e "s/AM_CONFIG_HEADER/AC_CONFIG_HEADERS/" -i configure.ac || die + sed \ + -e "s#/usr/local#/usr#" \ + -e 's:/usr/etc/:/etc/:g' \ + -i doc/nullmailer-send.8 || die + eautoreconf +} + +src_configure() { + # https://github.com/bruceg/nullmailer/pull/31/commits + append-lfs-flags #471102 + econf \ + --localstatedir="${EPREFIX}"/var \ + $(use_enable ssl tls) +} + +src_install() { + default + + # A small bit of sample config + insinto /etc/nullmailer + newins "${FILESDIR}"/remotes.sample-2.0 remotes + + # This contains passwords, so should be secure + fperms 0640 /etc/nullmailer/remotes + fowners root:nullmail /etc/nullmailer/remotes + + # daemontools stuff + dodir /var/spool/nullmailer/service{,/log} + + insinto /var/spool/nullmailer/service + newins scripts/nullmailer.run run + fperms 700 /var/spool/nullmailer/service/run + + insinto /var/spool/nullmailer/service/log + newins scripts/nullmailer-log.run run + fperms 700 /var/spool/nullmailer/service/log/run + + # usability + dosym ../sbin/sendmail usr/$(get_libdir)/sendmail + + # permissions stuff + keepdir /var/log/nullmailer /var/spool/nullmailer/{tmp,queue,failed} + fperms 770 /var/log/nullmailer + fowners nullmail:nullmail /usr/sbin/nullmailer-queue /usr/bin/mailq + fperms 4711 /usr/sbin/nullmailer-queue /usr/bin/mailq + + newinitd "${FILESDIR}"/init.d-nullmailer-r6 nullmailer + systemd_dounit scripts/${PN}.service +} + +pkg_postinst() { + if [[ ! -e ${EROOT}/var/spool/nullmailer/trigger ]]; then + mkfifo --mode=0660 "${EROOT}/var/spool/nullmailer/trigger" || die + fi + chown nullmail:nullmail \ + "${EROOT}"/var/log/nullmailer \ + "${EROOT}"/var/spool/nullmailer/{tmp,queue,failed,trigger} || die + chmod 770 \ + "${EROOT}"/var/log/nullmailer \ + "${EROOT}"/var/spool/nullmailer/{tmp,queue,failed} || die + chmod 660 "${EROOT}"/var/spool/nullmailer/trigger || die + + # This contains passwords, so should be secure + chmod 0640 "${EROOT}"/etc/nullmailer/remotes || die + chown root:nullmail "${EROOT}"/etc/nullmailer/remotes || die + + if [[ -z ${REPLACING_VERSIONS} ]]; then + elog "To create an initial setup, please do:" + elog "emerge --config =${CATEGORY}/${PF}" + fi +} + +pkg_postrm() { + if [[ -e ${EROOT}/var/spool/nullmailer/trigger ]]; then + rm "${EROOT}/var/spool/nullmailer/trigger" || die + fi +} + +pkg_config() { + if [[ ! -s ${EROOT}/etc/nullmailer/me ]]; then + einfo "Setting /etc/nullmailer/me" + hostname --fqdn > "${EROOT}/etc/nullmailer/me" + if [[ ! -s ${EROOT}/etc/nullmailer/me ]]; then + eerror "Got no output from 'hostname --fqdn'" + fi + fi + if [[ ! -s ${EROOT}/etc/nullmailer/defaultdomain ]]; then + einfo "Setting /etc/nullmailer/defaultdomain" + hostname --domain > "${EROOT}/etc/nullmailer/defaultdomain" + if [[ ! -s ${EROOT}/etc/nullmailer/me ]]; then + eerror "Got no output from 'hostname --domain'" + fi + fi + if ! grep -q '^[ \t]*[^# \t]' "${EROOT}/etc/nullmailer/remotes"; then + ewarn "Remember to tweak ${EROOT}/etc/nullmailer/remotes yourself!" + fi +} |