# Copyright 1999-2004 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/net-www/apache/apache-2.0.48.ebuild,v 1.4 2004/01/15 03:55:19 robbat2 Exp $
inherit flag-o-matic
has_version =sys-libs/glibc-2.2* && filter-flags -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
DESCRIPTION="Apache Web Server, Version 2.0.x"
HOMEPAGE="http://www.apache.org/"
S="${WORKDIR}/httpd-${PV}"
SRC_URI="http://www.apache.org/dist/httpd/httpd-${PV}.tar.gz"
KEYWORDS="x86 ~ppc ~alpha ~hppa ~mips sparc ~amd64"
LICENSE="Apache-1.1"
SLOT="2"
#Standard location for Gentoo Linux
DATADIR="/var/www/localhost"
DEPEND="dev-util/yacc
dev-lang/perl
sys-libs/zlib
dev-libs/expat
dev-libs/openssl
berkdb? ( sys-libs/db )
gdbm? ( sys-libs/gdbm )
!mips? ( ldap? ( =net-nds/openldap-2* ) )"
IUSE="berkdb gdbm ldap"
src_unpack() {
unpack ${A} || die
cd ${S} || die
patch -p1 <${FILESDIR}/apache-2.0.48-gentoo.diff || die
#avoid utf-8 charset problems
export LC_CTYPE=C
#the -1 shortcut is obsolete
perl -pi -e 's|head -1|head -n 1|;' srclib/apr/build/buildcheck.sh
#give it the stamp
perl -pi -e 's|" PLATFORM "|Gentoo/Linux|;' server/core.c
#fix perl with perl!
find -type f | xargs perl -pi -e \
"s|/usr/local/bin/perl|/usr/bin/perl|g; \
s|/usr/local/bin/perl5|/usr/bin/perl|g; \
s|/path/to/bin/perl|/usr/bin/perl|g;"
#dont want this cruft in /usr/bin
perl -pi -e 's|\@exp_bindir\@(/envvars)|\@exp_installbuilddir\@\1|;' \
support/apachectl.in
#setup the filesystem layout config
local prefix=/usr
cat >>config.layout <<-EOF
prefix: ${prefix}
exec_prefix: ${prefix}
bindir: ${prefix}/bin
sbindir: ${prefix}/sbin
libdir: ${prefix}/lib
libexecdir: ${prefix}/lib/apache2
mandir: ${prefix}/share/man
infodir: ${prefix}/share/info
includedir: ${prefix}/include/apache2
installbuilddir: ${prefix}/lib/apache2/build
datadir: ${DATADIR}
errordir: ${DATADIR}/error
iconsdir: ${DATADIR}/icons
htdocsdir: ${DATADIR}/htdocs
cgidir: ${DATADIR}/cgi-bin
manualdir: /usr/share/doc/${PF}/manual
sysconfdir: /etc/apache2/conf
localstatedir: /var
runtimedir: /var/run
logfiledir: /var/log/apache2
proxycachedir: /var/cache/apache2
EOF
#gotta do these next two as well :\
cat >>srclib/apr/config.layout <<-EOF
prefix: ${prefix}
exec_prefix: ${prefix}
bindir: ${prefix}/bin
sbindir: ${prefix}/sbin
libdir: ${prefix}/lib
libexecdir: ${prefix}/lib/apache2
mandir: ${prefix}/share/man
sysconfdir: /etc/apache2/conf
datadir: ${DATADIR}
installbuilddir: ${prefix}/lib/apache2/build
includedir: ${prefix}/include/apache2
localstatedir: /var
libsuffix: -\${APR_MAJOR_VERSION}
EOF
cat >>srclib/apr-util/config.layout <<-EOF
prefix: ${prefix}
exec_prefix: ${prefix}
bindir: ${prefix}/bin
sbindir: ${prefix}/sbin
libdir: ${prefix}/lib
libexecdir: ${prefix}/lib/apache2
mandir: ${prefix}/share/man
sysconfdir: /etc/apache2/conf
datadir: ${DATADIR}
installbuilddir: ${prefix}/lib/apache2/build
includedir: ${prefix}/include/apache2
localstatedir: /var
libsuffix: -\${APRUTIL_MAJOR_VERSION}
EOF
./buildconf || die "buildconf failed"
}
src_compile() {
local myconf
use !mips && use ldap && \
myconf="--with-ldap --enable-auth-ldap=shared --enable-ldap=shared"
select_modules_config || die "determining modules"
# fix for bug #24215 - robbat2@gentoo.org, 30 Oct 2003
# we pre-load the cache with the correct answer!
# this avoids it violating the sandbox
# this may have to be changed for non-Linux systems
# or if sem_open changes on Linux
# this hack is built around documentation in /usr/include/semaphore.h and
# the glibc (pthread) source
echo 'ac_cv_func_sem_open=${ac_cv_func_sem_open=no}' >> ${S}/config.cache
SSL_BASE="SYSTEM" \
./configure \
--cache-file=${S}/config.cache \
--with-suexec-safepath="/usr/local/bin:/usr/bin:/bin" \
--with-suexec-logfile=/var/log/apache2/suexec_log \
--with-suexec-bin=/usr/sbin/suexec2 \
--with-suexec-userdir=public_html \
--with-suexec-caller=apache \
--with-suexec-docroot=/home \
--with-suexec-uidmin=1000 \
--with-suexec-gidmin=100 \
--with-suexec-umask=077 \
--enable-suexec=shared \
\
${MY_BUILTINS} \
\
--with-perl=/usr/bin/perl \
--with-expat=/usr \
--with-ssl=/usr \
--with-z=/usr \
--with-port=80 \
--with-mpm=${MPM:=prefork} \
--enable-layout=Gentoo \
--with-program-name=apache2 \
--host=${CHOST} ${myconf} || die "bad ./configure"
#--with-mpm={worker|prefork|perchild|leader|threadpool}
emake || die "problem compiling Apache2 :("
#build ssl version of apache bench (ab-ssl)
cd support; rm -f ab .libs/ab ab.lo ab.o
make ab CFLAGS="${CFLAGS} -DUSE_SSL -lcrypto -lssl \
-I/usr/include/openssl -L/usr/lib" || die
mv ab ab-ssl; mv .libs/ab .libs/ab-ssl; rm -f ab.lo ab.o
make ab || die
}
src_install () {
local i
make DESTDIR=${D} install || die
dodoc ABOUT_APACHE CHANGES INSTALL LAYOUT \
LICENSE README* ${FILESDIR}/robots.txt
#bogus values pointing at /var/tmp/portage
perl -pi -e "s/(APR_SOURCE_DIR=).*/\1\"\"/" ${D}/usr/bin/apr-config
perl -pi -e "s/(APU_SOURCE_DIR=).*/\1\"\"/" ${D}/usr/bin/apu-config
perl -pi -e "s/(APU_BUILD_DIR=).*/\1\"\"/" ${D}/usr/bin/apu-config
#protect the suexec binary
local gid=`getent group apache |cut -d: -f3`
[ -z "${gid}" ] && gid=81
fowners root:${gid} /usr/sbin/suexec
fperms 4710 /usr/sbin/suexec
#setup links in /etc/apache2
cd ${D}/etc/apache2
ln -sf ../../usr/lib/apache2 modules
#apxs needs this to pickup the right lib for install
ln -sf ../../usr/lib lib
ln -sf ../../var/log/apache2 logs
ln -sf ../../usr/lib/apache2-extramodules extramodules
cd ${S}
#Credits to advx.org people for these scripts. Heck, thanks for
#the nice layout and everything else ;-)
exeinto /usr/sbin
for i in apache2logserverstatus apache2splitlogfile
do
doexe ${FILESDIR}/2.0.40/$i
done
exeinto /usr/lib/ssl/apache2-mod_ssl
doexe ${FILESDIR}/2.0.40/gentestcrt.sh
#some more scripts
exeinto /usr/sbin
for i in split-logfile list_hooks.pl logresolve.pl log_server_status
do
doexe ${S}/support/$i
done
#the ssl version of apache bench
doexe support/.libs/ab-ssl
#move some mods to extramodules
dodir /usr/lib/apache2-extramodules
for i in mod_ssl.so mod_ldap.so mod_auth_ldap.so
do
[ -x ${D}/usr/lib/apache2/$i ] && \
mv ${D}/usr/lib/apache2/$i ${D}/usr/lib/apache2-extramodules
done
#modules.d config file snippets
insinto /etc/apache2/conf/modules.d
for i in 40_mod_ssl.conf 41_mod_ssl.default-vhost.conf 45_mod_dav.conf
do
doins ${FILESDIR}/2.0.40/$i
done
use !mips && use ldap && doins ${FILESDIR}/2.0.40/46_mod_ldap.conf
#drop in a convenient link to the manual
dosym /usr/share/doc/${PF}/manual ${DATADIR}/htdocs/manual
#SLOT=2!!!
cd ${D}
mv -v usr/sbin/apachectl usr/sbin/apache2ctl
mv -v usr/sbin/htdigest usr/sbin/htdigest2
mv -v usr/sbin/htpasswd usr/sbin/htpasswd2
mv -v usr/sbin/logresolve usr/sbin/logresolve2
mv -v usr/sbin/apxs usr/sbin/apxs2
mv -v usr/sbin/ab usr/sbin/ab2
mv -v usr/sbin/ab-ssl usr/sbin/ab2-ssl
mv -v usr/sbin/suexec usr/sbin/suexec2
mv -v usr/sbin/rotatelogs usr/sbin/rotatelogs2
mv -v usr/sbin/dbmmanage usr/sbin/dbmmanage2
mv -v usr/sbin/checkgid usr/sbin/checkgid2
mv -v usr/sbin/split-logfile usr/sbin/split-logfile2
mv -v usr/sbin/list_hooks.pl usr/sbin/list_hooks2.pl
mv -v usr/sbin/logresolve.pl usr/sbin/logresolve2.pl
mv -v usr/sbin/log_server_status usr/sbin/log_server_status2
mv -v usr/share/man/man1/htdigest.1 usr/share/man/man1/htdigest2.1
mv -v usr/share/man/man1/htpasswd.1 usr/share/man/man1/htpasswd2.1
mv -v usr/share/man/man1/dbmmanage.1 usr/share/man/man1/dbmmanage2.1
mv -v usr/share/man/man8/ab.8 usr/share/man/man8/ab2.8
mv -v usr/share/man/man8/apxs.8 usr/share/man/man8/apxs2.8
mv -v usr/share/man/man8/apachectl.8 usr/share/man/man8/apache2ctl.8
mv -v usr/share/man/man8/httpd.8 usr/share/man/man8/apache2.8
mv -v usr/share/man/man8/logresolve.8 usr/share/man/man8/logresolve2.8
mv -v usr/share/man/man8/rotatelogs.8 usr/share/man/man8/rotatelogs2.8
mv -v usr/share/man/man8/suexec.8 usr/share/man/man8/suexec2.8
#tidy up
mv ${D}/usr/sbin/envvars* ${D}/usr/lib/apache2/build
dodoc ${D}/etc/apache2/conf/*-std.conf
rm -f ${D}/etc/apache2/conf/*.conf
rm -rf ${D}/var/run ${D}/var/log
#config files
insinto /etc/conf.d; newins ${FILESDIR}/2.0.40/apache2.confd apache2
exeinto /etc/init.d; newexe ${FILESDIR}/2.0.40/apache2.initd apache2
insinto /etc/apache2; doins ${FILESDIR}/2.0.40/apache2-builtin-mods
insinto /etc/apache2/conf
doins ${FILESDIR}/2.0.40/commonapache2.conf
doins ${FILESDIR}/2.0.40/apache2.conf
insinto /etc/apache2/conf/vhosts
doins ${FILESDIR}/2.0.40/virtual-homepages.conf
doins ${FILESDIR}/2.0.40/dynamic-vhosts.conf
doins ${FILESDIR}/2.0.40/vhosts.conf
# Added by Jason Wever
# A little sedfu to fix bug #7172 for sparc64s
if [ ${ARCH} = "sparc" ]
then
sed -i -e '13a\AcceptMutex fcntl' \
${D}/etc/apache2/conf/apache2.conf
fi
}
parse_modules_config() {
local filename=$1
local name=""
local dso=""
local disable=""
[ -f ${filename} ] || return 1
for i in `cat $filename | sed "s/^#.*//"` ; do
if [ $i == "-" ] ; then
disable="true"
elif [ -z "$name" ] && [ ! -z "`echo $i | grep "mod_"`" ] ; then
name=`echo $i | sed "s/mod_//"`
elif [ "$disable" ] && ( [ $i == "static" ] || [ $i == "shared" ] ) ; then
MY_BUILTINS="${MY_BUILTINS} --disable-$name"
name="" ; disable=""
elif [ $i == "static" ] ; then
MY_BUILTINS="${MY_BUILTINS} --enable-$name=yes"
name="" ; disable=""
elif [ $i == "shared" ] ; then
MY_BUILTINS="${MY_BUILTINS} --enable-$name=shared"
name="" ; disable=""
fi
done
einfo "${filename} options:\n${MY_BUILTINS}"
}
select_modules_config() {
parse_modules_config /etc/apache2/apache2-builtin-mods || \
parse_modules_config ${FILESDIR}/2.0.40/apache2-builtin-mods || \
return 1
}
pkg_postinst() {
#empty dirs...
install -d -m0755 -o apache -g apache ${ROOT}/var/lib/dav
install -d -m0755 -o root -g root ${ROOT}/var/log/apache2
install -d -m0755 -o root -g root ${ROOT}/var/cache/apache2
install -d -m0755 -o root -g root ${ROOT}/etc/apache2/conf/ssl
cd ${ROOT}/etc/apache2/conf/ssl
einfo
einfo "Generating self-signed test certificate in /etc/apache2/conf/ssl..."
yes "" 2>/dev/null | ${ROOT}/usr/lib/ssl/apache2-mod_ssl/gentestcrt.sh >/dev/null 2>&1
einfo
if has_version '=net-www/apache-1*' ; then
ewarn
ewarn "Please add the 'apache2' flag to your USE variable and (re)install"
ewarn "any additional DSO modules you may wish to use with Apache-2.x."
ewarn "Addon modules are configured in /etc/apache2/conf/modules.d/"
ewarn
fi
einfo
einfo "Please remember to update your config files in /etc/apache2"
einfo "as --datadir has been changed to ${DATADIR}!"
einfo
}