From owner-freebsd-ports-bugs@FreeBSD.ORG Fri May 13 19:10:06 2005 Return-Path: Delivered-To: freebsd-ports-bugs@hub.freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 485CE16A4CE for ; Fri, 13 May 2005 19:10:06 +0000 (GMT) Received: from freefall.freebsd.org (freefall.freebsd.org [216.136.204.21]) by mx1.FreeBSD.org (Postfix) with ESMTP id 1864943D6D for ; Fri, 13 May 2005 19:10:06 +0000 (GMT) (envelope-from gnats@FreeBSD.org) Received: from freefall.freebsd.org (gnats@localhost [127.0.0.1]) by freefall.freebsd.org (8.13.3/8.13.3) with ESMTP id j4DJA5La055694 for ; Fri, 13 May 2005 19:10:05 GMT (envelope-from gnats@freefall.freebsd.org) Received: (from gnats@localhost) by freefall.freebsd.org (8.13.3/8.13.1/Submit) id j4DJA56x055693; Fri, 13 May 2005 19:10:05 GMT (envelope-from gnats) Date: Fri, 13 May 2005 19:10:05 GMT Message-Id: <200505131910.j4DJA56x055693@freefall.freebsd.org> To: freebsd-ports-bugs@FreeBSD.org From: Renato Botelho Subject: Re: ports/80911: [MAINTAINER] mail/qmail: Rewrite pkg-install X-BeenThere: freebsd-ports-bugs@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list Reply-To: Renato Botelho List-Id: Ports bug reports List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 13 May 2005 19:10:06 -0000 The following reply was made to PR ports/80911; it has been noted by GNATS. From: Renato Botelho To: bug-followup@FreeBSD.org, freebsd@galle.com.br Cc: Subject: Re: ports/80911: [MAINTAINER] mail/qmail: Rewrite pkg-install Date: Fri, 13 May 2005 15:59:47 -0300 Dear commiter, Here is a new patch, it adds CONFLICTS var for all slave-ports, I didn't generate it using cvs because we are having some problems with internet here and I can't access anoncvs server. --- qmail.diff starts here --- diff -ruN --exclude=CVS /usr/ports/mail/qmail/Makefile /usr/home/renato/ports/mail/qmail/Makefile --- /usr/ports/mail/qmail/Makefile Wed May 11 11:32:04 2005 +++ /usr/home/renato/ports/mail/qmail/Makefile Fri May 13 15:06:44 2005 @@ -17,6 +17,34 @@ DIST_SUBDIR= qmail +.if defined(SLAVE_LDAP) || \ + defined(SLAVE_MYSQL) || \ + defined(SLAVE_SMTP_AUTH_TLS) || \ + defined(SLAVE_SPAMCONTROL) || \ + defined(SLAVE_TLS) +CONFLICTS+= qmail-[0-9]* +.endif + +.if !defined(SLAVE_LDAP) +CONFLICTS+= qmail-ldap2*-[0-9]* +.endif + +.if !defined(SLAVE_MYSQL) +CONFLICTS+= qmail-mysql-[0-9]* +.endif + +.if !defined(SLAVE_SMTP_AUTH_TLS) +CONFLICTS+= qmail-smtp_auth+tls-[0-9]* +.endif + +.if !defined(SLAVE_SPAMCONTROL) +CONFLICTS+= qmail-spamcontrol-[0-9]* +.endif + +.if !defined(SLAVE_TLS) +CONFLICTS+= qmail-tls-[0-9]* +.endif + .if defined(SLAVE_LDAP) || defined(SLAVE_SPAMCONTROL) BARRIER_DNS_PATCH=yes BARRIER_BIG_CONCURRENCY_PATCH=yes @@ -197,8 +225,11 @@ SUB_FILES+= pkg-message${PKGMESSAGE_SUFFIX} mailer.conf.sample \ bootfiles.sed enable-qmail +PKGINSTALL?= ${WRKDIR}/pkg-install PKGMESSAGE?= ${WRKDIR}/pkg-message${PKGMESSAGE_SUFFIX} +CSH?= /bin/csh + DOCFILES+= ${WRKSRC}/BLURB ${WRKSRC}/BLURB2 ${WRKSRC}/BLURB3 \ ${WRKSRC}/BLURB4 ${WRKSRC}/INTERNALS ${WRKSRC}/SECURITY \ ${WRKSRC}/THOUGHTS ${FILESDIR}/PORT_NOTES \ @@ -304,8 +335,10 @@ .if defined(WITH_RCDLINK) PLIST_SUB+= RCDLINK="" +RCDLINK= .else PLIST_SUB+= RCDLINK="@comment " +RCDLINK= \# .endif # Fill SELECTED_OPTIONS with options to write conf-spamcontrol @@ -448,12 +481,10 @@ /"doc"/d; /"boot","/d' \ ${WRKSRC}/hier.c -# If you want to change the qmail users, they must be changed in both -# work/*/conf-users and pkg/INSTALL. - do-configure: - @# Create/Check the necessary groups/users - @PKG_PREFIX=${PREFIX} ${PKGINSTALL} + @${SED} -e 's,%%RCDLINK%%,${RCDLINK2},g; s,%%LOCALBASE%%,${LOCALBASE},g' \ + ${FILESDIR}/pkg-install.in > ${WRKDIR}/pkg-install + @${SETENV} PKG_PREFIX="${PREFIX}" ${CSH} ${PKGINSTALL} ${PKGNAME} PRE-INSTALL @${ECHO_CMD} "${CC} ${CFLAGS}" > ${WRKSRC}/conf-cc @${ECHO_CMD} ${PREFIX} > ${WRKSRC}/conf-qmail .if defined(WITH_BIG_CONCURRENCY_PATCH) \ @@ -473,8 +504,6 @@ ${SED} -f ${WRKDIR}/bootfiles.sed ${FILESDIR}/$i > ${WRKDIR}/${i} ; \ fi .endfor - @# Check again, just in case (ideally should error if not found) - @PKG_PREFIX=${PREFIX} ${PKGINSTALL} @${MKDIR} ${DOCSDIR} ${PREFIX}/configure @cd ${WRKSRC} ; ./install ${INSTALL_PROGRAM} ${CONFIGUREPROGS} ${PREFIX}/configure @@ -504,17 +533,7 @@ @cd ${WRKSRC} && ${CAT} `${CAT} SYSDEPS` \ > ${DOCSDIR}/SYSDEPS .endif -.for i in root postmaster mailer-daemon - @${TOUCH} ${PREFIX}/alias/.qmail-${i} -.endfor - @# This is not part of qmail proper, hence the 2nd class citizenship - @if [ ! -e ${PREFIX}/control/me ]; then \ - cd ${PREFIX}/configure ; ./config ; \ - fi -.if !defined(WITHOUT_RCDLINK) - @${MKDIR} ${LOCALBASE}/etc/rc.d - @${LN} -sf ${PREFIX}/rc ${LOCALBASE}/etc/rc.d/qmail.sh -.endif + @${SETENV} PKG_PREFIX="${PREFIX}" ${CSH} ${PKGINSTALL} ${PKGNAME} POST-INSTALL @${ECHO_CMD} @${CAT} ${PKGMESSAGE} @${ECHO_CMD} diff -ruN --exclude=CVS /usr/ports/mail/qmail/files/pkg-install.in /usr/home/renato/ports/mail/qmail/files/pkg-install.in --- /usr/ports/mail/qmail/files/pkg-install.in Wed Dec 31 21:00:00 1969 +++ /usr/home/renato/ports/mail/qmail/files/pkg-install.in Wed May 11 14:38:50 2005 @@ -0,0 +1,114 @@ +#!/bin/csh -f +# +# $FreeBSD: ports/mail/qmail/pkg-install,v 1.5 2005/05/11 12:50:32 pav Exp $ +# + +# Author : Marcos Tischer Vallim +# E-Mail : tischer@gmail.com +# Date : Tue Mar 22 00:40:45 BRT 2005 + +set path = ( /bin /sbin /usr/bin /usr/sbin ) + +if ($uid != 0) then + echo "It is necessary to add missing qmail users/groups at"; + echo "this stage. Please either add them manually or retry"; + echo "as root."; + exit 1; +endif + +if (! -x `which pw`) then + echo "This system looks like a pre-2.2 version of FreeBSD. We see that it"; + echo "is missing the "pw" utility. We need this utility. Please get and"; + echo "install it, and try again. You can get the source from:"; + echo ""; + echo " ftp://ftp.freebsd.org/pub/FreeBSD/FreeBSD-current/src/usr.sbin/pw.tar.gz"; + echo ""; + echo "No pw"; + exit 1; +endif + +switch ($argv[2]) + +case "PRE-INSTALL": + set groups = (qmail qnofiles); + set gids = (82 81); + set users = (alias qmaild qmaill qmailp qmailq qmailr qmails); + set users_g = (qnofiles qnofiles qnofiles qnofiles qmail qmail qmail); + set uids = (81 82 83 84 85 86 87); + + + set k = 1; + foreach group ($groups) + pw groupshow $group >& /dev/null; + + if ($status) then + pw groupadd $group -g $gids[$k]; + + if ($status) then + echo "Failed to add group '$group' as gid '$gids[$k]'"; + exit 1; + endif + endif + + set chkgid = (`pw groupshow $group | sed -e "s,:, ,g"`); + if ($chkgid[3] != $gids[$k]) then + echo "Group '$group' should have gid '$gids[$k]'"; + exit 1; + endif + + @ k++; + end + + set k = 1; + foreach user ($users) + pw usershow $user >& /dev/null; + + if ($status) then + if ($user == "alias") then + set home = ${PKG_PREFIX}/alias; + else + set home = ${PKG_PREFIX}; + endif + + pw useradd $user -g $users_g[$k] -d $home -s /nonexistent -u $uids[$k]; + + if ($status) then + echo "Failed to add user '$user' as uid '$uids[$k]'"; + exit 1; + endif + endif + + set chkuid = (`pw usershow $user | sed -e "s,:, ,g"`); + if ($chkuid[3] != $uids[$k]) then + echo "User '$user' should have uid '$uids[$k]'"; + exit 1; + endif + + @ k++; + end + + breaksw; + +case "POST-INSTALL": + ${PKG_PREFIX}/configure/install x; + + if ( ! `filetest -e ${PKG_PREFIX}/control/me` ) then + cd ${PKG_PREFIX}/configure && ./config; + endif + + %%RCDLINK%%ln -s ${PKG_PREFIX}/rc %%LOCALBASE%%/etc/rc.d/qmail.sh; + + touch "${PKG_PREFIX}/alias/.qmail-{postmaster,root,mailer-daemon}"; + + if ($status) then + echo "Failed to create files :"; + echo " ${PKG_PREFIX}/alias/.qmail-postmaster"; + echo " ${PKG_PREFIX}/alias/.qmail-root"; + echo " ${PKG_PREFIX}/alias/.qmail-mailer-daemon"; + exit 1; + endif + + breaksw; +endsw + +exit 0; diff -ruN --exclude=CVS /usr/ports/mail/qmail/pkg-install /usr/home/renato/ports/mail/qmail/pkg-install --- /usr/ports/mail/qmail/pkg-install Wed May 11 11:32:04 2005 +++ /usr/home/renato/ports/mail/qmail/pkg-install Wed Dec 31 21:00:00 1969 @@ -1,124 +0,0 @@ -#!/bin/csh -f -# -# $FreeBSD: ports/mail/qmail/pkg-install,v 1.5 2005/05/11 12:50:32 pav Exp $ -# - -# Author : Marcos Tischer Vallim -# E-Mail : tischer@gmail.com -# Date : Tue Mar 22 00:40:45 BRT 2005 - -# Variables -set pw = '/usr/sbin/pw'; -set touch = '/usr/bin/touch'; -set sed = '/usr/bin/sed'; -set null = '/dev/null'; - -if ($uid != 0) then - echo "It is necessary to add missing qmail users/groups at"; - echo "this stage. Please either add them manually or retry"; - echo "as root."; - exit 1; -endif - -if (! -x "$pw") then - echo "This system looks like a pre-2.2 version of FreeBSD. We see that it"; - echo "is missing the "pw" utility. We need this utility. Please get and"; - echo "install it, and try again. You can get the source from:"; - echo ""; - echo " ftp://ftp.freebsd.org/pub/FreeBSD/FreeBSD-current/src/usr.sbin/pw.tar.gz"; - echo ""; - echo "No $pw"; - exit 1; -endif - -set groups = (qmail qnofiles); -set gids = (82 81); -set users = (alias qmaild qmaill qmailp qmailq qmailr qmails); -set users_g = (qnofiles qnofiles qnofiles qnofiles qmail qmail qmail); -set uids = (81 82 83 84 85 86 87); -set doguid = 0; - -if ($#argv) then - if ($argv[1] == "POST-INSTALL") then - ${PKG_PREFIX}/configure/install x; - if ( ! `filetest -e ${PKG_PREFIX}/control/me` ) then - cd ${PKG_PREFIX}/configure && ./config; - endif - - $touch "${PKG_PREFIX}/alias/.{qmail-postmaster,qmail-root,qmail-mailer-daemon}"; - - if ($status) then - echo "Failed to create files :"; - echo " ${PKG_PREFIX}/alias/.qmail-postmaster"; - echo " ${PKG_PREFIX}/alias/.qmail-root"; - echo " ${PKG_PREFIX}/alias/.qmail-mailer-daemon"; - exit 1; - endif - - exit 0; - endif - - if ($argv[1] == "PRE-INSTALL") then - set doguid = 1; - endif -endif - -if (${?PACKAGE_BUILDING}) then - set doguid = 1; -endif - -set k = 1; -foreach group ($groups) - $pw groupshow $group >& $null; - - if ($status) then - $pw groupadd $group -g $gids[$k]; - - if ($status) then - echo "Failed to add group '$group' as gid '$gids[$k]'"; - exit 1; - endif - endif - - if ($doguid) then - set chkgid = (`$pw groupshow $group | $sed -e "s/:/ /g"`); - if ($chkgid[3] != $gids[$k]) then - echo "Group '$group' should have gid '$gids[$k]'"; - exit 1; - endif - endif - - @ k = $k + 1; -end - -set k = 1; -foreach user ($users) - $pw usershow $user >& $null; - - if ($status) then - if ($user == "alias") then - set home = ${PKG_PREFIX}/alias; - else - set home = ${PKG_PREFIX}; - endif - - $pw useradd $user -g $users_g[$k] -d $home -s /nonexistent -u $uids[$k]; - - if ($status) then - echo "Failed to add user '$user' as uid '$uids[$k]'"; - exit 1; - endif - endif - - if ($doguid) then - set chkuid = (`$pw usershow $user | $sed -e "s/:/ /g"`); - if ($chkuid[3] != $uids[$k]) then - echo "User '$user' should have uid '$uids[$k]'"; - exit 1; - endif - endif - - @ k = $k + 1; -end - -exit 0; --- qmail.diff end here --- Thanks -- Renato Botelho AIM: RBGargaBR | ICQ: 54596223 GnuPG Key: http://www.galle.com.br/~renato/pubkey.asc H. L. Mencken suffers from the hallucination that he is H. L. Mencken -- there is no cure for a disease of that magnitude. -- Maxwell Bodenheim