commit:     cd38ad0d6d0663ee4b16965d268df76e15a5f540
Author:     Eray Aslan <eras <AT> gentoo <DOT> org>
AuthorDate: Tue May 27 06:45:06 2025 +0000
Commit:     Eray Aslan <eras <AT> gentoo <DOT> org>
CommitDate: Tue May 27 06:45:06 2025 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=cd38ad0d

net-mail/dovecot: fix building without ldap

Closes: https://bugs.gentoo.org/956507
Signed-off-by: Eray Aslan <eras <AT> gentoo.org>

 net-mail/dovecot/dovecot-2.4.1-r2.ebuild           | 247 +++++++++++++++++++++
 .../files/dovecot-2.4.1-fix-ldap-build.patch       |  29 +++
 2 files changed, 276 insertions(+)

diff --git a/net-mail/dovecot/dovecot-2.4.1-r2.ebuild 
b/net-mail/dovecot/dovecot-2.4.1-r2.ebuild
new file mode 100644
index 000000000000..e08cbe9b65a0
--- /dev/null
+++ b/net-mail/dovecot/dovecot-2.4.1-r2.ebuild
@@ -0,0 +1,247 @@
+# Copyright 1999-2025 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+LUA_COMPAT=( lua5-1 lua5-{3..4} )
+# do not add a ssl USE flag.  ssl is mandatory
+SSL_DEPS_SKIP=1
+inherit autotools eapi9-ver flag-o-matic lua-single ssl-cert systemd 
toolchain-funcs
+
+MY_P="${P/_/.}-4"
+MY_PV="${PV}-4"
+major_minor="$(ver_cut 1-2)"
+
+DESCRIPTION="An IMAP and POP3 server written with security primarily in mind"
+HOMEPAGE="https://www.dovecot.org/";
+SRC_URI="https://www.dovecot.org/releases/${major_minor}/${MY_P}.tar.gz \
+               -> ${P}.tar.gz
+       sieve? (
+       
https://pigeonhole.dovecot.org/releases/${major_minor}/${PN}-pigeonhole-${MY_PV}.tar.gz
 \
+               -> ${PN}-pigeonhole-${PV}.tar.gz
+       )
+       managesieve? (
+       
https://pigeonhole.dovecot.org/releases/${major_minor}/${PN}-pigeonhole-${MY_PV}.tar.gz
 \
+               -> ${PN}-pigeonhole-${PV}.tar.gz
+       ) "
+S="${WORKDIR}/${MY_P}"
+PIEGONHOLE_S="../dovecot-pigeonhole-${MY_PV}"
+LICENSE="LGPL-2.1 MIT"
+SLOT="0/${PV}"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~mips ~ppc ~ppc64 ~riscv ~s390 
~sparc ~x86"
+
+IUSE_DOVECOT_AUTH_DICT="cdb kerberos ldap lua mysql pam postgres sqlite"
+IUSE_DOVECOT_COMPRESS="lz4 zstd"
+IUSE_DOVECOT_FTS="solr stemmer textcat xapian"
+IUSE_DOVECOT_OTHER="argon2 managesieve selinux sieve static-libs suid systemd 
unwind"
+
+IUSE="${IUSE_DOVECOT_AUTH_DICT} ${IUSE_DOVECOT_COMPRESS} ${IUSE_DOVECOT_FTS} 
${IUSE_DOVECOT_OTHER}"
+
+REQUIRED_USE="lua? ( ${LUA_REQUIRED_USE} )"
+
+DEPEND="
+       app-arch/bzip2
+       dev-libs/icu:=
+       dev-libs/openssl:0=
+       net-libs/libtirpc:=
+       net-libs/rpcsvc-proto
+       sys-libs/libcap
+       sys-libs/zlib:=
+       virtual/libiconv
+       argon2? ( dev-libs/libsodium:= )
+       cdb? ( dev-db/tinycdb )
+       kerberos? ( virtual/krb5 )
+       ldap? ( net-nds/openldap:= )
+       lua? ( ${LUA_DEPS} )
+       xapian? ( dev-libs/xapian:= )
+       lz4? ( app-arch/lz4 )
+       mysql? ( dev-db/mysql-connector-c:0= )
+       pam? ( sys-libs/pam:= )
+       postgres? ( dev-db/postgresql:* )
+       selinux? ( sec-policy/selinux-dovecot )
+       solr? ( net-misc/curl dev-libs/expat )
+       sqlite? ( dev-db/sqlite:* )
+       stemmer? ( dev-libs/snowball-stemmer:= )
+       suid? ( acct-group/mail )
+       systemd? ( sys-apps/systemd:= )
+       textcat? ( app-text/libexttextcat )
+       unwind? ( sys-libs/libunwind:= )
+       zstd? ( app-arch/zstd:= )
+       virtual/libcrypt:=
+       "
+
+RDEPEND="
+       ${DEPEND}
+       acct-group/dovecot
+       acct-group/dovenull
+       acct-user/dovecot
+       acct-user/dovenull
+       net-mail/mailbase[pam?]
+       "
+
+BDEPEND="virtual/pkgconfig"
+
+PATCHES=(
+       "${FILESDIR}/${PN}-autoconf-lua-version-v3.patch"
+       "${FILESDIR}/${PN}-2.4.1-gssapi-regression.patch"
+       "${FILESDIR}/${PN}-2.4.1-fix-hardened-crash.patch"
+)
+
+pkg_setup() {
+       use lua && lua-single_pkg_setup
+       if use managesieve && ! use sieve; then
+               ewarn "managesieve USE flag selected but sieve USE flag 
unselected"
+               ewarn "sieve USE flag will be turned on"
+       fi
+}
+
+src_prepare() {
+       default
+       if use sieve || use managesieve; then
+               pushd "${PIEGONHOLE_S}" > /dev/null || die
+               eapply "${FILESDIR}/${PN}-2.4.1-fix-ldap-build.patch"
+               popd > /dev/null || die
+       fi
+
+       # rename default cert files
+       sed -i -e "s:ssl-cert.pem:server.pem:" \
+               -e "s:ssl-key.pem:server.key:" \
+               doc/dovecot.conf.in || die "sed failed"
+
+       # bug 657108, 782631
+       #elibtoolize
+       eautoreconf
+
+       # Bug #727244
+       append-cflags -fasynchronous-unwind-tables
+}
+
+src_configure() {
+       # --disable-hardening because our toolchain already defaults to
+       # these bits on, and it actually regresses the default _FORTIFY_SOURCE
+       # level for hardened at least from 3 to 2.
+       #
+       # turn valgrind tests off. Bug #340791
+       VALGRIND=no \
+       LUAPC="${ELUA}" \
+       systemdsystemunitdir="$(systemd_get_systemunitdir)" \
+       econf \
+               --with-rundir="${EPREFIX}/run/dovecot" \
+               --with-statedir="${EPREFIX}/var/lib/dovecot" \
+               --with-moduledir="${EPREFIX}/usr/$(get_libdir)/dovecot" \
+               --disable-hardening \
+               --disable-rpath \
+               --with-bzlib \
+               --without-libbsd \
+               --with-libcap \
+               --with-icu \
+               --enable-experimental-mail-utf8 \
+               $( use_with argon2 sodium ) \
+               $( use_with cdb) \
+               $( use_with kerberos gssapi ) \
+               $( use_with lua ) \
+               $( use_with ldap ) \
+               $( use_with xapian flatcurve ) \
+               $( use_with lz4 ) \
+               $( use_with mysql ) \
+               $( use_with pam ) \
+               $( use_with postgres pgsql ) \
+               $( use_with sqlite ) \
+               $( use_with solr ) \
+               $( use_with stemmer ) \
+               $( use_with systemd ) \
+               $( use_with textcat ) \
+               $( use_with unwind libunwind ) \
+               $( use_with zstd ) \
+               $( use_enable static-libs static )
+
+       if use sieve || use managesieve; then
+               # The sieve plugin needs this file to be build to determine the 
plugin
+               # directory and the list of libraries to link to
+               emake dovecot-config
+               pushd "${PIEGONHOLE_S}" > /dev/null || die
+               econf \
+                       $( use_enable static-libs static ) \
+                       --localstatedir="${EPREFIX}/var" \
+                       --enable-shared \
+                       --disable-hardening \
+                       --with-dovecot="${S}" \
+                       $( use_with ldap ) \
+                       $( use_with managesieve )
+               popd > /dev/null || die
+       fi
+}
+
+src_compile() {
+       default
+       if use sieve || use managesieve; then
+               pushd "${PIEGONHOLE_S}" > /dev/null || die
+               emake CC="$(tc-getCC)" CFLAGS="${CFLAGS}"
+               popd > /dev/null || die
+       fi
+}
+
+src_test() {
+       # bug #340791 and bug #807178
+       local -x NOVALGRIND=true
+
+       default
+       if use sieve || use managesieve; then
+               pushd "${PIEGONHOLE_S}" > /dev/null || die
+               default
+               popd > /dev/null || die
+       fi
+}
+
+src_install() {
+       default
+
+       if use suid; then
+               einfo "Changing perms to allow deliver to be suided"
+               fowners root:mail "/usr/libexec/dovecot/dovecot-lda"
+               fperms 4750 "/usr/libexec/dovecot/dovecot-lda"
+       fi
+
+       newinitd "${FILESDIR}"/dovecot.init-r6 dovecot
+
+       use pam && dosym imap /etc/pam.d/dovecot
+
+       insinto /etc/dovecot/conf.d
+       doins "${FILESDIR}/50-misc.conf"
+
+       dodoc AUTHORS NEWS README.md TODO
+       docinto stopwords
+       dodoc src/lib-language/stopwords/stopwords*.txt
+
+       if use sieve || use managesieve; then
+               pushd "${PIEGONHOLE_S}" > /dev/null || die
+               emake DESTDIR="${ED}" install
+
+               newdoc README README.pigeonhole
+               insinto /etc/dovecot/conf.d
+               doins doc/example-config/conf.d/90-sieve{,-extprograms}.conf
+               use managesieve && doins 
doc/example-config/conf.d/20-managesieve.conf
+               popd > /dev/null || die
+       fi
+
+       rm -r "${ED}"/usr/share/dovecot
+       use static-libs || find "${ED}"/usr/lib* -name '*.la' -delete
+}
+
+pkg_postinst() {
+       if ver_replacing -lt 2.4 ; then
+               # This is an upgrade which requires user review
+               ewarn "Dovecot-2.4.x has new settings and WILL NOT work"
+               ewarn "unless the configuration files are updated."
+               ewarn "Please read the migration guide at:"
+               ewarn "  
https://doc.dovecot.org/2.4.1/installation/upgrade/2.3-to-2.4.html";
+       fi
+
+       # Let's not make a new certificate if we already have one
+       if ! [[ -e "${ROOT}"/etc/ssl/dovecot/server.pem && \
+               -e "${ROOT}"/etc/ssl/dovecot/server.key ]];     then
+               einfo "Creating SSL     certificate"
+               SSL_ORGANIZATION="${SSL_ORGANIZATION:-Dovecot IMAP Server}"
+               install_cert /etc/dovecot/server
+       fi
+}

diff --git a/net-mail/dovecot/files/dovecot-2.4.1-fix-ldap-build.patch 
b/net-mail/dovecot/files/dovecot-2.4.1-fix-ldap-build.patch
new file mode 100644
index 000000000000..23e78ff47d67
--- /dev/null
+++ b/net-mail/dovecot/files/dovecot-2.4.1-fix-ldap-build.patch
@@ -0,0 +1,29 @@
+From b37322a8d338bf999bc9774154dce79c4857d622 Mon Sep 17 00:00:00 2001
+From: Aki Tuomi <[email protected]>
+Date: Mon, 26 May 2025 09:12:52 +0300
+Subject: [PATCH] sieve-ldap-storage: Only include LDAP when it's used
+
+---
+ src/lib-sieve/storage/ldap/sieve-ldap-storage.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/src/lib-sieve/storage/ldap/sieve-ldap-storage.c 
b/src/lib-sieve/storage/ldap/sieve-ldap-storage.c
+index ecf2724c..715572c7 100644
+--- a/src/lib-sieve/storage/ldap/sieve-ldap-storage.c
++++ b/src/lib-sieve/storage/ldap/sieve-ldap-storage.c
+@@ -3,7 +3,6 @@
+ 
+ #include "lib.h"
+ #include "settings.h"
+-#include "ldap-utils.h"
+ #include "iostream-ssl.h"
+ 
+ #include "sieve-common.h"
+@@ -13,6 +12,7 @@
+ 
+ #if defined(SIEVE_BUILTIN_LDAP) || defined(PLUGIN_BUILD)
+ 
++#include "ldap-utils.h"
+ #include "sieve-error.h"
+ 
+ #ifndef PLUGIN_BUILD

Reply via email to