diff options
-rw-r--r-- | mail-filter/dspam/ChangeLog | 8 | ||||
-rw-r--r-- | mail-filter/dspam/Manifest | 4 | ||||
-rw-r--r-- | mail-filter/dspam/dspam-3.4.0-r1.ebuild | 23 | ||||
-rw-r--r-- | mail-filter/dspam/dspam-3.4.1.ebuild | 505 | ||||
-rw-r--r-- | mail-filter/dspam/files/digest-dspam-3.4.1 | 2 |
5 files changed, 530 insertions, 12 deletions
diff --git a/mail-filter/dspam/ChangeLog b/mail-filter/dspam/ChangeLog index 2de2b16c223c..e8969d4bf8ab 100644 --- a/mail-filter/dspam/ChangeLog +++ b/mail-filter/dspam/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for mail-filter/dspam # Copyright 1999-2005 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/mail-filter/dspam/ChangeLog,v 1.48 2005/03/21 00:10:29 st_lim Exp $ +# $Header: /var/cvsroot/gentoo-x86/mail-filter/dspam/ChangeLog,v 1.49 2005/03/23 10:22:48 st_lim Exp $ + +*dspam-3.4.1 (23 Mar 2005) + + 23 Mar 2005; Lim Swee Tat <st_lim@gentoo.org> dspam-3.4.0-r1.ebuild, + +dspam-3.4.1.ebuild: + Added 3.4.1, fixed virtual users.sql *dspam-3.4.0-r1 (20 Mar 2005) diff --git a/mail-filter/dspam/Manifest b/mail-filter/dspam/Manifest index f44e8da41c73..e2e9249b4dd5 100644 --- a/mail-filter/dspam/Manifest +++ b/mail-filter/dspam/Manifest @@ -1,7 +1,8 @@ MD5 ad3184f48bb6dbfd3e0d1ce67cda6c58 ChangeLog 9612 MD5 e380a39924d3ab14f6b1bcffcba31030 dspam-3.2.7.ebuild 15589 -MD5 38bc389154a7b4fb417c661f7fa345cf dspam-3.4.0-r1.ebuild 19654 +MD5 4d0bd61cdf7591a3ee7f29c1996b10df dspam-3.4.0-r1.ebuild 19636 MD5 6556567b335a4c95782565be3fc57e3a dspam-3.4.0.ebuild 16374 +MD5 ccf7f49ebbc247be46af4c69eaf4d393 dspam-3.4.1.ebuild 19712 MD5 53fa7ac719a55e42f5558b3f367be77e dspam-3.4_rc2.ebuild 16374 MD5 82cc2a81e351669279b735fbd67f910e dspam-3.4_rc3.ebuild 16376 MD5 dbfbe5a3bbe3347938107f5f5bd2197e metadata.xml 308 @@ -16,4 +17,5 @@ MD5 34841f2d2c9d6e057b9839bbe354e34a files/dspam.cron 3478 MD5 e2850ede85e459ab5479b7d2e79eeb5a files/dspam.rc 1025 MD5 2163ca41de383f09f4d754e2d35cb158 files/logrotate.dspam 156 MD5 086d49ad3a5e289bd80de810b1f52b7f files/digest-dspam-3.4.0 129 +MD5 52a1a027d9b3a0428a7c44b352b5b16b files/digest-dspam-3.4.1 129 MD5 7735956f416bd58bfcbeee99af43bea0 files/digest-dspam-3.2.7 63 diff --git a/mail-filter/dspam/dspam-3.4.0-r1.ebuild b/mail-filter/dspam/dspam-3.4.0-r1.ebuild index c89d4a4dae48..08e308a4b05e 100644 --- a/mail-filter/dspam/dspam-3.4.0-r1.ebuild +++ b/mail-filter/dspam/dspam-3.4.0-r1.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2005 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/mail-filter/dspam/dspam-3.4.0-r1.ebuild,v 1.1 2005/03/21 00:10:30 st_lim Exp $ +# $Header: /var/cvsroot/gentoo-x86/mail-filter/dspam/dspam-3.4.0-r1.ebuild,v 1.2 2005/03/23 10:22:48 st_lim Exp $ inherit eutils @@ -107,7 +107,7 @@ src_compile() { myconf="${myconf} --enable-daemon" fi - use virtual-users && myconf="${myconf} --enable-virtual-users-users" + use virtual-users && myconf="${myconf} --enable-virtual-users" # an experimental feature available with MySQL and PgSQL backend use neural && myconf="${myconf} --enable-neural-networking" elif use postgres ; then @@ -120,13 +120,13 @@ src_compile() { myconf="${myconf} --enable-daemon" fi - use virtual-users && myconf="${myconf} --enable-virtual-users-users" + use virtual-users && myconf="${myconf} --enable-virtual-users" # an experimental feature available with MySQL and PgSQL backend use neural && myconf="${myconf} --enable-neural-networking" elif use oci8 ; then myconf="${myconf} --with-storage-driver=ora_drv" myconf="${myconf} --with-oracle-home=${ORACLE_HOME}" - myconf="${myconf} --enable-virtual-users-users" + myconf="${myconf} --enable-virtual-users" # I am in no way a Oracle specialist. If someone knows # how to query the version of Oracle, then let me know. @@ -135,10 +135,10 @@ src_compile() { fi elif use sqlite3 ; then myconf="${myconf} --with-storage-driver=sqlite3_drv" - myconf="${myconf} --enable-virtual-users-users" + myconf="${myconf} --enable-virtual-users" elif use sqlite ; then myconf="${myconf} --with-storage-driver=sqlite_drv" - myconf="${myconf} --enable-virtual-users-users" + myconf="${myconf} --enable-virtual-users" else myconf="${myconf} --with-storage-driver=libdb4_drv" fi @@ -200,7 +200,10 @@ src_install () { dodoc ${DISTDIR}/dspam_sa_trainer.tar.gz # build some initial configuration data - cp src/dspam.conf ${T}/dspam.conf + [ -f ${HOMEDIR}/dspam.conf ] \ + && cp ${HOMEDIR}/dspam.conf ${T}/dspam.conf \ + || cp src/dspam.conf ${T}/dspam.conf + if use cyrus; then sed -i 's:^#*\(UntrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/lib/cyrus/deliver %u\":gI' ${T}/dspam.conf sed -i 's:^\(TrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/lib/cyrus/deliver\":gI' ${T}/dspam.conf @@ -272,7 +275,7 @@ src_install () { newins src/tools.mysql_drv/mysql_objects-space.sql mysql_objects-space.sql newins src/tools.mysql_drv/mysql_objects-speed.sql mysql_objects-speed.sql newins src/tools.mysql_drv/mysql_objects-4.1.sql mysql_objects-4.1.sql - newins src/tools.mysql_drv/virtual-users_users.sql mysql_virtual-users_users.sql + newins src/tools.mysql_drv/virtual-users.sql mysql_virtual-users.sql newins src/tools.mysql_drv/neural.sql mysql_neural.sql newins src/tools.mysql_drv/purge.sql mysql_purge.sql newins src/tools.mysql_drv/purge-4.1.sql mysql_purge-4.1.sql @@ -308,7 +311,7 @@ src_install () { insopts -m644 -o dspam -g dspam doins ${T}/pgsql.data newins src/tools.pgsql_drv/pgsql_objects.sql pgsql_objects.sql - newins src/tools.pgsql_drv/virtual-users_users.sql pgsql_virtual-users_users.sql + newins src/tools.pgsql_drv/virtual-users.sql pgsql_virtual-users.sql newins src/tools.pgsql_drv/purge.sql pgsql_purge.sql elif use oci8 ; then @@ -339,7 +342,7 @@ src_install () { insopts -m644 -o dspam -g dspam doins ${T}/oracle.data newins src/tools.ora_drv/oral_objects.sql ora_objects.sql - newins src/tools.ora_drv/virtual-users_users.sql ora_virtual-users_users.sql + newins src/tools.ora_drv/virtual-users.sql ora_virtual-users.sql newins src/tools.ora_drv/purge.sql ora_purge.sql elif use sqlite || sqlite3 ; then insinto ${HOMEDIR} diff --git a/mail-filter/dspam/dspam-3.4.1.ebuild b/mail-filter/dspam/dspam-3.4.1.ebuild new file mode 100644 index 000000000000..b962cc092c21 --- /dev/null +++ b/mail-filter/dspam/dspam-3.4.1.ebuild @@ -0,0 +1,505 @@ +# Copyright 1999-2005 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/mail-filter/dspam/dspam-3.4.1.ebuild,v 1.1 2005/03/23 10:22:48 st_lim Exp $ + +inherit eutils + +S=${WORKDIR}/${PN}-${PV} +DESCRIPTION="A statistical-algorithmic hybrid anti-spam filter" +SRC_URI="http://dspam.nuclearelephant.com/sources/${PN}-${PV}.tar.gz + http://dspam.nuclearelephant.com/sources/extras/dspam_sa_trainer.tar.gz" +HOMEPAGE="http://dspam.nuclearelephant.com/" +LICENSE="GPL-2" + +IUSE="cyrus debug exim mysql maildrop neural oci8 postgres procmail sqlite sqlite3 large-domain virtual-users" +DEPEND="exim? ( >=mail-mta/exim-4.34 ) + mysql? ( >=dev-db/mysql-3.23 ) || ( >=sys-libs/db-4.0 ) + maildrop? ( >=mail-filter/maildrop-1.5.3 ) + sqlite? ( <dev-db/sqlite-3 ) + sqlite3? ( >=dev-db/sqlite-3 ) + postgres? ( >=dev-db/postgresql-7.4.3 ) + procmail? ( >=mail-filter/procmail-3.22 ) + x86? ( cyrus? ( >=net-mail/cyrus-imapd-2.1.15 ) ) + >=sys-libs/db-4.0 + " +RDEPEND="sys-process/cronbase + app-admin/logrotate" +KEYWORDS="~x86 ~ppc ~alpha" +SLOT="0" + +# some FHS-like structure +HOMEDIR="/etc/mail/dspam" +DATADIR="/var/spool/dspam" +LOGDIR="/var/log/dspam" + +pkg_setup() { + local multiple_dbs="0" + local supported_dbs="mysql postgres oci8 sqlite sqlite3" + for foo in ${supported_dbs}; do + if use ${foo}; then + let multiple_dbs="((multiple_dbs + 1 ))" + einfo " ${foo} database support in your USE flags." + fi + done + if [ "${multiple_dbs}" -ge "2" ]; then + echo + ewarn "You have multiple database backends active in your USE flags." + ewarn "Will default to MySQL as your dspam database backend." + ewarn "If you want to build with another database backend; hit Control-C now." + ewarn "Change your USE flag -mysql and emerge again." + echo + has_version ">=sys-apps/portage-2.0.50" && ( + einfo "It would be best practice to add the set of USE flags that you use for this" + einfo "package to the file: /etc/portage/package.use. Example:" + einfo "\`echo \"mail-filter/dspam -mysql postgres -oci8 -sqlite\" >> /etc/portage/package.use\`" + einfo "to build dspam with Postgres database as your dspam backend." + ) + echo + ewarn "Waiting 30 seconds before starting..." + ewarn "(Control-C to abort)..." + epause 30 + elif [ "${multiple_dbs}" -eq "0" ]; then + echo + ewarn "You need to select at least one database backend in your USE flags." + ewarn "Please enable one of the following USE flags:" + ewarn " ${supported_dbs}" + echo + die "Database support missing" + fi + has_version sys-kernel/linux26-headers || ( + einfo "To use the new DSPAM deamon mode, you need to emerge" + einfo "sys-kernel/linux26-headers and rebuild glibc to support NPTL" + echo + ewarn "Waiting 30 seconds before starting..." + ewarn "(Control-C to abort)..." + epause 30 + ) + id dspam 2>/dev/null || enewgroup dspam 26 + id dspam 2>/dev/null || enewuser dspam 26 /bin/bash ${HOMEDIR} dspam +} + +src_compile() { + local myconf + + myconf="${myconf} --enable-long-username" + use large-domain && myconf="${myconf} --enable-large-scale" ||\ + myconf="${myconf} --enable-domain-scale" + + myconf="${myconf} --with-dspam-mode=4755" + myconf="${myconf} --with-dspam-owner=dspam" + myconf="${myconf} --with-dspam-group=dspam" + myconf="${myconf} --sysconfdir=${HOMEDIR}" + myconf="${myconf} --with-logdir=${LOGDIR}" + use virtual-users || myconf="${myconf} --with-dspam-home=${HOMEDIR}" + + # enables support for debugging (touch /etc/dspam/.debug to turn on) + # optional: even MORE debugging output, use with extreme caution! + use debug && myconf="${myconf} --enable-debug --enable-verbose-debug" + + # select storage driver + if use mysql; then + myconf="${myconf} --with-storage-driver=mysql_drv" + myconf="${myconf} --with-mysql-includes=/usr/include/mysql" + myconf="${myconf} --with-mysql-libraries=/usr/lib/mysql" + myconf="${myconf} --enable-preferences-extension" + + if has_version sys-kernel/linux26-headers; then + myconf="${myconf} --enable-daemon" + fi + + use virtual-users && myconf="${myconf} --enable-virtual-users" + # an experimental feature available with MySQL and PgSQL backend + use neural && myconf="${myconf} --enable-neural-networking" + elif use postgres ; then + myconf="${myconf} --with-storage-driver=pgsql_drv" + myconf="${myconf} --with-pgsql-includes=/usr/include/postgresql" + myconf="${myconf} --with-pgsql-libraries=/usr/lib/postgresql" + myconf="${myconf} --enable-preferences-extension" + + if has_version sys-kernel/linux26-headers; then + myconf="${myconf} --enable-daemon" + fi + + use virtual-users && myconf="${myconf} --enable-virtual-users" + # an experimental feature available with MySQL and PgSQL backend + use neural && myconf="${myconf} --enable-neural-networking" + elif use oci8 ; then + myconf="${myconf} --with-storage-driver=ora_drv" + myconf="${myconf} --with-oracle-home=${ORACLE_HOME}" + myconf="${myconf} --enable-virtual-users" + + # I am in no way a Oracle specialist. If someone knows + # how to query the version of Oracle, then let me know. + if (expr ${ORACLE_HOME/*\/} : 10 1>/dev/null 2>&1); then + myconf="${myconf} --with-oracle-version=10" + fi + elif use sqlite3 ; then + myconf="${myconf} --with-storage-driver=sqlite3_drv" + myconf="${myconf} --enable-virtual-users" + elif use sqlite ; then + myconf="${myconf} --with-storage-driver=sqlite_drv" + myconf="${myconf} --enable-virtual-users" + else + myconf="${myconf} --with-storage-driver=libdb4_drv" + fi + + econf ${myconf} || die + emake || die + +} + +src_install () { + + # Fix issues with older dspam configuration + CONFIG_PROTECT="${CONFIG_PROTECT} ${DATADIR} /var/run/dspam" + CONFIG_PROTECT_MASK="${CONFIG_PROTECTMASK/${HOMEDIR}/}" + CONFIG_PROTECT_MASK="${CONFIG_PROTECTMASK/${DATADIR}/}" + + # open up perms on /etc/mail/dspam + diropts -m0775 -o dspam -g dspam + dodir ${HOMEDIR} + keepdir ${HOMEDIR} + + # keeps dspam data in /var + diropts -m0775 -o dspam -g dspam + dodir ${DATADIR} + keepdir ${DATADIR} + + # keeps dspam log in /var/log + diropts -m0775 -o dspam -g dspam + dodir ${LOGDIR} + keepdir ${LOGDIR} + touch ${T}/empty.file + newins ${T}/empty.file system.log + dosym ${LOGDIR}/system.log ${HOMEDIR}/system.log + + # ${HOMEDIR}/data is a symlink to ${DATADIR} + dosym ${DATADIR} ${HOMEDIR}/data + + # make install + sed -e 's/rm -f ..mandir.\(.*\)/rm -f ${D}${mandir}\1/g' \ + -e 's/ln -s ..mandir.\(.*\) ..mandir.\(.*3\)/ln -s ${mandir}\1.gz ${D}${mandir}\2.gz/g' \ + -i Makefile + make DESTDIR=${D} install || die + chmod 4755 ${D}/usr/bin/dspam + chmod 4755 ${D}/usr/bin/dspam_stats + + # documentation + dodoc CHANGELOG LICENSE README* RELEASE.NOTES UPGRADING + dodoc ${FILESDIR}/README.postfix ${FILESDIR}/README.qmail + if use mysql; then + dodoc src/tools.mysql_drv/README + elif use postgres ; then + dodoc src/tools.pgsql_drv/README + elif use oci8 ; then + dodoc src/tools.ora_drv/README + elif use sqlite || sqlite3 ; then + dodoc src/tools.sqlite_drv/README + fi + doman man/dspam* + dodoc ${DISTDIR}/dspam_sa_trainer.tar.gz + + # build some initial configuration data + [ -f ${HOMEDIR}/dspam.conf ] \ + && cp ${HOMEDIR}/dspam.conf ${T}/dspam.conf \ + || cp src/dspam.conf ${T}/dspam.conf + + if use cyrus; then + sed -i 's:^#*\(UntrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/lib/cyrus/deliver %u\":gI' ${T}/dspam.conf + sed -i 's:^\(TrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/lib/cyrus/deliver\":gI' ${T}/dspam.conf + elif use exim; then + sed -i 's:^#*\(UntrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/sbin/exim -oMr spam-scanned %u\":gI' ${T}/dspam.conf + sed -i 's:^\(TrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/sbin/exim -oMr spam-scanned %u\":gI' ${T}/dspam.conf + elif use maildrop; then + sed -i 's:^#*\(UntrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/bin/maildrop -d %u\":gI' ${T}/dspam.conf + sed -i 's:^\(TrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/bin/maildrop\":gI' ${T}/dspam.conf + elif use procmail; then + sed -i 's:^#*\(UntrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/bin/procmail -d %u\":gI' ${T}/dspam.conf + sed -i 's:^\(TrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/bin/procmail":gI' ${T}/dspam.conf + else + sed -i 's:^#*\(UntrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/sbin/sendmail\":gI' ${T}/dspam.conf + sed -i 's:^\(TrustedDeliveryAgent\)[\t ]*.*:\1 \"/usr/sbin/sendmail\":gI' ${T}/dspam.conf + fi + if use mysql || use postgres; then + if has_version sys-kernel/linux26-headers; then + # keeps dspam socket for deamon in /var/run/dspam + diropts -m0775 -o dspam -g dspam + dodir /var/run/dspam + keepdir /var/run/dspam + + # We use sockets for the deamon instead of tcp port 24 + sed -i 's:^#*\(ServerDomainSocketPath[\t ]\{1,\}\).*:\1\"/var/run/dspam/dspam.sock\":gI' ${T}/dspam.conf + sed -i 's:^#*\(ServerPID[\t ]\{1,\}\).*:\1/var/run/dspam/dspam.pid:gI' ${T}/dspam.conf + + # dspam init script + exeinto /etc/init.d + exeopts -m0755 -o root -g root + newexe ${FILESDIR}/dspam.rc dspam + fi + fi + + # generate random password + local PASSWORD="${RANDOM}${RANDOM}${RANDOM}${RANDOM}" + + # database related configuration and scripts + if use mysql; then + # Use existing configuration if possible + if [[ -f ${ROOT}${HOMEDIR}/mysql.data ]]; then + DSPAM_DB_DATA=( $(sed "s:^[\t ]*$:###:gI" "${ROOT}${HOMEDIR}/mysql.data") ) + for DB_DATA_INDEX in $(seq 0 $((${#DSPAM_DB_DATA[@]} - 1))); do + [[ "${DSPAM_DB_DATA[$DB_DATA_INDEX]}" = "###" ]] && DSPAM_DB_DATA[$DB_DATA_INDEX]="" + done + else + DSPAM_DB_DATA[0]="/var/run/mysqld/mysqld.sock" + DSPAM_DB_DATA[1]="" + DSPAM_DB_DATA[2]="dspam" + DSPAM_DB_DATA[3]="${PASSWORD}" + DSPAM_DB_DATA[4]="dspam" + DSPAM_DB_DATA[5]="true" + fi + + # Modify configuration and create mysql.data file + sed -e "s:^#*\(MySQLServer[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[0]}:gI" \ + -e "s:^#*\(MySQLPort[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[1]}:gI" \ + -e "s:^#*\(MySQLUser[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[2]}:gI" \ + -e "s:^#*\(MySQLPass[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[3]}:gI" \ + -e "s:^#*\(MySQLDb[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[4]}:gI" \ + -e "s:^#*\(MySQLCompress[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[5]}:gI" \ + ${T}/dspam.conf + for DB_DATA_INDEX in $(seq 0 $((${#DSPAM_DB_DATA[@]} - 1))); do + echo "${DSPAM_DB_DATA[$DB_DATA_INDEX]}" >> ${T}/mysql.data + done + insinto ${HOMEDIR} + insopts -m644 -o dspam -g dspam + doins ${T}/mysql.data + newins src/tools.mysql_drv/mysql_objects-space.sql mysql_objects-space.sql + newins src/tools.mysql_drv/mysql_objects-speed.sql mysql_objects-speed.sql + newins src/tools.mysql_drv/mysql_objects-4.1.sql mysql_objects-4.1.sql + newins src/tools.mysql_drv/virtual-users.sql mysql_virtual-users.sql + newins src/tools.mysql_drv/neural.sql mysql_neural.sql + newins src/tools.mysql_drv/purge.sql mysql_purge.sql + newins src/tools.mysql_drv/purge-4.1.sql mysql_purge-4.1.sql + + elif use postgres ; then + # Use existing configuration if possible + if [ -f ${ROOT}${HOMEDIR}/pgsql.data ]; then + DSPAM_DB_DATA=( $(cat "${ROOT}${HOMEDIR}/pgsql.data") ) + for DB_DATA_INDEX in $(seq 0 $((${#DSPAM_DB_DATA[@]} - 1))); do + [[ "${DSPAM_DB_DATA[$DB_DATA_INDEX]}" = "###" ]] && DSPAM_DB_DATA[$DB_DATA_INDEX]="" + done + else + DSPAM_DB_DATA[0]="127.0.0.1" + DSPAM_DB_DATA[1]="5432" + DSPAM_DB_DATA[2]="dspam" + DSPAM_DB_DATA[3]="${PASSWORD}" + DSPAM_DB_DATA[4]="dspam" + fi + + # Modify configuration and create pgsql.data file + sed -e "s:^#*\(PgSQLServer[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[0]}:gI" \ + -e "s:^#*\(PgSQLPort[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[1]}:gI" \ + -e "s:^#*\(PgSQLUser[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[2]}:gI" \ + -e "s:^#*\(PgSQLPass[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[3]}:gI" \ + -e "s:^#*\(PgSQLDb[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[4]}:gI" \ + -e "s:^#*\(PgSQLConnectionCache[\t ]*.\):\1:gI" \ + -i ${T}/dspam.conf + for DB_DATA_INDEX in $(seq 0 $((${#DSPAM_DB_DATA[@]} - 1))); do + echo "${DSPAM_DB_DATA[$DB_DATA_INDEX]}" >> ${T}/pgsql.data + done + + insinto ${HOMEDIR} + insopts -m644 -o dspam -g dspam + doins ${T}/pgsql.data + newins src/tools.pgsql_drv/pgsql_objects.sql pgsql_objects.sql + newins src/tools.pgsql_drv/virtual-users.sql pgsql_virtual-users.sql + newins src/tools.pgsql_drv/purge.sql pgsql_purge.sql + + elif use oci8 ; then + # Use existing configuration if possible + if [ -f ${ROOT}${HOMEDIR}/oracle.data ]; then + DSPAM_DB_DATA=( $(cat "${ROOT}${HOMEDIR}/oracle.data") ) + for DB_DATA_INDEX in $(seq 0 $((${#DSPAM_DB_DATA[@]} - 1))); do + [[ "${DSPAM_DB_DATA[$DB_DATA_INDEX]}" = "###" ]] && DSPAM_DB_DATA[$DB_DATA_INDEX]="" + done + else + DSPAM_DB_DATA[0]="(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521))(CONNECT_DATA=(SID=PROD)))" + DSPAM_DB_DATA[1]="dspam" + DSPAM_DB_DATA[2]="${PASSWORD}" + DSPAM_DB_DATA[3]="dspam" + fi + + # Modify configuration and create oracle.data file + sed -e "s:^#*\(OraServer[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[0]}:gI" \ + -e "s:^\(OraUser[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[1]}:gI" \ + -e "s:^\(OraPass[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[2]}:gI" \ + -e "s:^\(OraSchema[\t ]\{1,\}\).*:\1${DSPAM_DB_DATA[3]}:gI"\ + -i ${T}/dspam.conf + for DB_DATA_INDEX in $(seq 0 $((${#DSPAM_DB_DATA[@]} - 1))); do + echo "${DSPAM_DB_DATA[$DB_DATA_INDEX]}" >> ${T}/oracle.data + done + + insinto ${HOMEDIR} + insopts -m644 -o dspam -g dspam + doins ${T}/oracle.data + newins src/tools.ora_drv/oral_objects.sql ora_objects.sql + newins src/tools.ora_drv/virtual-users.sql ora_virtual-users.sql + newins src/tools.ora_drv/purge.sql ora_purge.sql + elif use sqlite || sqlite3 ; then + insinto ${HOMEDIR} + insopts -m644 -o dspam -g dspam + newins src/tools.sqlite_drv/purge.sql sqlite_purge.sql + fi + + sed -i "s:^\(Purge.*\):###\1:g" ${T}/dspam.conf + sed -i "s:^#\(Purge.*\):\1:g" ${T}/dspam.conf + sed -i "s:^###\(Purge.*\):#\1:g" ${T}/dspam.conf + insinto ${HOMEDIR} + insopts -m644 -o dspam -g dspam + doins ${T}/dspam.conf + + # installs the notification messages + # -> The documentation is wrong! The files need to be in ./txt + diropts -m0775 -o dspam -g dspam + dodir ${HOMEDIR}/txt + keepdir ${HOMEDIR}/txt + insinto ${HOMEDIR}/txt + insopts -m644 -o dspam -g dspam + doins ${S}/txt/*.txt + + # Create the opt-in / opt-out directories + diropts -m0775 -o dspam -g dspam + dodir ${HOMEDIR}/opt-in + keepdir ${HOMEDIR}/opt-in + dodir ${HOMEDIR}/opt-out + keepdir ${HOMEDIR}/opt-out + + # logrotation scripts + diropts -m0755 -o dspam -g dspam + dodir /etc/logrotate.d + keepdir /etc/logrotate.d + insinto /etc/logrotate.d + insopts -m0755 -o dspam -g dspam + newins ${FILESDIR}/logrotate.dspam dspam + + # dspam cron job + diropts -m0755 -o dspam -g dspam + dodir /etc/cron.daily + keepdir /etc/cron.daily + exeinto /etc/cron.daily + exeopts -m0755 -o dspam -g dspam + doexe ${FILESDIR}/dspam.cron + + # dspam enviroment + echo -ne "CONFIG_PROTECT=\"${DATADIR} /var/run/dspam\"\n\n" > ${T}/40dspam + doenvd ${T}/40dspam || die +} + +pkg_postinst() { + env-update + if use mysql || use postgres || use oci8; then + echo + einfo "To setup DSPAM to run out-of-the-box on your system with a MySQL," + einfo "PostgreSQL or Oracle database, run:" + einfo "ebuild /var/db/pkg/${CATEGORY}/${PF}/${PF}.ebuild config" + fi + if use mysql || use postgres; then + if has_version sys-kernel/linux26-headers; then + einfo "If you want to run DSPAM in the new deamon mode. Remember" + einfo "to make the DSPAM daemon start durig boot:" + einfo " rc-update add dspam default" + fi + fi + if use exim ; then + echo + einfo "To use dspam in conjunction with your exim system, you should read the README" + fi +} + +pkg_config () { + if use mysql ; then + [[ -f ${HOMEDIR}/mysql.data ]] && mv -f ${HOMEDIR}/mysql.data ${HOMEDIR} + + DSPAM_DB_DATA=( $(sed "s:^[\t ]*$:###:gI" "${ROOT}${HOMEDIR}/mysql.data") ) + for DB_DATA_INDEX in $(seq 0 $((${#DSPAM_DB_DATA[@]} - 1))); do + [[ "${DSPAM_DB_DATA[$DB_DATA_INDEX]}" = "###" ]] && DSPAM_DB_DATA[$DB_DATA_INDEX]="" + done + DSPAM_MySQL_USER="$DSPAM_DB_DATA[2]" + DSPAM_MySQL_PWD="$DSPAM_DB_DATA[3]" + DSPAM_MySQL_DB="$DSPAM_DB_DATA[4]" + + ewarn "When prompted for a password, please enter your MySQL root password" + ewarn "" + + einfo "Creating DSPAM MySQL database \"${DSPAM_MySQL_DB}\"" + /usr/bin/mysqladmin -u root -p create ${DSPAM_MySQL_DB} + + einfo "Creating DSPAM MySQL tables for data objects" + einfo " Please select what kind of object database you like to use." + einfo " [1] Space optimized database" + einfo " [2] Speed optimized database" + einfo + while true + do + read -n 1 -s -p " Press 1 or 2 on the keyboard to select database" DSPAM_MySQL_DB_Type + [[ "${DSPAM_MySQL_DB_Type}" == "1" || "${DSPAM_MySQL_DB_Type}" == "2" ]] && echo && break + done + + if [ "${DSPAM_MySQL_DB_Type}" == "1" ] + then + /usr/bin/mysql -u root -p ${DSPAM_MySQL_DB} < ${HOMEDIR}/mysql_objects-space.sql + else + /usr/bin/mysql -u root -p ${DSPAM_MySQL_DB} < ${HOMEDIR}/mysql_objects-speed.sql + fi + + einfo "Creating DSPAM MySQL database for virtual-users users" + /usr/bin/mysql -u root -p ${DSPAM_MySQL_DB} < ${HOMEDIR}/mysql_virtual-users.sql + + if use neural ; then + /usr/bin/mysql -u root -p ${DSPAM_MySQL_DB} < ${HOMEDIR}/mysql_neural.sql + fi + + einfo "Creating DSPAM MySQL user \"${DSPAM_MySQL_USER}\"" + /usr/bin/mysql -u root -p -e "GRANT SELECT,INSERT,UPDATE,DELETE ON ${DSPAM_MySQL_DB}.* TO ${DSPAM_MySQL_USER}@localhost IDENTIFIED BY '${DSPAM_MySQL_PWD}';FLUSH PRIVILEGES;" -D mysql + elif use postgres ; then + [[ -f ${HOMEDIR}/pgsql.data ]] && mv -f ${HOMEDIR}/pgsql.data ${HOMEDIR} + + DSPAM_DB_DATA=( $(sed "s:^[\t ]*$:###:gI" "${ROOT}${HOMEDIR}/pgsql.data") ) + for DB_DATA_INDEX in $(seq 0 $((${#DSPAM_DB_DATA[@]} - 1))); do + [[ "${DSPAM_DB_DATA[$DB_DATA_INDEX]}" = "###" ]] && DSPAM_DB_DATA[$DB_DATA_INDEX]="" + done + DSPAM_PgSQL_USER="${DSPAM_DB_DATA[2]}" + DSPAM_PgSQL_PWD="${DSPAM_DB_DATA[3]}" + DSPAM_PgSQL_DB="${DSPAM_DB_DATA[4]}" + + ewarn "When prompted for a password, please enter your PgSQL postgres password" + ewarn "" + + einfo "Creating DSPAM PostgreSQL database \"${DSPAM_PgSQL_DB}\" and user \"${DSPAM_PgSQL_USER}\"" + /usr/bin/psql -h localhost -d template1 -U postgres -c "CREATE USER ${DSPAM_PgSQL_USER} WITH PASSWORD '${DSPAM_PgSQL_PWD}' NOCREATEDB NOCREATEUSER; CREATE DATABASE ${DSPAM_PgSQL_DB}; GRANT ALL PRIVILEGES ON DATABASE ${DSPAM_PgSQL_DB} TO ${DSPAM_PgSQL_USER}; GRANT ALL PRIVILEGES ON SCHEMA public TO ${DSPAM_PgSQL_USER}; UPDATE pg_database SET datdba=(SELECT usesysid FROM pg_shadow WHERE usename='${DSPAM_PgSQL_USER}') WHERE datname='${DSPAM_PgSQL_DB}';" + + einfo "Creating DSPAM PostgreSQL tables" + PGUSER=${DSPAM_PgSQL_USER} PGPASSWORD=${DSPAM_PgSQL_PWD} /usr/bin/psql -d ${DSPAM_PgSQL_DB} -U ${DSPAM_PgSQL_USER} -f ${HOMEDIR}/pgsql_objects.sql 1>/dev/null 2>&1 + PGUSER=${DSPAM_PgSQL_USER} PGPASSWORD=${DSPAM_PgSQL_PWD} /usr/bin/psql -d ${DSPAM_PgSQL_DB} -U ${DSPAM_PgSQL_USER} -f ${HOMEDIR}/pgsql_virtual-users.sql 1>/dev/null 2>&1 + + elif use oci8 ; then + [[ -f ${HOMEDIR}/oracle.data ]] && mv -f ${HOMEDIR}/oracle.data ${HOMEDIR} + einfo "We have not enought Oracle knowledge to configure Oracle" + einfo "automatically. If you know how, please post a message in" + einfo "Gentoo Bugzilla." + einfo "" + einfo "You need manually to create the Oracle user for DSPAM and" + einfo "the necessary database." + einfo "But the DSPAM configuration file dspam.conf and oracle.data" + einfo "was already configured with the necessary information to" + einfo "access the database." + einfo "Pleae read your dspam.conf, oracle.data and the README for" + einfo "more info on how to setup DSPAM with Oracle." + elif use sqlite3 ; then + einfo "sqlite3_drv will automatically create the necessary database" + einfo "objects for each user upon first use of DSPAM by that user." + elif use sqlite ; then + einfo "sqlite_drv will automatically create the necessary database" + einfo "objects for each user upon first use of DSPAM by that user." + fi + +} diff --git a/mail-filter/dspam/files/digest-dspam-3.4.1 b/mail-filter/dspam/files/digest-dspam-3.4.1 new file mode 100644 index 000000000000..c6dfd8ada71f --- /dev/null +++ b/mail-filter/dspam/files/digest-dspam-3.4.1 @@ -0,0 +1,2 @@ +MD5 46764fdcf5db676ac784e7a633e19da3 dspam-3.4.1.tar.gz 692977 +MD5 8ffe9d41e6104a4c6d19067528193145 dspam_sa_trainer.tar.gz 1230 |