mirror of
https://github.com/gentoo-mirror/gentoo.git
synced 2025-12-21 21:17:37 -08:00
mail-mta/courier: drop 1.3.5, 1.3.10, 1.3.12, 1.3.13, 1.4.0, 1.5.0
Signed-off-by: Hanno Böck <hanno@gentoo.org>
This commit is contained in:
parent
f13ec27cc9
commit
0d7b450cfa
@ -1,8 +1,2 @@
|
|||||||
DIST courier-1.3.10.tar.bz2 7898254 BLAKE2B 10558f78cd58540cacbd85fb4dadbeddd374b8832a27c546864023aeebdf9e5ca1fa4d770cdefce6bf7ed2bbaf334a893393eae79cee2b13482e75d8b157824f SHA512 266d2785ea7a8b9455b9448e3279f77d399c182ec4408b599a301f389a28dd40b7b869c8b158eb49b4416b58ce09805fad3f176796a2cf0408bb93b766081ce3
|
|
||||||
DIST courier-1.3.12.tar.bz2 7901365 BLAKE2B 95cbfeb0926366cf94876b5f03bd14fee516a0057771b083672151174cdbe7cbdbf2531e98dff0615432482526a883e972d56db8f8b1aa38e94d4b29ddcdeb71 SHA512 58ea9e3178de63a574a0cc456c07a48068170f2f3d89c8373a994430c381561845a305bddeb6f4e00922920ecd53acfff9db7f1de1bea3f06ae61682e1ede688
|
|
||||||
DIST courier-1.3.13.tar.bz2 7903044 BLAKE2B 94e70d79ffddc295f029478f6aca2727682bc1f09c22eac9212288aba5fa91d3a9d771829b4f1a2c6929310ea2042bf4c9d2714fe01585f345416ad906642cb3 SHA512 bb2e9a0eeca17025675627ced44fec86fb0104836be16c3bb6bdc451d97fa0c37ef078d908f2fb0e4652dd8ee90ffb108d77c381381c74033244e9988e8e41b4
|
|
||||||
DIST courier-1.3.5.tar.bz2 7901040 BLAKE2B 5a79d02d1d40967f98f2a1942fee6786d8e6e2ddc7dea6677a85db0480f71e4b974a671adc81c4bafd66c888c5b54012eb5684f2936f5164496699939d179fc4 SHA512 5f51383356f4a36f9c114be6aa69d694c82bb95b1a336d2948d486d582bd6559da69be93b7c20aee2ff57826ab7eeb265aa20794074456d036b22da7f280f95d
|
|
||||||
DIST courier-1.4.0.tar.bz2 7904288 BLAKE2B dd6e598f7c62beb8d2609d990644ac28f2de8854cbe8990c1f99018de4e80de7128a6d889add6ac75f291b2fa7d41371e109fa9ec227d55934dddc6f8db94aa8 SHA512 2a2270ab7abfbece71b5621d5389824ebdcd0fa5f529ba408393bbd6887d1daad096671fbf7085f1580a98ef6d81012743c1ae3a1fb1dbccb45bf456d7a23b52
|
|
||||||
DIST courier-1.4.1.tar.bz2 7904154 BLAKE2B 029a4ee48955069fdb9de2e189c7e354ac742143d3f177d0533fb361aad9a17f276616c160db2b625a5efe5dfaa304f0fb204045dc95529dfbca97e163c1018e SHA512 0b2d7cbad97d3328beb75e424725f638c2344e29acc7e1a37d56919e53a090790533057e43fa3a8638d9432b0ea0f7f6dfa89bf62a05136cac4e65c0584b17a6
|
DIST courier-1.4.1.tar.bz2 7904154 BLAKE2B 029a4ee48955069fdb9de2e189c7e354ac742143d3f177d0533fb361aad9a17f276616c160db2b625a5efe5dfaa304f0fb204045dc95529dfbca97e163c1018e SHA512 0b2d7cbad97d3328beb75e424725f638c2344e29acc7e1a37d56919e53a090790533057e43fa3a8638d9432b0ea0f7f6dfa89bf62a05136cac4e65c0584b17a6
|
||||||
DIST courier-1.5.0.tar.bz2 8469027 BLAKE2B 6a73c4e38a9f7b7275e45890ec15ecaf6da3541af082b1e5e3e2c9ce3bf719994a12f3f6d7c8818ebec7137ae894f5b7677c8a34fce2eb7ab089143c99c41f68 SHA512 f091e4887c5dcba92acd2e00d15f955249743c7c7dc30fe6281c51545549e5c752892ca9b0cca4180142e44620be83da2a19c94f146daa09f5468be3bce6e70a
|
|
||||||
DIST courier-1.5.1.tar.bz2 8470196 BLAKE2B d7cea5a6dd8075e94c7cfc6d50a7f4e8b8b46941d8013812ae5fc0ee0f820b636aa2e14f55481dc47cfc67fa7a9bdd9100315f23eaa102afcbcaedf0bbbde95d SHA512 7b3ee3e0882e66f5cf26ec2286fe7cd34f1d0ef5db8ad70b199473fec7d11d784a7164724b715da7f554039487153ffe07ac88c33afa505995c5266a04b8cc97
|
DIST courier-1.5.1.tar.bz2 8470196 BLAKE2B d7cea5a6dd8075e94c7cfc6d50a7f4e8b8b46941d8013812ae5fc0ee0f820b636aa2e14f55481dc47cfc67fa7a9bdd9100315f23eaa102afcbcaedf0bbbde95d SHA512 7b3ee3e0882e66f5cf26ec2286fe7cd34f1d0ef5db8ad70b199473fec7d11d784a7164724b715da7f554039487153ffe07ac88c33afa505995c5266a04b8cc97
|
||||||
|
|||||||
@ -1,313 +0,0 @@
|
|||||||
# Copyright 1999-2025 Gentoo Authors
|
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
|
||||||
|
|
||||||
EAPI=8
|
|
||||||
|
|
||||||
inherit flag-o-matic
|
|
||||||
|
|
||||||
DESCRIPTION="An MTA designed specifically for maildirs"
|
|
||||||
HOMEPAGE="https://www.courier-mta.org/"
|
|
||||||
SRC_URI="https://downloads.sourceforge.net/courier/${P}.tar.bz2"
|
|
||||||
|
|
||||||
LICENSE="GPL-3"
|
|
||||||
SLOT="0"
|
|
||||||
KEYWORDS="~alpha amd64 arm arm64 ~hppa ~ppc ppc64 ~riscv ~s390 ~sparc x86"
|
|
||||||
IUSE="postgres ldap mysql pam nls ipv6 spell fax crypt norewrite \
|
|
||||||
fam web webmail gnutls split-usr"
|
|
||||||
|
|
||||||
DEPEND="
|
|
||||||
>=net-libs/courier-authlib-0.72.1
|
|
||||||
>=net-libs/courier-unicode-2.3.0:=
|
|
||||||
net-dns/libidn2:=
|
|
||||||
gnutls? ( net-libs/gnutls:= )
|
|
||||||
!gnutls? (
|
|
||||||
dev-libs/openssl:0=
|
|
||||||
)
|
|
||||||
>=sys-libs/gdbm-1.8.0:=
|
|
||||||
dev-libs/libpcre2
|
|
||||||
app-misc/mime-types
|
|
||||||
dev-lang/perl:=
|
|
||||||
fax? ( >=media-libs/netpbm-9.12 app-text/ghostscript-gpl >=net-dialup/mgetty-1.1.28 )
|
|
||||||
pam? ( sys-libs/pam )
|
|
||||||
mysql? ( dev-db/mysql-connector-c )
|
|
||||||
ldap? ( >=net-nds/openldap-1.2.11:= )
|
|
||||||
postgres? ( dev-db/postgresql:= )
|
|
||||||
spell? ( app-text/aspell )
|
|
||||||
fam? ( virtual/fam )
|
|
||||||
!mail-filter/maildrop
|
|
||||||
!mail-mta/esmtp
|
|
||||||
!mail-mta/exim
|
|
||||||
!mail-mta/msmtp[mta]
|
|
||||||
!mail-mta/netqmail
|
|
||||||
!mail-mta/nullmailer
|
|
||||||
!mail-mta/postfix
|
|
||||||
!mail-mta/sendmail
|
|
||||||
!mail-mta/ssmtp[mta]
|
|
||||||
!mail-mta/opensmtpd
|
|
||||||
!net-mail/dot-forward
|
|
||||||
!sys-apps/ucspi-tcp
|
|
||||||
"
|
|
||||||
|
|
||||||
RDEPEND="${DEPEND}
|
|
||||||
sys-process/procps"
|
|
||||||
|
|
||||||
# get rid of old style virtual/imapd - bug 350792
|
|
||||||
# all blockers really needed?
|
|
||||||
RDEPEND="${RDEPEND}
|
|
||||||
!net-mail/courier-imap
|
|
||||||
!net-mail/cyrus-imapd"
|
|
||||||
|
|
||||||
PDEPEND="pam? ( net-mail/mailbase )
|
|
||||||
crypt? ( >=app-crypt/gnupg-1.0.4 )"
|
|
||||||
|
|
||||||
src_prepare() {
|
|
||||||
use norewrite && eapply "${FILESDIR}/norewrite.patch"
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
src_configure() {
|
|
||||||
filter-flags '-fomit-frame-pointer'
|
|
||||||
|
|
||||||
local myconf
|
|
||||||
myconf=""
|
|
||||||
|
|
||||||
use ldap && myconf="${myconf} --with-ldapconfig=/etc/courier/maildropldap.conf"
|
|
||||||
|
|
||||||
econf ${myconf} \
|
|
||||||
$(use_with fam) \
|
|
||||||
$(use_with ipv6) \
|
|
||||||
$(use_with spell ispell) \
|
|
||||||
$(use_with ldap ldapaliasd) \
|
|
||||||
$(use_enable ldap maildroldap) \
|
|
||||||
$(use_with gnutls) \
|
|
||||||
--with-notice=unicode \
|
|
||||||
--enable-mimetypes=/etc/mime.types \
|
|
||||||
--prefix=/usr \
|
|
||||||
--disable-root-check \
|
|
||||||
--mandir=/usr/share/man \
|
|
||||||
--sysconfdir=/etc/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}" debug=true || die "./configure"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_compile() {
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
etc_courier() {
|
|
||||||
# Import existing /etc/courier/file if it exists.
|
|
||||||
# Add option only if it was not already set or even commented out
|
|
||||||
local 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() {
|
|
||||||
local 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/lib/courier/tmp
|
|
||||||
keepdir /var/lib/courier/msgs
|
|
||||||
make install DESTDIR="${D}" || die "install"
|
|
||||||
make install-configure DESTDIR="${D}" || die "install-configure"
|
|
||||||
|
|
||||||
# init script takes care of this
|
|
||||||
rm -rf "${D}/var/run"
|
|
||||||
|
|
||||||
# Get rid of files we dont want
|
|
||||||
if ! use webmail ; then
|
|
||||||
rm -rf "${D}/usr/$(get_libdir)/courier/courier/webmail" \
|
|
||||||
"${D}/usr/$(get_libdir)/courier/courier/sqwebmaild" \
|
|
||||||
"${D}/usr/share/courier/sqwebmail/" \
|
|
||||||
"${D}/usr/sbin/webmaild" \
|
|
||||||
"${D}/usr/sbin/webgpg" \
|
|
||||||
"${D}/etc/courier/webmail.authpam" \
|
|
||||||
"${D}/var/lib/courier/webmail-logincache" \
|
|
||||||
"${D}"/etc/courier/sqwebmaild*
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! use web ; then
|
|
||||||
rm -rf "${D}/usr/share/courier/courierwebadmin/" \
|
|
||||||
"${D}/etc/courier/webadmin"
|
|
||||||
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-r4" "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:mail ldapaliasrc ; chmod 640 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
|
|
||||||
dosym ../share/courier/pop3d /usr/sbin/courier-pop3d
|
|
||||||
dosym ../share/courier/pop3d-ssl /usr/sbin/courier-pop3d-ssl
|
|
||||||
dosym ../share/courier/imapd /usr/sbin/courier-imapd
|
|
||||||
dosym ../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 libs/tcpd/README.couriertls
|
|
||||||
mv "${D}/usr/share/courier/htmldoc" "${D}/usr/share/doc/${PF}/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 split-usr; then
|
|
||||||
dosym ../bin/sendmail /usr/sbin/sendmail
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
src_test() {
|
|
||||||
if [ `whoami` != 'root' ]; then
|
|
||||||
# Disable valgrind checks
|
|
||||||
echo '#!/bin/sh' > libs/imap/testsuitevalgrind
|
|
||||||
echo '#!/bin/sh' > libs/maildir/testsuitevalgrind
|
|
||||||
sed -i -e 's:VALGRIND=:exit 0 #VALGRIND=:g' libs/maildrop/Makefile*
|
|
||||||
emake -j1 check
|
|
||||||
else
|
|
||||||
einfo "make check skipped, can't run as root."
|
|
||||||
einfo "You can enable it with FEATURES=\"userpriv\""
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
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 [[ -z "${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
|
|
||||||
}
|
|
||||||
@ -1,313 +0,0 @@
|
|||||||
# Copyright 1999-2024 Gentoo Authors
|
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
|
||||||
|
|
||||||
EAPI=8
|
|
||||||
|
|
||||||
inherit flag-o-matic
|
|
||||||
|
|
||||||
DESCRIPTION="An MTA designed specifically for maildirs"
|
|
||||||
HOMEPAGE="https://www.courier-mta.org/"
|
|
||||||
SRC_URI="https://downloads.sourceforge.net/courier/${P}.tar.bz2"
|
|
||||||
|
|
||||||
LICENSE="GPL-3"
|
|
||||||
SLOT="0"
|
|
||||||
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
|
|
||||||
IUSE="postgres ldap mysql pam nls ipv6 spell fax crypt norewrite \
|
|
||||||
fam web webmail gnutls split-usr"
|
|
||||||
|
|
||||||
DEPEND="
|
|
||||||
>=net-libs/courier-authlib-0.72.3
|
|
||||||
>=net-libs/courier-unicode-2.3.1:=
|
|
||||||
net-dns/libidn2:=
|
|
||||||
gnutls? ( net-libs/gnutls:= )
|
|
||||||
!gnutls? (
|
|
||||||
dev-libs/openssl:0=
|
|
||||||
)
|
|
||||||
>=sys-libs/gdbm-1.8.0:=
|
|
||||||
dev-libs/libpcre2
|
|
||||||
app-misc/mime-types
|
|
||||||
dev-lang/perl:=
|
|
||||||
fax? ( >=media-libs/netpbm-9.12 app-text/ghostscript-gpl >=net-dialup/mgetty-1.1.28 )
|
|
||||||
pam? ( sys-libs/pam )
|
|
||||||
mysql? ( dev-db/mysql-connector-c )
|
|
||||||
ldap? ( >=net-nds/openldap-1.2.11:= )
|
|
||||||
postgres? ( dev-db/postgresql:= )
|
|
||||||
spell? ( app-text/aspell )
|
|
||||||
fam? ( virtual/fam )
|
|
||||||
!mail-filter/maildrop
|
|
||||||
!mail-mta/esmtp
|
|
||||||
!mail-mta/exim
|
|
||||||
!mail-mta/msmtp[mta]
|
|
||||||
!mail-mta/netqmail
|
|
||||||
!mail-mta/nullmailer
|
|
||||||
!mail-mta/postfix
|
|
||||||
!mail-mta/sendmail
|
|
||||||
!mail-mta/ssmtp[mta]
|
|
||||||
!mail-mta/opensmtpd
|
|
||||||
!net-mail/dot-forward
|
|
||||||
!sys-apps/ucspi-tcp
|
|
||||||
"
|
|
||||||
|
|
||||||
RDEPEND="${DEPEND}
|
|
||||||
sys-process/procps"
|
|
||||||
|
|
||||||
# get rid of old style virtual/imapd - bug 350792
|
|
||||||
# all blockers really needed?
|
|
||||||
RDEPEND="${RDEPEND}
|
|
||||||
!net-mail/courier-imap
|
|
||||||
!net-mail/cyrus-imapd"
|
|
||||||
|
|
||||||
PDEPEND="pam? ( net-mail/mailbase )
|
|
||||||
crypt? ( >=app-crypt/gnupg-1.0.4 )"
|
|
||||||
|
|
||||||
src_prepare() {
|
|
||||||
use norewrite && eapply "${FILESDIR}/norewrite.patch"
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
src_configure() {
|
|
||||||
filter-flags '-fomit-frame-pointer'
|
|
||||||
|
|
||||||
local myconf
|
|
||||||
myconf=""
|
|
||||||
|
|
||||||
use ldap && myconf="${myconf} --with-ldapconfig=/etc/courier/maildropldap.conf"
|
|
||||||
|
|
||||||
econf ${myconf} \
|
|
||||||
$(use_with fam) \
|
|
||||||
$(use_with ipv6) \
|
|
||||||
$(use_with spell ispell) \
|
|
||||||
$(use_with ldap ldapaliasd) \
|
|
||||||
$(use_enable ldap maildroldap) \
|
|
||||||
$(use_with gnutls) \
|
|
||||||
--with-notice=unicode \
|
|
||||||
--enable-mimetypes=/etc/mime.types \
|
|
||||||
--prefix=/usr \
|
|
||||||
--disable-root-check \
|
|
||||||
--mandir=/usr/share/man \
|
|
||||||
--sysconfdir=/etc/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}" debug=true || die "./configure"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_compile() {
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
etc_courier() {
|
|
||||||
# Import existing /etc/courier/file if it exists.
|
|
||||||
# Add option only if it was not already set or even commented out
|
|
||||||
local 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() {
|
|
||||||
local 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/lib/courier/tmp
|
|
||||||
keepdir /var/lib/courier/msgs
|
|
||||||
make install DESTDIR="${D}" || die "install"
|
|
||||||
make install-configure DESTDIR="${D}" || die "install-configure"
|
|
||||||
|
|
||||||
# init script takes care of this
|
|
||||||
rm -rf "${D}/var/run"
|
|
||||||
|
|
||||||
# Get rid of files we dont want
|
|
||||||
if ! use webmail ; then
|
|
||||||
rm -rf "${D}/usr/$(get_libdir)/courier/courier/webmail" \
|
|
||||||
"${D}/usr/$(get_libdir)/courier/courier/sqwebmaild" \
|
|
||||||
"${D}/usr/share/courier/sqwebmail/" \
|
|
||||||
"${D}/usr/sbin/webmaild" \
|
|
||||||
"${D}/usr/sbin/webgpg" \
|
|
||||||
"${D}/etc/courier/webmail.authpam" \
|
|
||||||
"${D}/var/lib/courier/webmail-logincache" \
|
|
||||||
"${D}"/etc/courier/sqwebmaild*
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! use web ; then
|
|
||||||
rm -rf "${D}/usr/share/courier/courierwebadmin/" \
|
|
||||||
"${D}/etc/courier/webadmin"
|
|
||||||
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-r4" "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:mail ldapaliasrc ; chmod 640 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
|
|
||||||
dosym ../share/courier/pop3d /usr/sbin/courier-pop3d
|
|
||||||
dosym ../share/courier/pop3d-ssl /usr/sbin/courier-pop3d-ssl
|
|
||||||
dosym ../share/courier/imapd /usr/sbin/courier-imapd
|
|
||||||
dosym ../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 libs/tcpd/README.couriertls
|
|
||||||
mv "${D}/usr/share/courier/htmldoc" "${D}/usr/share/doc/${PF}/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 split-usr; then
|
|
||||||
dosym ../bin/sendmail /usr/sbin/sendmail
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
src_test() {
|
|
||||||
if [ `whoami` != 'root' ]; then
|
|
||||||
# Disable valgrind checks
|
|
||||||
echo '#!/bin/sh' > libs/imap/testsuitevalgrind
|
|
||||||
echo '#!/bin/sh' > libs/maildir/testsuitevalgrind
|
|
||||||
sed -i -e 's:VALGRIND=:exit 0 #VALGRIND=:g' libs/maildrop/Makefile*
|
|
||||||
emake -j1 check
|
|
||||||
else
|
|
||||||
einfo "make check skipped, can't run as root."
|
|
||||||
einfo "You can enable it with FEATURES=\"userpriv\""
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
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 [[ -z "${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
|
|
||||||
}
|
|
||||||
@ -1,313 +0,0 @@
|
|||||||
# Copyright 1999-2025 Gentoo Authors
|
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
|
||||||
|
|
||||||
EAPI=8
|
|
||||||
|
|
||||||
inherit flag-o-matic
|
|
||||||
|
|
||||||
DESCRIPTION="An MTA designed specifically for maildirs"
|
|
||||||
HOMEPAGE="https://www.courier-mta.org/"
|
|
||||||
SRC_URI="https://downloads.sourceforge.net/courier/${P}.tar.bz2"
|
|
||||||
|
|
||||||
LICENSE="GPL-3"
|
|
||||||
SLOT="0"
|
|
||||||
KEYWORDS="~alpha amd64 arm arm64 ~hppa ~ppc ppc64 ~riscv ~s390 ~sparc x86"
|
|
||||||
IUSE="postgres ldap mysql pam nls ipv6 spell fax crypt norewrite \
|
|
||||||
fam web webmail gnutls split-usr"
|
|
||||||
|
|
||||||
DEPEND="
|
|
||||||
>=net-libs/courier-authlib-0.72.3
|
|
||||||
>=net-libs/courier-unicode-2.3.1:=
|
|
||||||
net-dns/libidn2:=
|
|
||||||
gnutls? ( net-libs/gnutls:= )
|
|
||||||
!gnutls? (
|
|
||||||
dev-libs/openssl:0=
|
|
||||||
)
|
|
||||||
>=sys-libs/gdbm-1.8.0:=
|
|
||||||
dev-libs/libpcre2
|
|
||||||
app-misc/mime-types
|
|
||||||
dev-lang/perl:=
|
|
||||||
fax? ( >=media-libs/netpbm-9.12 app-text/ghostscript-gpl >=net-dialup/mgetty-1.1.28 )
|
|
||||||
pam? ( sys-libs/pam )
|
|
||||||
mysql? ( dev-db/mysql-connector-c )
|
|
||||||
ldap? ( >=net-nds/openldap-1.2.11:= )
|
|
||||||
postgres? ( dev-db/postgresql:= )
|
|
||||||
spell? ( app-text/aspell )
|
|
||||||
fam? ( virtual/fam )
|
|
||||||
!mail-filter/maildrop
|
|
||||||
!mail-mta/esmtp
|
|
||||||
!mail-mta/exim
|
|
||||||
!mail-mta/msmtp[mta]
|
|
||||||
!mail-mta/netqmail
|
|
||||||
!mail-mta/nullmailer
|
|
||||||
!mail-mta/postfix
|
|
||||||
!mail-mta/sendmail
|
|
||||||
!mail-mta/ssmtp[mta]
|
|
||||||
!mail-mta/opensmtpd
|
|
||||||
!net-mail/dot-forward
|
|
||||||
!sys-apps/ucspi-tcp
|
|
||||||
"
|
|
||||||
|
|
||||||
RDEPEND="${DEPEND}
|
|
||||||
sys-process/procps"
|
|
||||||
|
|
||||||
# get rid of old style virtual/imapd - bug 350792
|
|
||||||
# all blockers really needed?
|
|
||||||
RDEPEND="${RDEPEND}
|
|
||||||
!net-mail/courier-imap
|
|
||||||
!net-mail/cyrus-imapd"
|
|
||||||
|
|
||||||
PDEPEND="pam? ( net-mail/mailbase )
|
|
||||||
crypt? ( >=app-crypt/gnupg-1.0.4 )"
|
|
||||||
|
|
||||||
src_prepare() {
|
|
||||||
use norewrite && eapply "${FILESDIR}/norewrite.patch"
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
src_configure() {
|
|
||||||
filter-flags '-fomit-frame-pointer'
|
|
||||||
|
|
||||||
local myconf
|
|
||||||
myconf=""
|
|
||||||
|
|
||||||
use ldap && myconf="${myconf} --with-ldapconfig=/etc/courier/maildropldap.conf"
|
|
||||||
|
|
||||||
econf ${myconf} \
|
|
||||||
$(use_with fam) \
|
|
||||||
$(use_with ipv6) \
|
|
||||||
$(use_with spell ispell) \
|
|
||||||
$(use_with ldap ldapaliasd) \
|
|
||||||
$(use_enable ldap maildroldap) \
|
|
||||||
$(use_with gnutls) \
|
|
||||||
--with-notice=unicode \
|
|
||||||
--enable-mimetypes=/etc/mime.types \
|
|
||||||
--prefix=/usr \
|
|
||||||
--disable-root-check \
|
|
||||||
--mandir=/usr/share/man \
|
|
||||||
--sysconfdir=/etc/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}" debug=true || die "./configure"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_compile() {
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
etc_courier() {
|
|
||||||
# Import existing /etc/courier/file if it exists.
|
|
||||||
# Add option only if it was not already set or even commented out
|
|
||||||
local 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() {
|
|
||||||
local 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/lib/courier/tmp
|
|
||||||
keepdir /var/lib/courier/msgs
|
|
||||||
make install DESTDIR="${D}" || die "install"
|
|
||||||
make install-configure DESTDIR="${D}" || die "install-configure"
|
|
||||||
|
|
||||||
# init script takes care of this
|
|
||||||
rm -rf "${D}/var/run"
|
|
||||||
|
|
||||||
# Get rid of files we dont want
|
|
||||||
if ! use webmail ; then
|
|
||||||
rm -rf "${D}/usr/$(get_libdir)/courier/courier/webmail" \
|
|
||||||
"${D}/usr/$(get_libdir)/courier/courier/sqwebmaild" \
|
|
||||||
"${D}/usr/share/courier/sqwebmail/" \
|
|
||||||
"${D}/usr/sbin/webmaild" \
|
|
||||||
"${D}/usr/sbin/webgpg" \
|
|
||||||
"${D}/etc/courier/webmail.authpam" \
|
|
||||||
"${D}/var/lib/courier/webmail-logincache" \
|
|
||||||
"${D}"/etc/courier/sqwebmaild*
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! use web ; then
|
|
||||||
rm -rf "${D}/usr/share/courier/courierwebadmin/" \
|
|
||||||
"${D}/etc/courier/webadmin"
|
|
||||||
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-r4" "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:mail ldapaliasrc ; chmod 640 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
|
|
||||||
dosym ../share/courier/pop3d /usr/sbin/courier-pop3d
|
|
||||||
dosym ../share/courier/pop3d-ssl /usr/sbin/courier-pop3d-ssl
|
|
||||||
dosym ../share/courier/imapd /usr/sbin/courier-imapd
|
|
||||||
dosym ../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 libs/tcpd/README.couriertls
|
|
||||||
mv "${D}/usr/share/courier/htmldoc" "${D}/usr/share/doc/${PF}/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 split-usr; then
|
|
||||||
dosym ../bin/sendmail /usr/sbin/sendmail
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
src_test() {
|
|
||||||
if [ `whoami` != 'root' ]; then
|
|
||||||
# Disable valgrind checks
|
|
||||||
echo '#!/bin/sh' > libs/imap/testsuitevalgrind
|
|
||||||
echo '#!/bin/sh' > libs/maildir/testsuitevalgrind
|
|
||||||
sed -i -e 's:VALGRIND=:exit 0 #VALGRIND=:g' libs/maildrop/Makefile*
|
|
||||||
emake -j1 check
|
|
||||||
else
|
|
||||||
einfo "make check skipped, can't run as root."
|
|
||||||
einfo "You can enable it with FEATURES=\"userpriv\""
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
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 [[ -z "${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
|
|
||||||
}
|
|
||||||
@ -1,313 +0,0 @@
|
|||||||
# Copyright 1999-2025 Gentoo Authors
|
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
|
||||||
|
|
||||||
EAPI=8
|
|
||||||
|
|
||||||
inherit flag-o-matic
|
|
||||||
|
|
||||||
DESCRIPTION="An MTA designed specifically for maildirs"
|
|
||||||
HOMEPAGE="https://www.courier-mta.org/"
|
|
||||||
SRC_URI="https://downloads.sourceforge.net/courier/${P}.tar.bz2"
|
|
||||||
|
|
||||||
LICENSE="GPL-3"
|
|
||||||
SLOT="0"
|
|
||||||
KEYWORDS="~alpha amd64 arm arm64 ~hppa ~ppc ppc64 ~riscv ~s390 ~sparc x86"
|
|
||||||
IUSE="postgres ldap mysql pam nls ipv6 spell fax crypt norewrite \
|
|
||||||
fam web webmail gnutls split-usr"
|
|
||||||
|
|
||||||
DEPEND="
|
|
||||||
>=net-libs/courier-authlib-0.72.1
|
|
||||||
>=net-libs/courier-unicode-2.3.0:=
|
|
||||||
net-dns/libidn2:=
|
|
||||||
gnutls? ( net-libs/gnutls:= )
|
|
||||||
!gnutls? (
|
|
||||||
dev-libs/openssl:0=
|
|
||||||
)
|
|
||||||
>=sys-libs/gdbm-1.8.0:=
|
|
||||||
dev-libs/libpcre2
|
|
||||||
app-misc/mime-types
|
|
||||||
fax? ( >=media-libs/netpbm-9.12 app-text/ghostscript-gpl >=net-dialup/mgetty-1.1.28 )
|
|
||||||
pam? ( sys-libs/pam )
|
|
||||||
mysql? ( dev-db/mysql-connector-c )
|
|
||||||
ldap? ( >=net-nds/openldap-1.2.11:= )
|
|
||||||
postgres? ( dev-db/postgresql:= )
|
|
||||||
spell? ( app-text/aspell )
|
|
||||||
fam? ( virtual/fam )
|
|
||||||
!mail-filter/maildrop
|
|
||||||
!mail-mta/esmtp
|
|
||||||
!mail-mta/exim
|
|
||||||
!mail-mta/msmtp[mta]
|
|
||||||
!mail-mta/netqmail
|
|
||||||
!mail-mta/nullmailer
|
|
||||||
!mail-mta/postfix
|
|
||||||
!mail-mta/sendmail
|
|
||||||
!mail-mta/ssmtp[mta]
|
|
||||||
!mail-mta/opensmtpd
|
|
||||||
!net-mail/dot-forward
|
|
||||||
!sys-apps/ucspi-tcp
|
|
||||||
"
|
|
||||||
|
|
||||||
RDEPEND="${DEPEND}
|
|
||||||
dev-lang/perl
|
|
||||||
sys-process/procps"
|
|
||||||
|
|
||||||
# get rid of old style virtual/imapd - bug 350792
|
|
||||||
# all blockers really needed?
|
|
||||||
RDEPEND="${RDEPEND}
|
|
||||||
!net-mail/courier-imap
|
|
||||||
!net-mail/cyrus-imapd"
|
|
||||||
|
|
||||||
PDEPEND="pam? ( net-mail/mailbase )
|
|
||||||
crypt? ( >=app-crypt/gnupg-1.0.4 )"
|
|
||||||
|
|
||||||
src_prepare() {
|
|
||||||
use norewrite && eapply "${FILESDIR}/norewrite.patch"
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
src_configure() {
|
|
||||||
filter-flags '-fomit-frame-pointer'
|
|
||||||
|
|
||||||
local myconf
|
|
||||||
myconf=""
|
|
||||||
|
|
||||||
use ldap && myconf="${myconf} --with-ldapconfig=/etc/courier/maildropldap.conf"
|
|
||||||
|
|
||||||
econf ${myconf} \
|
|
||||||
$(use_with fam) \
|
|
||||||
$(use_with ipv6) \
|
|
||||||
$(use_with spell ispell) \
|
|
||||||
$(use_with ldap ldapaliasd) \
|
|
||||||
$(use_enable ldap maildroldap) \
|
|
||||||
$(use_with gnutls) \
|
|
||||||
--with-notice=unicode \
|
|
||||||
--enable-mimetypes=/etc/mime.types \
|
|
||||||
--prefix=/usr \
|
|
||||||
--disable-root-check \
|
|
||||||
--mandir=/usr/share/man \
|
|
||||||
--sysconfdir=/etc/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}" debug=true || die "./configure"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_compile() {
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
etc_courier() {
|
|
||||||
# Import existing /etc/courier/file if it exists.
|
|
||||||
# Add option only if it was not already set or even commented out
|
|
||||||
local 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() {
|
|
||||||
local 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/lib/courier/tmp
|
|
||||||
keepdir /var/lib/courier/msgs
|
|
||||||
make install DESTDIR="${D}" || die "install"
|
|
||||||
make install-configure DESTDIR="${D}" || die "install-configure"
|
|
||||||
|
|
||||||
# init script takes care of this
|
|
||||||
rm -rf "${D}/var/run"
|
|
||||||
|
|
||||||
# Get rid of files we dont want
|
|
||||||
if ! use webmail ; then
|
|
||||||
rm -rf "${D}/usr/$(get_libdir)/courier/courier/webmail" \
|
|
||||||
"${D}/usr/$(get_libdir)/courier/courier/sqwebmaild" \
|
|
||||||
"${D}/usr/share/courier/sqwebmail/" \
|
|
||||||
"${D}/usr/sbin/webmaild" \
|
|
||||||
"${D}/usr/sbin/webgpg" \
|
|
||||||
"${D}/etc/courier/webmail.authpam" \
|
|
||||||
"${D}/var/lib/courier/webmail-logincache" \
|
|
||||||
"${D}"/etc/courier/sqwebmaild*
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! use web ; then
|
|
||||||
rm -rf "${D}/usr/share/courier/courierwebadmin/" \
|
|
||||||
"${D}/etc/courier/webadmin"
|
|
||||||
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-r4" "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:mail ldapaliasrc ; chmod 640 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
|
|
||||||
dosym ../share/courier/pop3d /usr/sbin/courier-pop3d
|
|
||||||
dosym ../share/courier/pop3d-ssl /usr/sbin/courier-pop3d-ssl
|
|
||||||
dosym ../share/courier/imapd /usr/sbin/courier-imapd
|
|
||||||
dosym ../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 libs/tcpd/README.couriertls
|
|
||||||
mv "${D}/usr/share/courier/htmldoc" "${D}/usr/share/doc/${PF}/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 split-usr; then
|
|
||||||
dosym ../bin/sendmail /usr/sbin/sendmail
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
src_test() {
|
|
||||||
if [ `whoami` != 'root' ]; then
|
|
||||||
# Disable valgrind checks
|
|
||||||
echo '#!/bin/sh' > libs/imap/testsuitevalgrind
|
|
||||||
echo '#!/bin/sh' > libs/maildir/testsuitevalgrind
|
|
||||||
sed -i -e 's:VALGRIND=:#VALGRIND=:g' libs/maildrop/Makefile*
|
|
||||||
emake -j1 check
|
|
||||||
else
|
|
||||||
einfo "make check skipped, can't run as root."
|
|
||||||
einfo "You can enable it with FEATURES=\"userpriv\""
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
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 [[ -z "${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
|
|
||||||
}
|
|
||||||
@ -1,313 +0,0 @@
|
|||||||
# Copyright 1999-2025 Gentoo Authors
|
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
|
||||||
|
|
||||||
EAPI=8
|
|
||||||
|
|
||||||
inherit flag-o-matic
|
|
||||||
|
|
||||||
DESCRIPTION="An MTA designed specifically for maildirs"
|
|
||||||
HOMEPAGE="https://www.courier-mta.org/"
|
|
||||||
SRC_URI="https://downloads.sourceforge.net/courier/${P}.tar.bz2"
|
|
||||||
|
|
||||||
LICENSE="GPL-3"
|
|
||||||
SLOT="0"
|
|
||||||
KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ppc ~ppc64 ~riscv ~s390 ~sparc ~x86"
|
|
||||||
IUSE="postgres ldap mysql pam nls ipv6 spell fax crypt norewrite \
|
|
||||||
fam web webmail gnutls split-usr"
|
|
||||||
|
|
||||||
DEPEND="
|
|
||||||
>=net-libs/courier-authlib-0.72.3
|
|
||||||
>=net-libs/courier-unicode-2.3.1:=
|
|
||||||
net-dns/libidn2:=
|
|
||||||
gnutls? ( net-libs/gnutls:= )
|
|
||||||
!gnutls? (
|
|
||||||
dev-libs/openssl:0=
|
|
||||||
)
|
|
||||||
>=sys-libs/gdbm-1.8.0:=
|
|
||||||
dev-libs/libpcre2
|
|
||||||
app-misc/mime-types
|
|
||||||
dev-lang/perl:=
|
|
||||||
fax? ( >=media-libs/netpbm-9.12 app-text/ghostscript-gpl >=net-dialup/mgetty-1.1.28 )
|
|
||||||
pam? ( sys-libs/pam )
|
|
||||||
mysql? ( dev-db/mysql-connector-c )
|
|
||||||
ldap? ( >=net-nds/openldap-1.2.11:= )
|
|
||||||
postgres? ( dev-db/postgresql:= )
|
|
||||||
spell? ( app-text/aspell )
|
|
||||||
fam? ( virtual/fam )
|
|
||||||
!mail-filter/maildrop
|
|
||||||
!mail-mta/esmtp
|
|
||||||
!mail-mta/exim
|
|
||||||
!mail-mta/msmtp[mta]
|
|
||||||
!mail-mta/netqmail
|
|
||||||
!mail-mta/nullmailer
|
|
||||||
!mail-mta/postfix
|
|
||||||
!mail-mta/sendmail
|
|
||||||
!mail-mta/ssmtp[mta]
|
|
||||||
!mail-mta/opensmtpd
|
|
||||||
!net-mail/dot-forward
|
|
||||||
!sys-apps/ucspi-tcp
|
|
||||||
"
|
|
||||||
|
|
||||||
RDEPEND="${DEPEND}
|
|
||||||
sys-process/procps"
|
|
||||||
|
|
||||||
# get rid of old style virtual/imapd - bug 350792
|
|
||||||
# all blockers really needed?
|
|
||||||
RDEPEND="${RDEPEND}
|
|
||||||
!net-mail/courier-imap
|
|
||||||
!net-mail/cyrus-imapd"
|
|
||||||
|
|
||||||
PDEPEND="pam? ( net-mail/mailbase )
|
|
||||||
crypt? ( >=app-crypt/gnupg-1.0.4 )"
|
|
||||||
|
|
||||||
src_prepare() {
|
|
||||||
use norewrite && eapply "${FILESDIR}/norewrite.patch"
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
src_configure() {
|
|
||||||
filter-flags '-fomit-frame-pointer'
|
|
||||||
|
|
||||||
local myconf
|
|
||||||
myconf=""
|
|
||||||
|
|
||||||
use ldap && myconf="${myconf} --with-ldapconfig=/etc/courier/maildropldap.conf"
|
|
||||||
|
|
||||||
econf ${myconf} \
|
|
||||||
$(use_with fam) \
|
|
||||||
$(use_with ipv6) \
|
|
||||||
$(use_with spell ispell) \
|
|
||||||
$(use_with ldap ldapaliasd) \
|
|
||||||
$(use_enable ldap maildroldap) \
|
|
||||||
$(use_with gnutls) \
|
|
||||||
--with-notice=unicode \
|
|
||||||
--enable-mimetypes=/etc/mime.types \
|
|
||||||
--prefix=/usr \
|
|
||||||
--disable-root-check \
|
|
||||||
--mandir=/usr/share/man \
|
|
||||||
--sysconfdir=/etc/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}" debug=true || die "./configure"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_compile() {
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
etc_courier() {
|
|
||||||
# Import existing /etc/courier/file if it exists.
|
|
||||||
# Add option only if it was not already set or even commented out
|
|
||||||
local 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() {
|
|
||||||
local 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/lib/courier/tmp
|
|
||||||
keepdir /var/lib/courier/msgs
|
|
||||||
make install DESTDIR="${D}" || die "install"
|
|
||||||
make install-configure DESTDIR="${D}" || die "install-configure"
|
|
||||||
|
|
||||||
# init script takes care of this
|
|
||||||
rm -rf "${D}/var/run"
|
|
||||||
|
|
||||||
# Get rid of files we dont want
|
|
||||||
if ! use webmail ; then
|
|
||||||
rm -rf "${D}/usr/$(get_libdir)/courier/courier/webmail" \
|
|
||||||
"${D}/usr/$(get_libdir)/courier/courier/sqwebmaild" \
|
|
||||||
"${D}/usr/share/courier/sqwebmail/" \
|
|
||||||
"${D}/usr/sbin/webmaild" \
|
|
||||||
"${D}/usr/sbin/webgpg" \
|
|
||||||
"${D}/etc/courier/webmail.authpam" \
|
|
||||||
"${D}/var/lib/courier/webmail-logincache" \
|
|
||||||
"${D}"/etc/courier/sqwebmaild*
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! use web ; then
|
|
||||||
rm -rf "${D}/usr/share/courier/courierwebadmin/" \
|
|
||||||
"${D}/etc/courier/webadmin"
|
|
||||||
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-r4" "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:mail ldapaliasrc ; chmod 640 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
|
|
||||||
dosym ../share/courier/pop3d /usr/sbin/courier-pop3d
|
|
||||||
dosym ../share/courier/pop3d-ssl /usr/sbin/courier-pop3d-ssl
|
|
||||||
dosym ../share/courier/imapd /usr/sbin/courier-imapd
|
|
||||||
dosym ../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 libs/tcpd/README.couriertls
|
|
||||||
mv "${D}/usr/share/courier/htmldoc" "${D}/usr/share/doc/${PF}/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 split-usr; then
|
|
||||||
dosym ../bin/sendmail /usr/sbin/sendmail
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
src_test() {
|
|
||||||
if [ `whoami` != 'root' ]; then
|
|
||||||
# Disable valgrind checks
|
|
||||||
echo '#!/bin/sh' > libs/imap/testsuitevalgrind
|
|
||||||
echo '#!/bin/sh' > libs/maildir/testsuitevalgrind
|
|
||||||
sed -i -e 's:VALGRIND=:exit 0 #VALGRIND=:g' libs/maildrop/Makefile*
|
|
||||||
emake -j1 check
|
|
||||||
else
|
|
||||||
einfo "make check skipped, can't run as root."
|
|
||||||
einfo "You can enable it with FEATURES=\"userpriv\""
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
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 [[ -z "${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
|
|
||||||
}
|
|
||||||
@ -1,313 +0,0 @@
|
|||||||
# Copyright 1999-2025 Gentoo Authors
|
|
||||||
# Distributed under the terms of the GNU General Public License v2
|
|
||||||
|
|
||||||
EAPI=8
|
|
||||||
|
|
||||||
inherit flag-o-matic
|
|
||||||
|
|
||||||
DESCRIPTION="An MTA designed specifically for maildirs"
|
|
||||||
HOMEPAGE="https://www.courier-mta.org/"
|
|
||||||
SRC_URI="https://downloads.sourceforge.net/courier/${P}.tar.bz2"
|
|
||||||
|
|
||||||
LICENSE="GPL-3"
|
|
||||||
SLOT="0"
|
|
||||||
KEYWORDS="~amd64 ~arm64 ~ppc ~ppc64 ~riscv ~x86"
|
|
||||||
IUSE="postgres ldap mysql pam nls ipv6 spell fax crypt norewrite \
|
|
||||||
fam web webmail gnutls split-usr test"
|
|
||||||
RESTRICT="!test? ( test )"
|
|
||||||
|
|
||||||
DEPEND="
|
|
||||||
>=net-libs/courier-authlib-0.72.5
|
|
||||||
>=net-libs/courier-unicode-2.4.0:=
|
|
||||||
net-dns/libidn2:=
|
|
||||||
gnutls? ( net-libs/gnutls:= )
|
|
||||||
!gnutls? (
|
|
||||||
dev-libs/openssl:0=
|
|
||||||
)
|
|
||||||
>=sys-libs/gdbm-1.8.0:=
|
|
||||||
dev-libs/libpcre2
|
|
||||||
app-misc/mime-types
|
|
||||||
dev-lang/perl:=
|
|
||||||
fax? ( >=media-libs/netpbm-9.12 app-text/ghostscript-gpl >=net-dialup/mgetty-1.1.28 )
|
|
||||||
pam? ( sys-libs/pam )
|
|
||||||
mysql? ( dev-db/mysql-connector-c )
|
|
||||||
ldap? ( >=net-nds/openldap-1.2.11:= )
|
|
||||||
postgres? ( dev-db/postgresql:= )
|
|
||||||
spell? ( app-text/aspell )
|
|
||||||
fam? ( virtual/fam )
|
|
||||||
!mail-filter/maildrop
|
|
||||||
!mail-mta/esmtp
|
|
||||||
!mail-mta/exim
|
|
||||||
!mail-mta/msmtp[mta]
|
|
||||||
!mail-mta/netqmail
|
|
||||||
!mail-mta/nullmailer
|
|
||||||
!mail-mta/postfix
|
|
||||||
!mail-mta/sendmail
|
|
||||||
!mail-mta/ssmtp[mta]
|
|
||||||
!mail-mta/opensmtpd
|
|
||||||
!net-mail/dot-forward
|
|
||||||
!sys-apps/ucspi-tcp
|
|
||||||
test? ( dev-debug/valgrind )
|
|
||||||
"
|
|
||||||
|
|
||||||
RDEPEND="${DEPEND}
|
|
||||||
sys-process/procps"
|
|
||||||
|
|
||||||
# get rid of old style virtual/imapd - bug 350792
|
|
||||||
# all blockers really needed?
|
|
||||||
RDEPEND="${RDEPEND}
|
|
||||||
!net-mail/courier-imap
|
|
||||||
!net-mail/cyrus-imapd"
|
|
||||||
|
|
||||||
PDEPEND="pam? ( net-mail/mailbase )
|
|
||||||
crypt? ( >=app-crypt/gnupg-1.0.4 )"
|
|
||||||
|
|
||||||
src_prepare() {
|
|
||||||
use norewrite && eapply "${FILESDIR}/norewrite.patch"
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
src_configure() {
|
|
||||||
filter-flags '-fomit-frame-pointer'
|
|
||||||
|
|
||||||
local myconf
|
|
||||||
myconf=""
|
|
||||||
|
|
||||||
use ldap && myconf="${myconf} --with-ldapconfig=/etc/courier/maildropldap.conf"
|
|
||||||
|
|
||||||
econf ${myconf} \
|
|
||||||
$(use_with fam) \
|
|
||||||
$(use_with ipv6) \
|
|
||||||
$(use_with spell ispell) \
|
|
||||||
$(use_with ldap ldapaliasd) \
|
|
||||||
$(use_enable ldap maildroldap) \
|
|
||||||
$(use_with gnutls) \
|
|
||||||
--with-notice=unicode \
|
|
||||||
--enable-mimetypes=/etc/mime.types \
|
|
||||||
--prefix=/usr \
|
|
||||||
--disable-root-check \
|
|
||||||
--mandir=/usr/share/man \
|
|
||||||
--sysconfdir=/etc/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}" debug=true || die "./configure"
|
|
||||||
}
|
|
||||||
|
|
||||||
src_compile() {
|
|
||||||
default
|
|
||||||
}
|
|
||||||
|
|
||||||
etc_courier() {
|
|
||||||
# Import existing /etc/courier/file if it exists.
|
|
||||||
# Add option only if it was not already set or even commented out
|
|
||||||
local 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() {
|
|
||||||
local 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/lib/courier/tmp
|
|
||||||
keepdir /var/lib/courier/msgs
|
|
||||||
make install DESTDIR="${D}" || die "install"
|
|
||||||
make install-configure DESTDIR="${D}" || die "install-configure"
|
|
||||||
|
|
||||||
# init script takes care of this
|
|
||||||
rm -rf "${D}/var/run"
|
|
||||||
|
|
||||||
# Get rid of files we dont want
|
|
||||||
if ! use webmail ; then
|
|
||||||
rm -rf "${D}/usr/$(get_libdir)/courier/courier/webmail" \
|
|
||||||
"${D}/usr/$(get_libdir)/courier/courier/sqwebmaild" \
|
|
||||||
"${D}/usr/share/courier/sqwebmail/" \
|
|
||||||
"${D}/usr/sbin/webmaild" \
|
|
||||||
"${D}/usr/sbin/webgpg" \
|
|
||||||
"${D}/etc/courier/webmail.authpam" \
|
|
||||||
"${D}/var/lib/courier/webmail-logincache" \
|
|
||||||
"${D}"/etc/courier/sqwebmaild*
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! use web ; then
|
|
||||||
rm -rf "${D}/usr/share/courier/courierwebadmin/" \
|
|
||||||
"${D}/etc/courier/webadmin"
|
|
||||||
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-r4" "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:mail ldapaliasrc ; chmod 640 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
|
|
||||||
dosym ../share/courier/pop3d /usr/sbin/courier-pop3d
|
|
||||||
dosym ../share/courier/pop3d-ssl /usr/sbin/courier-pop3d-ssl
|
|
||||||
dosym ../share/courier/imapd /usr/sbin/courier-imapd
|
|
||||||
dosym ../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 libs/tcpd/README.couriertls
|
|
||||||
mv "${D}/usr/share/courier/htmldoc" "${D}/usr/share/doc/${PF}/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 split-usr; then
|
|
||||||
dosym ../bin/sendmail /usr/sbin/sendmail
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
src_test() {
|
|
||||||
if [ `whoami` = 'root' ]; then
|
|
||||||
einfo "make check skipped, can't run as root."
|
|
||||||
einfo "You can enable it with FEATURES=\"userpriv\""
|
|
||||||
elif [ $(locale -a|grep '^en_US.iso88591$\|^en_US.utf8$'|wc -l) -le 2 ]; then
|
|
||||||
einfo "make check skipped, tests need en_US.iso88591 and en_US.utf8 locales."
|
|
||||||
else
|
|
||||||
emake -j1 check
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
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 [[ -z "${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
|
|
||||||
}
|
|
||||||
Loading…
x
Reference in New Issue
Block a user