diff options
-rw-r--r-- | security/Makefile | 1 | ||||
-rw-r--r-- | security/pks/Makefile | 44 | ||||
-rw-r--r-- | security/pks/distinfo | 3 | ||||
-rw-r--r-- | security/pks/files/patch-aa | 61 | ||||
-rw-r--r-- | security/pks/files/patch-ab | 9 | ||||
-rw-r--r-- | security/pks/files/patch-ac | 55 | ||||
-rw-r--r-- | security/pks/files/patch-ad | 9 | ||||
-rw-r--r-- | security/pks/files/pksd.sh | 52 | ||||
-rw-r--r-- | security/pks/pkg-comment | 1 | ||||
-rw-r--r-- | security/pks/pkg-deinstall | 27 | ||||
-rw-r--r-- | security/pks/pkg-descr | 4 | ||||
-rw-r--r-- | security/pks/pkg-install | 22 | ||||
-rw-r--r-- | security/pks/pkg-plist | 12 |
13 files changed, 300 insertions, 0 deletions
diff --git a/security/Makefile b/security/Makefile index faa7ca6b5fd1..bacab8fed6ef 100644 --- a/security/Makefile +++ b/security/Makefile @@ -101,6 +101,7 @@ SUBDIR += pgpdump SUBDIR += pgpgpg SUBDIR += pidentd + SUBDIR += pks SUBDIR += pktsuckers SUBDIR += portscanner SUBDIR += portsentry diff --git a/security/pks/Makefile b/security/pks/Makefile new file mode 100644 index 000000000000..2adaf529f424 --- /dev/null +++ b/security/pks/Makefile @@ -0,0 +1,44 @@ +# New ports collection makefile for: pks +# Date created: 15 Jan 2001 +# Whom: kris@FreeBSD.org +# +# $FreeBSD$ +# + +PORTNAME= pks +PORTVERSION= 0.9.4 +CATEGORIES= security www +MASTER_SITES+= http://www.mit.edu/people/marc/pks/ \ + ftp://ftp.neonramp.com/pub/pksd/ + +PATCH_SITES= http://www.mit.edu/people/marc/pks/ \ + ftp://ftp.neonramp.com/pub/pksd/ +PATCHFILES= pks094-patch2 \ + x509patch +PATCH_DIST_STRIP=-p1 + +MAINTAINER= kris@FreeBSD.org + +LIB_DEPENDS= db2.0:${PORTSDIR}/databases/db + +GNU_CONFIGURE= yes +CONFIGURE_ARGS= --datadir=${PREFIX}/share/pks --localstatedir=/var/pks \ + --sysconfdir=${PREFIX}/share/examples \ + --libdir=${LOCALBASE}/lib +CONFIGURE_ENV= LDFLAGS=-L${LOCALBASE}/lib + +MAN5= pksd.conf.5 +MAN8= pks-intro.8 pksclient.8 pksd.8 pksdctl.8 + +post-build: + ${SED} -e "s,@PREFIX@,${PREFIX},g" \ + < ${FILESDIR}/pksd.sh > ${WRKDIR}/pksd.sh + +post-install: + ${INSTALL_SCRIPT} ${WRKDIR}/pksd.sh ${PREFIX}/etc/rc.d/pksd.sh +.if !exists(${PREFIX}/etc/pksd.conf) + ${INSTALL_DATA} ${WRKSRC}/pksd.conf ${PREFIX}/etc/pksd.conf +.endif + PKG_PREFIX=${PREFIX} ${SH} ${PKGINSTALL} ${PKGNAME} POST-INSTALL + +.include <bsd.port.mk> diff --git a/security/pks/distinfo b/security/pks/distinfo new file mode 100644 index 000000000000..e651b3c31441 --- /dev/null +++ b/security/pks/distinfo @@ -0,0 +1,3 @@ +MD5 (pks-0.9.4.tar.gz) = 365d062bbc3f7bfda745474693d0fdec +MD5 (pks094-patch2) = 33effba52c7a195d02d42ae41ba2795e +MD5 (x509patch) = 87625aac1b984410cc22c2ca530a95d8 diff --git a/security/pks/files/patch-aa b/security/pks/files/patch-aa new file mode 100644 index 000000000000..8d2f9b083b4a --- /dev/null +++ b/security/pks/files/patch-aa @@ -0,0 +1,61 @@ +$NetBSD$ + +--- Makefile.in.orig Thu Jul 27 11:11:28 2000 ++++ Makefile.in Thu Jul 27 11:24:02 2000 +@@ -9,9 +9,9 @@ + SHELL = /bin/sh + + ## this does recursion for db2, if it's in the tree +- +-SUBDIRS = db2-sleepycat/dist +- ++# ++# We use the installed db2, so we don't need this line anymore ++# + depend all install check clean distclean maintainer-clean:: + for i in ${SUBDIRS}; do (test -d $$i && cd $$i && ${MAKE} $@) || exit 1; done + +@@ -32,12 +32,13 @@ + all-pure:: $(ALL_PURE) + all-utils:: $(UTILS) + +-DBDIR = db2-sleepycat/dist ++DBDIR = ${LOCALBASE}/include/db2 + + CC = @CC@ + INSTALL = @INSTALL@ +-INSTALL_PROGRAM = $(INSTALL) +-INSTALL_DATA = $(INSTALL) ++INSTALL_PROGRAM = $(BSD_INSTALL_PROGRAM) ++INSTALL_DATA = $(BSD_INSTALL_DATA) ++INSTALL_SCRIPT = $(BSD_INSTALL_SCRIPT) + SOCKLIBS = @LIBS@ + VPATH = @srcdir@ + +@@ -60,7 +61,7 @@ + DEFINES = $(DBG) @DEFS@ + CFLAGS = @gcc_cflags@ -g -O $(INCLUDES) $(DEFINES) + +-LIBDB = $(DBDIR)/libdb.a ++LIBDB = -ldb2 + + CLEAN = rm -f + +@@ -118,6 +119,8 @@ + pgpdump: pgpdump.o pgpfile.o $(PGPOBJS) $(UTILOBJS) + + pgpsplit: pgpsplit.o $(PGPOBJS) $(UTILOBJS) ++ $(CC) -o $@ pgpsplit.o $(PGPOBJS) $(UTILOBJS) $(LDFLAGS) \ ++ $(SOCKLIBS) $(LIBDB) + + kvcv: kvcv.o pgpfile.o logging.o $(PGPOBJS) $(UTILOBJS) + +@@ -138,7 +141,7 @@ + install:: all installdirs + for f in $(ALL); do $(INSTALL_PROGRAM) $$f $(bindir); done + for f in $(SYSCONF); do $(INSTALL_DATA) $$f $(sysconfdir); done +- for f in $(ALL_SH); do $(INSTALL_PROGRAM) $(srcdir)/$$f $(bindir); done ++ for f in $(ALL_SH); do $(INSTALL_SCRIPT) $(srcdir)/$$f $(bindir); done + for f in $(DATA); do $(INSTALL_DATA) $(srcdir)/$$f $(datadir); done + for f in $(MAN5); do $(INSTALL_DATA) $(srcdir)/$$f $(man5dir); done + for f in $(MAN8); do $(INSTALL_DATA) $(srcdir)/$$f $(man8dir); done diff --git a/security/pks/files/patch-ab b/security/pks/files/patch-ab new file mode 100644 index 000000000000..75a39a1cdc0c --- /dev/null +++ b/security/pks/files/patch-ab @@ -0,0 +1,9 @@ +--- pksd.c.orig Thu Jul 27 10:16:19 2000 ++++ pksd.c Thu Jul 27 10:17:34 2000 +@@ -85,6 +85,7 @@ + psc.mrc = &mrc; + + pwc.port = pc.www_port; ++ pwc.db_dir = pc.db_dir; + pwc.max_reply_keys = pc.max_reply_keys; + pwc.pic = &pic; diff --git a/security/pks/files/patch-ac b/security/pks/files/patch-ac new file mode 100644 index 000000000000..0f3f06a0f1cb --- /dev/null +++ b/security/pks/files/patch-ac @@ -0,0 +1,55 @@ +$NetBSD$ + +--- pks_www.c.orig Wed Jun 2 02:06:01 1999 ++++ pks_www.c Thu Jul 27 10:17:35 2000 +@@ -113,6 +113,9 @@ + w_error(fd, vers, (unsigned char *) str, strlen(str)); + } + ++static const char homepage_str[] = "/"; ++static int homepage_len = sizeof(homepage_str)-1; ++ + static const char lookup_str[] = "/pks/lookup"; + static int lookup_len = sizeof(lookup_str)-1; + +@@ -291,6 +294,34 @@ + search = -1; + search_len = 0; + ++ if (is_token(uri, urilen, homepage_str, homepage_len, 1)) { ++ FILE *homepage; ++ char homepage_path[2048]; ++ char buf[1024]; ++ unsigned char *line; ++ xbuffer xb; ++ ++ strncpy(homepage_path, conf->db_dir, 2035); ++ strncat(homepage_path, "/index.html", 2046); ++ if ((homepage = fopen(homepage_path,"r")) == NULL) { ++ log_fatal("pks_www", "non-existent homepage"); ++ return; ++ } ++ ++ xbuffer_alloc(&xb); ++ ++ while (line = (unsigned char *) fgets(buf,sizeof(buf), homepage)) { ++ if (!xbuffer_append_str(&xb, line)) { ++ log_fatal("pks_www", "displaying home page"); ++ return; ++ } ++ } ++ ++ w_reply(fd, vers, xb.buf, xb.len); ++ ++ xbuffer_free(&xb); ++ return; ++ } + if (is_token(uri, urilen, lookup_str, lookup_len, 1)) { + long op, op_len, exact, exact_len, fingerprint, fingerprint_len; + int flags; +@@ -498,4 +529,5 @@ + void pks_www_init(pks_www_conf *conf) + { + www_init(conf->port, pks_www, conf); ++ www_init(conf->db_dir, pks_www, conf); + } diff --git a/security/pks/files/patch-ad b/security/pks/files/patch-ad new file mode 100644 index 000000000000..fa726f684e9d --- /dev/null +++ b/security/pks/files/patch-ad @@ -0,0 +1,9 @@ +--- pks_www.h.orig Wed May 19 23:39:52 1999 ++++ pks_www.h Thu Jul 27 10:17:35 2000 +@@ -13,6 +13,7 @@ + typedef struct _pks_www_conf { + int port; + int max_reply_keys; ++ char *db_dir; + pks_incr_conf *pic; + } pks_www_conf; diff --git a/security/pks/files/pksd.sh b/security/pks/files/pksd.sh new file mode 100644 index 000000000000..bf8ce4d6c38b --- /dev/null +++ b/security/pks/files/pksd.sh @@ -0,0 +1,52 @@ +#!/bin/sh +# +# $NetBSD: pksd.sh,v 1.1.1.1 2000/07/27 16:10:24 jlam Exp $ +# +# PROVIDE: pksd +# REQUIRE: DAEMON + +name="pksd" +command=${1:-start} + +case ${command} in +start) + if [ ! -f /etc/${name}.conf ] + then + exit 0 + else + dbdir=`awk '/db_dir/ { print $2 }' < /etc/${name}.conf` + fi + if [ ! -f ${dbdir}/keydb000 -a -x @PREFIX@/bin/pksclient ] + then + @PREFIX@/bin/pksclient ${dbdir} create + fi + if [ -x @PREFIX@/bin/${name} -a -x @PREFIX@/bin/pks-queue-run.sh ] + then + echo "Starting ${name}." + @PREFIX@/bin/${name} /etc/${name}.conf & + sleep 5 + @PREFIX@/bin/pks-queue-run.sh /etc/${name}.conf + fi + ;; +stop) + if [ ! -f /etc/${name}.conf ] + then + exit 0 + else + socket=`awk '/socket_name/ { print $2 }' < /etc/${name}.conf` + fi + if [ -x @PREFIX@/bin/${name}ctl -a -S ${socket} ] + then + echo "Stopping ${name}." + @PREFIX@/bin/${name}ctl ${socket} shutdown + else + echo "couldn't stop ${name}." + fi + ;; +restart) + ( $0 stop ) + sleep 1 + $0 start + ;; +esac +exit 0 diff --git a/security/pks/pkg-comment b/security/pks/pkg-comment new file mode 100644 index 000000000000..34cea9e471c1 --- /dev/null +++ b/security/pks/pkg-comment @@ -0,0 +1 @@ +PGP Public Key Server diff --git a/security/pks/pkg-deinstall b/security/pks/pkg-deinstall new file mode 100644 index 000000000000..f3949fc343f6 --- /dev/null +++ b/security/pks/pkg-deinstall @@ -0,0 +1,27 @@ +#!/bin/sh +# +# $NetBSD$ + +PKGNAME=$1 +STAGE=$2 + +case ${STAGE} in +DEINSTALL) + ;; +POST-DEINSTALL) + cat << EOF +=========================================================================== +If you won't be using ${PKGNAME} any longer, you may want to remove the +following directories and files: + + /usr/local/etc/pksd.conf + /var/pks +=========================================================================== +EOF + ;; +*) + echo "Unexpected argument: ${STAGE}" + exit 1 + ;; +esac +exit 0 diff --git a/security/pks/pkg-descr b/security/pks/pkg-descr new file mode 100644 index 000000000000..c5fc42c8e2d6 --- /dev/null +++ b/security/pks/pkg-descr @@ -0,0 +1,4 @@ +This program implements a standard PGP Key Server, which can be assumed +to be in addition to the public key server at MIT. + +WWW: http://www.mit.edu/people/marc/pks/ diff --git a/security/pks/pkg-install b/security/pks/pkg-install new file mode 100644 index 000000000000..d2c772b14e80 --- /dev/null +++ b/security/pks/pkg-install @@ -0,0 +1,22 @@ +#!/bin/sh +# +# $NetBSD$ + +PKGNAME=$1 +STAGE=$2 + +case ${STAGE} in +PRE-INSTALL) + ;; +POST-INSTALL) + DBDIR=/var/pks/db + MAILDIR=/var/pks/incoming + + mkdir -p ${DBDIR} ${MAILDIR} + ;; +*) + echo "Unexpected argument: ${STAGE}" + exit 1 + ;; +esac +exit 0 diff --git a/security/pks/pkg-plist b/security/pks/pkg-plist new file mode 100644 index 000000000000..1c2e2b924dd5 --- /dev/null +++ b/security/pks/pkg-plist @@ -0,0 +1,12 @@ +bin/pgpsplit +bin/pks-mail.sh +bin/pks-queue-run.sh +bin/pksclient +bin/pksd +bin/pksdctl +etc/rc.d/pksd.sh +@unexec if cmp -s %D/etc/pksd.conf %D/share/examples/pksd.conf; then rm -f %D/etc/pksd.conf; fi +share/examples/pksd.conf +share/pks/mail_intro +share/pks/pks_help.en +@dirrm share/pks |