diff options
author | Hanno Böck <hanno@gentoo.org> | 2008-04-21 12:05:22 +0000 |
---|---|---|
committer | Hanno Böck <hanno@gentoo.org> | 2008-04-21 12:05:22 +0000 |
commit | bb2ad64e097bbecaee4985c99dd3827a4423a856 (patch) | |
tree | c6e9a0b58623e7082972ad9b5900e55a84f60281 /mail-mta | |
parent | add local useflags for courier (diff) | |
download | gentoo-2-bb2ad64e097bbecaee4985c99dd3827a4423a856.tar.gz gentoo-2-bb2ad64e097bbecaee4985c99dd3827a4423a856.tar.bz2 gentoo-2-bb2ad64e097bbecaee4985c99dd3827a4423a856.zip |
courier version bump, proxy-maintained ebuild
(Portage version: 2.1.5_rc5)
Diffstat (limited to 'mail-mta')
-rw-r--r-- | mail-mta/courier/ChangeLog | 8 | ||||
-rw-r--r-- | mail-mta/courier/courier-0.59.0.ebuild | 325 | ||||
-rw-r--r-- | mail-mta/courier/files/remove-sysconftool.patch | 30 |
3 files changed, 362 insertions, 1 deletions
diff --git a/mail-mta/courier/ChangeLog b/mail-mta/courier/ChangeLog index 56f94c1f9ad3..15ea9131b8be 100644 --- a/mail-mta/courier/ChangeLog +++ b/mail-mta/courier/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for mail-mta/courier # Copyright 2002-2008 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/mail-mta/courier/ChangeLog,v 1.99 2008/04/20 12:11:16 hanno Exp $ +# $Header: /var/cvsroot/gentoo-x86/mail-mta/courier/ChangeLog,v 1.100 2008/04/21 12:05:22 hanno Exp $ + +*courier-0.59.0 (21 Apr 2008) + + 21 Apr 2008; Hanno Boeck <hanno@gentoo.org> + +files/remove-sysconftool.patch, +courier-0.59.0.ebuild: + Version bump, proxy-maintained user ebuild by Bernd Wurst. 20 Apr 2008; Hanno Boeck <hanno@gentoo.org> courier-0.55.1-r1.ebuild: Fix quoting. diff --git a/mail-mta/courier/courier-0.59.0.ebuild b/mail-mta/courier/courier-0.59.0.ebuild new file mode 100644 index 000000000000..6d310ab3f881 --- /dev/null +++ b/mail-mta/courier/courier-0.59.0.ebuild @@ -0,0 +1,325 @@ +# Copyright 1999-2008 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/mail-mta/courier/courier-0.59.0.ebuild,v 1.1 2008/04/21 12:05:22 hanno Exp $ + +WANT_AUTOCONF="latest" +WANT_AUTOMAKE="latest" + +inherit eutils flag-o-matic autotools + +DESCRIPTION="An MTA designed specifically for maildirs" +[ -z "${PV/?.??/}" ] && SRC_URI="mirror://sourceforge/courier/${P}.tar.bz2" +[ -z "${PV/?.??.?/}" ] && SRC_URI="mirror://sourceforge/courier/${P}.tar.bz2" +[ -z "${SRC_URI}" ] && SRC_URI="http://www.courier-mta.org/beta/courier/${P%%_pre}.tar.bz2" +HOMEPAGE="http://www.courier-mta.org/" +S="${WORKDIR}/${P%%_pre}" + +SLOT="0" +LICENSE="GPL-2" +# not in keywords due to missing dependencies: ~arm ~s390 ~ppc64 +KEYWORDS="~alpha ~amd64 ~hppa ~ia64 ~mips ~ppc ~sparc ~x86" +IUSE="postgres ldap mysql pam nls ipv6 spell fax crypt norewrite mailwrapper \ + fam web webmail" + +PROVIDE="virtual/mta + virtual/mda + virtual/imapd" + +DEPEND=" + >=net-libs/courier-authlib-0.59 + >=dev-libs/openssl-0.9.6 + >=sys-libs/gdbm-1.8.0 + dev-libs/libpcre + app-misc/mime-types + fax? ( >=media-libs/netpbm-9.12 virtual/ghostscript >=net-dialup/mgetty-1.1.28 ) + pam? ( virtual/pam ) + mysql? ( virtual/mysql ) + ldap? ( >=net-nds/openldap-1.2.11 ) + postgres? ( >=dev-db/postgresql-7.1.3 ) + spell? ( virtual/aspell-dict ) + fam? ( virtual/fam ) + !mailwrapper? ( !virtual/mta ) + !virtual/imapd + !mail-filter/maildrop" + +RDEPEND="${DEPEND} + dev-lang/perl + sys-process/procps" + +PDEPEND="mailwrapper? ( >=net-mail/mailwrapper-0.2 ) + pam? ( net-mail/mailbase ) + crypt? ( >=app-crypt/gnupg-1.0.4 )" + +filter-flags '-fomit-frame-pointer' + +src_unpack() { + use fam || ( + ewarn "File Alteration Monitor (FAM) is disabled" + ewarn "courier-imap will fall back to 60 second polls." + ewarn 'add "fam" to your USE flags to build as usual' + ebeep 4 + epause 4 ) + unpack ${A} + cd "${S}" + use norewrite && epatch "${FILESDIR}/norewrite.patch" + use elibc_uclibc && sed -i -e 's:linux-gnu\*:linux-gnu\*\ \|\ linux-uclibc:' config.sub + + epatch "${FILESDIR}/remove-sysconftool.patch" + + # some libtool version mismatch + _elibtoolize --copy --force || die +} + +src_compile() { + local myconf + myconf="`use_with ipv6` \ + `use_with ldap ldapaliasd` `use_enable ldap maildropldap`" + + use ldap && myconf="${myconf} --with-ldapconfig=/etc/courier/maildropldap.conf" + use spell || myconf="${myconf} --without-ispell" + + myconf="${myconf} --enable-mimetypes=/etc/mime.types" + + myconf="${myconf} $(use_with fam)" + + einfo "Configuring courier: $(echo ${myconf} | xargs echo)" + + econf \ + --prefix=/usr \ + --disable-root-check \ + --mandir=/usr/share/man \ + --sysconfdir=/etc/courier \ + --libexecdir=/usr/$(get_libdir)/courier \ + --datadir=/usr/share/courier \ + --sharedstatedir=/var/lib/courier/com \ + --localstatedir=/var/lib/courier \ + --with-piddir=/var/run/courier \ + --with-authdaemonvar=/var/lib/courier/authdaemon \ + --with-mailuser=mail \ + --with-mailgroup=mail \ + --with-paranoid-smtpext \ + --with-db=gdbm \ + --disable-autorenamesent \ + --cache-file="${S}/configuring.cache" \ + --host="${CHOST}" ${myconf} debug=true || die "./configure" + sed -e'/^install-perms-local:/a\ sed -e\"s|^|'"${D}"'|g\" -i permissions.dat' -i Makefile + emake || die "Compile problem" +} + +etc_courier() { + # Import existing /etc/courier/file if it exists. + # Add option only if it was not already set or even commented out + file="${1}" ; word="`echo \"${2}\" | sed -e\"s|=.*$||\" -e\"s|^.*opt ||\"`" + [ ! -e "${D}/etc/courier/${file}" ] && [ -e "/etc/courier/${file}" ] && \ + cp "/etc/courier/${file}" "${D}/etc/courier/${file}" + grep -q "${word}" "${D}/etc/courier/${file}" || \ + echo "${2}" >> "${D}/etc/courier/${file}" +} + +etc_courier_chg() { + file="${1}" ; key="${2}" ; value="${3}" ; section="${4}" + [ -z "${section}" ] && section="${2}" + grep -q "${key}" "${file}" && elog "Changing ${file}: ${key} to ${value}" + sed -i -e"/\#\#NAME: ${section}/,+30 s|${key}=.*|${key}=\"${value}\"|g" ${file} +} + + +src_install() { + local f + diropts -o mail -g mail + keepdir /var/run/courier + keepdir /var/lib/courier/tmp + keepdir /var/lib/courier/msgs + make install DESTDIR="${D}" || die "install" + make install-configure || die "install-configure" + + # Get rid of files we dont want + if ! use webmail ; then + cd "${D}" + cat "${FILESDIR}/webmail_files" | xargs rm -rf + fi + + if ! use web ; then + cd "${D}" + cat "${FILESDIR}/webadmin_files" | xargs rm -rf + fi + + for dir2keep in $(cd "${D}" && find ./var/lib/courier -type d) ; do + keepdir "$dir2keep" || die "failed running keepdir: $dir2keep" + done + + newinitd "${FILESDIR}/courier-init-r1" "courier" + use fam || sed -i -e's|^.*use famd$||g' "${D}/etc/init.d/courier" + + cd "${D}/etc/courier" + if use webmail ; then + insinto /etc/courier + newins "${FILESDIR}/apache-sqwebmail.inc" apache-sqwebmail.inc + fi + + for f in *.dist ; do cp "${f}" "${f%%.dist}" ; done + if use ldap ; then + [ -e ldapaliasrc ] && ( chown root:0 ldapaliasrc ; chmod 400 ldapaliasrc ) + else + rm -f ldapaliasrc + fi + + ( [ -e /etc/courier/sizelimit ] && cat /etc/courier/sizelimit || echo 0 ) \ + > "${D}/etc/courier/sizelimit" + etc_courier maildroprc "" + etc_courier esmtproutes "" + etc_courier backuprelay "" + etc_courier locallowercase "" + etc_courier bofh "opt BOFHBADMIME=accept" + etc_courier bofh "opt BOFHSPFTRUSTME=1" + etc_courier bofh "opt BOFHSPFHELO=pass,neutral,unknown,none,error,softfail,fail" + etc_courier bofh "opt BOFHSPFHELO=pass,neutral,unknown,none" + etc_courier bofh "opt BOFHSPFFROM=all" + etc_courier bofh "opt BOFHSPFMAILFROM=all" + etc_courier bofh "#opt BOFHSPFHARDERROR=fail" + etc_courier esmtpd "BOFHBADMIME=accept" + etc_courier esmtpd-ssl "BOFHBADMIME=accept" + etc_courier esmtpd-msa "BOFHBADMIME=accept" + + use fam && etc_courier_chg imapd IMAP_CAPABILITY "IMAP4rev1 UIDPLUS CHILDREN NAMESPACE THREAD=ORDEREDSUBJECT THREAD=REFERENCES SORT QUOTA AUTH=CRAM-MD5 AUTH=CRAM-SHA1 AUTH=CRAM-SHA256 IDLE" + use fam || etc_courier_chg imapd IMAP_CAPABILITY "IMAP4rev1 UIDPLUS CHILDREN NAMESPACE THREAD=ORDEREDSUBJECT THREAD=REFERENCES SORT QUOTA AUTH=CRAM-MD5 AUTH=CRAM-SHA1 AUTH=CRAM-SHA256" + + # Fix for a sandbox violation on subsequential merges + # - ticho@gentoo.org, 2005-07-10 + rm "${D}"/usr/sbin/{pop3d,imapd}{,-ssl} + dosym /usr/share/courier/pop3d /usr/sbin/courier-pop3d + dosym /usr/share/courier/pop3d-ssl /usr/sbin/courier-pop3d-ssl + dosym /usr/share/courier/imapd /usr/sbin/courier-imapd + dosym /usr/share/courier/imapd-ssl /usr/sbin/courier-imapd-ssl + + cd "${S}" + cp imap/README README.imap + use nls && cp unicode/README README.unicode + dodoc AUTHORS BENCHMARKS COPYING* ChangeLog* INSTALL NEWS README* TODO courier/doc/*.txt + dodoc tcpd/README.couriertls + mv "${D}/usr/share/courier/htmldoc" "${D}/usr/share/doc/${P}/html" + + if use webmail ; then + insinto /usr/$(get_libdir)/courier/courier + insopts -m 755 -o mail -g mail + doins "${S}/courier/webmaild" + fi + + if use web ; then + insinto /etc/courier/webadmin + insopts -m 400 -o mail -g mail + doins "${FILESDIR}/password.dist" + fi + + # avoid name collisions in /usr/sbin, make webadmin match + cd "${D}/usr/sbin" + for f in imapd imapd-ssl pop3d pop3d-ssl ; do mv "${f}" "courier-${f}" ; done + if use web ; then + sed -i -e 's:\$sbindir\/imapd:\$sbindir\/courier-imapd:g' \ + -e 's:\$sbindir\/imapd-ssl:\$sbindir\/courier-imapd-ssl:g' \ + "${D}/usr/share/courier/courierwebadmin/admin-40imap.pl" \ + || ewarn "failed to fix webadmin" + sed -i -e 's:\$sbindir\/pop3d:\$sbindir\/courier-pop3d:g' \ + -e 's:\$sbindir\/pop3d-ssl:\$sbindir\/courier-pop3d-ssl:g' \ + "${D}/usr/share/courier/courierwebadmin/admin-45pop3.pl" \ + || ewarn "failed to fix webadmin" + fi + + # users should be able to send mail. Could be restricted with suictl. + chmod u+s "${D}/usr/bin/sendmail" + + if use mailwrapper ; then + mv "${D}/usr/bin/sendmail" "${D}/usr/bin/sendmail.courier" + mv "${D}/usr/bin/rmail" "${D}/usr/bin/rmail.courier" + mv "${D}/usr/bin/mailq" "${D}/usr/bin/mailq.courier" + + mv "${D}/usr/share/man/man1/sendmail.1" \ + "${D}/usr/share/man/man1/sendmail-courier.1" + mv "${D}/usr/share/man/man1/mailq.1" \ + "${D}/usr/share/man/man1/mailq-courier.1" + mv "${D}/usr/share/man/man1/rmail.1" \ + "${D}/usr/share/man/man1/rmail-courier.1" + + insopts -m 444 -o mail -g mail + insinto /etc/mail + doins "${FILESDIR}/mailer.conf" + else + dosym /usr/bin/sendmail /usr/sbin/sendmail + fi +} + +src_test() { + addpredict / + vecho ">>> Test phase [check]: ${CATEGORY}/${PF}" + if hasq userpriv "${FEATURES}" ; then + if ! emake -j1 check; then + hasq test "${FEATURES}" && die "Make check failed. See above for details." + hasq test "${FEATURES}" || eerror "Make check failed. See above for details." + fi + else + hasq test "${FEATURES}" && eerror "Make check needs FEATURES="userpriv" to work." + fi + SANDBOX_PREDICT="${SANDBOX_PREDICT%:/}" +} + +pkg_postinst() { + use fam && elog "fam daemon is needed for courier-imapd" \ + || ewarn "courier was built without fam support" +} + +pkg_config() { + mailhost="$(hostname)" + export mailhost + + domainname="$(domainname)" + if [ "x$domainname" = "x(none)" ] ; then + domainname="$(echo ${mailhost} | sed -e "s/[^\.]*\.\(.*\)/\1/")" + fi + export domainname + + if [ "${ROOT}" = "/" ] ; then + file="${ROOT}/etc/courier/locals" + if [ ! -f "${file}" ] ; then + echo "localhost" > "${file}"; + echo "${domainname}" >> "${file}"; + fi + file="${ROOT}/etc/courier/esmtpacceptmailfor.dir/${domainname}" + if [ ! -f "${file}" ] ; then + echo "${domainname}" > "${file}" + /usr/sbin/makeacceptmailfor + fi + + file="${ROOT}/etc/courier/smtpaccess/${domainname}" + if [ ! -f "${file}" ] + then + netstat -nr | grep "^[1-9]" | while read network gateway netmask rest + do + i=1 + net="" + TIFS="${IFS}" + IFS="." + for o in "${netmask}" + do + if [ "${o}" == "255" ] + then + [ "_${net}" == "_" ] || net="${net}." + t="$(echo "${network}" | cut -d " " -f ${i})" + net="${net}${t}" + fi + i="$((${i} + 1))" + done + IFS="${TIFS}" + echo "doing configuration - relay control for the network ${net} !" + echo "${net} allow,RELAYCLIENT" >> ${file} + done + /usr/sbin/makesmtpaccess + fi + fi + + echo "creating cert for esmtpd-ssl:" + /usr/sbin/mkesmtpdcert + echo "creating cert for imapd-ssl:" + /usr/sbin/mkpop3dcert + echo "creating cert for pop3d-ssl:" + /usr/sbin/mkimapdcert +} diff --git a/mail-mta/courier/files/remove-sysconftool.patch b/mail-mta/courier/files/remove-sysconftool.patch new file mode 100644 index 000000000000..cf191be76db3 --- /dev/null +++ b/mail-mta/courier/files/remove-sysconftool.patch @@ -0,0 +1,30 @@ +--- orig/configure.in 2008-03-06 13:50:29.000000000 +0100 ++++ new/configure.in 2008-03-06 13:50:39.000000000 +0100 +@@ -19,7 +19,6 @@ + + AC_PROG_MAKE_SET + AC_PROG_CXX +-AC_PROG_SYSCONFTOOL + AC_PATH_PROGS(SETENV, env) + + AC_ARG_ENABLE(root-check, [ --disable-root-check Allow build as root (make check will fail)], +--- orig/Makefile.in 2008-03-06 19:37:53.000000000 +0100 ++++ new/Makefile.in 2008-03-06 19:38:22.000000000 +0100 +@@ -791,7 +791,6 @@ + + install-configure: + @$(MAKE) -$(MAKEFLAGS) install-perms +- @SYSCONFTOOL@ `awk ' $$5 == "config" && $$1 ~ /\.dist$$/ { print $$1 }' <permissions.dat` + + install-webadmin-password: + @stty -echo ; echo -n "Password: " ; read P; stty echo ; echo "" ; echo $$P >@sysconfdir@/webadmin/password && chown @mailuser@ @sysconfdir@/webadmin/password && chgrp @mailgroup@ @sysconfdir@/webadmin/password && chmod 400 @sysconfdir@/webadmin/password +--- orig/Makefile.am 2008-03-06 19:39:06.000000000 +0100 ++++ new/Makefile.am 2008-03-06 19:39:21.000000000 +0100 +@@ -160,7 +160,6 @@ + + install-configure: + @$(MAKE) -$(MAKEFLAGS) install-perms +- @SYSCONFTOOL@ `awk ' $$5 == "config" && $$1 ~ /\.dist$$/ { print $$1 }' <permissions.dat` + + install-webadmin-password: + @stty -echo ; echo -n "Password: " ; read P; stty echo ; echo "" ; echo $$P >@sysconfdir@/webadmin/password && chown @mailuser@ @sysconfdir@/webadmin/password && chgrp @mailgroup@ @sysconfdir@/webadmin/password && chmod 400 @sysconfdir@/webadmin/password |