update to 1.4-7; generate news user if necessary;

use BSD install programs, not cp; mktemp -> mkstemp;
setreuid -> setuid; update packing list; don't
even try to build a package as it won't install
correctly
This commit is contained in:
marc 1998-07-25 06:16:10 +00:00
parent 9fc633cff3
commit 4fca24adba
10 changed files with 276 additions and 149 deletions

View File

@ -1,22 +1,21 @@
# OpenBSD makefile for: leafnode
# Version required: 1.0.2
# Version required: 1.4-7
# Date created: 19 Dec 1997
# Whom: joey
#
# $OpenBSD: Makefile,v 1.1.1.1 1997/12/20 02:03:08 joey Exp $
# $OpenBSD: Makefile,v 1.2 1998/07/25 06:16:10 marc Exp $
#
DISTNAME= leafnode-1.0.2
CATEGORIES= news
MASTER_SITES= ${MASTER_SITE_SUNSITE}
DISTNAME= leafnode-1.4-7
PKGNAME= leafnode-1.4.7
CATEGORIES= news
MAINTAINER= marc@OpenBSD.ORG
MASTER_SITES= ${MASTER_SITE_SUNSITE}
MASTER_SITE_SUBDIR= system/news/readers
EXTRACT_SUFX= .src.elf.tgz
EXTRACT_SUFX= .src.elf.tar.gz
MAINTAINER= joey@OpenBSD.ORG
MAN8= fetch.8 leafnode.8 texpire.8
post-install:
strip ${PREFIX}/sbin/fetch ${PREFIX}/sbin/leafnode ${PREFIX}/sbin/texpire
NO_PACKAGE= "won't install correctly"
.include <bsd.port.mk>

View File

@ -1 +1 @@
MD5 (leafnode-1.0.2.src.elf.tgz) = 525afc4a4b99962de82dbf9cc8148cf9
MD5 (leafnode-1.4-7.src.elf.tar.gz) = db921095821f58e644ac77bd88bfac87

View File

@ -1,12 +1,114 @@
*** fetch.c.orig Fri Jul 4 10:32:32 1997
--- fetch.c Fri Jul 4 10:32:39 1997
***************
*** 14,20 ****
#include <ctype.h>
#include <dirent.h>
#include <fcntl.h>
- #include <malloc.h>
#include <netdb.h>
#include <netinet/in.h>
#include <pwd.h>
--- 14,19 ----
--- Makefile.orig Sun Mar 1 11:48:31 1998
+++ Makefile Fri Jul 24 22:58:37 1998
@@ -4,7 +4,7 @@
DEBUG = $(RPM_OPT_FLAGS) -O2 -Wall -Wformat -Wstrict-prototypes -Wmissing-prototypes
CFLAGS = $(DEBUG)
LIBS =
-PREFIX_USR = /usr
+PREFIX_USR = ${PREFIX}
PREFIX_VAR = /var
BINDIR = $(PREFIX_USR)/sbin
MANDIR = $(PREFIX_USR)/man
@@ -13,13 +13,18 @@
# this is the directory where the news is stored.
SPOOLDIR = $(PREFIX_VAR)/spool/news
#
-# this is the directory where the configuration and group information is
-# kept. It should preferably not be on the same partition as spooldir
+# ETCDIR is where the program will look for configuration and
+# group information, LIBDIR is where an example configuration
+# file will be placed.
+# They should preferably not be on the same partition as spooldir
LIBDIR = $(PREFIX_USR)/lib/leafnode
+ETCDIR = /etc/leafnode
+
#
# This is the lock file for fetch. The normal locations for such lock
# files are /var/run or /var/lock.
-LOCKFILE = "/var/run/news/fetch.lck"
+LOCKDIR = ${PREFIX_VAR}/run/news
+LOCKFILE = ${LOCKDIR}/fetch.lck
all: nntpd fetch texpire checkgroups
@@ -43,7 +48,7 @@
config.o: config.c Makefile
$(CC) -c -DSPOOLDIR=\"$(SPOOLDIR)\" \
- -DLIBDIR=\"$(LIBDIR)\" \
+ -DLIBDIR=\"$(ETCDIR)\" \
-DLOCKFILE=\"$(LOCKFILE)\" \
-DVERSION=\"$(VERSION)\" $<
@@ -53,23 +58,23 @@
cp texpire $(BINDIR)/texpire
cp checkgroups $(BINDIR)/checkgroups
cp *.8 $(MANDIR)/man8
- -mkdir -p /var/run/news
- chown news.news /var/run/news
+ -mkdir -p ${LOCKDIR}
+ chown news.news ${LOCKDIR}
chmod 750 $(BINDIR)/{leafnode,fetch,texpire,checkgroups}
chown news.news $(BINDIR)/{leafnode,fetch,texpire,checkgroups}
install: nntpd fetch texpire checkgroups
- cp nntpd $(BINDIR)/leafnode
- cp fetch $(BINDIR)/fetch
- cp texpire $(BINDIR)/texpire
- cp checkgroups $(BINDIR)/checkgroups
- cp newsq $(BINDIR)/newsq
- cp texpire.cron $(BINDIR)/texpire.cron
- cp *.8 $(MANDIR)/man8
- cp newsq.1 $(MANDIR)/man1
- -mkdir -p $(PREFIX_VAR)/run/news
- chown news.news $(PREFIX_VAR)/run/news
- -mkdir -p $(SPOOLDIR) $(LIBDIR)
+ ${BSD_INSTALL_PROGRAM} nntpd $(BINDIR)/leafnode
+ ${BSD_INSTALL_PROGRAM} fetch $(BINDIR)/fetch
+ ${BSD_INSTALL_PROGRAM} texpire $(BINDIR)/texpire
+ ${BSD_INSTALL_PROGRAM} checkgroups $(BINDIR)/checkgroups
+ ${BSD_INSTALL_PROGRAM} newsq $(BINDIR)/newsq
+ ${BSD_INSTALL_PROGRAM} texpire.cron $(BINDIR)/texpire.cron
+ ${BSD_INSTALL_MAN} *.8 $(MANDIR)/man8
+ ${BSD_INSTALL_MAN} newsq.1 $(MANDIR)/man1
+ -mkdir -p $(LOCKDIR)
+ chown news.news $(LOCKDIR)
+ -mkdir -p $(SPOOLDIR) $(LIBDIR) $(ETCDIR)
-mkdir -p $(SPOOLDIR)/{message.id,interesting.groups,out.going,failed.postings}
cd $(SPOOLDIR)/message.id ; for a in 0 1 2 3 4 5 6 7 8 9 ; do \
for b in 0 1 2 3 4 5 6 7 8 9 ; do \
@@ -78,12 +83,20 @@
$${a}$${b}6 $${a}$${b}7 $${a}$${b}8 \
$${a}$${b}9 ; \
done ; done
- cp config.example $(LIBDIR)/config
- chown -R news.news $(LIBDIR) $(SPOOLDIR)
+ ${BSD_INSTALL_DATA} README INSTALL config.example $(LIBDIR)
+ test -f $(ETCDIR)/config || \
+ ${BSD_INSTALL_DATA} config.example $(ETCDIR)/config
+ chown -R news.news $(ETCDIR) $(LIBDIR) $(SPOOLDIR)
chmod 2750 $(SPOOLDIR)
chmod 750 $(BINDIR)/{leafnode,fetch,texpire,checkgroups,newsq,texpire.cron}
chown news.news $(BINDIR)/{leafnode,fetch,texpire,checkgroups,newsq,texpire.cron}
- @echo edit /etc/inetd.conf to start $(BINDIR)/leafnode
+ @echo ""
+ @echo "*** edit /etc/inetd.conf to start $(BINDIR)/leafnode"
+ @echo "*** Verify $(ETCDIR)/config -- a copy of which is saved"
+ @echo "*** as $(LIBDIR)/config.example."
+ @echo "*** See $(LIBDIR)/README" and
+ @echo "*** $(LIBDIR)/INSTALL for more information"
+ @echo ""
install-bin:
cp linux.bin/nntpd $(BINDIR)/leafnode
@@ -94,8 +107,8 @@
cp texpire.cron $(BINDIR)/texpire.cron
cp *.8 $(MANDIR)/man8
cp newsq.1 $(MANDIR)/man1
- -mkdir -p $(PREFIX_VAR)/run/news
- chown news.news $(PREFIX_VAR)/run/news
+ -mkdir -p $(LOCKDIR)
+ chown news.news $(LOCKDIR)
-mkdir -p $(SPOOLDIR) $(LIBDIR)
-mkdir -p $(SPOOLDIR)/{message.id,interesting.groups,out.going,failed.postings}
cd $(SPOOLDIR)/message.id ; for a in 0 1 2 3 4 5 6 7 8 9 ; do \

View File

@ -1,33 +1,30 @@
*** util.c.orig Fri Jul 4 10:29:40 1997
--- util.c Fri Jul 4 10:32:43 1997
***************
*** 16,22 ****
#include <ctype.h>
#include <errno.h>
#include <limits.h>
- #include <malloc.h>
#include <netdb.h>
#include <setjmp.h>
#include <signal.h>
--- 16,21 ----
***************
*** 485,491 ****
--- util.c.~1~ Sun Mar 1 09:50:07 1998
+++ util.c Fri Jul 24 22:09:07 1998
@@ -1172,7 +1172,7 @@
supplement = ns;
} else {
syslog( LOG_ERR,
- "impossibility 122", s );
+ "impossibility 122" );
exit( 2 );
}
} else {
@@ -1686,7 +1686,7 @@
error, getcwd( s, 1024 ) );
strcpy(s, libdir);
strcat(s, "/groupinfo");
- fd = open( s, O_RDONLY );
if ( stat( s, &st ) ) {
syslog( LOG_ERR, "can't stat %s: %m", s );
return;
--- 484,489 ----
***************
*** 494,499 ****
--- 492,499 ----
if ( (fd=open( s, O_RDONLY))<0 ||
(read( fd, stuff, st.st_size ) < st.st_size) ) {
syslog( LOG_ERR, "can't open/read %s: %m", s );
+ if (fd >= 0)
+ close( fd );
return;
} else {
close( fd );
strcpy( newfile, ".overview.XXXXXX" );
- if ( (wfd=open( mktemp(newfile), O_WRONLY|O_CREAT|O_EXCL, 0664 )) ) {
+ if ( (wfd=mkstemp(newfile)) != -1 ) {
struct iovec oooh[UIO_MAXIOV];
int vi, vc, va;
@@ -1739,8 +1739,7 @@
.overview file I think */
}
} else {
- syslog( LOG_ERR, "open(O_WRONLY|O_CREAT|O_EXCL) of new "
- ".overview failed: %m" );
+ syslog( LOG_ERR, "mkstemp of new .overview failed: %m" );
}
}
return 1;

View File

@ -1,69 +1,13 @@
*** Makefile.orig Tue May 27 09:50:36 1997
--- Makefile Fri Jul 4 10:50:49 1997
***************
*** 4,11 ****
DEBUG = -O2 -m486 -fno-strength-reduce -Wall -Wformat -Wstrict-prototypes -Wmissing-prototypes
CFLAGS = $(DEBUG)
LIBS =
! BINDIR = /usr/sbin
! MANDIR = /usr/man
VERSION = 1.0.2
#
# this is the directory where the news is stored.
--- 4,11 ----
DEBUG = -O2 -m486 -fno-strength-reduce -Wall -Wformat -Wstrict-prototypes -Wmissing-prototypes
CFLAGS = $(DEBUG)
LIBS =
! BINDIR = $(PREFIX)/sbin
! MANDIR = $(PREFIX)/man
VERSION = 1.0.2
#
# this is the directory where the news is stored.
***************
*** 13,19 ****
#
# this is the directory where the configuration and group information is
# kept. It should preferably not be on the same partition as spooldir
! LIBDIR = /usr/lib/leafnode
--- fetch.c.~1~ Sun Mar 1 09:32:00 1998
+++ fetch.c Fri Jul 24 22:18:05 1998
@@ -918,8 +918,8 @@
exit( 1 );
}
all: nntpd fetch texpire
- setregid( pw->pw_gid, pw->pw_gid );
- setreuid( pw->pw_uid, pw->pw_uid );
+ setgid( pw->pw_gid );
+ setuid( pw->pw_uid );
--- 13,19 ----
#
# this is the directory where the configuration and group information is
# kept. It should preferably not be on the same partition as spooldir
! LIBDIR = $(PREFIX)/lib/leafnode
all: nntpd fetch texpire
***************
*** 41,54 ****
cp texpire $(BINDIR)
cp *.8 $(MANDIR)/man8
-mkdir -p $(SPOOLDIR) $(LIBDIR)
! -mkdir -p $(SPOOLDIR)/{message.id,interesting.groups,out.going}
@echo This is actually quite fast, for _small_ servers.
! mkdir -p /var/spool/news/message.id/{0,1,2,3,4,5,6,7,8,9}{0,12,3,4,5,6,7,8,9}{0,1,2,3,4,5,6,7,8,9}
! cp config.example /usr/lib/leafnode/config
chown -R news.news $(LIBDIR) $(SPOOLDIR)
chmod 2750 $(SPOOLDIR)
! chmod 750 $(BINDIR)/{leafnode,fetch,texpire}
! chown news.news $(BINDIR)/{leafnode,fetch,texpire}
@echo edit /etc/inetd.conf to start $(BINDIR)/leafnode
dist:
--- 41,54 ----
cp texpire $(BINDIR)
cp *.8 $(MANDIR)/man8
-mkdir -p $(SPOOLDIR) $(LIBDIR)
! -csh -c 'mkdir -p $(SPOOLDIR)/{message.id,interesting.groups,out.going}'
@echo This is actually quite fast, for _small_ servers.
! csh -c 'mkdir -p /var/spool/news/message.id/{0,1,2,3,4,5,6,7,8,9}{0,1,2,3,4,5,6,7,8,9}{0,1,2,3,4,5,6,7,8,9}'
! cp config.example $(LIBDIR)/config.example
chown -R news.news $(LIBDIR) $(SPOOLDIR)
chmod 2750 $(SPOOLDIR)
! csh -c 'chmod 750 $(BINDIR)/{leafnode,fetch,texpire}'
! csh -c 'chown news.news $(BINDIR)/{leafnode,fetch,texpire}'
@echo edit /etc/inetd.conf to start $(BINDIR)/leafnode
dist:
if ( getuid() != pw->pw_uid || getgid() != pw->pw_gid ) {
fprintf( stderr, "%s: must be run as news or root\n", argv[0] );

View File

@ -1,11 +1,11 @@
--- util.c.orig Tue Oct 29 20:26:36 1996
+++ util.c Fri Dec 19 16:52:20 1997
@@ -1331,7 +1331,7 @@
error, getcwd( s, 1024 ) );
--- checkgroups.c.~1~ Wed Jul 23 11:35:26 1997
+++ checkgroups.c Fri Jul 24 22:20:15 1998
@@ -72,7 +72,7 @@
}
strcpy( newfile, ".overview.XXXXXX" );
- if ( (wfd=open( mktemp(newfile), O_WRONLY|O_CREAT|O_EXCL, 0664 )) ) {
+ if ( (wfd=open( mkstemp(newfile), O_WRONLY|O_CREAT|O_EXCL, 0664 )) ) {
struct iovec oooh[UIO_MAXIOV];
int vi, vc, va;
setgid( pw->pw_gid );
- setreuid( pw->pw_uid, pw->pw_uid );
+ setuid( pw->pw_uid );
if ( getuid() != pw->pw_uid || getgid() != pw->pw_gid ) {
fprintf( stderr, "%s: must be run as news or root\n", argv[0] );

View File

@ -1,11 +1,20 @@
--- fetch.c.orig Sun Oct 27 19:34:06 1996
+++ fetch.c Fri Dec 19 16:42:23 1997
@@ -645,7 +645,7 @@
struct newsgroup * g;
--- texpire.c.orig Wed Jul 23 11:35:26 1997
+++ texpire.c Fri Jul 24 22:38:02 1998
@@ -59,7 +59,7 @@
FILE * f;
char *l, *group, *stime, *end;
unsigned long i;
- struct expire_entry *ent, *prev = NULL;
+ struct expire_entry *ent = NULL, *prev = NULL;
strcpy( newfile, ".supplement.XXXXX" );
- o = fopen( mktemp( newfile ), "w" );
+ o = fopen( mkstemp( newfile ), "w" );
sprintf(s, "%s/expireinfo", libdir);
if ((f = fopen(s, "r"))) {
@@ -493,7 +493,7 @@
}
sprintf( s, "%s/interesting.groups",
spooldir );
setgid( pw->pw_gid );
- setreuid( pw->pw_uid, pw->pw_uid );
+ setuid( pw->pw_uid );
if ( getuid() != pw->pw_uid || getgid() != pw->pw_gid ) {
fprintf( stderr, "%s: must be run as news or root\n", argv[0] );

View File

@ -1,5 +1,4 @@
Leafnode v1.0.2 is a simple NNTP server designed for small sites.
It does NOT have NOV support.
Leafnode is a simple NNTP server designed for small sites.
It "learns" which newsgroups should be downloaded based on what's
accessed.

View File

@ -1,7 +1,32 @@
@cwd /usr/local
@name leafnode-1.4.7
lib/leafnode/config.example
lib/leafnode/README
lib/leafnode/INSTALL
man/man1/newsq.1
man/man8/fetch.8
man/man8/checkgroups.8
man/man8/leafnode.8
man/man8/texpire.8
sbin/fetch
sbin/leafnode
sbin/fetch
sbin/texpire
sbin/checkgroups
sbin/newsq
sbin/texpire.cron
@dirrm lib/leafnode
@comment Lots of things to do by hand to install
@exec echo ""
@exec echo "*** edit /etc/inetd.conf to start %D/sbin/leafnode"
@exec echo "*** Verify /etc/config -- a copy of which is saved"
@exec echo "*** as %D/lib/leafnode/config.example. See"
@exec echo "*** %D/lib/leafnode/README and"
@exec echo "*** %D/lib/leafnode/INSTALL for more information"
@exec echo ""
@unexec echo ""
@unexec echo "*** To completely remove this package you must issue the"
@unexec echo "*** following commands as root. Be sure you want to do this."
@unexec echo "*** rm -rf /etc/leafnode"
@unexec echo "*** rm -rf /var/run/news"
@unexec echo "*** rm -rf /var/spool/news"
@unexec echo ""

View File

@ -0,0 +1,52 @@
#!/usr/bin/perl
#
eval '(exit $?0)' && eval 'exec /usr/bin/perl -S $0 ${1+"$@"}'
& eval 'exec /usr/bin/perl -S $0 $argv:q'
if 0;
if( $> ) {
print "\nYou must be root to run this step!\n\n";
exit 1;
}
if( getpwnam( "news" ) ) {
( $null, $null, $pgUID ) = getpwnam( "news" );
} else {
$pgUID = 75;
while( getpwuid( $pgUID ) ) {
$pgUID++;
}
}
if( getgrnam( "news" ) ) {
( $null, $null, $pgGID ) = getgrnam( "news" );
} else {
$pgGID = 75;
while( getgrgid( $pgGID ) ) {
$pgGID++;
}
&append_file( "/etc/group", "news:*:$pgGID:" );
}
print "news user using uid $pgUID\n";
print "news user using gid $pgGID\n";
print( "/usr/bin/chpass -a \"news:*:$pgUID\:$pgGID\:\:\:\:news pseudo-user:/var/spool/news:/bin/sh\"" );
system( "/usr/bin/chpass -a \"news:*:$pgUID\:$pgGID\:\:\:\:news pseudo-user:/var/spool/news:/bin/sh\"" );
print( "\n" );
sub append_file {
local($file,@list) = @_;
local($LOCK_EX) = 2;
local($LOCK_NB) = 4;
local($LOCK_UN) = 8;
open(F, ">> $file") || die "$file: $!\n";
while( ! flock( F, $LOCK_EX | $LOCK_NB ) ) {
exit 1;
}
print F join( "\n", @list) . "\n";
close F;
flock( F, $LOCK_UN );
}