blob: bfea96fd23edfc245a3054816a4b15ad748ac350 (
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
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
|
# Copyright 1999-2004 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-mail/cyrus-imapd/cyrus-imapd-2.1.13.ebuild,v 1.8 2004/04/26 12:20:45 agriffis Exp $
inherit eutils
DESCRIPTION="The Cyrus IMAP Server"
HOMEPAGE="http://asg.web.cmu.edu/cyrus/imapd/"
SRC_URI="ftp://ftp.andrew.cmu.edu/pub/cyrus-mail/OLD-VERSIONS/imap/${P}.tar.gz"
IUSE="afs snmp ssl kerberos"
LICENSE="as-is"
SLOT="0"
KEYWORDS="x86 -ppc -sparc"
PROVIDE="virtual/imapd"
DEPEND="virtual/glibc
afs? ( >=net-fs/openafs-1.2.2 )
snmp? ( >=net-analyzer/ucd-snmp-4.2.3 )
ssl? ( >=dev-libs/openssl-0.9.6 )
kerberos? ( virtual/krb5 )
>=sys-libs/db-3.2
>=sys-libs/pam-0.75
>=dev-libs/cyrus-sasl-2.1.13
>=sys-apps/tcp-wrappers-7.6
net-mail/mailbase"
pkg_setup() {
if ! grep -q ^cyrus: /etc/passwd ; then
useradd -c cyrus -d /usr/cyrus -g mail -s /bin/false -u 96 cyrus \
|| die "problem adding user cyrus"
fi
}
src_unpack() {
unpack ${A}
cd ${S}
# remove spurious -I/usr/includes
epatch ${FILESDIR}/${PN}-2.1.12-includepath.patch
# add libwrap defines as we don't have a dynamicly linked library.
epatch ${FILESDIR}/${PN}-libwrap.patch
# when linking with rpm, you need to link with more libraries.
cp configure configure.orig
sed -e "s:lrpm:lrpm -lrpmio -lrpmdb:" \
< configure.orig > configure
}
src_compile() {
local myconf
use afs && myconf="--with-afs" \
|| myconf="--without-afs"
use snmp && myconf="${myconf} --with-ucdsnmp=/usr" \
myconf="${myconf} --without-ucdsnmp"
use ssl && myconf="${myconf} --with-openssl=/usr" \
|| myconf="${myconf} --without-openssl"
#use kerberos && myconf="${myconf} --with-krb=/usr/athena --with-auth=krb --enable-gssapi" \
# || myconf="${myconf} --without-krb --with-auth=unix --disable-gssapi"
# As cyrus-sasl-2.1.12 doesn't appear to compile in krb4 support
# (neither did previous versions) only support krb5
use kerberos && myconf="${myconf} --with-auth=krb --enable-gssapi" \
|| myconf="${myconf} --without-krb --with-auth=unix --disable-gssapi"
econf \
--enable-listext \
--with-cyrus-group=mail \
--enable-netscapehack \
--with-com_err=yes \
--without-perl \
--disable-cyradm \
--with-libwrap=/usr \
${myconf} || die "econf failed"
# make depends break with -f... in CFLAGS
make depend CFLAGS="" || die "make depend problem"
make || die "compile problem"
}
src_install() {
make DESTDIR=${D} install || die
# Remove the developer stuff (-> dev-libs/cyrus-imap-devel)
rm -rf ${D}usr/include ${D}usr/lib
# Rename the master from cyrus to cyrusmaster (postfix has a master too)
mv ${D}usr/cyrus/bin/master ${D}usr/cyrus/bin/cyrusmaster
# Fix manpage stuff
rm -rf ${D}usr/man
# master is renamed to cyrusmaster because postfix has a master too
mv man/master.8 man/cyrusmaster.8
patch man/cyrusmaster.8 ${FILESDIR}/master.8.diff || die "error patching master.8"
doman man/*.?
# remove man-pages from packet net-mail/cyrus-imapd-admin
rm ${D}usr/share/man/man1/installsieve.1.gz ${D}usr/share/man/man1/sieveshell.1.gz
dodir /etc
cp ${FILESDIR}/imapd_2.conf ${D}etc/imapd.conf
cp ${FILESDIR}/cyrus_2.conf ${D}etc/cyrus.conf
dodir /etc/pam.d
cp ${FILESDIR}/pam.d-imap ${D}etc/pam.d/imap
dodir /var
mkdir -m 0750 ${D}var/imap
chown -R cyrus:mail ${D}var/imap
keepdir /var/imap
mkdir -m 0755 ${D}var/imap/db
chown -R cyrus:mail ${D}var/imap/db
keepdir /var/imap/db
mkdir -m 0755 ${D}var/imap/log
chown -R cyrus:mail ${D}var/imap/log
keepdir /var/imap/log
mkdir -m 0755 ${D}var/imap/msg
chown -R cyrus:mail ${D}var/imap/msg
keepdir /var/imap/msg
mkdir -m 0755 ${D}var/imap/user
chown -R cyrus:mail ${D}var/imap/user
keepdir /var/imap/user
for i in a b c d e f g h i j k l m n o p q r s t u v w x y z ; do mkdir -m 0755 ${D}var/imap/user/$i ; \
chown -R cyrus:mail ${D}var/imap/user/$i
keepdir /var/imap/user/$i
done
mkdir -m 0755 ${D}var/imap/proc
chown -R cyrus:mail ${D}var/imap/proc
keepdir /var/imap/proc
mkdir -m 0755 ${D}var/imap/quota
for i in a b c d e f g h i j k l m n o p q r s t u v w x y z ; do mkdir -m 0755 ${D}var/imap/quota/$i ; \
chown -R cyrus:mail ${D}var/imap/quota/$i
keepdir /var/imap/quota/$i
done
mkdir -m 0755 ${D}var/imap/sieve
chown -R cyrus:mail ${D}var/imap/sieve
for i in a b c d e f g h i j k l m n o p q r s t u v w x y z ; do mkdir -m 0755 ${D}var/imap/sieve/$i ; \
chown -R cyrus:mail ${D}var/imap/sieve/$i
keepdir /var/imap/sieve/$i
done
mkdir -m 0755 ${D}var/imap/socket
chown -R cyrus:mail ${D}var/imap/socket
keepdir /var/imap/socket
mkdir ${D}var/spool
mkdir -m 0750 ${D}var/spool/imap
chown -R cyrus:mail ${D}var/spool/imap
keepdir /var/spool/imap
mkdir -m 0755 ${D}var/spool/imap/stage.
chown -R cyrus:mail ${D}var/spool/imap/stage.
keepdir /var/spool/imap/stage.
# For hashimapspool
for i in a b c d e f g h i j k l m n o p q r s t u v w x y z ; do mkdir -m 0755 ${D}var/spool/imap/$i ; \
chown -R cyrus:mail ${D}var/spool/imap/$i
keepdir /var/spool/imap/$i
done
dodoc COPYRIGHT README*
dohtml doc/*.html doc/murder.png
cp doc/cyrusv2.mc ${D}usr/share/doc/${PF}/html
cp -r contrib tools ${D}usr/share/doc/${PF}
# Remove the CVS directories
find 2>/dev/null ${D}usr/share/doc/ -type d -name CVS -exec rm -rf '{}' \;
exeinto /etc/init.d ; newexe ${FILESDIR}/cyrus.rc6_2 cyrus
if [ "'use ssl'" ]; then
# from mod_ssl
echo "Generating self-signed test certificate"
echo "(Ignore any message from the yes command below)"
mkdir certs
cd certs
yes "" | ${FILESDIR}/gentestcrt.sh >/dev/null 2>&1
mkdir ${D}etc/cyrusimapd
cp server.crt server.key ${D}etc/cyrusimapd
chown cyrus:root ${D}etc/cyrusimapd/server.crt ${D}etc/cyrusimapd/server.key
chmod 0400 ${D}etc/cyrusimapd/server.crt ${D}etc/cyrusimapd/server.key
fi
}
pkg_postinst() {
ewarn "If you change the fs-type of /var/imap or"
ewarn "/var/spool/imap you should read step 9 of"
ewarn "/usr/share/doc/${P}/html/install-configure.html."
echo ""
if df -T /var/imap | grep -q ' ext[23] ' ; then
ewarn "Setting /var/imap/user/* and /var/imap/quota/* to synchronous"
ewarn "updates."
chattr +S /var/imap/user /var/imap/user/* /var/imap/quota /var/imap/quota/*
echo ""
fi
if df -T /var/spool/imap | grep -q ' ext[23] ' ; then
ewarn "Setting /var/spool/imap/* to synchronous updates."
chattr +S /var/spool/imap /var/spool/imap/*
echo ""
fi
ewarn "If the queue directory of the mail daemon resides on an ext2"
ewarn "or ext3 partition you need to set it manually to update"
ewarn "synchronously. E.g. 'chattr +S /var/spool/mqueue'."
echo ""
einfo "For correct logging with syslog add"
einfo "\tlocal6.* /var/log/imapd.log"
einfo "\tauth.debug /var/log/auth.log"
einfo "to /etc/syslog.conf."
echo ""
ewarn "You have to add user cyrus to the sasldb2. Do this with:"
ewarn "\tsaslpasswd2 cyrus"
}
|