diff options
Diffstat (limited to 'mail/dspam/Makefile')
-rw-r--r-- | mail/dspam/Makefile | 575 |
1 files changed, 429 insertions, 146 deletions
diff --git a/mail/dspam/Makefile b/mail/dspam/Makefile index dffc9a2bfbb7..5e8c9a55f200 100644 --- a/mail/dspam/Makefile +++ b/mail/dspam/Makefile @@ -6,23 +6,29 @@ # PORTNAME= dspam -PORTVERSION= 3.0.0 +PORTVERSION= 3.2.2${SNAP_DATE} CATEGORIES= mail -MASTER_SITES= http://www.nuclearelephant.com/projects/dspam/sources/ +MASTER_SITES= http://people.tecnik93.com/~itetcu/FreeBSD/ports/dspam/sources/ +DISTFILES= dspam.3.2.2.cvs.stable.20041117.1515.tar.gz MAINTAINER= itetcu@people.tecnik93.com -COMMENT= A server-side bayesian spam filter - -## debug / log options -OPTIONS= NO_CONFLICTS "DO NOT conflict with dspam-2.x" off -OPTIONS+= DEBUG "Enable debug in DSPAM_HOME/dspam.debug" on -OPTIONS+= VERBOSE_DEBUG "Enable verbose debug" on -OPTIONS+= USER_LOGGING "Log mail in DSPAM_HOME/data/user/user.log" on -OPTIONS+= SYSTEM_LOGGING "Log some info DSPAM_HOME/system.log" on -OPTIONS+= SAT "Log spam source addresses to syslog" on +COMMENT= Bayesian spam filter - development version + +WRKSRC= ${WRKDIR}/dspam-cvs-stable${SNAP_DATE} + +SNAP_DATE= .20041117.1515 + +## debug / log / admin options +OPTIONS= DEBUG "Enable debugging logging" on +OPTIONS+= VERBOSE_DEBUG "Enable debug in LOGDIR/dspam.debug" off +#OPTIONS+= USER_LOGGING "Log mail in DSPAM_HOME/data/user/user.log" off +#OPTIONS+= SYSTEM_LOGGING "Log some info DSPAM_HOME/system.log" on +#OPTIONS+= SAT "Log spam source addresses to syslog" on +#OPTIONS+= PARSE_TO_HEADERS "Get user from To header on fp spam" off +OPTIONS+= PREF_EXT "Preferences in database not in files" off ## algorithm options -OPTIONS+= TRAD_BAYES "Enable traditional-bayesian" on -OPTIONS+= ALT_BAYES "Enable alternative-bayesian" on +OPTIONS+= GRAHAM_BAYES "Enable Graham (traditional) bayesian" on +OPTIONS+= BURTON_BAYES "Enable Burton (alternative) bayesian" on OPTIONS+= RNB "Use Robinson Naive Bayesian calculation" off OPTIONS+= CHI_SQUARE "Use Fisher-Robinson Inv Chi-Square" off OPTIONS+= RPV "Use Robinson technique combining p-values" off @@ -31,117 +37,156 @@ OPTIONS+= NO_BIAS "No bias toward innocent mail" off OPTIONS+= WHITELIST "Automatic whitelisting of ham" off OPTIONS+= NEURAL_NET "Enable neural networking" off ## run-time configure options -OPTIONS+= HOMEDIR_DOT "Dot files in ~/USER not DSPAM_HOME" off -OPTIONS+= OPT_IN "Run only for users with .dspam" off +#OPTIONS+= HOMEDIR_DOT "Dot files in ~/USER not DSPAM_HOME" off +OPTIONS+= USER_HOMEDIR "Store user data in ~/.dspam" off +#OPTIONS+= OPT_IN "Run only for users with .dspam" off OPTIONS+= TRUSTED_USERS "Disable trusted user security" off ## mesage taging options -OPTIONS+= SPAM_SUBJ "Prepends SPAM to the Subject header" off -OPTIONS+= SIGNATURE_HEADERS "Put signatures IDs in the header" off -OPTIONS+= WEBMAIL "Only with mail stored server-side" off +#OPTIONS+= SPAM_SUBJ "Prepends SPAM to the Subject header" off +#OPTIONS+= SIGNATURE_HEADERS "Put signatures IDs ONLY in headers" off +#OPTIONS+= WEBMAIL "Only with mail stored server-side" off ## back-end -OPTIONS+= MYSQL "Use MySQL as back-end" off +OPTIONS+= MYSQL40 "Use MySQL 4.0.x as back-end" off +OPTIONS+= MYSQL41 "Use MySQL 4.1.x as back-end" off OPTIONS+= MYSQL_COMPRESS "Compress dspam <--> MySQL" off OPTIONS+= POSTGRESQL73 "Use PostgreSQL v.7.3 as back-end" off OPTIONS+= POSTGRESQL74 "Use PostgreSQL v.7.4 as back-end" off #OPTIONS+= PGSQL_INSTALLED "You have the client installed" on OPTIONS+= ORACLE "Use Oracle as back-end (BROKEN)" off +OPTIONS+= BDB4 "Use BDB4 as back-end (not recomanded)" off +OPTIONS+= SQLITE "Use SQLite as back-end" on OPTIONS+= VIRT_USERS "Enable virtual users (needs SQL back-end)" off OPTIONS+= LONG_USERNAMES "Usernames longer that OS supports" off OPTIONS+= LARGE_SCALE "File structure for large scale" off OPTIONS+= DOMAIN_SCALE "File structure for multiple domains" off -OPTIONS+= SIGNATURE_ATACH "Put server-side signature in mails" off +#OPTIONS+= SIGNATURE_ATACH "Put server-side signature in mails" off ## MTA and LDA -OPTIONS+= MAILDROP "Use Maildrop as local delivery agent" off -OPTIONS+= PROCMAIL "Use Procmail as local delivery agent" off +OPTIONS+= MAILDROP_LDA "Use Maildrop as local delivery agent" off +OPTIONS+= PROCMAIL_LDA "Use Procmail as local delivery agent" off +OPTIONS+= CYRUS21_LDA "Use Cyrus's 2.1 deliver as LDA" off +OPTIONS+= CYRUS22_LDA "Use Cyrus's 2.2 deliver as LDA" off OPTIONS+= SENDMAIL_LDA "Use Sendmail as local delivery agent" off + OPTIONS+= SENDMAIL "Play nice with sendmail server" off +OPTIONS+= POSTFIX_MBC "Dspam as mailbox_command in Postfix" off OPTIONS+= QMAIL "Play nice with Qmail mail server" off -OPTIONS+= BROKEN_ERR_CODES "99=spam, 0=not, other=error (qmailish)" off -OPTIONS+= BROKEN_MTA "Enable if MTA pases ^M to dspam" off +#OPTIONS+= BROKEN_ERR_CODES "99=spam, 0=not, other=error (qmailish)" off +#OPTIONS+= BROKEN_MTA "Enable if MTA pases ^M to dspam" off + OPTIONS+= CGI "Install CGI (pulls in apache)" off -USE_GNOME= pkgconfig -USE_INC_LIBTOOL_VER=13 +#USE_GNOME= pkgconfig lthack +#USE_INC_LIBTOOL_VER=13 +USE_LIBTOOL_VER=15 USE_REINPLACE= yes INSTALLS_SHLIB= yes GNU_CONFIGURE= yes CONFIGURE_ENV= LDFLAGS="-L${LOCALBASE}/lib" CONFIGURE_TARGET= --build=${MACHINE_ARCH}-portbld-freebsd${OSREL} -SED_SCRIPT= -e 's,%%DOCSDIR%%,${DOCSDIR},g' \ - -e 's,%%EXAMPLESDIR%%,${EXAMPLESDIR},g' \ - -e 's,%%LOCALBASE%%,${LOCALBASE},g' +PKGMESSAGE= ${WRKSRC}/README.FreeBSD + +CONFLICTS= dspam-2* dspam-3.0* -WITH_SIGNATURE_LIFE?= 28 +SIGNATURE_LIFE?= 15 +_VAR_DIR= /var +LOG_DIR?= ${_VAR_DIR}/log/dspam +DSPAM_HOME?= ${_VAR_DIR}/db/dspam +DSPAM_HOME_MODE?= 0660 .include <bsd.port.pre.mk> -.if !defined(WITH_NO_CONFLICTS) -CONFLICTS= dspam-2* +CONFIGURE_ARGS+= --with-logdir=${LOG_DIR} +PLIST_SUB+= LOG_DIR=${LOG_DIR} + +CONFIGURE_ARGS+= --with-dspam-home=${DSPAM_HOME} +PLIST_SUB+= DSPAM_HOME=${DSPAM_HOME} + +.if defined(DSPAM_HOME_OWNER) +CONFIGURE_ARGS+= --with-dspam-home-owner=${DSPAM_HOME_OWNER} +.endif +.if defined(DSPAM_HOME_GROUP) +CONFIGURE_ARGS+= --with-dspam-home-group=${DSPAM_HOME_GROUP} +.endif +.if defined(DSPAM_HOME_MODE) +CONFIGURE_ARGS+= --with-dspam-home-mode=${DSPAM_HOME_MODE} +.endif + +.if defined(DSPAM_OWNER) +CONFIGURE_ARGS+= --with-dspam-owner=${DSPAM_OWNER} +.endif +.if defined(DSPAM_GROUP) +CONFIGURE_ARGS+= --with-dspam-group=${DSPAM_HOME_GROUP} +.endif +.if defined(DSPAM_MODE) +CONFIGURE_ARGS+= --with-dspam-mode=${DSPAM_HOME_MODE} .endif -.if defined(WITHOUT_DEBUG) -CONFIGURE_ARGS+= --disable-debug -.else +SED_SCRIPT= -e 's,%%DOCSDIR%%,${DOCSDIR},g' \ + -e 's,%%EXAMPLESDIR%%,${EXAMPLESDIR},g' \ + -e 's,%%LOCALBASE%%,${LOCALBASE},g' \ + -e 's,%%PREFIX%%,${PREFIX},g' \ + -e 's,%%PKGNAME%%,${PKGNAME},g' \ + -e 's,%%DSPAM_HOME%%,${DSPAM_HOME},g' + +.if defined(WITH_DEBUG) CONFIGURE_ARGS+= --enable-debug .endif -.if defined(WITHOUT_VERBOSE_DEBUG) -CONFIGURE_ARGS+= --disable-verbose-debug -.else +.if defined(WITH_VERBOSE_DEBUG) CONFIGURE_ARGS+= --enable-verbose-debug .endif -.if defined(WITHOUT_SYSTEM_LOGGING) -CONFIGURE_ARGS+= --disable-system-logging -.else -CONFIGURE_ARGS+= --enable-logging -.endif +# conf option +#.if defined(WITH_SYSTEM_LOGGING) +#CONFIGURE_ARGS+= --enable-logging +#.else +#CONFIGURE_ARGS+= --disable-system-logging +#.endif -.if defined(WITHOUT_USER_LOGGING) -CONFIGURE_ARGS+= --disable-user-logging -.else -CONFIGURE_ARGS+= --enable-user-logging -.endif +# conf option +#.if defined(WITH_USER_LOGGING) +#CONFIGURE_ARGS+= --enable-user-logging +#.else +#CONFIGURE_ARGS+= --disable-user-logging +#.endif -.if !defined(WITHOUT_SAT) -CONFIGURE_ARGS+= --enable-source-address-tracking +# conf +#.if defined(WITH_SAT) +#CONFIGURE_ARGS+= --enable-source-address-tracking +#.endif + +# conf +#.if defined(PARSE_TO_HEADERS) +#CONFIGURE_ARGS+= --enable-parse-to-headers +#.endif + +.if defined(PREF_EXT) +CONFIGURE_ARGS+= --enable-preferences-extension .endif -.if defined(WITHOUT_TRAD_BAYES) +.if !defined(WITH_GRAHAM_BAYES) CONFIGURE_ARGS+= --disable-traditional-bayesian -.else -CONFIGURE_ARGS+= --enable-traditional-bayesian .endif -.if defined(WITHOUT_ALT_BAYES) +.if !defined(WITH_BURTON_BAYES) CONFIGURE_ARGS+= --disable-alternative-bayesian -.else -CONFIGURE_ARGS+= --enable-alternative-bayesian .endif .if defined(WITH_RNB) CONFIGURE_ARGS+= --enable-robinson -.else -CONFIGURE_ARGS+= --disable-robinson .endif .if defined(WITH_CHI_SQUARE) CONFIGURE_ARGS+= --enable-robinson -.else -CONFIGURE_ARGS+= --disable-robinson .endif .if defined(WITH_RPV) CONFIGURE_ARGS+= --enable-robinson-pvalues -.else -CONFIGURE_ARGS+= --disable-robinson-pvalues .endif -.if defined(WITHOUT_TEST_COND) +.if !defined(WITH_TEST_COND) CONFIGURE_ARGS+= --disable-test-conditional -.else -CONFIGURE_ARGS+= --enable-test-conditional .endif .if defined(WITH_NO_BIAS) @@ -154,47 +199,73 @@ CONFIGURE_ARGS+= --enable-whitelist .if defined(WITH_NEURAL_NET) CONFIGURE_ARGS+= --enable-neural-networking -#NEED_M_P=. @${TRUE} .endif -.if defined(WITH_HOMEDIR_DOT) -CONFIGURE_ARGS+= --enable-homedir-dotfiles -.endif +#.if defined(WITH_HOMEDIR_DOT) +#CONFIGURE_ARGS+= --enable-homedir-dotfiles +#.endif -.if defined(WITH_OPT_IN) -CONFIGURE_ARGS+= --enable-opt-in +.if defined(WITH_USER_HOMEDIR) +CONFIGURE_ARGS+= --enable-homedir +## XXXXXXXX +# to check incompatibility with CGI and warn user +# to install setuid root .endif +# conf +#.if defined(WITH_OPT_IN) +#CONFIGURE_ARGS+= --enable-opt-in +#.endif + .if defined(WITH_TRUSTED_USERS) CONFIGURE_ARGS+= --disable-trusted-user-security .endif -.if defined(WITH_SPAM_SUBJ) -CONFIGURE_ARGS+= --enable-spam-subject -.endif +# conf +#.if defined(WITH_SPAM_SUBJ) +#CONFIGURE_ARGS+= --enable-spam-subject +#.endif -.if defined(WITH_SIGNATURE_HEADERS) -CONFIGURE_ARGS+= --enable-signature-headers -.endif +# .conf option +#.if defined(WITH_SIGNATURE_HEADERS) +#CONFIGURE_ARGS+= --enable-signature-headers +#SED_SCRIPT+= -e 's,%%SIGHDR%%,,g' +#.else +#SED_SCRIPT+= -e '/%%SIGHDR%%/D' +#.endif -.if defined(SIGNATURE_ATACH) -CONFIGURE_ARGS+= --enable-signature-attachments -.endif +# not supported anymore +#.if defined(SIGNATURE_ATACH) +#CONFIGURE_ARGS+= --enable-signature-attachments +#.endif -.if defined(WITH_WEBMAIL) -CONFIGURE_ARGS+= --enable-webmail +#.if defined(WITH_WEBMAIL) +#CONFIGURE_ARGS+= --enable-webmail +#.endif + +DBDRV_TOTAL_COUNT= ooooooo # 7 +DBDRV_COUNT= ${DBDRV_TOTAL_COUNT} + +.if defined(WITH_MYSQL40) +WANT_MYSQL_VER= 40 +#PKGNAMESUFFIX= -mysql40 +.elseif defined(WITH_MYSQL41) +WANT_MYSQL_VER= 41 +#PKGNAMESUFFIX= -mysql41 .endif -.if defined(WITH_MYSQL) -USE_MYSQL= yes +.if defined(WITH_MYSQL40) || defined(WITH_MYSQL41) CONFIGURE_ARGS+= --with-storage-driver=mysql_drv \ --with-mysql-includes=${LOCALBASE}/include/mysql \ --with-mysql-libraries=${LOCALBASE}/lib/mysql PLIST_SUB+= DB4="@comment " PLIST_SUB+= MYSQL="" PLIST_SUB+= PGSQL="@comment " +PLIST_SUB+= SQLITE="@comment " SED_SCRIPT+= -e 's,%%MYSQL%%,,g' SED_SCRIPT+= -e '/%%PGSQL%%/D' +SED_SCRIPT+= -e '/%%SQLITE%%/D' +DBDRV_COUNT:= ${DBDRV_COUNT:S/o//} .if defined(WITH_MYSQL_COMPRESS) CONFIGURE_ARGS+= --enable-client-compression .endif @@ -209,8 +280,12 @@ CONFIGURE_ARGS+= --with-storage-driver=pgsql_drv \ PLIST_SUB+= DB4="@comment " PLIST_SUB+= MYSQL="@comment " PLIST_SUB+= PGSQL="" +PLIST_SUB+= SQLITE="@comment " SED_SCRIPT+= -e '/%%MYSQL%%/D' SED_SCRIPT+= -e 's,%%PGSQL%%,,g' +SED_SCRIPT+= -e '/%%SQLITE%%/D' +#PKGNAMESUFFIX= -pgsql73 +DBDRV_COUNT:= ${DBDRV_COUNT:S/o//} .endif .if defined(WITH_POSTGRESQL74) @@ -222,29 +297,58 @@ CONFIGURE_ARGS+= --with-storage-driver=pgsql_drv \ PLIST_SUB+= DB4="@comment " PLIST_SUB+= MYSQL="@comment " PLIST_SUB+= PGSQL="" +PLIST_SUB+= SQLITE="@comment " SED_SCRIPT+= -e '/%%MYSQL%%/D' SED_SCRIPT+= -e 's,%%PGSQL%%,,g' +SED_SCRIPT+= -e '/%%SQLITE%%/D' +#PKGNAMESUFFIX= -pgsql74 +DBDRV_COUNT:= ${DBDRV_COUNT:S/o//} .endif .if defined(WITH_ORACLE) -BUILD_DEPENDS+= ${LOCALBASE}/oracle7/rdbms/lib/libnlsrtl3.a:${PORTSDIR}/databases/oracle7-client +BUILD_DEPENDS+= ${LOCALBASE}/oracle7/rdbms/lib/libnlsrtl3.a:\ + ${PORTSDIR}/databases/oracle7-client CONFIGURE_ARGS+= --with-storage-driver=ora_drv \ --with-oracle-home= ${LOCALBASE}/oracle7 +#PKGNAMESUFFIX= -oracle +DBDRV_COUNT:= ${DBDRV_COUNT:S/o//} .endif -.if defined(WITH_VIRT_USERS) -CONFIGURE_ARGS+= --enable-virtual-users -#NEED_M_P=. @${TRUE} -.endif - -.if !(defined(WITH_MYSQL) || defined(WITH_POSTGRESQL73) || defined(WITH_POSTGRESQL74) || defined(WITH_ORACLE)) +.if defined(WITH_BDB) LIB_DEPENDS+= db41.1:${PORTSDIR}/databases/db41 -CONFIGURE_ARGS+= --with-db4-includes=${LOCALBASE}/include/db41 +CONFIGURE_ARGS+= --with-storage-driver=libdb4_drv \ + --with-db4-includes=${LOCALBASE}/include/db41 PLIST_SUB+= DB4="" PLIST_SUB+= MYSQL="@comment " PLIST_SUB+= PGSQL="@comment " +PLIST_SUB+= SQLITE="@comment " +SED_SCRIPT+= -e '/%%MYSQL%%/D' +SED_SCRIPT+= -e '/%%PGSQL%%/D' +SED_SCRIPT+= -e '/%%SQLITE%%/D' +#PKGNAMESUFFIX= -bdb +DBDRV_COUNT:= ${DBDRV_COUNT:S/o//} +.endif + +.if ${DBDRV_TOTAL_COUNT}==${DBDRV_COUNT} || defined(WITH_SQLITE) +# DBDRV_COUNT==!(defined(WITH_MYSQL) || defined(WITH_POSTGRESQL73) || defined(WITH_POSTGRESQL74) || defined(WITH_ORACLE) || defined(WITH_BDB)) +WITH_SQLITE= on +LIB_DEPENDS+= sqlite.2:${PORTSDIR}/databases/sqlite2 +CONFIGURE_ARGS+= --with-storage-driver=sqlite_drv \ + --with-sqlite-includes=${LOCALBASE}/include \ + --with-sqlite-libraries=${LOCALBASE}/lib +PLIST_SUB+= DB4="@comment " +PLIST_SUB+= MYSQL="@comment " +PLIST_SUB+= PGSQL="@comment " +PLIST_SUB+= SQLITE="" SED_SCRIPT+= -e '/%%MYSQL%%/D' SED_SCRIPT+= -e '/%%PGSQL%%/D' +SED_SCRIPT+= -e 's,%%SQLITE%%,,g' +#PKGNAMESUFFIX= -sqlite2 +DBDRV_COUNT:= ${DBDRV_COUNT:S/o//} +.endif + +.if defined(WITH_VIRT_USERS) +CONFIGURE_ARGS+= --enable-virtual-users .endif .if defined(WITH_LONG_USERNAMES) @@ -257,116 +361,295 @@ CONFIGURE_ARGS+= --enable-large-scale CONFIGURE_ARGS+= --enable-domain-scale .endif -.if defined(WITH_MAILDROP) +# add one 'o' here for each new LDA +LDA_TOTAL_COUNT= oooooo #6 +LDA_COUNT= ${LDA_TOTAL_COUNT} + +.if defined(WITH_MAILDROP_LDA) RUN_DEPENDS+= maildrop:${PORTSDIR}/mail/maildrop -CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/bin/maildrop $u' +CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/bin/maildrop -d $$u' +CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/bin/maildrop' +LDA_COUNT:= ${LDA_COUNT:S/o//} .endif -.if defined(WITH_PROCMAIL) +.if defined(WITH_PROCMAIL_LDA) RUN_DEPENDS+= procmail:${PORTSDIR}/mail/procmail -CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/bin/procmail $u' +CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/bin/procmail -d $$u' +CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/bin/procmail' +LDA_COUNT:= ${LDA_COUNT:S/o//} .endif .if defined(WITH_SENDMAIL_LDA) && exists(/usr/sbin/sendmail) CONFIGURE_ARGS+= --with-delivery-agent=/usr/sbin/sendmail +LDA_COUNT:= ${LDA_COUNT:S/o//} .else -.if defined(WITH_SENDMAIL_LDA) && exists(${LOCALBASE}/sbin/sendmail) +. if defined(WITH_SENDMAIL_LDA) && exists(${LOCALBASE}/sbin/sendmail) CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/sbin/sendmail' -.endif +CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/sbin/sendmail' +LDA_COUNT:= ${LDA_COUNT:S/o//} +. endif .endif -.if defined(WITH_SENDMAIL) -CONFIGURE_ARGS+= --with-dspam-mode=4511 +.if defined(WITH_CYRUS21_LDA) +RUN_DEPENDS+= ${LOCALBASE}/cyrus/bin/deliver:${PORTSDIR}/mail/cyrus-imapd2 +#CONFIGURE_ARGS+=\ +#--with-delivery-agent='${LOCALBASE}/cyrus/bin/deliver -e -r $${sender} -m $${extension} $${user} $$u' +CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/cyrus/bin/deliver' +LDA_COUNT:= ${LDA_COUNT:S/o//} .endif -.if defined(WITH_QMAIL) -CONFIGURE_ARGS+= --with-dspam-mode=4511 +.if defined(WITH_CYRUS22_LDA) +RUN_DEPENDS+= ${LOCALBASE}/cyrus/bin/deliver:${PORTSDIR}/mail/cyrus-imapd22 +#CONFIGURE_ARGS+=\ +#--with-delivery-agent='${LOCALBASE}/cyrus/bin/deliver -e -r $${sender} -m $${extension} $${user} $$u' +CONFIGURE_ARGS+= --with-delivery-agent='${LOCALBASE}/cyrus/bin/deliver' +LDA_COUNT:= ${LDA_COUNT:S/o//} .endif -.if defined(WITH_BROKEN_ERR_CODES) -CONFIGURE_ARGS+= --enable-broken-return-codes +.if defined(WITH_SENDMAIL) +CONFIGURE_ARGS+= --with-dspam-mode=4511 .endif -.if defined(DSPAM_HOME) -CONFIGURE_ARGS+=--with-dspam-home=${DSPAM_HOME} +.if defined(WITH_POSTFIX_MBC) +CONFIGURE_ARGS+= --with-dspam-mode=4511 +SED_SCRIPT+= -e 's,%%POSTFIX_MBC%%,,g' .else -CONFIGURE_ARGS+=--with-dspam-home=${PREFIX}/etc/dspam +SED_SCRIPT+= -e '/%%POSTFIX_MBC%%/D' .endif -# --with-dspam-home=DIR Specify directory where per-user dictionaries -# --with-dspam-home-mode=MODE Set access mode for DSPAM_HOME -# --with-dspam-home-owner=OWNER Set owner for DSPAM_HOME -# --with-dspam-home-group=GROUP Set group for DSPAM_HOME - -# --with-dspam-mode=MODE Set access mode for dspam binary -# --with-dspam-owner=OWNER Set owner for dspam binary -# --with-dspam-group=GROUP Set group for dspam binary - -.if defined(WITH_BROKEN_MTA) -CONFIGURE_ARGS+= --enable-broken-mta +.if defined(WITH_QMAIL) +CONFIGURE_ARGS+= --with-dspam-mode=4511 .endif -.if defined(WITH_SIGNATURE_LIFE) -CONFIGURE_ARGS+= --with-signature-life=${WITH_SIGNATURE_LIFE} -.endif +# conf +#.if defined(WITH_BROKEN_ERR_CODES) +#CONFIGURE_ARGS+= --enable-broken-return-codes +#.endif +# conf +#.if defined(WITH_BROKEN_MTA) +#CONFIGURE_ARGS+= --enable-broken-mta +#.endif + +# conf option .if defined(QUARANTINE_AGENT) CONFIGURE_ARGS+= --with-quarantine-agent=${QUARANTINE_AGENT} .endif .if defined(WITH_CGI) -RUN_DEPENDS+= ${LOCALBASE}/etc/apache/httpd.conf:${PORTSDIR}/${APACHE_PORT} -.endif - -MAN1= dspam.1 dspam_clean.1 dspam_corpus.1 dspam_dump.1 dspam_merge.1 dspam_stats.1 - -DOCS= CHANGELOG README LICENSE RELEASE.NOTES - -pre-everything:: - @${SH} ${PKGINSTALL} ${PORTNAME} PRE-INSTALL +LIB_DEPENDS+= gd.4:${PORTSDIR}/graphics/gd +RUN_DEPENDS+= ${LOCALBASE}/sbin/apachectl:${PORTSDIR}/${APACHE_PORT} +RUN_DEPENDS+= ${SITE_PERL}/mach/GD.pm:${PORTSDIR}/graphics/p5-GD +RUN_DEPENDS+= ${SITE_PERL}/GD/Graph.pm:${PORTSDIR}/graphics/p5-GD-Graph +RUN_DEPENDS+= ${SITE_PERL}/GD/Graph3d.pm:${PORTSDIR}/graphics/p5-GD-Graph3d +RUN_DEPENDS+= ${SITE_PERL}/GD/Text.pm:${PORTSDIR}/graphics/p5-GD-TextUtil +CONFIGURE_ARGS+=--enable-logging +CONFIGURE_ARGS+=--enable-user-logging +USE_PERL5_RUN= yes +PLIST_SUB+= CGI="" +CGI_PATH?= ${PREFIX}/www/vhosts/dspam +SED_SCRIPT+= -e 's,%%CGI%%,,g' +SED_SCRIPT+= -e 's,%%CGI_PATH%%,${CGI_PATH},g' +#SED_FILES= ${LS} ${WRKSRC}/cgi/*.pl +#SED_FILES+= ${LS} $PWRKSRC}/cgi/*.cgi +.else +PLIST_SUB+= CGI="@comment " +SED_SCRIPT+= -e '/%%CGI%%/D' +.endif + +MAN1= dspam.1 dspam_clean.1 dspam_corpus.1 dspam_dump.1 dspam_merge.1 \ + dspam_stats.1 +MAN3= libdspam.3 +MLINKS= libdspam.3 dspam_init.3 +MLINKS+= libdspam.3 dspam_create.3 +MLINKS+= libdspam.3 dspam_addattribute.3 +MLINKS+= libdspam.3 dspam_attach.3 +MLINKS+= libdspam.3 dspam_process.3 +MLINKS+= libdspam.3 dspam_getsource.3 +MLINKS+= libdspam.3 dspam_destroy.3 +MLINKS+= libdspam.3 dspam_detach.3 + +DOCS= CHANGELOG LICENSE README README.FreeBSD README.courier README.exim \ + README.pop3filter README.postfix README.qmail README.sendmail \ + RELEASE.NOTES + +pre-extract: +BAD_OPT= `${PKG_VERSION} -t ${_OPTIONS_READ} ${PKGNAME}` + +pre-patch: + @${ECHO_CMD} "" + @${ECHO_CMD} "******************************************************************" + @${ECHO_CMD} "Warning: If upgrading please proceed as stated in" + @${ECHO_CMD} "${FILESDIR}/UPDATING" + @${ECHO_CMD} "******************************************************************" + @${ECHO_CMD} "" + @${ECHO_CMD} "Define vars below before make-ing if you need:" + @${ECHO_CMD} "" + @${ECHO_CMD} "SIGNATURE_LIFE (default 15)" + @${ECHO_CMD} "DSPAM_OWNER (default: root)" + @${ECHO_CMD} "DSPAM_GROUP (default: mail)" + @${ECHO_CMD} "DSPAM_MODE" + @${ECHO_CMD} "DSPAM_HOME (default: ${_VAR_DIR}/dspam)" + @${ECHO_CMD} "DSPAM_HOME_OWNER" + @${ECHO_CMD} "DSPAM_HOME_GROUP" + @${ECHO_CMD} "DSPAM_HOME_MODE (default: 0660)" + @${ECHO_CMD} "LOG_DIR (default: ${_VAR_DIR}/log/dspam)" + @${ECHO_CMD} "QUARANTINE_AGENT (default: mail.local)" +. if defined(WITH_CGI) + @${ECHO_CMD} "Define CGI_PATH before make-ing if you need the CGI files" + @${ECHO_CMD} "installed in other place that this installation's default" + @${ECHO_CMD} "${PREFIX}/www/vhosts/dspam" +. endif +.for old_opt in MAILDROP PROCMAIL TRAD_BAYES ALT_BAYES WITH_SPAM_SUBJ \ + USER_LOGGING SYSTEM_LOGGING WEBMAIL OPT_IN SAT PARSE_TO_HEADERS \ + BROKEN_MTA BROKEN_ERR_CODES SIGNATURE_HEADERS SIGNATURE_ATACH \ + HOMEDIR_DOT SIGNATURE_LIFE +. if defined(WITH_${old_opt}) || defined(WITHOUT_${old_opt}) || ${BAD_OPT}=='<' +#. if defined(CUCU) + @${ECHO_CMD} "" + @${ECHO_CMD} "******************************************************************" + @${ECHO_CMD} "******************************************************************" + @${ECHO_CMD} "Either:" + @${ECHO_CMD} "an old option ${old_opt} or " + @${ECHO_CMD} "OPTIONS config-file ${_OPTIONS_READ} has been detected !!!" + @${ECHO_CMD} "Trying to prevent self-shooting this port's make ends here." + @${ECHO_CMD} "You shold always read ${PORTSDIR}/UPDATING before installing/updating" + @${ECHO_CMD} "any port. Please remove/adjust your pkgtools.conf, environment and" + @${ECHO_CMD} "your make command-line and/or do 'make rmconfig' as appropiate." + @${ECHO_CMD} "But before read ${FILESDIR}/UPDATING" + @${ECHO_CMD} "as a lot of things have changed, notably the majority of" + @${ECHO_CMD} "compile-time options can/must now be set in" + @${ECHO_CMD} "${PREFIX}/etc/dspam.conf" + @${ECHO_CMD} "******************************************************************" + @${ECHO_CMD} "******************************************************************" + @${ECHO_CMD} "" + @${FALSE} +. endif +.endfor post-patch: - @${REINPLACE_CMD} -e 's|%%LIBTOOLFLAGS%%|${LIBTOOLFLAGS}|g ; \ - s|-ldb-4.1|-ldb41|g' ${WRKSRC}/configure + ${REINPLACE_CMD} -e 's|%%PORTNAME%%|${PORTNAME}|; \ + s|%%PKGNAME%%|${PKGNAME}|; s|%%MAINTAINER%%|${MAINTAINER}|; \ + s|%%LIBTOOLFLAGS%%|${LIBTOOLFLAGS}|g; \ + s|-ldb-4.1|-ldb41|g;' ${WRKSRC}/configure @${REINPLACE_CMD} -e 's|(libdir)/pkgconfig|(prefix)/libdata/pkgconfig|' \ ${WRKSRC}/Makefile.in + @${REINPLACE_CMD} -e 's|where @a-14 > to_days(created_on);|where @a-${SIGNATURE_LIFE} > to_days(created_on);|' ${WRKSRC}/tools.mysql_drv/purge.sql + @${REINPLACE_CMD} -e 's|WHERE CURRENT_DATE - created_on > 14;|WHERE CURRENT_DATE - created_on > ${SIGNATURE_LIFE};|' ${WRKSRC}/tools.pgsql_drv/purge.sql + @${REINPLACE_CMD} -e 's|where SYSDATE-created_on > 14|where SYSDATE-created_on > ${SIGNATURE_LIFE};|' ${WRKSRC}/tools.ora_drv/purge.sql + @${REINPLACE_CMD} -e "s|where date('now')-date(created_on) > 14;|where date('now')-date(created_on) > ${SIGNATURE_LIFE};|" ${WRKSRC}/tools.sqlite_drv/purge.sql pre-configure: -.if defined(WITH_MAILDROP) && (defined(WITH_PROCMAIL) || defined(WITH_SENDMAIL_LDA)) + @${ECHO_CMD} +.if !( ${LDA_TOTAL_COUNT:S/o//}==${LDA_COUNT} || ${LDA_TOTAL_COUNT}==${LDA_COUNT} ) @${ECHO_CMD} "You can only use one local delivery agent at once." + @${ECHO_CMD} "See ${LOCALBASE}/etc/dspam.conf for how to chage it at run time." @${FALSE} .endif -.if defined(WITH_PROCMAIL) && (defined(WITH_MAILDROP) || defined(WITH_SENDMAIL_LDA)) - @${ECHO_CMD} "You can only use one local delivery agent at once." +.if ${DBDRV_TOTAL_COUNT:S/o//}!=${DBDRV_COUNT} + @${ECHO_CMD} + @${ECHO_CMD} "You can use one and only one database back-end at once." @${FALSE} .endif -.if defined(WITH_NEURAL_NET) && !(defined(WITH_MYSQL) || defined(WITH_POSTGRESQL)) +.if defined(WITH_NEURAL_NET) && !(defined(WITH_MYSQL) || defined(WITH_POSTGRESQL73) || defined(WITH_POSTGRESQL74)) @${ECHO_CMD} "You need MySQL or POSTGRESQL to use neural networking." @${FALSE} .endif -.if defined(WITH_VIRT_USERS) && !(defined(WITH_MYSQL) || defined(WITH_POSTGRESQL) || defined(WITH_ORACLE)) +.if defined(WITH_VIRT_USERS) && !(defined(WITH_MYSQL) || \ + defined(WITH_POSTGRESQL73) || defined(WITH_POSTGRESQL74) || defined(WITH_ORACLE)) @${ECHO_CMD} "You need MySQL, POSTGRESQL or ORACLE for virtual users." @${FALSE} .endif +.if defined(WITH_PREF_EXT) && !( defined(WITH_MYSQL) || \ + defined(WITH_POSTGRESQL73) || defined(WITH_POSTGRESQL74) ) + @${ECHO_CMD} "You need MySQL or Postgres for preferences extension" + @${FALSE} +.endif +.if defined(WITH_USER_HOMEDIR) && defined(WITH_CGI) + @${ECHO_CMD} "USER_HOMEDIR and CGI are incopatible" + @${FALSE} +.endif post-install: -.if defined(WITH_MYSQL) +### to patch dspam.conf + ${REINPLACE_CMD} -e 's|/usr/bin/|${PREFIX}/bin/|g' ${WRKSRC}/dspam.conf + @${CP} ${WRKSRC}/dspam.conf ${WRKSRC}/dspam.conf.sample + cd ${WRKSRC}/ && \ + ${INSTALL_DATA} dspam.conf.sample ${PREFIX}/etc +# @${MKDIR} ${LOG_DIR} +# @${MKDIR} ${DSPAM_HOME} + +.if defined(WITH_MYSQL40) || defined(WITH_MYSQL41) @${MKDIR} ${EXAMPLESDIR}/mysql cd ${WRKSRC}/tools.mysql_drv && \ - ${INSTALL_DATA} README *.sql* ${EXAMPLESDIR}/mysql - ${INSTALL_DATA} ${FILESDIR}/mysql.data ${EXAMPLESDIR}/mysql - ${INSTALL_DATA} ${FILESDIR}/2x_to_3x_db.sql ${EXAMPLESDIR}/mysql + ${INSTALL_DATA} README mysql_objects-space.sql \ + mysql_objects-speed.sql purge.sql \ + virtual_users.sql mysql_objects-4.1.sql \ + purge-4.1.sql neural.sql ${EXAMPLESDIR}/mysql + @${INSTALL_DATA} ${FILESDIR}/2x_to_3x_db.sql ${EXAMPLESDIR}/mysql + @${INSTALL_DATA} ${FILESDIR}/310_to_320.my.sql ${EXAMPLESDIR}/mysql .endif .if defined(WITH_POSTGRESQL73) || defined(WITH_POSTGRESQL74) - ${MKDIR} ${EXAMPLESDIR}/pgsql - cd ${WRKSRC}/tools.pgsql_drv && \ + @${MKDIR} ${EXAMPLESDIR}/pgsql + @cd ${WRKSRC}/tools.pgsql_drv && \ ${INSTALL_DATA} README *.sql ${EXAMPLESDIR}/pgsql - ${INSTALL_DATA} ${FILESDIR}/pgsql.data ${EXAMPLESDIR}/pgsql +# ${INSTALL_DATA} ${FILESDIR}/pgsql.data ${EXAMPLESDIR}/pgsql +.endif +.if defined(WITH_SQLITE) + @${MKDIR} ${EXAMPLESDIR}/sqlite + cd ${WRKSRC}/tools.sqlite_drv && \ + ${INSTALL_DATA} README *.sql ${EXAMPLESDIR}/sqlite .endif +.if defined(WITH_ORACLE) + @${MKDIR} ${EXAMPLESDIR}/oracle + cd ${WRKSRC}/tools.ora_drv && \ + ${INSTALL_DATA} README *.sql ${EXAMPLESDIR}/oracle +.endif + +.if defined(WITH_CGI) +. for I in admin.cgi admingraph.cgi configure.pl dspam.cgi graph.cgi + @${SED} -i '' -e "s,/usr/bin/perl,${PERL},g" ${WRKSRC}/cgi/${I} +. endfor + cd ${WRKSRC}/cgi && ${MV} configure.pl configure.pl.sample + cd ${WRKSRC}/cgi && ${MKDIR} ${CGI_PATH} && \ + ${INSTALL_SCRIPT} configure.pl.sample ${CGI_PATH}/ && \ + ${INSTALL_SCRIPT} *.cgi ${CGI_PATH} + cd ${WRKSRC}/cgi && \ + ${INSTALL_DATA} base.css dspam-logo-small.gif rgb.txt ${CGI_PATH}/ + cd ${WRKSRC}/cgi && \ + ${INSTALL_DATA} default.prefs ${CGI_PATH}/default.prefs.sample + cd ${WRKSRC}/cgi && \ + ${INSTALL_DATA} admins ${CGI_PATH}/admins.sample +# cd ${WRKSRC}/cgi && \ +# ${INSTALL_DATA} configure.pl.sample ${CGI_PATH}/configure.pl.sample + @${MKDIR} ${CGI_PATH}/templates && cd ${WRKSRC}/cgi/templates && \ + ${INSTALL_DATA} *.html ${CGI_PATH}/templates/ +.endif + + @${SED} ${SED_SCRIPT} ${.CURDIR}/pkg-message > ${WRKSRC}/README.FreeBSD .if !defined(NOPORTDOCS) @${MKDIR} ${DOCSDIR} cd ${WRKSRC} && ${INSTALL_DATA} ${DOCS} ${DOCSDIR} -.endif - @${SED} ${SED_SCRIPT} ${PKGMESSAGE} + cd ${FILESDIR} && ${INSTALL_DATA} UPDATING ${DOCSDIR} +.endif + + @${MKDIR} -m ${DSPAM_HOME_MODE} ${DSPAM_HOME} + @${CHOWN} ${DSPAM_HOME_OWNER}:${DSPAM_HOME_GROUP} ${DSPAM_HOME} +.for _file in firstrun.txt firstspam.txt quarantinefull.txt + if ! ${TEST} -e ${WRKSRC}/txt/${_file}.sample;\ + then\ + cd ${WRKSRC}/txt && \ + ${MV} ${_file} ${_file}.sample;\ + fi + cd ${WRKSRC}/txt && \ + ${INSTALL_DATA} ${_file}.sample ${DSPAM_HOME} +.endfor + + @${MKDIR} -m ${DSPAM_HOME_MODE} ${LOG_DIR} + + @${CAT} ${WRKSRC}/README.FreeBSD + @${ECHO_CMD} "If you haven't defined NOPORTDOCS you can review this" + @${ECHO_CMD} "message in ${DOCSDIR}/README.FreeBSD" + @${ECHO_CMD} .include <bsd.port.post.mk> |