Date: Sat, 09 Jul 2005 17:46:38 +0400 From: Vsevolod Stakhov <vsevolod@highsecure.ru> To: FreeBSD-gnats-submit@FreeBSD.org Subject: ports/83181: Update port: security/rdigest to be up to date with digest Message-ID: <E1DrFfC-0005Nt-Du@spray.anyhost.ru> Resent-Message-ID: <200507091350.j69DoI7e000794@freefall.freebsd.org>
next in thread | raw e-mail | index | archive | help
>Number: 83181 >Category: ports >Synopsis: Update port: security/rdigest to be up to date with digest >Confidential: no >Severity: non-critical >Priority: low >Responsible: freebsd-ports-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: update >Submitter-Id: current-users >Arrival-Date: Sat Jul 09 13:50:17 GMT 2005 >Closed-Date: >Last-Modified: >Originator: Vsevolod Stakhov >Release: FreeBSD 5.4-RELEASE i386 >Organization: >Environment: >Description: Update to latest NetBSD snapshot. Make changes to Makefile to be up to date to the last security/digest PR. >How-To-Repeat: >Fix: diff -ruPN rdigest.orig/Makefile rdigest/Makefile --- rdigest.orig/Makefile Sat Jul 9 17:43:09 2005 +++ rdigest/Makefile Sat Jul 9 17:43:36 2005 @@ -9,6 +9,8 @@ COMMENT= Recursive message digest wrapper utility +DISTNAME= digest-${PORTVERSION} + DESCR= ${.CURDIR}/pkg-descr CONFLICTS= # none diff -ruPN rdigest.orig/files/patch-aa rdigest/files/patch-aa --- rdigest.orig/files/patch-aa Sat Jul 9 17:43:09 2005 +++ rdigest/files/patch-aa Sat Jul 9 17:43:36 2005 @@ -1,8 +1,8 @@ -$NetBSD: patch-aa,v 1.1.1.1 2003/07/24 05:21:05 atatat Exp $ +$NetBSD: patch-aa,v 1.2 2005/03/28 20:52:55 agc Exp $ ---- Makefile.in.orig 2002-12-20 23:06:12.000000000 -0500 -+++ Makefile.in -@@ -56,7 +56,7 @@ missing mkinstalldirs regress.sh +--- Makefile.in.orig 2005-03-28 21:39:38.000000000 +0100 ++++ Makefile.in 2005-03-28 21:41:02.000000000 +0100 +@@ -57,7 +57,7 @@ .c.o: $(COMPILE) -c $< -o $@ @@ -11,7 +11,7 @@ digest-types.h: bits ./bits digest-types.h -@@ -64,10 +64,10 @@ digest-types.h: bits +@@ -65,10 +65,10 @@ bits: bits.o $(LINK) $(bits_OBJS) $(LIBS) @@ -24,8 +24,8 @@ @SHELL@ $(srcdir)/regress.sh digest.o: digest-types.h -@@ -81,7 +81,7 @@ sha1.o: digest-types.h - sha1hl.o: digest-types.h +@@ -84,7 +84,7 @@ + whirlpool.o: digest-types.h clean: - rm -f *.o digest bits digest-types.h @@ -33,7 +33,7 @@ distclean: clean rm -f Makefile config.h -@@ -90,18 +90,18 @@ distclean: clean +@@ -93,18 +93,18 @@ maintainer-clean: distclean rm -f configure config.h.in diff -ruPN rdigest.orig/files/patch-ab rdigest/files/patch-ab --- rdigest.orig/files/patch-ab Sat Jul 9 17:43:09 2005 +++ rdigest/files/patch-ab Sat Jul 9 17:43:36 2005 @@ -1,14 +1,20 @@ -$NetBSD: patch-ab,v 1.1.1.1 2003/07/24 05:21:07 atatat Exp $ +$NetBSD: patch-ab,v 1.3 2005/03/31 05:02:24 atatat Exp $ ---- digest.1.orig 2002-02-16 15:24:32.000000000 -0500 +--- digest.1.orig 2005-03-30 23:40:39.000000000 -0500 +++ digest.1 -@@ -31,21 +31,29 @@ - .\" SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +@@ -2,5 +2,5 @@ .\" .\" --.Dd February 28, 2001 +-.\" Copyright (c) 2001 Alistair G. Crooks. All rights reserved. ++.\" Copyright (c) 2001-2005 Alistair G. Crooks. All rights reserved. + .\" + .\" Redistribution and use in source and binary forms, with or without +@@ -32,12 +32,13 @@ + .\" + .\" +-.Dd March 23, 2005 -.Dt DIGEST 1 -+.Dd July 24, 2003 ++.Dd March 31, 2005 +.Dt RDIGEST 1 .Os .Sh NAME @@ -21,7 +27,7 @@ +.Op Fl x Ar directory .Ar algorithm .Op file ... - .Sh DESCRIPTION +@@ -45,6 +46,13 @@ The .Nm -utility calculates message digests of files or, @@ -36,42 +42,37 @@ +.Pp The list of possible algorithms is: .Bl -tag -width Ds - .It md5 -@@ -81,11 +89,32 @@ algorithm implementations, which are loc +@@ -89,4 +97,23 @@ algorithm implementations, which are loc C library, and was designed to be scalable as new message digest algorithms are developed. - .Pp +The checksum for a directory is implemented as the hash over a list of +one or two hashes for each of the items in the tree. +.Bl -bullet +.It +For a file, the string -+.Li Dq f \& ++.Dq f \& +along with the path make up the data for one hash, and the contents of +the file is used for the second hash. +.It +For a symbolic link, the string -+.Li Dq l \& ++.Dq l \& +along with the path to the symbolic link make up the data for one +hash, and the target of the symbolic link is used for the second hash. +.It +For a directory, the string -+.Li Dq d \& ++.Dq d \& +along with the path make up the data for one hash. +There is no second hash for a directory. +.El -+.Pp + .Pp The - .Nm - utility exits 0 on success, and >0 if an error occurs. +@@ -95,4 +122,5 @@ utility exits 0 on success, and \*[Gt]0 .Sh SEE ALSO .Xr cksum 1 , +.Xr digest 1 , .Xr md5 3 , .Xr rmd160 3 , - .Xr sha1 3 -@@ -93,9 +122,13 @@ utility exits 0 on success, and >0 if an - The +@@ -102,8 +130,12 @@ The .Nm utility first appeared in -.Nx 1.6 . diff -ruPN rdigest.orig/files/patch-ac rdigest/files/patch-ac --- rdigest.orig/files/patch-ac Sat Jul 9 17:43:09 2005 +++ rdigest/files/patch-ac Sat Jul 9 17:43:36 2005 @@ -1,6 +1,6 @@ -$NetBSD: patch-ac,v 1.1.1.1 2003/07/24 05:21:07 atatat Exp $ +$NetBSD: patch-ac,v 1.2 2005/01/21 02:18:23 tv Exp $ ---- digest.c.orig 2003-07-23 20:27:09.000000000 -0400 +--- digest.c.orig 2005-01-20 21:10:03.000000000 -0500 +++ digest.c @@ -43,9 +43,14 @@ __RCSID("$NetBSD: digest.c,v 1.8 2003/07 #endif @@ -17,7 +17,7 @@ #ifdef HAVE_LOCALE_H #include <locale.h> #endif -@@ -147,21 +152,172 @@ digest_file(char *fn, alg_t *alg) +@@ -147,21 +152,178 @@ digest_file(char *fn, alg_t *alg) return (rc); } @@ -26,7 +26,7 @@ + const char *p; +}; + -+LIST_HEAD(, excl) excl = LIST_HEAD_INITIALIZER(excl); ++LIST_HEAD(, excl) excl; + +static void +exclude(const char *p) @@ -43,7 +43,11 @@ +{ + struct excl *e; + ++#ifdef LIST_FOREACH + LIST_FOREACH(e, &excl, n) ++#else ++ for (e = excl.lh_first; e; e = e->n.le_next) ++#endif + if (strcmp(e->p, p) == 0) + return (1); + @@ -175,6 +179,8 @@ int rval; int i; + struct stat st; ++ ++ LIST_INIT(&excl); #ifdef HAVE_SETLOCALE (void) setlocale(LC_ALL, ""); @@ -191,7 +197,7 @@ } } argc -= optind; -@@ -186,7 +342,9 @@ main(int argc, char **argv) +@@ -186,7 +348,9 @@ main(int argc, char **argv) } } else { for (i = 0 ; i < argc ; i++) { diff -ruPN rdigest.orig/pkg-descr rdigest/pkg-descr --- rdigest.orig/pkg-descr Sat Jul 9 17:43:09 2005 +++ rdigest/pkg-descr Sat Jul 9 17:43:36 2005 @@ -1,8 +1,6 @@ -This utility is a wrapper for the md5(3), sha1(3) and rmd160(3) -routines. - -It is remarkably similar to the digest package, except that it -can recursively checksum directory trees. +This utility is a wrapper for the md5(3), sha1(3), rmd160(3), and +tiger hash routines. It is remarkably similar to the digest package, +except that it can recursively checksum directory trees. While a simple checksum on a tar file is usually satisfactory, once said archive has been extracted, it is virtually impossible to @@ -11,37 +9,8 @@ changes in file ordering within directories can affect the checksum of the archive, while not really impacting the actual code at all. -The algorithm used to checksum a directory in this implementation is -as follows: - - cd into directory - initialize MASTER_HASH - walk directory tree, sorting all entries - foreach entry - if it is a directory: - skip it if it is named "RCS", "CVS", or "SCCS" - initialize SLAVE_HASH - add the string "d " into SLAVE_HASH - add the pathname of the directory into SLAVE_HASH - finish SLAVE_HASH - fold the hexified SLAVE_HASH result into MASTER_HASH - if it is a file: - initialize SLAVE_HASH - add the string "f " into SLAVE_HASH - add the pathname of the file into SLAVE_HASH - finish SLAVE_HASH - fold the hexified SLAVE_HASH result into MASTER_HASH - initialize SLAVE_HASH - add the contents of the file into SLAVE_HASH - finish SLAVE_HASH - fold the hexified SLAVE_HASH result into MASTER_HASH - if it is a symbolic link - initialize SLAVE_HASH - add the string "l " into SLAVE_HASH - add the pathname of the link into SLAVE_HASH - finish SLAVE_HASH - fold the hexified SLAVE_HASH result into MASTER_HASH - initialize SLAVE_HASH - add the contents of the link into SLAVE_HASH - finish SLAVE_HASH - fold the hexified SLAVE_HASH result into MASTER_HASH +The algorithm used to checksum a directory in this implementation +is considers only the files' pathnames, the files' types (ie, +directory vs. file vs. symbolic link), and their contents (for +the latter two). It is described in greater detail in the man +page. >Release-Note: >Audit-Trail: >Unformatted:
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?E1DrFfC-0005Nt-Du>