# Copyright 1999-2011 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Header: /var/cvsroot/gentoo-x86/net-ftp/proftpd/proftpd-1.3.4_rc1.ebuild,v 1.1 2011/01/21 20:38:02 voyageur Exp $ EAPI="2" inherit eutils autotools MOD_CASE="0.4" MOD_CLAMAV="0.11rc" MOD_DISKUSE="0.9" MOD_GSS="1.3.3" MOD_VROOT="0.9.2" DESCRIPTION="An advanced and very configurable FTP server." HOMEPAGE="http://www.proftpd.org/ http://www.castaglia.org/proftpd/ http://www.thrallingpenguin.com/resources/mod_clamav.htm http://gssmod.sourceforge.net/" SRC_URI="ftp://ftp.proftpd.org/distrib/source/${P/_/}.tar.bz2 case? ( http://www.castaglia.org/${PN}/modules/${PN}-mod-case-${MOD_CASE}.tar.gz ) clamav? ( https://secure.thrallingpenguin.com/redmine/attachments/download/1/mod_clamav-${MOD_CLAMAV}.tar.gz ) diskuse? ( http://www.castaglia.org/${PN}/modules/${PN}-mod-diskuse-${MOD_DISKUSE}.tar.gz ) kerberos? ( mirror://sourceforge/gssmod/mod_gss-${MOD_GSS}.tar.gz ) vroot? ( http://www.castaglia.org/${PN}/modules/${PN}-mod-vroot-${MOD_VROOT}.tar.gz )" LICENSE="GPL-2" SLOT="0" KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86" IUSE="acl authfile ban +caps case clamav copy +ctrls deflate diskuse doc exec hardened ifsession ifversion ident ipv6 kerberos ldap mysql ncurses nls pam postgres qos radius ratio readme rewrite selinux sftp shaper sitemisc softquota sqlite ssl tcpd trace vroot xinetd" DEPEND="acl? ( sys-apps/acl sys-apps/attr ) caps? ( sys-libs/libcap ) clamav? ( app-antivirus/clamav ) kerberos? ( virtual/krb5 ) ldap? ( net-nds/openldap ) mysql? ( virtual/mysql ) ncurses? ( sys-libs/ncurses ) pam? ( virtual/pam ) postgres? ( dev-db/postgresql-base ) sftp? ( dev-libs/openssl ) sqlite? ( dev-db/sqlite:3 ) ssl? ( dev-libs/openssl ) tcpd? ( sys-apps/tcp-wrappers ) xinetd? ( virtual/inetd )" RDEPEND="${DEPEND} net-ftp/ftpbase selinux? ( sec-policy/selinux-ftpd )" S="${WORKDIR}/${P/_/}" __prepare_module() { mv "${WORKDIR}"/$1/$1.c contrib mv "${WORKDIR}"/$1/$1.html doc/contrib rm -rf "${WORKDIR}"/$1 } src_prepare() { use case && __prepare_module mod_case if use clamav ; then mv "${WORKDIR}"/mod_clamav-${MOD_CLAMAV}/mod_clamav.{c,h} contrib epatch "${WORKDIR}"/mod_clamav-${MOD_CLAMAV}/${PN}.patch rm -rf "${WORKDIR}"/mod_clamav-${MOD_CLAMAV} fi use vroot && __prepare_module mod_vroot # Manipulate build system sed -i -e "s/utils install-conf install/utils install/g" Makefile.in sed -i -e "s/ @INSTALL_STRIP@//g" Make.rules.in # Support new versions of mit-krb5 (Gentoo Bugs #284853, #324903) if use kerberos ; then cd "${WORKDIR}"/mod_gss-${MOD_GSS} sed -i -e "s/krb5_principal2principalname/_\0/" mod_auth_gss.c.in sed -i -e "/ac_gss_libs/s/\-ldes425\ //" configure.in eautoreconf fi } src_configure() { local myc myl mym use acl && mym="${mym}:mod_facl" use ban && mym="${mym}:mod_ban" use case && mym="${mym}:mod_case" use clamav && mym="${mym}:mod_clamav" use copy && mym="${mym}:mod_copy" if use ctrls || use shaper ; then myc="${myc} --enable-ctrls" mym="${mym}:mod_ctrls_admin" fi use deflate && mym="${mym}:mod_deflate" if use diskuse ; then cd "${WORKDIR}"/mod_diskuse econf mv mod_diskuse.{c,h} "${S}"/contrib mv mod_diskuse.html "${S}"/doc/contrib cd "${S}" rm -rf "${WORKDIR}"/mod_diskuse mym="${mym}:mod_diskuse" fi use exec && mym="${mym}:mod_exec" use ifversion && mym="${mym}:mod_ifversion" if use kerberos ; then cd "${WORKDIR}"/mod_gss-${MOD_GSS} if has_version app-crypt/mit-krb5 ; then econf --enable-mit else econf --enable-heimdal fi mv mod_{auth_gss,gss}.c "${S}"/contrib mv mod_gss.h "${S}"/include mv README.mod_{auth_gss,gss} "${S}" mv mod_gss.html "${S}"/doc/contrib mv rfc{1509,2228}.txt "${S}"/doc/rfc cd "${S}" rm -rf "${WORKDIR}"/mod_gss-${MOD_GSS} mym="${mym}:mod_gss:mod_auth_gss" fi if use ldap ; then myl="${myl} -lresolv" mym="${mym}:mod_ldap" fi if use mysql || use postgres || use sqlite ; then mym="${mym}:mod_sql:mod_sql_passwd" use mysql && mym="${mym}:mod_sql_mysql" use postgres && mym="${mym}:mod_sql_postgres" use sqlite && mym="${mym}:mod_sql_sqlite" fi use qos && mym="${mym}:mod_qos" use radius && mym="${mym}:mod_radius" use ratio && mym="${mym}:mod_ratio" use readme && mym="${mym}:mod_readme" use rewrite && mym="${mym}:mod_rewrite" if use sftp || use ssl ; then CFLAGS="${CFLAGS} -DHAVE_OPENSSL" myc="${myc} --enable-openssl --with-includes=/usr/include/openssl" myl="${myl} -lcrypto" fi if use sftp ; then mym="${mym}:mod_sftp" use pam && mym="${mym}:mod_sftp_pam" if use mysql || use postgres ; then mym="${mym}:mod_sftp_sql" fi fi use shaper && mym="${mym}:mod_shaper" use sitemisc && mym="${mym}:mod_site_misc" if use softquota ; then mym="${mym}:mod_quotatab:mod_quotatab_file" use ldap && mym="${mym}:mod_quotatab_ldap" use radius && mym="${mym}:mod_quotatab_radius" if use mysql || use postgres ; then mym="${mym}:mod_quotatab_sql" fi fi use ssl && mym="${mym}:mod_tls:mod_tls_shmcache" use tcpd && mym="${mym}:mod_wrap" use vroot && mym="${mym}:mod_vroot" # mod_ifsession needs to be the last module in the mym list. use ifsession && mym="${mym}:mod_ifsession" [ -z ${mym} ] || myc="${myc} --with-modules=${mym:1}" LIBS="${myl:1}" econf --sbindir=/usr/sbin --localstatedir=/var/run/proftpd \ --sysconfdir=/etc/proftpd --enable-shadow --enable-autoshadow ${myc:1} \ $(use_enable acl facl) \ $(use_enable authfile auth-file) \ $(use_enable caps cap) \ $(use_enable ident) \ $(use_enable ipv6) \ $(use_enable ncurses) \ $(use_enable nls) \ $(use_enable trace) \ $(use_enable pam auth-pam) } src_install() { emake DESTDIR="${D}" install insinto /etc/proftpd doins "${FILESDIR}"/proftpd.conf.sample keepdir /var/run/proftpd newinitd "${FILESDIR}"/proftpd.initd proftpd if use xinetd ; then insinto /etc/xinetd.d newins "${FILESDIR}"/proftpd.xinetd proftpd fi dodoc ChangeLog CREDITS INSTALL NEWS README* RELEASE_NOTES if use doc ; then dohtml doc/*.html doc/contrib/*.html doc/howto/*.html doc/modules/*.html docinto rfc dodoc doc/rfc/*.txt fi } pkg_postinst() { if use exec ; then ewarn ewarn "ProFTPD has been built with the mod_exec module. This module" ewarn "can be a security risk for your server as it executes external" ewarn "programs. Vulnerables in these external programs may disclose" ewarn "information or even compromise your server." ewarn "You have been warned! Use this module at your own risk!" ewarn fi }