mirror of
https://git.FreeBSD.org/ports.git
synced 2025-01-02 06:03:50 +00:00
b50a4b0708
- Mk/bsd.database.mk rewrite, new default to db5. - db6 is eligible by default only if installed on the system. - Bump PORTREVISION of all ports that directly depend on BerkeleyDB or where USE_BDB is found in the port's directory - Patch a few ports such that they will pick up or work with newer versions. - Add UPDATING entry - Drive-by format fix for pks - Drop BerkeleyDB option from mail/popular for now, requires more work. - Exp-run logs linked from the PR below. - Ports that do not build (IGNORE, BROKEN, etc.) have pro-forma changes for new Berkeley DB, but are untested. NOTE: please read UPDATING and the Wiki page before proceeding! Announcement: http://lists.freebsd.org/pipermail/freebsd-ports-announce/2014-August/000090.html Wiki reference: https://wiki.freebsd.org/Ports/BerkeleyDBCleanup PR: 192690 Approved by: portmgr (implicit, PORTREVISION bump on unstaged ports)
174 lines
5.3 KiB
Makefile
174 lines
5.3 KiB
Makefile
# $FreeBSD$
|
|
|
|
PORTNAME= meta1
|
|
PORTVERSION= 1.0.0b.0.0
|
|
PORTREVISION= 1
|
|
DISTVERSION= 1.0.Beta0.0
|
|
CATEGORIES= mail ipv6
|
|
MASTER_SITES= http://www.MeTA1.org/download/.beta/proto/
|
|
PKGNAMESUFFIX?= ${TLS_SUFFIX}${SASL_SUFFIX}${BERKELEYDB_SUFFIX}${PMILTER_SUFFIX}${PKGNAMESUFFIX2}
|
|
|
|
MAINTAINER= dinoex@FreeBSD.org
|
|
COMMENT= Secure and efficient mail gateway
|
|
|
|
NOT_FOR_ARCHS= ia64
|
|
MAKE_JOBS_UNSAFE= yes
|
|
CONFLICTS= smx-*
|
|
NEED_ROOT= yes
|
|
|
|
.if !defined(SENDMAIL_WITHOUT_SHMEM) && !defined(BUILDING_INDEX)
|
|
IPCCHECK!= ipcrm -q 0 2>&1 || true
|
|
.if ${IPCCHECK:Mimplemented}
|
|
IGNORE= your system does not support sysvipc
|
|
.endif
|
|
.endif
|
|
|
|
MANUAL_PACKAGE_BUILD= needs hostname
|
|
|
|
WRKSRC= ${WRKDIR}/${PORTNAME}-${DISTVERSION}
|
|
GNU_CONFIGURE= yes
|
|
CONFIGURE_ARGS+= --disable-dependency-tracking
|
|
MAKE_ENV+= META1CONFDIR="${META1CONFDIR}"
|
|
PORTDOCS= README.dvi README.html README.pdf README.ps README.txt \
|
|
img1.png img2.png img3.png img4.png img5.png img6.png \
|
|
nx_grp_g.png overview1.eps overview1.gif overview1.pdf \
|
|
prev_g.png up_g.png pmilter.api.tex
|
|
PLIST_SUB+= NOLOGIN=${NOLOGIN_CMD}
|
|
EXTRA_SBIN= libcheck/noroot libconf/tree libmta/statit \
|
|
libmta/t-hostname checks/t-getgroup
|
|
# GROUPS/USERS does not work from package
|
|
#GROUPS= meta1s meta1q meta1c meta1m meta1
|
|
#USERS= meta1s meta1q meta1c meta1m meta1
|
|
|
|
# default config:
|
|
META1CONFDIR?= ${PREFIX}/etc/meta1
|
|
NOLOGIN_CMD?= /usr/sbin/nologin
|
|
|
|
OPTIONS_DEFINE= BDB PMILTER DKIM MSP SASL2 SASL2AUTHD TLS DOCS
|
|
OPTIONS_DEFAULT= BDB PMILTER DKIM SASL2 TLS
|
|
NO_OPTIONS_SORT=yes
|
|
OPTIONS_SUB= yes
|
|
|
|
BDB_DESC= External Berkeley DB support
|
|
PMILTER_DESC= Adds policy milter support
|
|
DKIM_DESC= Enable DKIM signing support
|
|
MSP_DESC= Enable mail submision program
|
|
SASL2_DESC= Adds SASL2 support
|
|
SASL2AUTHD_DESC= Enable plaintext authentication via SASL2
|
|
|
|
PMILTER_CONFIGURE_ENABLE= pmilter
|
|
DKIM_CONFIGURE_ENABLE= DKIM
|
|
MSP_CONFIGURE_ENABLE= msp
|
|
SASL2_LIB_DEPENDS= libsasl2.so:${PORTSDIR}/security/cyrus-sasl2
|
|
SASL2_CONFIGURE_ENABLE= SASL
|
|
SASL2_CONFIGURE_ON= --with-sasl-incdir=${LOCALBASE}/include \
|
|
--with-sasl-libdir=${LOCALBASE}/lib
|
|
SASL2AUTHD_RUN_DEPENDS= ${LOCALBASE}/sbin/saslauthd:${PORTSDIR}/security/cyrus-sasl2-saslauthd
|
|
TLS_CONFIGURE_ENABLE= TLS
|
|
|
|
.include <bsd.port.options.mk>
|
|
|
|
.if ${PORT_OPTIONS:MBDB}
|
|
USE_BDB= 42+
|
|
INVALID_BDB_VER= 46 47 48 5
|
|
BERKELEYDB_SUFFIX= -db${BDB_VER}
|
|
CONFIGURE_ARGS+= --disable-included-bdb
|
|
CONFIGURE_ARGS+= --with-bdb-incdir=${BDB_INCLUDE_DIR}
|
|
CONFIGURE_ARGS+= --with-bdb-libdir=${BDB_LIB_DIR}
|
|
PLIST_SUB+= WITH_BDBINT="@comment "
|
|
.else
|
|
BERKELEYDB_SUFFIX= -intbdb
|
|
PLIST_SUB+= WITH_BDBINT=""
|
|
.endif
|
|
|
|
.if ${PORT_OPTIONS:MPMILTER}
|
|
USE_OPENSSL= yes
|
|
.else
|
|
PMILTER_SUFFIX?= -nopmilter
|
|
.endif
|
|
|
|
.if ${PORT_OPTIONS:MMSP}
|
|
CONFLICTS+= courier-0.* postfix-1.* postfix-2.* smail-3.* zmailer-2.* opensmtpd-* sendmail-*
|
|
.endif
|
|
|
|
.if ! ${PORT_OPTIONS:MSASL2}
|
|
SASL_SUFFIX?= -nosasl
|
|
.endif
|
|
|
|
.if ${PORT_OPTIONS:MSASL2AUTHD}
|
|
.if empty(PORT_OPTIONS:MSASL2)
|
|
IGNORE= Option SASL2AUTHD needs option SASL2
|
|
.endif
|
|
.endif
|
|
|
|
.if ! ${PORT_OPTIONS:MTLS}
|
|
TLS_SUFFIX?= -notls
|
|
.endif
|
|
|
|
post-patch:
|
|
${REINPLACE_CMD} -e 's|echo aout|echo elf|' \
|
|
${WRKSRC}/db-4.3.28.NC/dist/configure
|
|
|
|
post-configure:
|
|
@${CP} ${WRKSRC}/misc/sm.check.sh ${WRKSRC}/misc/sm.setup.sh \
|
|
${WRKDIR}/
|
|
@${REINPLACE_CMD} -e 's|/etc/meta1|${META1CONFDIR}|g' \
|
|
-e 's|$${SD}/misc|${PREFIX}/bin|' \
|
|
-e 's|$${SD}/libcheck|${PREFIX}/sbin|' \
|
|
-e 's|$${SD}/libmta|${PREFIX}/sbin|' \
|
|
-e 's|$${SD}/checks|${PREFIX}/sbin|' \
|
|
${WRKDIR}/sm.check.sh
|
|
@${REINPLACE_CMD} -e 's|/etc/meta1|${META1CONFDIR}|g' \
|
|
-e 's|[.]/misc|${PREFIX}/bin|' \
|
|
-e 's|$${S}/libconf|${PREFIX}/sbin|' \
|
|
-e 's|[.]/libmta|${PREFIX}/sbin|' \
|
|
-e 's|[.]/checks|${PREFIX}/sbin|' \
|
|
-e 's|=mcp.sh|=${PREFIX}/etc/rc.d/meta1-mcp.sh|' \
|
|
${WRKDIR}/sm.setup.sh
|
|
|
|
test:
|
|
(cd ${WRKSRC} && ${SETENV} ${MAKE_ENV} \
|
|
${MAKE} ${MAKE_FLAGS} ${MAKEFILE} ${MAKE_ARGS} check)
|
|
|
|
#fails on bento
|
|
#regression-test: test
|
|
|
|
.if !defined(UID)
|
|
UID!= ${ID} -u
|
|
.endif
|
|
.if ${UID} != 0
|
|
post-build: test
|
|
.endif
|
|
|
|
pre-install:
|
|
if ! pw groupshow meta1s; then pw groupadd meta1s -g 260; fi
|
|
if ! pw groupshow meta1q; then pw groupadd meta1q -g 261; fi
|
|
if ! pw groupshow meta1c; then pw groupadd meta1c -g 262; fi
|
|
if ! pw groupshow meta1m; then pw groupadd meta1m -g 263; fi
|
|
if ! pw groupshow meta1; then pw groupadd meta1 -g 264; fi
|
|
if ! pw usershow meta1s; then pw useradd meta1s -g meta1s -u 260 \
|
|
-h - -d ${NONEXISTENT} -s ${NOLOGIN_CMD} -c "MeTA1 SMTPS"; fi
|
|
if ! pw usershow meta1q; then pw useradd meta1q -g meta1q -u 261 \
|
|
-h - -d ${NONEXISTENT} -s ${NOLOGIN_CMD} -c "MeTA1 QMGR"; fi
|
|
if ! pw usershow meta1c; then pw useradd meta1c -g meta1c -u 262 \
|
|
-h - -d ${NONEXISTENT} -s ${NOLOGIN_CMD} -c "MeTA1 SMTPC"; fi
|
|
if ! pw usershow meta1m; then pw useradd meta1m -g meta1m -u 263 \
|
|
-h - -d ${NONEXISTENT} -s ${NOLOGIN_CMD} -c "MeTA1 misc"; fi
|
|
if ! pw usershow meta1; then pw useradd meta1 -g meta1 -u 264 \
|
|
-h - -d ${NONEXISTENT} -s ${NOLOGIN_CMD} -c "MeTA1 other"; fi
|
|
pw groupmod meta1c -m meta1s
|
|
pw groupmod meta1m -m meta1s,meta1q
|
|
|
|
post-install:
|
|
${INSTALL_SCRIPT} ${WRKDIR}/sm.check.sh ${STAGEDIR}${PREFIX}/sbin/
|
|
${INSTALL_SCRIPT} ${WRKDIR}/sm.setup.sh ${STAGEDIR}${PREFIX}/sbin/
|
|
.for i in ${EXTRA_SBIN}
|
|
${INSTALL_PROGRAM} ${WRKSRC}/${i} ${STAGEDIR}${PREFIX}/sbin/
|
|
.endfor
|
|
.if ${PORT_OPTIONS:MDOCS}
|
|
${MKDIR} ${STAGEDIR}${DOCSDIR}
|
|
cd ${WRKSRC}/doc && ${INSTALL_DATA} ${PORTDOCS} ${STAGEDIR}${DOCSDIR}/
|
|
.endif
|
|
|
|
.include <bsd.port.mk>
|