# Copyright 1999-2025 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI=8 # Keep an eye on https://www.cyrusimap.org/imap/developer/compiling.html! inherit autotools eapi9-ver flag-o-matic pam ssl-cert DESCRIPTION="The Cyrus IMAP Server" HOMEPAGE="https://www.cyrusimap.org/" SRC_URI="https://github.com/cyrusimap/${PN}/releases/download/${P}/${P}.tar.gz" LICENSE="BSD-with-attribution GPL-2" SLOT="0" KEYWORDS="~amd64 ~arm ~hppa ~ppc ~ppc64 ~sparc ~x86" IUSE="afs backup calalarm caps clamav http kerberos ldap \ mysql nntp pam perl postgres replication +server sieve \ sqlite ssl static-libs tcpd test xapian" RESTRICT="!test? ( test )" DEPEND="dev-libs/libpcre:3 >=dev-libs/cyrus-sasl-2.1.13:2 dev-libs/jansson:= dev-libs/icu:= sys-apps/util-linux sys-fs/e2fsprogs:= sys-libs/zlib:= afs? ( net-fs/openafs ) calalarm? ( dev-libs/libical:= ) caps? ( sys-libs/libcap ) clamav? ( app-antivirus/clamav ) http? ( app-arch/brotli:= app-arch/zstd:= dev-libs/libxml2 dev-libs/libical:= net-libs/nghttp2:= sci-libs/shapelib:= ) kerberos? ( virtual/krb5 ) ldap? ( net-nds/openldap:= ) mysql? ( dev-db/mysql-connector-c:= ) nntp? ( !net-nntp/leafnode ) pam? ( >=net-mail/mailbase-1 sys-libs/pam ) perl? ( dev-lang/perl:= ) postgres? ( dev-db/postgresql:* ) ssl? ( >=dev-libs/openssl-1.0.1e:=[-bindist(-)] ) sqlite? ( dev-db/sqlite:3 ) tcpd? ( >=sys-apps/tcp-wrappers-7.6 ) xapian? ( >=dev-libs/xapian-1.4.0:= net-misc/rsync )" # all blockers really needed? # file collision with app-arch/dump - bug 619584 # file collision with dev-python/tables - bug 905765 RDEPEND="${DEPEND} acct-group/mail acct-user/cyrus !mail-mta/courier !net-mail/courier-imap !app-arch/dump !dev-python/tables" DEPEND+=" test? ( dev-util/cunit )" BDEPEND="app-alternatives/lex virtual/pkgconfig app-alternatives/yacc http? ( app-editors/vim-core )" # app-editors/vim-core needed for xxd REQUIRED_USE="afs? ( kerberos ) backup? ( sqlite ) calalarm? ( http ) http? ( sqlite )" # https://bugs.gentoo.org/678754 # TODO: check underlinking for other libraries PATCHES=( "${FILESDIR}"/${PN}-3.4.4-0001-Test-for-libm.patch "${FILESDIR}"/${PN}-3.4.4-0002-Avoid-underlinking-libcyrus-lm.patch "${FILESDIR}"/${P}-003-libcap-perl.patch ) src_prepare() { default # Fix master(8)->cyrusmaster(8) manpage. for i in `grep -rl -e 'master\.8' -e 'master(8)' "${S}"` ; do sed -i -e 's:master\.8:cyrusmaster.8:g' \ -e 's:master(8):cyrusmaster(8):g' \ "${i}" || die "sed failed" || die "sed failed" done mv man/master.8 man/cyrusmaster.8 || die "mv failed" sed -i -e "s:MASTER:CYRUSMASTER:g" \ -e "s:Master:Cyrusmaster:g" \ -e "s:master:cyrusmaster:g" \ man/cyrusmaster.8 || die "sed failed" # lock.h to afs/lock.h sed -i -e '/lock.h/s:lock.h:afs/lock.h:' \ ptclient/afskrb.c || die eautoreconf } src_configure() { local myconf # bug #604466 append-ldflags $(no-as-needed) # Workaround runtime crash # bug #834573 append-flags -fno-toplevel-reorder # Uses a lot of function pointers with undeclared function arguments append-cflags -std=gnu17 # lto-type-mismatch filter-lto if use afs ; then myconf+=" --with-afs-libdir=/usr/$(get_libdir)" myconf+=" --with-afs-incdir=/usr/include/afs" fi # TODO: # - revisit --with-sphinx-build=no? (it's docs this time, not the search engine) # - post-emerge message re lmdb removal? econf \ --enable-murder \ --enable-idled \ --enable-autocreate \ --enable-pcre \ --with-com_err \ --with-cyrus-user=cyrus \ --with-sasl \ --with-sphinx-build=no \ --without-krb \ --without-krbdes \ --enable-squat \ --with-zlib \ --without-wslay \ --without-chardet \ --without-cld2 \ --disable-srs \ $(use_enable afs) \ $(use_enable afs krb5afspts) \ $(use_enable backup) \ $(use_enable calalarm calalarmd) \ $(use_with caps libcap) \ $(use_with clamav) \ $(use_enable nntp) \ $(use_enable http) \ $(use_with http nghttp2) \ $(use_enable replication) \ $(use_enable kerberos gssapi) \ $(use_with ldap) \ $(use_with mysql) \ $(use_with postgres pgsql) \ $(use_with perl) \ $(use_with sqlite) \ $(use_with ssl openssl) \ $(use_enable server) \ $(use_enable sieve) \ $(use_enable static-libs static) \ $(use_with tcpd libwrap) \ $(use_enable xapian) \ $(use_enable test unit-tests) \ ${myconf} } src_install() { emake DESTDIR="${D}" INSTALLDIRS=vendor install dodoc README* dodoc -r doc cp -r contrib tools "${ED}"/usr/share/doc/${PF} || die rm -f doc/text/Makefile* || die mv "${ED}"/usr/libexec/{master,cyrusmaster} || die insinto /etc newins "${ED}"/usr/share/doc/${PF}/doc/examples/cyrus_conf/normal.conf cyrus.conf newins "${ED}"/usr/share/doc/${PF}/doc/examples/imapd_conf/normal.conf imapd.conf sed -i -e '/^configdirectory/s|/var/.*|/var/imap|' \ -e '/^partition-default/s|/var/.*|/var/spool/imap|' \ -e '/^sievedir/s|/var/.*|/var/imap/sieve|' \ "${ED}"/etc/imapd.conf || die sed -i -e 's|/var/imap/socket/lmtp|/run/cyrus/socket/lmtp|' \ -e 's|/var/imap/socket/notify|/run/cyrus/socket/notify|' \ "${ED}"/etc/cyrus.conf || die # turn off sieve if not installed if ! use sieve; then sed -i -e "/sieve/s/^/#/" "${ED}"/etc/cyrus.conf || die fi # same thing for http(s) as well if ! use http; then sed -i -e "/http/s/^/#/" "${ED}"/etc/cyrus.conf || die fi newinitd "${FILESDIR}"/cyrus.rc8 cyrus newconfd "${FILESDIR}"/cyrus.confd cyrus newpamd "${FILESDIR}"/cyrus.pam-include sieve for subdir in imap/{,db,log,msg,proc,socket,sieve} spool/imap/{,stage.} ; do keepdir "/var/${subdir}" fowners cyrus:mail "/var/${subdir}" fperms 0750 "/var/${subdir}" done for subdir in imap/{user,quota,sieve} spool/imap ; do for i in a b c d e f g h i j k l m n o p q r s t v u w x y z ; do keepdir "/var/${subdir}/${i}" fowners cyrus:mail "/var/${subdir}/${i}" fperms 0750 "/var/${subdir}/${i}" done done find "${ED}" -type f -name '*.la' -delete || die } pkg_preinst() { if ! has_version ${CATEGORY}/${PN} ; then elog "For correct logging add the following to /etc/syslog.conf:" elog " local6.* /var/log/imapd.log" elog " auth.debug /var/log/auth.log" echo elog "You have to add user cyrus to the sasldb2. Do this with:" elog " saslpasswd2 cyrus" fi } pkg_postinst() { # do not install server.{key,pem) if they exist if use ssl ; then if [[ ! -f "${ROOT}"/etc/ssl/cyrus/server.key ]]; then install_cert /etc/ssl/cyrus/server chown cyrus:mail "${ROOT}"/etc/ssl/cyrus/server.{key,pem} fi fi if ver_replacing -lt $(ver_cut 1-2) ; then elog "Please see https://www.cyrusimap.org/$(ver_cut 1-2)/imap/download/upgrade.html" elog "for upgrade instructions." fi if use backup ; then elog "Be aware that the experimental backup service has been deprecated by" elog "upstream in version 3.10.x and removed in 3.12.x." elog "You should migrate to other backup solutions" fi }