Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 18 Dec 2003 20:28:54 +0600 (NOVT)
From:      "Michael O. Boev" <mike@tric.tomsk.gov.ru>
To:        FreeBSD-gnats-submit@FreeBSD.org
Subject:   ports/60366: [maintainer-update] Update of port mail/relaydb
Message-ID:  <200312181428.hBIESsMa003064@isrv.tric.tomsk.gov.ru>
Resent-Message-ID: <200312181430.hBIEUFAs028772@freefall.freebsd.org>

next in thread | raw e-mail | index | archive | help

>Number:         60366
>Category:       ports
>Synopsis:       [maintainer-update] Update of port mail/relaydb
>Confidential:   no
>Severity:       non-critical
>Priority:       low
>Responsible:    freebsd-ports-bugs
>State:          open
>Quarter:        
>Keywords:       
>Date-Required:
>Class:          maintainer-update
>Submitter-Id:   current-users
>Arrival-Date:   Thu Dec 18 06:30:15 PST 2003
>Closed-Date:
>Last-Modified:
>Originator:     Michael O. Boev
>Release:        FreeBSD 4.9-RELEASE i386
>Organization:
>Environment:
System: FreeBSD 4.9-RELEASE
also tested on
FreeBSD 5.1-RELEASE

>Description:
	Update to version 1.7
>How-To-Repeat:
	-
>Fix:
    Please apply the following patch.
    
    Please also delete the directory files(recursively) and pkg-message.
    The problems for which the patches (and pkg-message) existed
    are all fixed in this version (partially by applying these patches).
    
--- relaydb.port begins here ---
diff -ruN relaydb.16/Makefile relaydb/Makefile
--- relaydb.16/Makefile	Wed Dec 17 03:49:17 2003
+++ relaydb/Makefile	Thu Dec 18 18:41:42 2003
@@ -2,12 +2,11 @@
 # Date created:				10 August 2003
 # Whom:					Matt Jibson <dolmant@dolmant.net>
 #
-# $FreeBSD: ports/mail/relaydb/Makefile,v 1.5 2003/12/16 14:23:34 sergei Exp $
+# $FreeBSD: ports/mail/relaydb/Makefile,v 1.4 2003/12/15 11:40:24 sergei Exp $
 #
 
 PORTNAME=	relaydb
-PORTVERSION=	1.6
-PORTREVISION=	1
+PORTVERSION=	1.7
 CATEGORIES=	mail
 MASTER_SITES=	http://www.benzedrine.cx/
 
@@ -20,6 +19,5 @@
 do-install:
 	${INSTALL_PROGRAM} ${WRKSRC}/relaydb ${PREFIX}/bin
 	${INSTALL_MAN} ${WRKSRC}/relaydb.8.gz ${MAN8PREFIX}/man/man8
-	@${CAT} ${PKGMESSAGE}
 
 .include <bsd.port.mk>
diff -ruN relaydb.16/distinfo relaydb/distinfo
--- relaydb.16/distinfo	Mon Dec 15 03:26:47 2003
+++ relaydb/distinfo	Thu Dec 18 18:40:52 2003
@@ -1 +1 @@
-MD5 (relaydb-1.6.tar.gz) = 4d5de68c51873fba7c312039e49d30fd
+MD5 (relaydb-1.7.tar.gz) = c23871ddb66a1445841cecdaf0e6dc26
diff -ruN relaydb.16/files/patch-relaydb.8 relaydb/files/patch-relaydb.8
--- relaydb.16/files/patch-relaydb.8	Wed Dec 17 03:49:17 2003
+++ relaydb/files/patch-relaydb.8	Thu Jan  1 07:00:00 1970
@@ -1,27 +0,0 @@
---- relaydb.8.orig	Fri Nov 21 00:41:34 2003
-+++ relaydb.8	Sun Dec 14 21:21:35 2003
-@@ -30,7 +30,7 @@
- .Nd spam relay database
- .Sh SYNOPSIS
- .Nm relaydb
--.Op Fl 46bdlnrvw
-+.Op Fl 46bdlnOrvw
- .Op Fl B Ar [+-]num
- .Op Fl W Ar [+-]num
- .Op Fl m Ar [+-]days
-@@ -118,6 +118,15 @@
- establish a new whitelist entry for a new host, then send spam from the
- same address, faking further Received: headers, to cause relaydb to blacklist
- those addresses, causing a denial of service for these addresses.
-+.It Fl O
-+List (just as
-+.Fl l
-+does) the IP addresses of a database in pre-1.5 format, necessary
-+for upgrading from earlier versions of
-+.Nm . Incompatible with
-+.Fl l 
-+and
-+.Fl d .
- .It Fl r
- Revert a previously made decision.
- For instance, if a mail has been run through
diff -ruN relaydb.16/files/patch-relaydb.c relaydb/files/patch-relaydb.c
--- relaydb.16/files/patch-relaydb.c	Wed Dec 17 03:49:17 2003
+++ relaydb/files/patch-relaydb.c	Thu Jan  1 07:00:00 1970
@@ -1,178 +0,0 @@
---- relaydb.c.orig	Sun Dec 14 15:59:30 2003
-+++ relaydb.c	Tue Dec 16 18:58:52 2003
-@@ -47,6 +47,11 @@
- 	time_t	 mtime;
- };
- 
-+struct old_data {
-+	int	 white;
-+	int	 black;
-+};
-+
- extern char	*__progname;
- const int	 bufsiz = 1024;
- const int	 factor = 3;
-@@ -318,7 +323,8 @@
- 			if (d.mtime >= mtime)
- 				continue;
- 			if (debug)
--				printf("touching %u %s\n", mtime, address);
-+				printf("touching %lu %s\n", 
-+					(unsigned long)mtime, address);
- 			d.mtime = mtime;
- 			memset(&dbk, 0, sizeof(dbk));
- 			dbk.size = strlen(address);
-@@ -349,6 +355,7 @@
- 	int		 pos = 0, r;
- 	struct data	 d;
- 	unsigned	 count = 0;
-+	unsigned long	 time_read;
- 
- 	if (debug)
- 		printf("importing %s\n", filename);
-@@ -364,8 +371,8 @@
- 			buf[pos] = 0;
- 			pos = 0;
- 
--			r = sscanf(buf, "%127s %d %d %u", address,
--			    &d.white, &d.black, &d.mtime);
-+			r = sscanf(buf, "%127s %d %d %lu", address,
-+			    &d.white, &d.black, &time_read);
- 			if (r == 3)
- 				d.mtime = time(NULL);
- 			else if (r != 4) {
-@@ -373,14 +380,16 @@
- 				    buf);
- 				fclose(f);
- 				return;
--			}
-+			} else
-+				d.mtime = time_read;
- 			if (!((use_v4 && address_valid_v4(address)) ||
- 			    (use_v6 && address_valid_v6(address))) ||
- 			    address_private(address))
- 				continue;
- 			if (debug)
--				printf("adding %s %d %d %u\n",
--				    address, d.white, d.black, d.mtime);
-+				printf("adding %s %d %d %lu\n",
-+				    address, d.white, d.black, 
-+				    (unsigned long)d.mtime);
- 			memset(&dbk, 0, sizeof(dbk));
- 			dbk.size = strlen(address);
- 			dbk.data = address;
-@@ -405,7 +414,7 @@
- void
- usage()
- {
--	fprintf(stderr, "usage: %s [-46bdlnrvw] "
-+	fprintf(stderr, "usage: %s [-46bdlnOrvw] "
- 	    "[-BW [+-]num] [-m [+-]days]\n\t[-f filename] "
- 	    "[-i filename] [-t filename]\n", __progname);
- 	exit(1);
-@@ -414,7 +423,7 @@
- int
- main(int argc, char *argv[])
- {
--	int		 list = 0, delete = 0;
-+	int		 list = 0, delete = 0, old_list = 0;
- 	const char	*filename = NULL, *import = NULL, *syslog = NULL;
- 	time_t		 mtime = 0;
- 	int		 mtime_op = 0;
-@@ -423,7 +432,7 @@
- 	int		 ch;
- 	unsigned	 count = 0;
- 
--	while ((ch = getopt(argc, argv, "46bB:df:i:lm:nrt:vwW:")) != -1) {
-+	while ((ch = getopt(argc, argv, "46bB:df:i:lm:nOrt:vwW:")) != -1) {
- 		switch (ch) {
- 		case '4':
- 			use_v4 = 1;
-@@ -482,6 +491,9 @@
- 		case 'n':
- 			traverse = 0;
- 			break;
-+		case 'O':
-+			old_list = 1;
-+			break;
- 		case 'r':
- 			reverse = 1;
- 			break;
-@@ -496,9 +508,14 @@
- 		}
- 	}
- 
--	if (!list && !delete && !action && import == NULL && syslog == NULL)
-+	if (!old_list && !list && !delete && !action && import == NULL && syslog == NULL)
- 		usage();
- 
-+	if (old_list && (list || delete)) {
-+		fprintf(stderr, "-O is incompatible with -l and -d\n");
-+		return (1);
-+	}
-+
- 	if (delete && !action && !mtime && black == -1 && white == -1) {
- 		fprintf(stderr, "to delete all entries, delete the file\n");
- 		return (1);
-@@ -583,8 +600,9 @@
- 				continue;
- 			if (list) {
- 				if (debug)
--					printf("%s %d %d %u\n",
--					    a, d.white, d.black, d.mtime);
-+					printf("%s %d %d %lu\n",
-+					    a, d.white, d.black, 
-+						(unsigned long)d.mtime);
- 				else
- 					printf("%s\n", a);
- 			} else {
-@@ -600,6 +618,40 @@
- 				count++;
- 			}
- 		}
-+	} else if (old_list) {
-+		int		 r;
-+		struct old_data	 d;
-+		char		 a[128];
-+
-+		memset(&dbk, 0, sizeof(dbk));
-+		memset(&dbd, 0, sizeof(dbd));
-+		r = db->seq(db, &dbk, &dbd, R_FIRST);
-+		while (!r) {
-+			if (dbk.size < 1 || dbk.size >= sizeof(a)||
-+			    dbd.size != sizeof(struct old_data)) {
-+				fprintf(stderr, "db->seq() invalid data\n");
-+				if (db->close(db))
-+					fprintf(stderr, "db->close() %s\n",
-+					    strerror(errno));
-+				return (1);
-+			}
-+			memcpy(&d, dbd.data, sizeof(d));
-+			if (!action ||
-+			    (action == 'b' && d.black >  factor * d.white) ||
-+			    (action == 'w' && d.black <= factor * d.white)) {
-+				memcpy(a, dbk.data, dbk.size);
-+				a[dbk.size] = 0;
-+				if ((use_v4 && address_valid_v4(a)) ||
-+				    (use_v6 && address_valid_v6(a))) {
-+					if (debug)
-+						printf("%s %d %d\n",
-+						    a, d.white, d.black);
-+					else
-+						printf("%s\n", a);
-+				}
-+			}
-+			r = db->seq(db, &dbk, &dbd, R_NEXT);
-+		}
- 	} else {
- 		if (debug)
- 			printf("reading mail headers, considering the mail "
-@@ -609,7 +661,7 @@
- 	if (delete && !list)
- 		printf("%u entries deleted\n", count);
- 
--	if (!list && db->sync(db, 0))
-+	if (!old_list && !list && db->sync(db, 0))
- 		fprintf(stderr, "db->sync() %s\n", strerror(errno));
- 	if (db->close(db))
- 		fprintf(stderr, "db->close() %s\n", strerror(errno));
diff -ruN relaydb.16/pkg-message relaydb/pkg-message
--- relaydb.16/pkg-message	Sun Dec 14 20:47:10 2003
+++ relaydb/pkg-message	Thu Jan  1 07:00:00 1970
@@ -1,6 +0,0 @@
-*************************************************************************
-* WARNING: the database format has changed in version 1.5,		*
-* so upgrades from earlier versions REQUIRE an export			*
-* with (relaydb -vO >text), deletion of the database			*
-* and re-import with the (relaydb -i text).				*
-*************************************************************************
--- relaydb.port ends here ---
>Release-Note:
>Audit-Trail:
>Unformatted:



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200312181428.hBIESsMa003064>