summaryrefslogtreecommitdiff
blob: b190b7dfc7f3b6e32aa82df94c1c4cbb227e3f6a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
# Copyright 1999-2004 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-mail/dovecot/dovecot-0.99.10.5-r1.ebuild,v 1.1 2004/06/12 14:46:51 g2boojum Exp $

IUSE="debug ipv6 ldap mbox pam postgres sasl ssl gnutls vpopmail nopop3d"

DESCRIPTION="An IMAP and POP3 server written with security primarily in mind"
HOMEPAGE="http://dovecot.procontrol.fi/"
SRC_URI="${HOMEPAGE}/${P}.tar.gz"

SLOT="0"
LICENSE="LGPL-2.1"
KEYWORDS="~x86 ~amd64 ~sparc ~ppc"

#PROVIDE="virtual/imapd"

# Note: current dovecot will break on gnutls-1.0.5
DEPEND=">=sys-libs/db-3.2
	>=sys-apps/sed-4
	ldap? ( >=net-nds/openldap-1.2 )
	pam? ( sys-libs/pam )
	sasl? ( >=dev-libs/cyrus-sasl-2.1 )
	ssl? ( >=dev-libs/openssl-0.9.6g )
	gnutls? ( <=net-libs/gnutls-1.0.4 )
	postgres? ( dev-db/postgresql )
	vpopmail? ( net-mail/vpopmail )"

RDEPEND="${DEPEND}
	net-mail/mailbase"


pkg_preinst() {
	# Add user and group for login process
	if ! getent group | grep -q ^dovecot
	then
		groupadd dovecot || die "problem adding group dovecot"
	fi
	if ! getent passwd | grep -q ^dovecot
	then
		useradd -c dovecot -d /usr/libexec/dovecot -g dovecot \
		-s /bin/false dovecot  || die "problem adding user dovecot"
	fi
}

src_compile() {
	local myconf
	use debug && myconf="--enable-debug"
	use ldap && myconf="${myconf} --with-ldap"
	use ipv6 || myconf="${myconf} --disable-ipv6"
	use nopop3d && myconf="${myconf} --without-pop3d"
	use pam || myconf="${myconf} --without-pam"
	use postgres && myconf="${myconf} --with-pgsql"
	use sasl && myconf="${myconf} --with-cyrus-sasl2"
	# prefer gnutls to ssl if both gnutls and ssl are defined
	use gnutls && myconf="${myconf} --with-ssl=gnutls"
	use ssl && ! use gnutls && myconf="${myconf} --with-ssl=openssl"
	! use gnutls && ! use ssl && myconf="${myconf} --without-ssl"
	use vpopmail || myconf="${myconf} --without-vpopmail"

	./configure \
	  --prefix=/usr \
	  --host=${CHOST} \
	  --mandir=/usr/share/man \
	  --infodir=/usr/share/info \
	  --datadir=/usr/share \
	  --sysconfdir=/etc \
	  --localstatedir=/var \
	  ${myconf} || die "configure failed"
	emake || die
}

src_install () {
	# Create the dovecot.conf file from the dovecot-example.conf file that
	# the dovecot folks nicely left for us, changing the default
	# mail spool locations to the Gentoo defaults.  
	if use mbox
	then
		# /var/spool/mail/$USER mail spool
		# The location of the INDEX may be overridden by the user if desired.
		if [ -z ${DOVECOT_INDEX_PATH} ]
		then
			DOVECOT_INDEX_PATH="/var/dovecot/%d/%n"
			dodir /var/dovecot
		fi
		sed -e \
			"s|#default_mail_env =|#default_mail_env = mbox:/var/spool/mail/%u:INDEX=${DOVECOT_INDEX_PATH}|" \
			dovecot-example.conf > dovecot.conf
	else
		# $HOME/.maildir mail spool.  
		sed -e \
			's|#default_mail_env =|default_mail_env = maildir:%h/.maildir|' \
			dovecot-example.conf > dovecot.conf
	fi
	insinto /etc
	doins dovecot.conf

	make DESTDIR=${D} install || die
	rm ${D}/etc/dovecot-example.conf

	# Documentation
	rm -fr ${D}/usr/share/doc/dovecot
	cd ${S}
	dodoc AUTHORS COPYING* NEWS README TODO dovecot-example.conf
	dodoc doc/*.txt doc/*.conf doc/*.cnf

	# per default dovecot wants it ssl cert called dovecot.pem
	# fix this in mkcert.sh, which we use to generate the ssl certs
	cd ${S}/doc
	sed -ie 's/imapd.pem/dovecot.pem/g' mkcert.sh
	dodoc mkcert.sh

	# rc script
	exeinto /etc/init.d
	newexe ${FILESDIR}/dovecot.init dovecot

	# PAM
	if use pam
	then
		dodir /etc/pam.d
		insinto /etc/pam.d
		newins ${FILESDIR}/dovecot.pam dovecot
	fi

	# Create SSL certificates
	if  use ssl || use gnutls
	then
		cd ${S}/doc
		dodir /etc/ssl/certs
		dodir /etc/ssl/private
		# Let's not make a new certificate if we already have one
		[ -e /etc/ssl/certs/dovecot.pem -a -e /etc/ssl/private/dovecot.pem ] \
			|| SSLDIR=${D}/etc/ssl sh mkcert.sh
	fi

	dodir /var/run/dovecot
	fowners root:root /var/run/dovecot
	fperms 0700 /var/run/dovecot
	keepdir /var/run/dovecot/login
	fowners root:dovecot /var/run/dovecot/login
	fperms 0750 /var/run/dovecot/login
	fperms 0600 /etc/dovecot.conf
}

pkg_postinst() {
	if use pam
	then
		ewarn "If you are upgrading from Dovecot prior to 0.99.10, be aware"
		ewarn "that the PAM profile was changed from 'imap' to 'dovecot'."
		einfo "Please review /etc/pam.d/dovecot."
	fi
	einfo "Please review /etc/dovecot.conf, particularly auth_userdb and auth_passdb."
}