blob: 83ca7d61adcc550824246871ff2589df0c3273b4 (
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
|
# Copyright 1999-2004 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# Updated to exim-4 by Ben Lutgens <lamer@gentoo.org>
# $Header: /var/cvsroot/gentoo-x86/mail-mta/exim/exim-4.10.ebuild,v 1.3 2004/06/24 22:23:33 agriffis Exp $
IUSE="tcpd ssl postgres mysql ldap pam"
S=${WORKDIR}/${P}
EXISCAN_VER=${PV}-16
DESCRIPTION="A highly configurable, drop-in replacement for sendmail"
SRC_URI="ftp://ftp.exim.org/pub/exim/exim4/${P}.tar.gz
http://duncanthrax.net/exiscan/exiscan-${EXISCAN_VER}.tar.gz"
HOMEPAGE="http://www.exim.org/"
DEPEND="virtual/glibc
>=sys-libs/db-3.2
>=dev-lang/perl-5.6.0
>=dev-libs/libpcre-3.4
pam? ( >=sys-libs/pam-0.75 )
tcpd? ( sys-apps/tcp-wrappers )
ssl? ( >=dev-libs/openssl-0.9.6 )
ldap? ( >=net-nds/openldap-2.0.7 )
mysql? ( >=dev-db/mysql-3.23.28 )
postgres? ( >=dev-db/postgresql-7 )"
RDEPEND="${DEPEND}
!virtual/mta
>=net-mail/mailbase-0.00"
PROVIDE="virtual/mta"
SLOT="0"
LICENSE="GPL-2"
KEYWORDS="x86 sparc ppc"
src_unpack() {
local myconf
unpack ${A}
cd ${S}/src
patch < ${FILESDIR}/${PF}-gentoo.diff || die
cd ${S}
einfo "Patching exiscan support into exim ${PV}.."
patch -p1 < ${WORKDIR}/exiscan-${EXISCAN_VER}/exiscan-${EXISCAN_VER}.patch
sed -e "48i\CFLAGS=${CFLAGS}" \
-e "s:# AUTH_CRAM_MD5=yes:AUTH_CRAM_MD5=yes:" \
-e "s:# AUTH_PLAINTEXT=yes:AUTH_PLAINTEXT=yes:" \
-e "s:BIN_DIRECTORY=/usr/exim/bin:BIN_DIRECTORY=/usr/sbin:" \
-e "s:COMPRESS_COMMAND=/opt/gnu/bin/gzip:COMPRESS_COMMAND=/usr/bin/gzip:" \
-e "s:ZCAT_COMMAND=/opt/gnu/bin/zcat:ZCAT_COMMAND=/usr/bin/zcat:" \
-e "s:CONFIGURE_FILE=/usr/exim/configure:CONFIGURE_FILE=/etc/exim/exim.conf:" \
-e "s:EXIM_MONITOR=eximon.bin:# EXIM_MONITOR=eximon.bin:" \
-e "s:# EXIM_PERL=perl.o:EXIM_PERL=perl.o:" \
-e "s:# INFO_DIRECTORY=/usr/local/info:INFO_DIRECTORY=/usr/share/info:" \
-e "s:# LOG_FILE_PATH=syslog:LOG_FILE_PATH=syslog:" \
-e "s:LOG_FILE_PATH=syslog\:/var/log/exim_%slog::" \
-e "s:# PID_FILE_PATH=/var/lock/exim%s.pid:PID_FILE_PATH=/var/run/exim%s.pid:" \
-e "s:# SPOOL_DIRECTORY=/var/spool/exim:SPOOL_DIRECTORY=/var/spool/exim:" \
-e "s:# SUPPORT_MAILDIR=yes:SUPPORT_MAILDIR=yes:" \
-e "s:# SUPPORT_MAILSTOR=yes:SUPPORT_MAILSTORE=yes:" \
-e "s:# SUPPORT_MBX=yes:SUPPORT_MBX=yes:" \
-e "s:EXIM_USER=:EXIM_USER=mail:" \
-e "s:# AUTH_SPA=yes:AUTH_SPA=yes:" \
src/EDITME > Local/Makefile
cd Local
if use pam; then
cp Makefile Makefile.orig
sed -e "s:# SUPPORT_PAM=yes:SUPPORT_PAM=yes:" Makefile.orig > Makefile
myconf="${myconf} -lpam"
fi
if use tcpd; then
cp Makefile Makefile.orig
sed -e "s:# USE_TCP_WRAPPERS=yes:USE_TCP_WRAPPERS=yes:" Makefile.orig > Makefile
myconf="${myconf} -lwrap"
fi
if [ -n "$myconf" ] ; then
echo "EXTRALIBS=${myconf}" >> Makefile
fi
cd ${S}
if use ssl; then
cp Local/Makefile Local/Makefile.tmp
sed -e "s:# SUPPORT_TLS=yes:SUPPORT_TLS=yes:" \
-e "s:# TLS_LIBS=-lssl -lcrypto:TLS_LIBS=-lssl -lcrypto:" Local/Makefile.tmp > Local/Makefile
fi
LOOKUP_INCLUDE=
LOOKUP_LIBS=
if use ldap; then
cp Local/Makefile Local/Makefile.tmp
sed -e "s:# LOOKUP_LDAP=yes:LOOKUP_LDAP=yes:" \
-e "s:# LDAP_LIB_TYPE=OPENLDAP2:LDAP_LIB_TYPE=OPENLDAP2:" \
Local/Makefile.tmp >| Local/Makefile
LOOKUP_INCLUDE="-I/usr/include/ldap"
LOOKUP_LIBS="-L/usr/lib -lldap -llber"
fi
if use mysql; then
cp Local/Makefile Local/Makefile.tmp
sed -e "s:# LOOKUP_MYSQL=yes:LOOKUP_MYSQL=yes:" \
Local/Makefile.tmp >| Local/Makefile
LOOKUP_INCLUDE="$LOOKUP_INCLUDE -I/usr/include/mysql"
LOOKUP_LIBS="$LOOKUP_LIBS -L/usr/lib -lmysqlclient"
fi
if use postgres; then
cp Local/Makefile Local/Makefile.tmp
sed -e "s:# LOOKUP_PGSQL=yes:LOOKUP_PGSQL=yes:" \
Local/Makefile.tmp >| Local/Makefile
LOOKUP_INCLUDE="$LOOKUP_INCLUDE -I/usr/include/postgresql"
LOOKUP_LIBS="$LOOKUP_LIBS -lpq"
fi
if [ -n "$LOOKUP_INCLUDE" ]; then
cp Local/Makefile Local/Makefile.tmp
sed -e "s:# LOOKUP_INCLUDE=-I /usr/local/ldap/include -I /usr/local/mysql/include -I /usr/local/pgsql/include:LOOKUP_INCLUDE=$LOOKUP_INCLUDE:" \
Local/Makefile.tmp >| Local/Makefile
fi
if [ -n "$LOOKUP_LIBS" ]; then
cp Local/Makefile Local/Makefile.tmp
sed -e "s:# LOOKUP_LIBS=-L/usr/local/lib -lldap -llber -lmysqlclient -lpq:LOOKUP_LIBS=$LOOKUP_LIBS:" \
Local/Makefile.tmp >| Local/Makefile
fi
cat Makefile | sed -e 's/^buildname=.*/buildname=exim-gentoo/g' > Makefile.gentoo && mv -f Makefile.gentoo Makefile
cp Local/Makefile Local/Makefile.tmp
sed -e "s:# LOOKUP_DSEARCH=yes:LOOKUP_DSEARCH=yes:" Local/Makefile.tmp >| Local/Makefile
cp Local/Makefile Local/Makefile.tmp
sed -e "s:# LOOKUP_CDB=yes:LOOKUP_CDB=yes:" Local/Makefile.tmp >| Local/Makefile
}
src_compile() {
make || die
}
src_install () {
cd ${S}/build-exim-gentoo
insopts -o root -g root -m 4755
insinto /usr/sbin
doins exim
dodir /usr/bin /usr/sbin /usr/lib
dosym /usr/sbin/exim /usr/bin/mailq
dosym /usr/sbin/exim /usr/bin/newaliases
dosym /usr/sbin/exim /usr/bin/mail
dosym exim /usr/sbin/rsmtp
dosym exim /usr/sbin/rmail
dosym /usr/sbin/exim /usr/lib/sendmail
dosym /usr/sbin/exim /usr/sbin/sendmail
exeinto /usr/sbin
for i in exicyclog exim_dbmbuild exim_dumpdb exim_fixdb exim_lock \
exim_tidydb exinext exiwhat exigrep eximstats exiqsumm \
convert4r3 convert4r4
do
doexe $i
done
dodir /etc/exim
cd ${S}/src
cp configure.default ${D}/etc/exim/exim.conf.dist
dodoc ${S}/doc/*
doman ${S}/doc/exim.8
# INSTALL a pam.d file for SMTP AUTH that works with gentoo's pam
insinto /etc/pam.d
doins ${FILESDIR}/pam.d-exim
# A nice filter for exim to protect your windows clients.
insinto /etc/exim
doins ${FILESDIR}/system_filter.exim
dodoc ${FILESDIR}/auth_conf.sub
doins ${FILESDIR}/exiscan.conf
exeinto /etc/init.d
newexe ${FILESDIR}/exim.rc6 exim
insinto /etc/conf.d
newins ${FILESDIR}/exim.confd exim
}
pkg_config() {
${ROOT}/usr/sbin/rc-update add exim
}
pkg_postinst() {
einfo "Read the bottom of /etc/exim/system_filter.exim for usage."
einfo "/usr/share/doc/${P}/auth_conf.sub.gz contains the configuration sub for using smtp auth."
einfo "Please create /etc/exim/exim.conf from /etc/exim/exim.conf.dist."
}
|