6757d8fc61
- While here, use WANT_QMAIL rather than hideous relative include PR: ports/159964 Submitted by: Nicolas de Bari Embriz <nbari@dalmp.com> Approved by: garga (carte blanche via email)
875 lines
30 KiB
Makefile
875 lines
30 KiB
Makefile
# New ports collection makefile for: qmail
|
|
# Date created: 25 May 1998
|
|
# Whom: Mario S F Ferreira <lioux@linf.unb.br> et al.
|
|
#
|
|
# $FreeBSD$
|
|
#
|
|
|
|
PORTNAME= qmail
|
|
PORTVERSION?= ${QMAIL_VERSION}
|
|
PORTREVISION?= 7
|
|
CATEGORIES= mail
|
|
MASTER_SITES+= ${MASTER_SITE_QMAIL}
|
|
DISTNAME= ${PORTNAME}-${QMAIL_VERSION}
|
|
DISTFILES?= ${DISTNAME}${EXTRACT_SUFX}
|
|
EXTRACT_ONLY?= ${DISTNAME}${EXTRACT_SUFX}
|
|
|
|
MAINTAINER?= garga@FreeBSD.org
|
|
COMMENT?= A secure, reliable, efficient, simple, and fast MTA
|
|
|
|
DIST_SUBDIR= qmail
|
|
|
|
CONFLICTS?= qmail-ldap-[0-9]* qmail-mysql-[0-9]* qmail-spamcontrol-[0-9]* qmail-tls-[0-9]*
|
|
CONFLICTS+= qmail-vida-[0-9]*
|
|
|
|
MAKE_JOBS_UNSAFE= yes
|
|
|
|
PORTSCOUT= skipv:1.04
|
|
|
|
USERS= alias
|
|
.for usersuffix in d l p q r s
|
|
USERS+= ${PORTNAME}${usersuffix}
|
|
.endfor
|
|
GROUPS= ${PORTNAME} qnofiles
|
|
|
|
.if defined(SLAVE_LDAP) || \
|
|
defined(SLAVE_MYSQL)
|
|
BARRIER_MAILDIRQUOTA_PATCH= yes
|
|
BARRIER_SPF_PATCH= yes
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP) || \
|
|
defined(SLAVE_SPAMCONTROL) || \
|
|
defined(SLAVE_MYSQL)
|
|
BARRIER_BLOCKEXEC_PATCH= yes
|
|
BARRIER_QMAILQUEUE_PATCH= yes
|
|
BARRIER_SMTP_AUTH_PATCH= yes
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP)
|
|
BARRIER_BIG_CONCURRENCY_PATCH= yes
|
|
BARRIER_EXTTODO_PATCH= yes
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP) || \
|
|
defined(SLAVE_SPAMCONTROL)
|
|
BARRIER_QMTPC_PATCH= yes
|
|
BARRIER_DISCBOUNCES_PATCH= yes
|
|
BARRIER_SENDMAIL_F_PATCH= yes
|
|
BARRIER_BIG_TODO_PATCH= yes
|
|
BARRIER_DNS_PATCH= yes
|
|
BARRIER_OUTGOINGIP_PATCH= yes
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP) || \
|
|
defined(SLAVE_SPAMCONTROL) || \
|
|
defined(SLAVE_TLS)
|
|
BARRIER_RFC2821_PATCH= yes
|
|
BARRIER_TARPIT_PATCH= yes
|
|
.endif
|
|
|
|
PATCH_DIST_STRIP+= -p1
|
|
|
|
.if !defined(BARRIER_DNS_PATCH)
|
|
# Patch necessary to cope with non-RFC >512 dns entries
|
|
# Since AOL has been using those, the problem has skyrocketed from minor to
|
|
# groundzero. qmail being RFC compliant need to be "fixed" to work with those
|
|
PATCH_SITES+= http://www.ckdhr.com/ckd/:dns
|
|
PATCHFILES+= qmail-103.patch:dns
|
|
.endif
|
|
|
|
.if !defined(BARRIER_SENDMAIL_F_PATCH)
|
|
# David Phillips noticed that sendmail's -f option sets a default
|
|
# From: header, and so should qmail's emulation.
|
|
PATCH_SITES+= http://david.acz.org/software/:sendmail_flagf
|
|
PATCHFILES+= sendmail-flagf.patch:sendmail_flagf
|
|
.endif
|
|
|
|
.if !defined(BARRIER_RFC2821_PATCH)
|
|
# This patch changes qmail-remote to skip over MX servers that greet with
|
|
# codes 400 to 499 and to bounce mail when any MX server that qmail tries
|
|
# greets with a code 500 to 599.
|
|
# Created by Matthias Andree
|
|
PATCH_SITES+= http://www-dt.e-technik.uni-dortmund.de/~ma/qmail/:rfc2821
|
|
PATCHFILES+= patch-qmail-1.03-rfc2821.diff:rfc2821
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP)
|
|
PATCH_SITES+= http://www.nrg4u.com/qmail/:ldap
|
|
PATCHFILES+= qmail-ldap-1.03-${LDAP_PATCH_DATE}.patch.gz:ldap
|
|
.elif defined(SLAVE_MYSQL)
|
|
PATCH_SITES+= http://iain.cx/unix/qmail/download/:mysql
|
|
PATCHFILES+= qmail-mysql-${MYSQL_PATCH_VERSION}.patch:mysql
|
|
.elif defined(SLAVE_TLS)
|
|
PATCH_SITES+= http://inoa.net/qmail-tls/:tls
|
|
PATCHFILES+= qmail-1.03-tls-${TLS_PATCH_DATE}-renato.patch:tls
|
|
.endif
|
|
|
|
PATCH_SITES+= ${MASTER_SITE_LOCAL:S/$/:dns,sendmail_flagf,rfc2821,ldap,mysql,tls,quota,blockexec,doublebounce,spf,localtime,qmtpc_outgoingip/}
|
|
PATCH_SITE_SUBDIR+= garga/qmail/:dns,sendmail_flagf,rfc2821,ldap,mysql,tls,quota,blockexec,doublebounce,spf,localtime,qmtpc_outgoingip
|
|
|
|
PREFIX?= ${QMAIL_PREFIX}
|
|
QMAIL_VERSION?= 1.03
|
|
|
|
.if !defined(BARRIER_SMTP_AUTH_PATCH)
|
|
SMTP_AUTH_VERSION= 0.31
|
|
SMTP_AUTH_DIR= ${WRKDIR}/${PORTNAME}-smtpd-auth-${SMTP_AUTH_VERSION}
|
|
|
|
OPTIONS+= SMTP_AUTH_PATCH "Provide SMTP Authentication" off
|
|
.endif
|
|
.if !defined(BARRIER_QMAILQUEUE_PATCH)
|
|
OPTIONS+= QMAILQUEUE_PATCH "run a QMAILQUEUE program" off
|
|
.endif
|
|
.if !defined(BARRIER_BIG_TODO_PATCH)
|
|
OPTIONS+= BIG_TODO_PATCH "enable big_todo qmail patch" off
|
|
.endif
|
|
.if !defined(BARRIER_BIG_CONCURRENCY_PATCH)
|
|
OPTIONS+= BIG_CONCURRENCY_PATCH "use a concurrency greater than 240" off
|
|
.endif
|
|
.if !defined(BARRIER_OUTGOINGIP_PATCH)
|
|
OPTIONS+= OUTGOINGIP_PATCH "set the IP address to send messages" off
|
|
.endif
|
|
.if !defined(BARRIER_LOCALTIME_PATCH)
|
|
OPTIONS+= LOCALTIME_PATCH "emit dates in the local timezone" off
|
|
.endif
|
|
.if !defined(BARRIER_QMTPC_PATCH)
|
|
OPTIONS+= QMTPC_PATCH "send email using qmtp protocol" off
|
|
.endif
|
|
.if !defined(BARRIER_MAILDIRQUOTA_PATCH)
|
|
OPTIONS+= MAILDIRQUOTA_PATCH "Maildir++ support" off
|
|
.endif
|
|
.if !defined(BARRIER_BLOCKEXEC_PATCH)
|
|
OPTIONS+= BLOCKEXEC_PATCH "block many windows viruses/worms" off
|
|
.endif
|
|
.if !defined(BARRIER_DISCBOUNCES_PATCH)
|
|
OPTIONS+= DISCBOUNCES_PATCH "discard double-bounces" off
|
|
.endif
|
|
.if !defined(BARRIER_SPF_PATCH)
|
|
OPTIONS+= SPF_PATCH "Implement SPF checker" off
|
|
.endif
|
|
.if !defined(BARRIER_TARPIT_PATCH)
|
|
OPTIONS+= TARPIT_PATCH "Implement TARPIT functions" off
|
|
.endif
|
|
.if !defined(BARRIER_EXTTODO_PATCH)
|
|
OPTIONS+= EXTTODO_PATCH "extern high-perform. todo processing" off
|
|
.endif
|
|
|
|
.if defined(SLAVE_TLS)
|
|
OPTIONS+= TLS_DEBUG "enable additional debug information" off
|
|
.elif defined(SLAVE_LDAP)
|
|
OPTIONS+= TLS "SMTP TLS support" on \
|
|
ALTQUEUE "run a QMAILQUEUE external queue" off \
|
|
BIGBROTHER "use the control/bigbrother program" off \
|
|
BIGTODO "use big_todo qmail patch" off \
|
|
BIND_8_COMPAT "Needed if compile fails building dns.c" off \
|
|
CLEARTEXTPASSWD "use cleartext passwords (Dangerous!)" off \
|
|
DASH_EXT "dash_ext extended mail addresses add" on \
|
|
DATA_COMPRESS "smtp on the fly DATA compression" on \
|
|
EXTERNAL_TODO "external high-performance todo processing" on \
|
|
IGNOREVERISIGN "disallow dns wildchar matches on gtlds" off \
|
|
QLDAP_CLUSTER "cluster support" on \
|
|
QMQP_COMPRESS "QMQP on the fly compression" on \
|
|
QUOTATRASH "include the Trash in the quota" off \
|
|
SMTPEXECCHECK "smtp DOS/Windows executable detection" on \
|
|
AUTOMAILDIRMAKE "the auto-maildir-make feature" on \
|
|
AUTOHOMEDIRMAKE "auto-homedir-make feature" on \
|
|
LDAP_DEBUG "possibility to log and debug imap/pop" off \
|
|
SMTPEXTFORK "Allow qmail-smtpd fork external progs" off \
|
|
XF_QUITASAP "Close SMTP session ASAP (SMTPEXTFORK)" off \
|
|
SENDERCHECK4 "LOOSE checks exclusively for RELAY clients" off \
|
|
ENHACELOGS "Enhace qmail-smtpd logs (spamcontrol-like)" off \
|
|
GRTDELAY "Add jms1's Greet Delay feature" off \
|
|
SMTPAUTHUSER "create env SMTPAUTHUSER containing authuser" off\
|
|
SRS "Sender Rewriting Scheme support" off
|
|
|
|
LDAP_PARAMS= ALTQUEUE BIGBROTHER BIGTODO BIND_8_COMPAT\
|
|
CLEARTEXTPASSWD DASH_EXT DATA_COMPRESS\
|
|
EXTERNAL_TODO IGNOREVERISIGN QLDAP_CLUSTER\
|
|
QMQP_COMPRESS QUOTATRASH SMTPEXECCHECK
|
|
|
|
.elif defined(SLAVE_SPAMCONTROL)
|
|
OPTIONS+= TLSREMOTE "TLS support" on \
|
|
MOREIPME "Add control files (more|not)ipme" off \
|
|
BIGTODO "Bruce Guenter's BigToDo patch" off \
|
|
NEWLINE "smtpd accept bare line feeds" off \
|
|
PAM111421 "smtpd allow email in case PAM failure" on \
|
|
SMTPEXTFORK "Allow qmail-smtpd fork external progs" off \
|
|
XF_QUITASAP "Close SMTP session ASAP (SMTPEXTFORK)" off
|
|
.endif
|
|
|
|
OPTIONS+= QEXTRA "enable QUEUE_EXTRA copy feature" off
|
|
|
|
.if !defined(SLAVE_LDAP)
|
|
OPTIONS+= RCDLINK "create rc.d/qmail.sh symlink" on
|
|
.endif
|
|
|
|
ALL_TARGET+= default dot-qmail.5 qmail-control.5 qmail-getpw.8 \
|
|
qmail-limits.7 qmail-newmrh.8 qmail-newu.8 qmail-pw2u.8 \
|
|
qmail-send.8 qmail-start.8 qmail-users.5
|
|
|
|
MAN1+= forward.1 condredirect.1 bouncesaying.1 except.1 maildirmake.1 \
|
|
maildir2mbox.1 maildirwatch.1 mailsubj.1 qreceipt.1 qbiff.1 preline.1 \
|
|
tcp-env.1
|
|
MAN5+= addresses.5 envelopes.5 maildir.5 mbox.5 dot-qmail.5 qmail-control.5 \
|
|
qmail-header.5 qmail-log.5 qmail-users.5 tcp-environ.5
|
|
MAN7+= forgeries.7 qmail-limits.7 qmail.7
|
|
MAN8+= qmail-local.8 qmail-lspawn.8 qmail-getpw.8 qmail-remote.8 \
|
|
qmail-rspawn.8 qmail-clean.8 qmail-send.8 qmail-start.8 splogger.8 \
|
|
qmail-queue.8 qmail-inject.8 qmail-showctl.8 qmail-newmrh.8 \
|
|
qmail-newu.8 qmail-pw2u.8 qmail-qread.8 qmail-qstat.8 qmail-tcpok.8 \
|
|
qmail-tcpto.8 qmail-pop3d.8 qmail-popup.8 qmail-qmqpc.8 qmail-qmqpd.8 \
|
|
qmail-qmtpd.8 qmail-smtpd.8 qmail-command.8
|
|
|
|
.if defined(SLAVE_MYSQL)
|
|
PKGMESSAGE_SUFFIX= mysql
|
|
.endif
|
|
|
|
.if defined(SLAVE_SPAMCONTROL)
|
|
EXTRA_MAN8= qmail-badloadertypes.8 qmail-badmimetypes.8 qmail-mfrules.8 qmail-recipients.8
|
|
ALL_TARGET+= ${EXTRA_MAN8}
|
|
MAN8+= ${EXTRA_MAN8}
|
|
USE_PERL5_BUILD= yes
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP)
|
|
PKGMESSAGE_SUFFIX= ldap
|
|
PLIST_SUB+= LDAP="" NOT_LDAP="@comment "
|
|
.else
|
|
PLIST_SUB+= LDAP="@comment " NOT_LDAP=""
|
|
.endif
|
|
|
|
.if defined(SLAVE_SPAMCONTROL)
|
|
PLIST_SUB+= SPAMCONTROL=""
|
|
.else
|
|
PLIST_SUB+= SPAMCONTROL="@comment "
|
|
.endif
|
|
|
|
.if defined(SLAVE_TLS)
|
|
PKGMESSAGE_SUFFIX= tls
|
|
.endif
|
|
|
|
.if defined(PKGMESSAGE_SUFFIX)
|
|
SLAVEPORT_LINE= ${PKGMESSAGE_SUFFIX}
|
|
.elif defined(SLAVE_SPAMCONTROL)
|
|
SLAVEPORT_LINE= spamcontrol
|
|
.endif
|
|
|
|
SUB_FILES+= mailer.conf.sample bootfiles.sed enable-qmail pkg-install
|
|
SUB_LIST+= ECHO_CMD=${ECHO_CMD} RCDLINK=${RCDLINK}
|
|
|
|
.if defined(PKGMESSAGE_SUFFIX)
|
|
SUB_FILES+= pkg-message-${PKGMESSAGE_SUFFIX}
|
|
PKGMESSAGE?= ${WRKDIR}/pkg-message-${PKGMESSAGE_SUFFIX}
|
|
.else
|
|
SUB_FILES+= pkg-message
|
|
.endif
|
|
|
|
WRKDIR_doc= ${WRKDIR}/doc
|
|
|
|
PORTDOCS= *
|
|
|
|
DOCFILES_WRKSRC+= BLURB BLURB2 BLURB3 BLURB4 INTERNALS SECURITY \
|
|
THOUGHTS FAQ UPGRADE SENDMAIL INSTALL INSTALL.alias \
|
|
INSTALL.ctl INSTALL.ids INSTALL.maildir INSTALL.mbox \
|
|
INSTALL.vsm TEST.deliver TEST.receive REMOVE.sendmail \
|
|
REMOVE.binmail PIC.local2alias PIC.local2ext \
|
|
PIC.local2local PIC.local2rem PIC.local2virt \
|
|
PIC.nullclient PIC.relaybad PIC.relaygood PIC.rem2local
|
|
DOCFILES_WRKDIR+= mailer.conf.sample
|
|
|
|
.if defined(SLAVE_LDAP)
|
|
DOCFILES_WRKSRC+= QLDAPINSTALL QLDAPNEWS POPBEFORESMTP QLDAPTODO \
|
|
QLDAPPICTURE QLDAPGROUP EXTTODO qmail.schema
|
|
.elif defined(SLAVE_TLS)
|
|
DOCFILES_WRKDIR+= TLS.readme
|
|
.elif defined(SLAVE_SPAMCONTROL)
|
|
DOCFILES_WRKDIR_doc+= FILES.spamcontrol HISTORY.spamcontrol \
|
|
INSTALL.spamcontrol LICENSE.spamcontrol \
|
|
LOGGING.spamcontrol PROPOSAL.mav README.bigtodo \
|
|
README.bouncemaxbytes README.clamav README.djbdns \
|
|
README.doublebouncetrim README.mav README.moreipme \
|
|
README.qmailqueue README.recipients \
|
|
README.wildmat README_spamcontrol.html \
|
|
RELEASE_22.spamcontrol RELEASE_23.spamcontrol \
|
|
RELEASE_24.spamcontrol RELEASE_25.spamcontrol \
|
|
RELEASE_26.spamcontrol SMTPREPLY.spamcontrol \
|
|
TODO.spamcontrol badloadertypes badmailfrom \
|
|
badmimetypes badrcptto
|
|
SCRIPTS+= qmail-alias2recipients qmail-pwd2recipients \
|
|
qmail-users2recipients qmail-vpopmail2recipients
|
|
.endif
|
|
|
|
.if !defined(SLAVE_LDAP)
|
|
BOOTFILES= home home+df proc proc+df binm1 binm1+df \
|
|
binm2 binm2+df binm3 binm3+df maildir
|
|
.endif
|
|
|
|
CONFIGUREPROGRAMS= install dnsfq hostname dnsip ipmeprint dnsptr
|
|
CONFIGURESCRIPTS= config config-fast
|
|
|
|
WANT_QMAIL= yes
|
|
|
|
.include <bsd.port.pre.mk>
|
|
|
|
.if ${PREFIX} != ${LOCALBASE}
|
|
DOCSDIR= ${PREFIX}/doc
|
|
.endif
|
|
|
|
NO_MTREE= yes
|
|
|
|
.if ${OSVERSION} >= 900007
|
|
. if defined(SLAVE_LDAP)
|
|
EXTRA_PATCHES+= ${FILESDIR}/extra-patch-utmpx-ldap
|
|
. else
|
|
EXTRA_PATCHES+= ${FILESDIR}/extra-patch-utmpx
|
|
. endif
|
|
.endif
|
|
|
|
.if defined(SLAVE_TLS)
|
|
CFLAGS+= -I${OPENSSLBASE}/include -L${OPENSSLBASE}/lib -DTLS
|
|
. if defined(WITH_TLS_DEBUG)
|
|
CFLAGS+= -DDEBUG
|
|
. endif
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP)
|
|
|
|
. if defined(WITH_TLS)
|
|
# we can't use USE_OPENSSL=yes after including bsd.port.pre.mk
|
|
.include "${PORTSDIR}/Mk/bsd.openssl.mk"
|
|
. endif
|
|
|
|
. for param in ${LDAP_PARAMS}
|
|
. if defined(WITH_${param}) && !defined(WITHOUT_${param})
|
|
LDAPFLAGS+= -D${param}
|
|
. endif
|
|
. endfor
|
|
|
|
. if defined(WITH_EXTERNAL_TODO)
|
|
PLIST_SUB+= EXTERNAL_TODO=""
|
|
. else
|
|
PLIST_SUB+= EXTERNAL_TODO="@comment "
|
|
. endif
|
|
|
|
. if defined(WITH_SRS)
|
|
BUILD_DEPENDS= srs:${PORTSDIR}/mail/libsrs2
|
|
MASTER_SITES+= http://qmail-ldap-smtpauthuser.googlecode.com/svn/trunk/:srs_ldap
|
|
SRS_LDAP_PATCH = qmail-ldap-1.03-20060201-SRS.patch
|
|
DISTFILES+= ${SRS_LDAP_PATCH}:srs_ldap
|
|
. endif
|
|
|
|
.endif
|
|
|
|
.if defined(WITH_SMTP_AUTH_PATCH) && !defined(BARRIER_SMTP_AUTH_PATCH)
|
|
MASTER_SITES+= http://members.elysium.pl/brush/qmail-smtpd-auth/dist/:smtp_auth \
|
|
${MASTER_SITE_LOCAL:S/$/:smtp_auth/}
|
|
MASTER_SITE_SUBDIR+= garga/qmail/:smtp_auth
|
|
DISTFILES+= qmail-smtpd-auth-${SMTP_AUTH_VERSION}.tar.gz:smtp_auth
|
|
EXTRACT_ONLY+= qmail-smtpd-auth-${SMTP_AUTH_VERSION}.tar.gz
|
|
MASTER_SITES+= http://tomclegg.net/qmail/:close3
|
|
DISTFILES+= qmail-smtpd-auth-close3.patch:close3
|
|
. if defined(SLAVE_TLS)
|
|
AUTH_PATCH= auth.patch.diff-tls
|
|
. elif defined(WITH_SPF_PATCH) && !defined(BARRIER_SPF_PATCH)
|
|
AUTH_PATCH= auth.patch.diff
|
|
. endif
|
|
|
|
. if defined(AUTH_PATCH)
|
|
DISTFILES+= ${AUTH_PATCH}:smtp_auth
|
|
. endif
|
|
.endif
|
|
|
|
.if defined(WITH_MAILDIRQUOTA_PATCH) && !defined(BARRIER_MAILDIRQUOTA_PATCH)
|
|
PATCH_SITES+= http://www.alexdupre.com/qmail/:quota
|
|
PATCHFILES+= qmail-maildir++.patch:quota
|
|
.endif
|
|
|
|
.if defined(WITH_BLOCKEXEC_PATCH) && !defined(BARRIER_BLOCKEXEC_PATCH)
|
|
PATCH_SITES+= http://www.alexdupre.com/qmail/:blockexec
|
|
PATCHFILES+= qmail-block-executables.patch:blockexec
|
|
.endif
|
|
|
|
.if defined(WITH_DISCBOUNCES_PATCH) && !defined(BARRIER_DISCBOUNCES_PATCH)
|
|
PATCH_SITES+= http://www.alexdupre.com/qmail/:doublebounce
|
|
PATCHFILES+= qmail-discard-double-bounces.patch:doublebounce
|
|
.endif
|
|
|
|
.if defined(WITH_SPF_PATCH) && !defined(BARRIER_SPF_PATCH)
|
|
. if defined(SLAVE_TLS) || defined(SLAVE_SPAMCONTROL)
|
|
. if defined(SLAVE_SPAMCONTROL)
|
|
SPF_SPAMCONTROL_PATCH= qmail-spf-rc5.patch-spamcontrol-26
|
|
MASTER_SITES+= ${MASTER_SITE_LOCAL:S/$/:spf_spamcontrol/}
|
|
MASTER_SITE_SUBDIR+= garga/qmail/:spf_spamcontrol
|
|
DISTFILES+= ${SPF_SPAMCONTROL_PATCH}:spf_spamcontrol
|
|
. elif defined(WITH_SMTP_AUTH_PATCH)
|
|
SPF_TLS_PATCH= qmail-spf-rc5.patch-auth-tls
|
|
MASTER_SITES+= http://manuel.mausz.at/programming/patches/qmail/:spf_tls
|
|
DISTFILES+= ${SPF_TLS_PATCH}:spf_tls
|
|
. else
|
|
SPF_TLS_PATCH= qmail-spf-rc5.patch-tls
|
|
MASTER_SITES+= http://manuel.mausz.at/programming/patches/qmail/:spf_tls
|
|
DISTFILES+= ${SPF_TLS_PATCH}:spf_tls
|
|
. endif
|
|
. else
|
|
PATCH_SITES+= http://www.saout.de/misc/spf/:spf
|
|
PATCHFILES+= qmail-spf-rc5.patch:spf
|
|
. endif
|
|
.endif
|
|
|
|
.if defined(WITH_EXTTODO_PATCH) && !defined(BARRIER_EXTTODO_PATCH)
|
|
PLIST_SUB+= EXTTODO=""
|
|
DOCFILES_WRKSRC+= EXTTODO
|
|
|
|
. if (defined(WITH_BIG_TODO_PATCH) && !defined(BARRIER_BIG_TODO_PATCH)) || \
|
|
(defined(SLAVE_SPAMCONTROL) && defined(WITH_BIGTODO))
|
|
MASTER_SITES+= ${MASTER_SITE_LOCAL:S/$/:ext_big_todo/}
|
|
MASTER_SITE_SUBDIR+= garga/qmail/:ext_big_todo
|
|
EXT_BIG_TODO_PATCH= ext_todo-20030105+big-todo.103.patch
|
|
DISTFILES+= ${EXT_BIG_TODO_PATCH}:ext_big_todo
|
|
. endif
|
|
|
|
. if defined(WITH_SPF_PATCH) && !defined(BARRIER_SPF_PATCH)
|
|
. if defined(SLAVE_TLS) || defined(SLAVE_SPAMCONTROL)
|
|
MASTER_SITES+= ${MASTER_SITE_LOCAL:S/$/:exttodo/}
|
|
MASTER_SITE_SUBDIR+= garga/qmail/:exttodo
|
|
EXTTODO_PATCH= ext_todo-20030105_spf.patch
|
|
DISTFILES+= ${EXTTODO_PATCH}:exttodo
|
|
. else
|
|
PATCH_SITES+= ${MASTER_SITE_LOCAL:S/$/:exttodo/}
|
|
PATCHFILES+= ext_todo-20030105_spf.patch:exttodo
|
|
PATCH_SITE_SUBDIR+= garga/qmail/:exttodo
|
|
. endif
|
|
. elif defined(SLAVE_MYSQL)
|
|
PATCH_SITES+= ${MASTER_SITE_LOCAL:S/$/:exttodo/}
|
|
PATCHFILES+= ext_todo-20030105_mysql.patch:exttodo
|
|
PATCH_SITE_SUBDIR+= garga/qmail/:exttodo
|
|
. else
|
|
PATCH_SITES+= http://www.nrg4u.com/qmail/:exttodo
|
|
PATCHFILES+= ext_todo-20030105.patch:exttodo
|
|
. endif
|
|
.else
|
|
PLIST_SUB+= EXTTODO="@comment "
|
|
.endif
|
|
|
|
.if !defined(BARRIER_DNS_PATCH) \
|
|
||(defined(WITH_QMAILQUEUE_PATCH) && !defined(BARRIER_QMAILQUEUE_PATCH)) \
|
|
||(defined(WITH_BIG_TODO_PATCH) && !defined(BARRIER_BIG_TODO_PATCH)) \
|
|
||(defined(WITH_BIG_CONCURRENCY_PATCH)&& !defined(BARRIER_BIG_CONCURRENCY_PATCH)) \
|
|
||(defined(WITH_OUTGOINGIP_PATCH) && !defined(BARRIER_OUTGOINGIP_PATCH)) \
|
|
||(defined(WITH_QMTPC_PATCH) && !defined(BARRIER_QMTPC_PATCH))
|
|
PATCH_SITES+= ${MASTER_SITE_QMAIL}
|
|
.endif
|
|
|
|
.if defined(WITH_QMAILQUEUE_PATCH) && !defined(BARRIER_QMAILQUEUE_PATCH)
|
|
PATCHFILES+= qmailqueue-patch
|
|
.endif
|
|
.if defined(WITH_BIG_TODO_PATCH) && !defined(BARRIER_BIG_TODO_PATCH)
|
|
PATCHFILES+= big-todo.103.patch
|
|
.endif
|
|
.if defined(WITH_BIG_CONCURRENCY_PATCH) && !defined(BARRIER_BIG_CONCURRENCY_PATCH)
|
|
PATCHFILES+= big-concurrency.patch
|
|
.endif
|
|
.if defined(WITH_OUTGOINGIP_PATCH) && !defined(BARRIER_OUTGOINGIP_PATCH) && \
|
|
defined(WITH_QMTPC_PATCH) && !defined(BARRIER_QMTPC_PATCH)
|
|
PATCHFILES+= qmail-1.03-qmtpc_outgoingip_20090630.patch:qmtpc_outgoingip
|
|
.elif defined(WITH_OUTGOINGIP_PATCH) && !defined(BARRIER_OUTGOINGIP_PATCH)
|
|
PATCHFILES+= outgoingip.patch
|
|
.elif defined(WITH_QMTPC_PATCH) && !defined(BARRIER_QMTPC_PATCH)
|
|
PATCHFILES+= qmail-1.03-qmtpc.patch
|
|
.endif
|
|
|
|
.if defined(WITH_LOCALTIME_PATCH) && !defined(BARRIER_LOCALTIME_PATCH)
|
|
PATCH_SITES+= http://www.alib.jp/files/:localtime
|
|
PATCHFILES+= qmail-date-localtime.patch:localtime
|
|
.endif
|
|
|
|
.if defined(WITH_TARPIT_PATCH) && !defined(BARRIER_TARPIT_PATCH)
|
|
PATCH_SITES+= http://www.palomine.net/qmail/:tarpit
|
|
PATCHFILES+= tarpit.patch:tarpit
|
|
.endif
|
|
|
|
.if defined(WITH_SMTPEXTFORK) && ( defined(SLAVE_SPAMCONTROL) || defined(SLAVE_LDAP) )
|
|
. if defined(SLAVE_SPAMCONTROL)
|
|
SMTPEXTFORK_PATCH= smtpextfork-spamcontrol-2519.patch
|
|
. else
|
|
SMTPEXTFORK_PATCH= smtpextfork-ldap-${LDAP_PATCH_DATE}_4.patch
|
|
. endif
|
|
|
|
MASTER_SITES+= http://www6.freebsdbrasil.com.br/~eksffa/l/dev/qmail-smtpextfork/patches/:extfork \
|
|
${MASTER_SITE_LOCAL:S/$/:extfork/}
|
|
MASTER_SITE_SUBDIR+= garga/qmail/:extfork
|
|
DISTFILES+= ${SMTPEXTFORK_PATCH:S/$/:extfork/} \
|
|
README.smtpextfork:extfork
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP) && defined(WITH_SENDERCHECK4)
|
|
PATCH_SITES+= http://www6.freebsdbrasil.com.br/~eksffa/l/dev/qmail/:sendercheck4 \
|
|
${MASTER_SITE_LOCAL:S/$/:sendercheck4/}
|
|
PATCH_SITE_SUBDIR+= garga/qmail/:sendercheck4
|
|
PATCHFILES+= qmail-ldap-1.03_qmail-smtpd_SENDERCHECK4.patch:sendercheck4
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP) && defined(WITH_GRTDELAY)
|
|
PATCH_SITES+= http://www6.freebsdbrasil.com.br/~eksffa/l/dev/qmail/:grtdelay \
|
|
${MASTER_SITE_LOCAL:S/$/:grtdelay/}
|
|
PATCH_SITE_SUBDIR+= garga/qmail/:grtdelay
|
|
PATCHFILES+= qmail-ldap-${LDAP_PATCH_DATE}-grtdelay.patch:grtdelay
|
|
DOCFILES_WRKSRC+= README.GREETDELAY
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP) && defined(WITH_ENHACELOGS)
|
|
PATCH_SITES+= http://www6.freebsdbrasil.com.br/~eksffa/l/dev/qmail/:ldapenhacelog \
|
|
${MASTER_SITE_LOCAL:S/$/:ldapenhacelog/}
|
|
PATCH_SITE_SUBDIR+= garga/qmail/:ldapenhacelog
|
|
PATCHFILES+= enhacelogging-ldap-${LDAP_PATCH_DATE}_4.patch:ldapenhacelog
|
|
.endif
|
|
|
|
.if defined(SLAVE_LDAP) && defined(WITH_SMTPAUTHUSER)
|
|
PATCH_SITES+= http://qmail-ldap-smtpauthuser.googlecode.com/svn/trunk/:smtpauthuser \
|
|
${MASTER_SITE_LOCAL:S/$/:smtpauthuser/}
|
|
PATCH_SITE_SUBDIR+= garga/qmail/:smtpauthuser
|
|
. if defined(WITH_ENHACELOGS)
|
|
PATCHFILES+= qmail-1.03-enhaceloggingSMTPAUTHUSER:smtpauthuser
|
|
. else
|
|
PATCHFILES+= SMTPAUTHUSER.patch:smtpauthuser
|
|
. endif
|
|
.endif
|
|
|
|
.if defined(SLAVE_SPAMCONTROL)
|
|
MASTER_SITES+= ${MASTER_SITE_LOCAL:S/$/:ucspi_ssl/} \
|
|
http://www.superscript.com/ucspi-ssl/:ucspi_ssl \
|
|
http://dev.qmailrocks.org/downloads/qmailrocks_3.0-beta/:ucspi_ssl \
|
|
${MASTER_SITE_GENTOO:S/$/:ucspi_ssl/}
|
|
MASTER_SITE_SUBDIR+= garga/ucspi-ssl/:ucspi_ssl
|
|
DISTFILES+= ucspi-ssl-0.70.tar.gz:ucspi_ssl
|
|
|
|
MASTER_SITES+= http://www.fehcom.de/qmail/spamcontrol/:ucspi_ssl_patch
|
|
DISTFILES+= ucspi-ssl-0.70_ucspitls-0.6.patch_:ucspi_ssl_patch
|
|
|
|
UCSPISRC= ${WRKDIR}/host/superscript.com/net/ucspi-ssl-0.70
|
|
.endif
|
|
|
|
# Some default values, these can be modified by make command line
|
|
.if defined(WITH_BIG_CONCURRENCY_PATCH) && !defined(BARRIER_BIG_CONCURRENCY_PATCH)
|
|
WITH_BIG_CONCURRENCY_PATCH_CONCURRENCY_LIMIT?= 509
|
|
.endif
|
|
|
|
.if defined(WITH_RCDLINK) && !defined(SLAVE_LDAP)
|
|
PLIST_SUB+= RCDLINK=""
|
|
RCDLINK=
|
|
.else
|
|
PLIST_SUB+= RCDLINK="@comment "
|
|
RCDLINK= \#
|
|
.endif
|
|
|
|
# Fill SELECTED_OPTIONS with options to write conf-spamcontrol
|
|
.if defined(SLAVE_SPAMCONTROL)
|
|
|
|
. if defined(WITH_TLSREMOTE)
|
|
SELECTED_OPTIONS+= tlsremote=yes
|
|
. else
|
|
SELECTED_OPTIONS+= tlsremote=no
|
|
. endif
|
|
|
|
. if defined(WITH_MOREIPME)
|
|
SELECTED_OPTIONS+= moreipme=yes
|
|
. else
|
|
SELECTED_OPTIONS+= moreipme=no
|
|
. endif
|
|
|
|
. if defined(WITH_BIGTODO)
|
|
SELECTED_OPTIONS+= bigtodo=yes
|
|
. else
|
|
SELECTED_OPTIONS+= bigtodo=no
|
|
. endif
|
|
|
|
. if defined(WITH_NEWLINE)
|
|
SELECTED_OPTIONS+= newline=yes
|
|
. else
|
|
SELECTED_OPTIONS+= newline=no
|
|
. endif
|
|
|
|
. if defined(WITH_PAM111421)
|
|
SELECTED_OPTIONS+= pam111421=yes
|
|
. else
|
|
SELECTED_OPTIONS+= pam111421=no
|
|
. endif
|
|
|
|
.endif
|
|
|
|
pre-everything::
|
|
.if !defined(BARRIER_BIG_CONCURRENCY_PATCH)
|
|
@${ECHO_MSG} ""
|
|
@${ECHO_MSG} "You may use the following build options:"
|
|
@${ECHO_MSG} ""
|
|
@${ECHO_MSG} "WITH_BIG_CONCURRENCY_PATCH_CONCURRENCY_LIMIT=NUMBER"
|
|
@${ECHO_MSG} " (default NUMBER=${WITH_BIG_CONCURRENCY_PATCH_CONCURRENCY_LIMIT})"
|
|
@${ECHO_MSG} " set this to a value reasonable for"
|
|
@${ECHO_MSG} " your system if you use the patch"
|
|
@${ECHO_MSG} ""
|
|
.endif
|
|
|
|
.if !defined(QMAIL_PREFIX)
|
|
@${ECHO_MSG} "QMAIL_PREFIX=PREFIX_PATH"
|
|
@${ECHO_MSG} " (default PREFIX_PATH=${PREFIX})"
|
|
@${ECHO_MSG} " A normal qmail installation puts"
|
|
@${ECHO_MSG} " everything into /var/qmail/."
|
|
@${ECHO_MSG} " If you want to install to ${LOCALBASE},"
|
|
@${ECHO_MSG} " then \"${LOCALBASE}/qmail\" is suggested"
|
|
@${ECHO_MSG} " instead of \"${LOCALBASE}\", but both will"
|
|
@${ECHO_MSG} " work."
|
|
@${ECHO_MSG} ""
|
|
.endif
|
|
|
|
post-extract:
|
|
.if defined(SLAVE_SPAMCONTROL)
|
|
@cd ${WRKSRC} && ${TAR} -xzf ${DISTDIR}/${DIST_SUBDIR}/${SPAMCONTROL_DIST}
|
|
@cd ${WRKDIR} && ${TAR} -xzf ${DISTDIR}/${DIST_SUBDIR}/ucspi-ssl-0.70.tar.gz
|
|
.endif
|
|
|
|
post-patch:
|
|
.if defined(WITH_SMTP_AUTH_PATCH) && !defined(BARRIER_SMTP_AUTH_PATCH)
|
|
@${CP} ${SMTP_AUTH_DIR}/base64.[ch] ${WRKSRC}
|
|
. if defined(AUTH_PATCH)
|
|
@${PATCH} -d ${SMTP_AUTH_DIR} < ${DISTDIR}/${DIST_SUBDIR}/${AUTH_PATCH}
|
|
. endif
|
|
@${PATCH} -d ${WRKSRC} < ${SMTP_AUTH_DIR}/auth.patch
|
|
. if defined(SLAVE_TLS) && defined(WITH_SPF_PATCH) && defined(SPF_TLS_PATCH)
|
|
@${PATCH} -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${SPF_TLS_PATCH}
|
|
. if defined(WITH_EXTTODO_PATCH) && defined(EXTTODO_PATCH)
|
|
@${PATCH} -p1 -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${EXTTODO_PATCH}
|
|
. endif
|
|
. endif
|
|
@${PATCH} -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/qmail-smtpd-auth-close3.patch
|
|
.elif defined(SLAVE_TLS) && defined(WITH_SPF_PATCH) && defined(SPF_TLS_PATCH)
|
|
@${PATCH} -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${SPF_TLS_PATCH}
|
|
. if defined(WITH_EXTTODO_PATCH) && defined(EXTTODO_PATCH)
|
|
@${PATCH} -p1 -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${EXTTODO_PATCH}
|
|
. endif
|
|
.endif
|
|
.if defined(SLAVE_MYSQL)
|
|
@${REINPLACE_CMD} 's|/opt/mysql|${LOCALBASE}|' \
|
|
${WRKSRC}/Makefile
|
|
.elif defined(SLAVE_SPAMCONTROL)
|
|
@${ECHO_CMD} ${WRKDIR} > ${WRKSRC}/conf-qmail
|
|
@${ECHO_CMD} "# Generated by qmail-spamcontrol FreeBSD port" \
|
|
> ${WRKSRC}/conf-spamcontrol
|
|
. for option in ${SELECTED_OPTIONS}
|
|
@${ECHO_CMD} ${option} >> ${WRKSRC}/conf-spamcontrol
|
|
. endfor
|
|
@cd ${UCSPISRC}/src && patch -p0 < ${DISTDIR}/${DIST_SUBDIR}/ucspi-ssl-0.70_ucspitls-0.6.patch_
|
|
@${ECHO_CMD} "${UCSPISRC}/compile" > ${WRKSRC}/conf-ucspissl
|
|
${ECHO_CMD} "${CC} ${CFLAGS}" > ${UCSPISRC}/src/conf-cc
|
|
${ECHO_CMD} "${PREFIX}" > ${UCSPISRC}/src/conf-home
|
|
${ECHO_CMD} "${PREFIX}/bin" > ${UCSPISRC}/src/conf-tcpbin
|
|
${ECHO_CMD} "/etc/ssl" > ${UCSPISRC}/src/conf-cadir
|
|
${ECHO_CMD} "/etc/ssl/cert.pem" > ${UCSPISRC}/src/conf-cafile
|
|
${ECHO_CMD} "/etc/ssl/dh1024.pem" > ${UCSPISRC}/src/conf-dhfile
|
|
@cd ${UCSPISRC} && package/compile
|
|
@cd ${WRKSRC} && ./install_spamcontrol.sh
|
|
@${PATCH} -d ${WRKSRC} < ${FILESDIR}/extra-patch-spamcontrol-qmail-smtpd.c
|
|
@${PATCH} -d ${WRKSRC} < ${FILESDIR}/extra-patch-spamcontrol-qmail-remote.c
|
|
. if defined(WITH_SPF_PATCH) && defined(SPF_SPAMCONTROL_PATCH)
|
|
@${PATCH} -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${SPF_SPAMCONTROL_PATCH}
|
|
. if defined(WITH_EXTTODO_PATCH) && defined(EXTTODO_PATCH)
|
|
@${PATCH} -p1 -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${EXTTODO_PATCH}
|
|
. endif
|
|
. endif
|
|
. if defined(WITH_SMTPEXTFORK)
|
|
@${PATCH} -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${SMTPEXTFORK_PATCH}
|
|
. if defined(WITH_XF_QUITASAP)
|
|
@${REINPLACE_CMD} 's!//#define XF_QUITASAP!#define XF_QUITASAP!g' \
|
|
${WRKSRC}/qmail-smtpd.c
|
|
. endif
|
|
. endif
|
|
@${REINPLACE_CMD} -E "/qhpsi *= *\"unknown\"/d; s/(\*qqx *== *'D')/qhpsi \&\& \1/g" \
|
|
${WRKSRC}/qmail-smtpd.c
|
|
.elif defined(SLAVE_TLS)
|
|
@${HEAD} -105 ${DISTDIR}/${DIST_SUBDIR}/qmail-1.03-tls-${TLS_PATCH_DATE}-renato.patch > \
|
|
${WRKDIR}/TLS.readme
|
|
@${REINPLACE_CMD} "s|/usr/local/ssl|${OPENSSLBASE}|" \
|
|
${WRKSRC}/Makefile
|
|
@${REINPLACE_CMD} -E 's!("control/tlsserverciphers")!\1, 0!' \
|
|
${WRKSRC}/qmail-smtpd.c
|
|
.elif defined(SLAVE_LDAP)
|
|
@${REINPLACE_CMD} "s|^LDAPLIBS=-L/usr/local/lib|LDAPLIBS=-L${LOCALBASE}/lib|; \
|
|
s|^LDAPINCLUDES=-I/usr/local/include|LDAPINCLUDES=-I${LOCALBASE}/include|" \
|
|
${WRKSRC}/Makefile
|
|
@${REINPLACE_CMD} "s|^#SHADOWLIBS=-lcrypt$$|SHADOWLIBS=-lcrypt|" \
|
|
${WRKSRC}/Makefile
|
|
. if defined(WITH_SMTPEXTFORK)
|
|
@${PATCH} -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${SMTPEXTFORK_PATCH}
|
|
. if defined(WITH_XF_QUITASAP)
|
|
@${REINPLACE_CMD} 's!//#define XF_QUITASAP!#define XF_QUITASAP!g' \
|
|
${WRKSRC}/qmail-smtpd.c
|
|
. endif
|
|
. endif
|
|
. if defined(WITH_TLS)
|
|
@${REINPLACE_CMD} "s|^#TLS=|TLS=|; \
|
|
s|^#TLSINCLUDES=-I/usr/local/include|TLSINCLUDES=-I${OPENSSLBASE}/include|; \
|
|
s|^#TLSLIBS=-L/usr/local/lib|TLSLIBS=-L${OPENSSLBASE}/lib|; \
|
|
s|^#OPENSSLBIN=/usr/local/bin/openssl|OPENSSLBIN=${OPENSSLBASE}/bin/openssl|" \
|
|
${WRKSRC}/Makefile
|
|
. endif
|
|
. if defined(WITH_DATA_COMPRESS) || defined(WITH_QMQP_COMPRESS)
|
|
@${REINPLACE_CMD} "s|^#ZLIB=-lz$$|ZLIB=-lz|" \
|
|
${WRKSRC}/Makefile
|
|
. endif
|
|
. if defined(WITH_AUTOMAILDIRMAKE)
|
|
@${REINPLACE_CMD} "s|^#MDIRMAKE=|MDIRMAKE=|" ${WRKSRC}/Makefile
|
|
. endif
|
|
. if defined(WITH_AUTOHOMEDIRMAKE)
|
|
@${REINPLACE_CMD} "s|^#HDIRMAKE=|HDIRMAKE=|" ${WRKSRC}/Makefile
|
|
. endif
|
|
. if defined(WITH_LDAP_DEBUG)
|
|
@${REINPLACE_CMD} "s|^#DEBUG=|DEBUG=|" ${WRKSRC}/Makefile
|
|
. endif
|
|
. if defined(LDAPFLAGS)
|
|
@${REINPLACE_CMD} "s|^#LDAPFLAGS=.*$$|LDAPFLAGS=${LDAPFLAGS}|" \
|
|
${WRKSRC}/Makefile
|
|
. endif
|
|
. if defined(WITH_SRS)
|
|
@${PATCH} -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${SRS_LDAP_PATCH}
|
|
. endif
|
|
.endif
|
|
.if defined(EXT_BIG_TODO_PATCH)
|
|
@${PATCH} -d ${WRKSRC} < ${DISTDIR}/${DIST_SUBDIR}/${EXT_BIG_TODO_PATCH}
|
|
.endif
|
|
@${REINPLACE_CMD} 's!/var/qmail!${PREFIX}!; \
|
|
s!/usr/local/!${LOCALBASE}/!' \
|
|
${WRKSRC}/Makefile
|
|
@${REINPLACE_CMD} 's!nofiles!qnofiles!g' \
|
|
${WRKSRC}/conf-groups
|
|
@${REINPLACE_CMD} '/"man"/d; /man\/man/d; /man\/cat/d; \
|
|
/"doc"/d; /"boot","/d' \
|
|
${WRKSRC}/hier.c
|
|
.if defined(WITH_QEXTRA)
|
|
@${REINPLACE_CMD} 's!QUEUE_EXTRA ""!QUEUE_EXTRA "Tlog\\0"!g; \
|
|
s!QUEUE_EXTRALEN 0!QUEUE_EXTRALEN 5!g' \
|
|
${WRKSRC}/extra.h
|
|
.endif
|
|
.if ( ${ARCH} == "amd64" || ${ARCH} == "ia64" ) && !defined(SLAVE_LDAP)
|
|
@${PATCH} -d ${WRKSRC} < ${FILESDIR}/extra-patch-amd64
|
|
.endif
|
|
@${REINPLACE_CMD} -e "s/void *main/int main/g" ${WRKSRC}/*.c
|
|
@${REINPLACE_CMD} -e "/int main/ s/argc, *argv/int argc, char **argv/" ${WRKSRC}/install.c
|
|
|
|
do-configure:
|
|
@${ECHO_CMD} "${CC} ${CFLAGS}" > ${WRKSRC}/conf-cc
|
|
@${ECHO_CMD} ${PREFIX} > ${WRKSRC}/conf-qmail
|
|
.if defined(WITH_BIG_CONCURRENCY_PATCH) \
|
|
&& !defined(BARRIER_BIG_CONCURRENCY_PATCH) \
|
|
&& defined(WITH_BIG_CONCURRENCY_PATCH_CONCURRENCY_LIMIT)
|
|
@if [ ${WITH_BIG_CONCURRENCY_PATCH_CONCURRENCY_LIMIT} -gt 0 ]; then \
|
|
${ECHO_CMD} "${WITH_BIG_CONCURRENCY_PATCH_CONCURRENCY_LIMIT}" \
|
|
> ${WRKSRC}/conf-spawn ; \
|
|
fi
|
|
.endif
|
|
|
|
do-install:
|
|
.for i in ${BOOTFILES}
|
|
@if [ -f ${WRKSRC}/${i}.sh ] ; then \
|
|
${SED} -f ${WRKDIR}/bootfiles.sed ${WRKSRC}/$i.sh > ${WRKDIR}/${i} ; \
|
|
elif [ -f ${FILESDIR}/${i} ] ; then \
|
|
${SED} -f ${WRKDIR}/bootfiles.sed ${FILESDIR}/$i > ${WRKDIR}/${i} ; \
|
|
fi
|
|
.endfor
|
|
@${MKDIR} ${PREFIX}/configure
|
|
@cd ${WRKSRC} ; ./install
|
|
.for f in ${CONFIGUREPROGRAMS}
|
|
${INSTALL_PROGRAM} ${WRKSRC}/${f} ${PREFIX}/configure
|
|
.endfor
|
|
.for f in ${CONFIGURESCRIPTS}
|
|
${INSTALL_SCRIPT} ${WRKSRC}/${f} ${PREFIX}/configure
|
|
.endfor
|
|
.for i in ${BOOTFILES}
|
|
${INSTALL_SCRIPT} ${WRKDIR}/${i:T} ${PREFIX}/boot
|
|
.endfor
|
|
.if !defined(SLAVE_LDAP)
|
|
${INSTALL_SCRIPT} ${FILESDIR}/qmail-smtpd.rcNG ${PREFIX}/boot
|
|
.endif
|
|
.for i in 1 5 7 8
|
|
@${MKDIR} ${PREFIX}/man/man$i
|
|
. for j in ${MAN${i}}
|
|
${INSTALL_MAN} ${WRKSRC}/$j ${PREFIX}/man/man${i}
|
|
. endfor
|
|
.endfor
|
|
.if !defined(NOPORTDOCS)
|
|
@${MKDIR} ${DOCSDIR}
|
|
. for sub in WRKSRC WRKDIR WRKDIR_doc
|
|
. for doc in ${DOCFILES_${sub}}
|
|
${INSTALL_DATA} ${${sub}}/${doc} ${DOCSDIR}
|
|
. endfor
|
|
. endfor
|
|
. if defined(WITH_SMTPEXTFORK) && ( defined(SLAVE_SPAMCONTROL) || defined(SLAVE_LDAP) )
|
|
${INSTALL_DATA} ${DISTDIR}/${DIST_SUBDIR}/README.smtpextfork ${DOCSDIR}
|
|
. endif
|
|
. if defined(PACKAGE_BUILDING)
|
|
@${ECHO_CMD} "FreeBSD Binary package qmail installation" \
|
|
> ${DOCSDIR}/SYSDEPS
|
|
. else
|
|
@cd ${WRKSRC} && ${CAT} `${CAT} SYSDEPS` \
|
|
> ${DOCSDIR}/SYSDEPS
|
|
. endif
|
|
.endif
|
|
@${MKDIR} ${PREFIX}/scripts
|
|
${INSTALL_SCRIPT} ${FILESDIR}/mkaliasdir ${PREFIX}/scripts
|
|
${INSTALL_SCRIPT} ${WRKDIR}/enable-qmail ${PREFIX}/scripts
|
|
.for script in ${SCRIPTS}
|
|
${INSTALL_SCRIPT} ${WRKDIR}/scripts/${script} ${PREFIX}/scripts
|
|
.endfor
|
|
@${SETENV} PKG_PREFIX="${PREFIX}" ${SH} ${PKGINSTALL} ${PKGNAME} POST-INSTALL
|
|
@${ECHO_CMD}
|
|
@${CAT} ${PKGMESSAGE}
|
|
@${ECHO_CMD}
|
|
.if defined(SLAVEPORT_LINE)
|
|
@${ECHO_CMD} "============================================="
|
|
@${ECHO_CMD}
|
|
@${ECHO_CMD} "ATTENTION"
|
|
@${ECHO_CMD}
|
|
@${ECHO_CMD} "Add the following line to your /etc/make.conf"
|
|
@${ECHO_CMD} "QMAIL_SLAVEPORT=${SLAVEPORT_LINE}"
|
|
@${ECHO_CMD}
|
|
@${ECHO_CMD} "============================================="
|
|
@${ECHO_CMD}
|
|
.endif
|
|
|
|
certificate:
|
|
.if defined(SLAVE_TLS) || defined(SLAVE_LDAP)
|
|
@if [ -f ${OPENSSLDIR}/openssl.cnf ]; then \
|
|
if [ ! -d ${WRKDIR} ]; then \
|
|
${MKDIR} ${WRKDIR} ; \
|
|
fi ; \
|
|
${OPENSSLBASE}/bin/openssl req -new -x509 -nodes \
|
|
-out ${WRKDIR}/servercert.pem -days 366 \
|
|
-keyout ${WRKDIR}/servercert.pem ; \
|
|
${INSTALL} -o qmaild -g qmail -m 0640 ${WRKDIR}/servercert.pem ${PREFIX}/control/servercert.pem ; \
|
|
${OPENSSLBASE}/bin/openssl ciphers > ${QMAIL_PREFIX}/control/tlsclientciphers ; \
|
|
${OPENSSLBASE}/bin/openssl ciphers > ${QMAIL_PREFIX}/control/tlsserverciphers ; \
|
|
${ECHO_MSG} "===> Do not forget to do 'make clean' to clean up temporary files" ; \
|
|
else \
|
|
${ECHO_MSG} "===> You must create the file ${OPENSSLDIR}/openssl.cnf first." ; \
|
|
fi
|
|
.endif
|
|
|
|
certificate-req:
|
|
.if defined(SLAVE_TLS) || defined(SLAVE_LDAP)
|
|
@if [ -f ${OPENSSLDIR}/openssl.cnf ]; then \
|
|
if [ ! -d ${WRKDIR} ]; then \
|
|
${MKDIR} ${WRKDIR} ; \
|
|
fi ; \
|
|
${OPENSSLBASE}/bin/openssl req -new -nodes \
|
|
-out ${WRKDIR}/req.pem \
|
|
-keyout ${WRKDIR}/servercert.pem ; \
|
|
${INSTALL} -o qmaild -g qmail -m 0640 ${WRKDIR}/servercert.pem ${PREFIX}/control/servercert.pem ; \
|
|
${ECHO_MSG} ; \
|
|
${ECHO_MSG} "===> Do not forget to do 'make clean' to clean up temporary files" ; \
|
|
${ECHO_MSG} "===> Send ${WRKDIR}/req.pem to your CA to obtain signed_req.pem, and do:" ; \
|
|
${ECHO_MSG} "===> cat signed_req.pem >> ${PREFIX}/control/servercert.pem" ; \
|
|
else \
|
|
${ECHO_MSG} "===> You must create the file ${OPENSSLDIR}/openssl.cnf first." ; \
|
|
fi
|
|
.endif
|
|
|
|
.include <bsd.port.post.mk>
|