Update to 0.44 with some patches from CVS.
Notable changes to the port: - creates opennap user/group to run as - tons of bugfixes, improved performance - no longer hardcodes SYSCONFDIR to /etc/opennap Submitted by Jolan Luff <jolan@pellaeon.com>.
This commit is contained in:
parent
66b2a1ee27
commit
c208dc5df3
@ -1,25 +1,31 @@
|
||||
# $OpenBSD: Makefile,v 1.7 2002/07/30 14:36:49 brad Exp $
|
||||
# $OpenBSD: Makefile,v 1.8 2002/08/10 01:14:04 naddy Exp $
|
||||
|
||||
COMMENT= "opensource Napster(tm) server"
|
||||
|
||||
DISTNAME= opennap-0.42
|
||||
DISTNAME= opennap-0.44
|
||||
CATEGORIES= audio net
|
||||
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE:=opennap/}
|
||||
|
||||
HOMEPAGE= http://opennap.sourceforge.net/
|
||||
|
||||
MAINTAINER= Jolan Luff <jolan@cryptonomicon.org>
|
||||
|
||||
# GPL
|
||||
PERMIT_PACKAGE_CDROM= Yes
|
||||
PERMIT_PACKAGE_FTP= Yes
|
||||
PERMIT_DISTFILES_CDROM= Yes
|
||||
PERMIT_DISTFILES_FTP= Yes
|
||||
|
||||
SYSCONFDIR= /etc/opennap
|
||||
SEPARATE_BUILD= concurrent
|
||||
USE_GMAKE= Yes
|
||||
CONFIGURE_STYLE= gnu
|
||||
CONFIGURE_ARGS= --enable-resume
|
||||
CONFIGURE_STYLE=gnu
|
||||
CONFIGURE_ARGS= \
|
||||
--enable-email \
|
||||
--enable-resume \
|
||||
--datadir=${SYSCONFDIR}
|
||||
# --enable-chroot \ (breaks uid, gid, and ip lookup
|
||||
|
||||
DOCS= README napster.txt
|
||||
DOCS= FAQ README manual.html napster.txt
|
||||
|
||||
post-install:
|
||||
${INSTALL_DATA_DIR} ${PREFIX}/share/doc/opennap
|
||||
|
@ -1,3 +1,3 @@
|
||||
MD5 (opennap-0.42.tar.gz) = fdea358b1beddec752d5515e1b53c823
|
||||
RMD160 (opennap-0.42.tar.gz) = 927a283fd458dcfd117e77cac021e52bf42a1639
|
||||
SHA1 (opennap-0.42.tar.gz) = cdc500f1a57c3efa94280971d335e869fe535ae9
|
||||
MD5 (opennap-0.44.tar.gz) = 1dcce1826283888111fb9fbe0684f6f2
|
||||
RMD160 (opennap-0.44.tar.gz) = af54ffb3b2183fe4858ec4548bdaeb177e566c79
|
||||
SHA1 (opennap-0.44.tar.gz) = 2abd38d440087913bd711aa5a2eb54d0ec423501
|
||||
|
20
audio/opennap/patches/patch-FAQ
Normal file
20
audio/opennap/patches/patch-FAQ
Normal file
@ -0,0 +1,20 @@
|
||||
$OpenBSD: patch-FAQ,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- FAQ.orig Thu Mar 8 17:55:02 2001
|
||||
+++ FAQ Tue Oct 16 23:02:47 2001
|
||||
@@ -42,6 +42,16 @@ A: Find the people who run the server y
|
||||
with them. If both parties agree you exchange a password and follow
|
||||
the directions in the README for linking up.
|
||||
|
||||
+Q: What is a metaserver? Do I need to run one?
|
||||
+A: A metaserver is a small server that attempts to provide load balancing
|
||||
+ to a cluster of linked OpenNap servers. You give it a list of all the
|
||||
+ servers in your cluster, and it will cycle through the list each time
|
||||
+ a connection is made. Originally, the Napster client would connect to
|
||||
+ the metaserver to find out which Napster server to connect to.
|
||||
+ However, most clients these days just have support for a list of
|
||||
+ servers to connect directly to, totally ignoring the metaserver.
|
||||
+ Hence, running a metaserver is NOT required.
|
||||
+
|
||||
* Configuration - Win32
|
||||
|
||||
Q: How do I get more than 256 connections under Windows?
|
32
audio/opennap/patches/patch-Makefile_am
Normal file
32
audio/opennap/patches/patch-Makefile_am
Normal file
@ -0,0 +1,32 @@
|
||||
$OpenBSD: patch-Makefile_am,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- Makefile.am.orig Tue Sep 25 23:59:56 2001
|
||||
+++ Makefile.am Tue Oct 16 18:14:04 2001
|
||||
@@ -1,5 +1,5 @@
|
||||
-sbin_PROGRAMS=opennap metaserver setup #mkpass
|
||||
-opennap_SOURCES=opennap.h main.c add_file.c search.c \
|
||||
+sbin_PROGRAMS=opennap metaserver setup
|
||||
+opennap_SOURCES=opennap.h main.c add_file.c discipline.c search.c \
|
||||
motd.c hash.h hash.c privmsg.c browse.c \
|
||||
debug.c debug.h login.c whois.c free_user.c \
|
||||
join.c part.c public.c part_channel.c \
|
||||
@@ -14,17 +14,16 @@ opennap_SOURCES=opennap.h main.c add_fil
|
||||
napigator.c win32-support.h #fast_snprintf.c
|
||||
opennap_LDADD=$(REGEX)
|
||||
opennap_DEPENDENCIES=$(REGEX)
|
||||
-#mkpass_SOURCES=mkpass.c md5.c debug.c util.c
|
||||
metaserver_SOURCES=metaserver.c
|
||||
setup_SOURCES=setup.c
|
||||
EXTRA_opennap_SOURCES=regex.c _regex.h
|
||||
EXTRA_DIST=sample.config sample.motd napster.txt .indent.pro \
|
||||
FAQ spyserv.c opennap.dsw opennap.dsp \
|
||||
opennap.opt sample.users sample.servers opennap.spec \
|
||||
- getopt.c mkpass.dsp sample.channels \
|
||||
- napchk logchk setup.dsp opennap.init sample.filter mkpass.c \
|
||||
+ getopt.c sample.channels \
|
||||
+ napchk logchk setup.dsp opennap.init sample.filter \
|
||||
manual.html start_opennap sample.block win98se_max_conn.reg \
|
||||
- notes.txt sample.block
|
||||
+ notes.txt sample.block metaserver.dsp
|
||||
INCLUDES=-DSHAREDIR=\"@SHAREDIR@\"
|
||||
|
||||
.PHONY: log
|
261
audio/opennap/patches/patch-Makefile_in
Normal file
261
audio/opennap/patches/patch-Makefile_in
Normal file
@ -0,0 +1,261 @@
|
||||
$OpenBSD: patch-Makefile_in,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- Makefile.in.orig Sun Sep 30 17:13:45 2001
|
||||
+++ Makefile.in Tue Oct 16 18:14:04 2001
|
||||
@@ -65,16 +65,15 @@ REGEX = @REGEX@
|
||||
SHAREDIR = @SHAREDIR@
|
||||
VERSION = @VERSION@
|
||||
|
||||
-sbin_PROGRAMS = opennap metaserver setup #mkpass
|
||||
-opennap_SOURCES = opennap.h main.c add_file.c search.c motd.c hash.h hash.c privmsg.c browse.c debug.c debug.h login.c whois.c free_user.c join.c part.c public.c part_channel.c announce.c kill_user.c remove_connection.c config.c download.c upload_complete.c topic.c muzzle.c level.c client_quit.c server_login.c server_connect.c synch.c util.c md5.c md5.h hotlist.c remove_file.c list_channels.c list_users.c ping.c resume.c change.c ban.c network.c buffer.c server_usage.c server_links.c init.c handler.c timer.c list.c list.h userdb.c serverlib.c kick.c usermode.c channel.c glob.c redirect.c filter.c hashlist.h hashlist.c class.c napigator.c win32-support.h #fast_snprintf.c
|
||||
+sbin_PROGRAMS = opennap metaserver setup
|
||||
+opennap_SOURCES = opennap.h main.c add_file.c discipline.c search.c motd.c hash.h hash.c privmsg.c browse.c debug.c debug.h login.c whois.c free_user.c join.c part.c public.c part_channel.c announce.c kill_user.c remove_connection.c config.c download.c upload_complete.c topic.c muzzle.c level.c client_quit.c server_login.c server_connect.c synch.c util.c md5.c md5.h hotlist.c remove_file.c list_channels.c list_users.c ping.c resume.c change.c ban.c network.c buffer.c server_usage.c server_links.c init.c handler.c timer.c list.c list.h userdb.c serverlib.c kick.c usermode.c channel.c glob.c redirect.c filter.c hashlist.h hashlist.c class.c napigator.c win32-support.h #fast_snprintf.c
|
||||
|
||||
opennap_LDADD = $(REGEX)
|
||||
opennap_DEPENDENCIES = $(REGEX)
|
||||
-#mkpass_SOURCES=mkpass.c md5.c debug.c util.c
|
||||
metaserver_SOURCES = metaserver.c
|
||||
setup_SOURCES = setup.c
|
||||
EXTRA_opennap_SOURCES = regex.c _regex.h
|
||||
-EXTRA_DIST = sample.config sample.motd napster.txt .indent.pro FAQ spyserv.c opennap.dsw opennap.dsp opennap.opt sample.users sample.servers opennap.spec getopt.c mkpass.dsp sample.channels napchk logchk setup.dsp opennap.init sample.filter mkpass.c manual.html start_opennap sample.block win98se_max_conn.reg notes.txt sample.block
|
||||
+EXTRA_DIST = sample.config sample.motd napster.txt .indent.pro FAQ spyserv.c opennap.dsw opennap.dsp opennap.opt sample.users sample.servers opennap.spec getopt.c sample.channels napchk logchk setup.dsp opennap.init sample.filter manual.html start_opennap sample.block win98se_max_conn.reg notes.txt sample.block metaserver.dsp
|
||||
|
||||
INCLUDES = -DSHAREDIR=\"@SHAREDIR@\"
|
||||
ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
|
||||
@@ -88,15 +87,15 @@ DEFS = @DEFS@ -I. -I$(srcdir) -I.
|
||||
CPPFLAGS = @CPPFLAGS@
|
||||
LDFLAGS = @LDFLAGS@
|
||||
LIBS = @LIBS@
|
||||
-opennap_OBJECTS = main.o add_file.o search.o motd.o hash.o privmsg.o \
|
||||
-browse.o debug.o login.o whois.o free_user.o join.o part.o public.o \
|
||||
-part_channel.o announce.o kill_user.o remove_connection.o config.o \
|
||||
-download.o upload_complete.o topic.o muzzle.o level.o client_quit.o \
|
||||
-server_login.o server_connect.o synch.o util.o md5.o hotlist.o \
|
||||
-remove_file.o list_channels.o list_users.o ping.o resume.o change.o \
|
||||
-ban.o network.o buffer.o server_usage.o server_links.o init.o handler.o \
|
||||
-timer.o list.o userdb.o serverlib.o kick.o usermode.o channel.o glob.o \
|
||||
-redirect.o filter.o hashlist.o class.o napigator.o
|
||||
+opennap_OBJECTS = main.o add_file.o discipline.o search.o motd.o hash.o \
|
||||
+privmsg.o browse.o debug.o login.o whois.o free_user.o join.o part.o \
|
||||
+public.o part_channel.o announce.o kill_user.o remove_connection.o \
|
||||
+config.o download.o upload_complete.o topic.o muzzle.o level.o \
|
||||
+client_quit.o server_login.o server_connect.o synch.o util.o md5.o \
|
||||
+hotlist.o remove_file.o list_channels.o list_users.o ping.o resume.o \
|
||||
+change.o ban.o network.o buffer.o server_usage.o server_links.o init.o \
|
||||
+handler.o timer.o list.o userdb.o serverlib.o kick.o usermode.o \
|
||||
+channel.o glob.o redirect.o filter.o hashlist.o class.o napigator.o
|
||||
opennap_LDFLAGS =
|
||||
metaserver_OBJECTS = metaserver.o
|
||||
metaserver_LDADD = $(LDADD)
|
||||
@@ -119,6 +118,23 @@ DISTFILES = $(DIST_COMMON) $(SOURCES) $(
|
||||
|
||||
TAR = tar
|
||||
GZIP_ENV = --best
|
||||
+DEP_FILES = .deps/add_file.P .deps/announce.P .deps/ban.P \
|
||||
+.deps/browse.P .deps/buffer.P .deps/change.P .deps/channel.P \
|
||||
+.deps/class.P .deps/client_quit.P .deps/config.P .deps/debug.P \
|
||||
+.deps/discipline.P .deps/download.P .deps/filter.P .deps/free_user.P \
|
||||
+.deps/glob.P .deps/handler.P .deps/hash.P .deps/hashlist.P \
|
||||
+.deps/hotlist.P .deps/init.P .deps/join.P .deps/kick.P \
|
||||
+.deps/kill_user.P .deps/level.P .deps/list.P .deps/list_channels.P \
|
||||
+.deps/list_users.P .deps/login.P .deps/main.P .deps/md5.P \
|
||||
+.deps/metaserver.P .deps/motd.P .deps/muzzle.P .deps/napigator.P \
|
||||
+.deps/network.P .deps/part.P .deps/part_channel.P .deps/ping.P \
|
||||
+.deps/privmsg.P .deps/public.P .deps/redirect.P .deps/regex.P \
|
||||
+.deps/remove_connection.P .deps/remove_file.P .deps/resume.P \
|
||||
+.deps/search.P .deps/server_connect.P .deps/server_links.P \
|
||||
+.deps/server_login.P .deps/server_usage.P .deps/serverlib.P \
|
||||
+.deps/setup.P .deps/synch.P .deps/timer.P .deps/topic.P \
|
||||
+.deps/upload_complete.P .deps/userdb.P .deps/usermode.P .deps/util.P \
|
||||
+.deps/whois.P
|
||||
SOURCES = $(opennap_SOURCES) $(EXTRA_opennap_SOURCES) $(metaserver_SOURCES) $(setup_SOURCES)
|
||||
OBJECTS = $(opennap_OBJECTS) $(metaserver_OBJECTS) $(setup_OBJECTS)
|
||||
|
||||
@@ -126,9 +142,9 @@ all: all-redirect
|
||||
.SUFFIXES:
|
||||
.SUFFIXES: .S .c .o .s
|
||||
$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ Makefile.am $(top_srcdir)/configure.in $(ACLOCAL_M4)
|
||||
- cd $(top_srcdir) && $(AUTOMAKE) --gnu --include-deps Makefile
|
||||
+ cd $(top_srcdir) && $(AUTOMAKE) --gnu Makefile
|
||||
|
||||
-Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||
+Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status $(BUILT_SOURCES)
|
||||
cd $(top_builddir) \
|
||||
&& CONFIG_FILES=$@ CONFIG_HEADERS= $(SHELL) ./config.status
|
||||
|
||||
@@ -193,9 +209,6 @@ uninstall-sbinPROGRAMS:
|
||||
rm -f $(DESTDIR)$(sbindir)/`echo $$p|sed 's/$(EXEEXT)$$//'|sed '$(transform)'|sed 's/$$/$(EXEEXT)/'`; \
|
||||
done
|
||||
|
||||
-.c.o:
|
||||
- $(COMPILE) -c $<
|
||||
-
|
||||
.s.o:
|
||||
$(COMPILE) -c $<
|
||||
|
||||
@@ -291,6 +304,11 @@ distdir: $(DISTFILES)
|
||||
-rm -rf $(distdir)
|
||||
mkdir $(distdir)
|
||||
-chmod 777 $(distdir)
|
||||
+ here=`cd $(top_builddir) && pwd`; \
|
||||
+ top_distdir=`cd $(distdir) && pwd`; \
|
||||
+ distdir=`cd $(distdir) && pwd`; \
|
||||
+ cd $(top_srcdir) \
|
||||
+ && $(AUTOMAKE) --include-deps --build-dir=$$here --srcdir-name=$(top_srcdir) --output-dir=$$top_distdir --gnu Makefile
|
||||
@for file in $(DISTFILES); do \
|
||||
d=$(srcdir); \
|
||||
if test -d $$d/$$file; then \
|
||||
@@ -301,74 +319,38 @@ distdir: $(DISTFILES)
|
||||
|| cp -p $$d/$$file $(distdir)/$$file || :; \
|
||||
fi; \
|
||||
done
|
||||
-add_file.o: add_file.c config.h opennap.h hash.h list.h debug.h
|
||||
-announce.o: announce.c config.h opennap.h hash.h list.h debug.h
|
||||
-ban.o: ban.c config.h opennap.h hash.h list.h debug.h
|
||||
-browse.o: browse.c config.h opennap.h hash.h list.h debug.h
|
||||
-buffer.o: buffer.c config.h opennap.h hash.h list.h debug.h
|
||||
-change.o: change.c config.h opennap.h hash.h list.h debug.h
|
||||
-channel.o: channel.c config.h opennap.h hash.h list.h debug.h
|
||||
-class.o: class.c config.h opennap.h hash.h list.h hashlist.h debug.h
|
||||
-client_quit.o: client_quit.c opennap.h hash.h list.h debug.h
|
||||
-config.o: config.c config.h opennap.h hash.h list.h debug.h
|
||||
-debug.o: debug.c config.h debug.h
|
||||
-download.o: download.c config.h opennap.h hash.h list.h debug.h
|
||||
-filter.o: filter.c config.h opennap.h hash.h list.h debug.h
|
||||
-free_user.o: free_user.c config.h opennap.h hash.h list.h hashlist.h \
|
||||
- debug.h
|
||||
-glob.o: glob.c config.h opennap.h hash.h list.h
|
||||
-handler.o: handler.c config.h opennap.h hash.h list.h debug.h
|
||||
-hash.o: hash.c config.h hash.h debug.h
|
||||
-hashlist.o: hashlist.c config.h list.h hash.h hashlist.h opennap.h \
|
||||
- debug.h
|
||||
-hotlist.o: hotlist.c config.h opennap.h hash.h list.h hashlist.h debug.h
|
||||
-init.o: init.c config.h opennap.h hash.h list.h hashlist.h debug.h
|
||||
-join.o: join.c config.h opennap.h hash.h list.h debug.h
|
||||
-kick.o: kick.c config.h opennap.h hash.h list.h debug.h
|
||||
-kill_user.o: kill_user.c config.h opennap.h hash.h list.h debug.h
|
||||
-level.o: level.c config.h opennap.h hash.h list.h debug.h
|
||||
-list.o: list.c config.h list.h debug.h
|
||||
-list_channels.o: list_channels.c config.h opennap.h hash.h list.h \
|
||||
- debug.h
|
||||
-list_users.o: list_users.c config.h opennap.h hash.h list.h debug.h
|
||||
-login.o: login.c config.h opennap.h hash.h list.h hashlist.h debug.h
|
||||
-main.o: main.c config.h opennap.h hash.h list.h debug.h
|
||||
-md5.o: md5.c config.h md5.h
|
||||
-metaserver.o: metaserver.c config.h
|
||||
-motd.o: motd.c config.h opennap.h hash.h list.h debug.h
|
||||
-muzzle.o: muzzle.c config.h opennap.h hash.h list.h debug.h
|
||||
-napigator.o: napigator.c config.h opennap.h hash.h list.h debug.h md5.h
|
||||
-network.o: network.c config.h opennap.h hash.h list.h debug.h
|
||||
-part.o: part.c config.h opennap.h hash.h list.h debug.h
|
||||
-part_channel.o: part_channel.c config.h opennap.h hash.h list.h debug.h
|
||||
-ping.o: ping.c config.h opennap.h hash.h list.h debug.h
|
||||
-privmsg.o: privmsg.c config.h opennap.h hash.h list.h debug.h
|
||||
-public.o: public.c config.h opennap.h hash.h list.h debug.h
|
||||
-redirect.o: redirect.c config.h opennap.h hash.h list.h
|
||||
-remove_connection.o: remove_connection.c config.h opennap.h hash.h \
|
||||
- list.h hashlist.h debug.h
|
||||
-remove_file.o: remove_file.c config.h opennap.h hash.h list.h debug.h
|
||||
-resume.o: resume.c config.h opennap.h hash.h list.h debug.h
|
||||
-search.o: search.c config.h opennap.h hash.h list.h debug.h
|
||||
-server_connect.o: server_connect.c config.h opennap.h hash.h list.h \
|
||||
- debug.h
|
||||
-server_links.o: server_links.c config.h opennap.h hash.h list.h debug.h
|
||||
-server_login.o: server_login.c config.h opennap.h hash.h list.h debug.h \
|
||||
- md5.h
|
||||
-server_usage.o: server_usage.c config.h opennap.h hash.h list.h \
|
||||
- hashlist.h debug.h
|
||||
-serverlib.o: serverlib.c config.h opennap.h hash.h list.h debug.h
|
||||
-setup.o: setup.c config.h
|
||||
-synch.o: synch.c config.h opennap.h hash.h list.h debug.h
|
||||
-timer.o: timer.c config.h opennap.h hash.h list.h debug.h
|
||||
-topic.o: topic.c config.h opennap.h hash.h list.h debug.h
|
||||
-upload_complete.o: upload_complete.c config.h opennap.h hash.h list.h \
|
||||
- debug.h
|
||||
-userdb.o: userdb.c config.h opennap.h hash.h list.h debug.h
|
||||
-usermode.o: usermode.c config.h opennap.h hash.h list.h debug.h
|
||||
-util.o: util.c config.h md5.h opennap.h hash.h list.h debug.h
|
||||
-whois.o: whois.c config.h opennap.h hash.h list.h debug.h
|
||||
|
||||
+DEPS_MAGIC := $(shell mkdir .deps > /dev/null 2>&1 || :)
|
||||
+
|
||||
+-include $(DEP_FILES)
|
||||
+
|
||||
+mostlyclean-depend:
|
||||
+
|
||||
+clean-depend:
|
||||
+
|
||||
+distclean-depend:
|
||||
+ -rm -rf .deps
|
||||
+
|
||||
+maintainer-clean-depend:
|
||||
+
|
||||
+%.o: %.c
|
||||
+ @echo '$(COMPILE) -c $<'; \
|
||||
+ $(COMPILE) -Wp,-MD,.deps/$(*F).pp -c $<
|
||||
+ @-cp .deps/$(*F).pp .deps/$(*F).P; \
|
||||
+ tr ' ' '\012' < .deps/$(*F).pp \
|
||||
+ | sed -e 's/^\\$$//' -e '/^$$/ d' -e '/:$$/ d' -e 's/$$/ :/' \
|
||||
+ >> .deps/$(*F).P; \
|
||||
+ rm .deps/$(*F).pp
|
||||
+
|
||||
+%.lo: %.c
|
||||
+ @echo '$(LTCOMPILE) -c $<'; \
|
||||
+ $(LTCOMPILE) -Wp,-MD,.deps/$(*F).pp -c $<
|
||||
+ @-sed -e 's/^\([^:]*\)\.o[ ]*:/\1.lo \1.o :/' \
|
||||
+ < .deps/$(*F).pp > .deps/$(*F).P; \
|
||||
+ tr ' ' '\012' < .deps/$(*F).pp \
|
||||
+ | sed -e 's/^\\$$//' -e '/^$$/ d' -e '/:$$/ d' -e 's/$$/ :/' \
|
||||
+ >> .deps/$(*F).P; \
|
||||
+ rm -f .deps/$(*F).pp
|
||||
info-am:
|
||||
info: info-am
|
||||
dvi-am:
|
||||
@@ -409,25 +391,27 @@ distclean-generic:
|
||||
|
||||
maintainer-clean-generic:
|
||||
mostlyclean-am: mostlyclean-hdr mostlyclean-sbinPROGRAMS \
|
||||
- mostlyclean-compile mostlyclean-tags \
|
||||
+ mostlyclean-compile mostlyclean-tags mostlyclean-depend \
|
||||
mostlyclean-generic
|
||||
|
||||
mostlyclean: mostlyclean-am
|
||||
|
||||
clean-am: clean-hdr clean-sbinPROGRAMS clean-compile clean-tags \
|
||||
- clean-generic mostlyclean-am
|
||||
+ clean-depend clean-generic mostlyclean-am
|
||||
|
||||
clean: clean-am
|
||||
|
||||
distclean-am: distclean-hdr distclean-sbinPROGRAMS distclean-compile \
|
||||
- distclean-tags distclean-generic clean-am
|
||||
+ distclean-tags distclean-depend distclean-generic \
|
||||
+ clean-am
|
||||
|
||||
distclean: distclean-am
|
||||
-rm -f config.status
|
||||
|
||||
maintainer-clean-am: maintainer-clean-hdr maintainer-clean-sbinPROGRAMS \
|
||||
maintainer-clean-compile maintainer-clean-tags \
|
||||
- maintainer-clean-generic distclean-am
|
||||
+ maintainer-clean-depend maintainer-clean-generic \
|
||||
+ distclean-am
|
||||
@echo "This command is intended for maintainers to use;"
|
||||
@echo "it deletes files that may require special tools to rebuild."
|
||||
|
||||
@@ -439,10 +423,12 @@ mostlyclean-sbinPROGRAMS distclean-sbinP
|
||||
maintainer-clean-sbinPROGRAMS uninstall-sbinPROGRAMS \
|
||||
install-sbinPROGRAMS mostlyclean-compile distclean-compile \
|
||||
clean-compile maintainer-clean-compile tags mostlyclean-tags \
|
||||
-distclean-tags clean-tags maintainer-clean-tags distdir info-am info \
|
||||
-dvi-am dvi check check-am installcheck-am installcheck all-recursive-am \
|
||||
-install-exec-am install-exec install-data-am install-data install-am \
|
||||
-install uninstall-am uninstall all-redirect all-am all installdirs \
|
||||
+distclean-tags clean-tags maintainer-clean-tags distdir \
|
||||
+mostlyclean-depend distclean-depend clean-depend \
|
||||
+maintainer-clean-depend info-am info dvi-am dvi check check-am \
|
||||
+installcheck-am installcheck all-recursive-am install-exec-am \
|
||||
+install-exec install-data-am install-data install-am install \
|
||||
+uninstall-am uninstall all-redirect all-am all installdirs \
|
||||
mostlyclean-generic distclean-generic clean-generic \
|
||||
maintainer-clean-generic clean mostlyclean distclean maintainer-clean
|
||||
|
134
audio/opennap/patches/patch-add_file_c
Normal file
134
audio/opennap/patches/patch-add_file_c
Normal file
@ -0,0 +1,134 @@
|
||||
$OpenBSD: patch-add_file_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- add_file.c.orig Sat Sep 29 00:21:51 2001
|
||||
+++ add_file.c Wed Oct 17 13:19:27 2001
|
||||
@@ -233,6 +233,7 @@ sNewDatum (char *filename, char *hash)
|
||||
FREE (info);
|
||||
return 0;
|
||||
}
|
||||
+ strlower (info->hash);
|
||||
#endif
|
||||
return info;
|
||||
}
|
||||
@@ -248,8 +249,8 @@ sBitrateToMask (int bitrate, USER * user
|
||||
if (bitrate <= BitRate[i])
|
||||
return i;
|
||||
}
|
||||
- log_message ("sBitrateToMask(): invalid bit rate %d (%s, \"%s\")", bitrate,
|
||||
- user->nick, user->clientinfo);
|
||||
+ log_message ("sBitrateToMask(): invalid bit rate %d (%s, \"%s\")",
|
||||
+ bitrate, user->nick, user->clientinfo);
|
||||
return 0; /* invalid bitrate */
|
||||
}
|
||||
|
||||
@@ -287,6 +288,8 @@ HANDLER (add_file)
|
||||
|
||||
if (!option (ON_ALLOW_SHARE))
|
||||
return;
|
||||
+ if(con->user->level==LEVEL_LEECH)
|
||||
+ return;
|
||||
|
||||
if (Max_Shared && con->user->shared >= Max_Shared)
|
||||
{
|
||||
@@ -376,6 +379,8 @@ HANDLER (share_file)
|
||||
|
||||
if (!option (ON_ALLOW_SHARE))
|
||||
return;
|
||||
+ if(con->user->level==LEVEL_LEECH)
|
||||
+ return;
|
||||
if (Max_Shared && con->user->shared >= Max_Shared)
|
||||
{
|
||||
log_message ("add_file(): %s is already sharing %d files",
|
||||
@@ -466,6 +471,8 @@ HANDLER (add_directory)
|
||||
CHECK_USER_CLASS ("add_directory");
|
||||
if (!option (ON_ALLOW_SHARE))
|
||||
return;
|
||||
+ if(con->user->level==LEVEL_LEECH)
|
||||
+ return;
|
||||
dir = next_arg (&pkt); /* directory */
|
||||
if (!dir)
|
||||
{
|
||||
@@ -653,8 +660,40 @@ HANDLER (user_sharing)
|
||||
user->libsize);
|
||||
}
|
||||
|
||||
+void
|
||||
+unshare_all_internal (USER * user)
|
||||
+{
|
||||
+ if (user->shared)
|
||||
+ {
|
||||
+#ifndef ROUTING_ONLY
|
||||
+ if (ISUSER (user->con))
|
||||
+ {
|
||||
+ /* local user */
|
||||
+ free_hash (user->con->uopt->files);
|
||||
+ user->con->uopt->files = 0;
|
||||
+ ASSERT (Local_Files >= user->shared);
|
||||
+ Local_Files -= user->shared;
|
||||
+ }
|
||||
+#endif /* !ROUTING_ONLY */
|
||||
+ if (user->libsize > Num_Gigs)
|
||||
+ {
|
||||
+ log_message ("unshare_all: sender->libsize=%u Num_Gigs=%f",
|
||||
+ user->libsize, Num_Gigs);
|
||||
+ Num_Gigs = user->libsize;
|
||||
+ }
|
||||
+ ASSERT (Num_Gigs >= user->libsize);
|
||||
+ Num_Gigs -= user->libsize;
|
||||
+ ASSERT (Num_Files >= user->shared);
|
||||
+ Num_Files -= user->shared;
|
||||
+ user->libsize = 0;
|
||||
+ user->shared = 0;
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
/* 110 [:sender]
|
||||
- * unshare all files
|
||||
+ * unshare all files. this will handle the case of a remote server forcing
|
||||
+ * a local client to unshare all files as well, so we can have the hub
|
||||
+ * perform this action.
|
||||
*/
|
||||
HANDLER (unshare_all)
|
||||
{
|
||||
@@ -664,33 +703,18 @@ HANDLER (unshare_all)
|
||||
(void) len;
|
||||
if (pop_user_server (con, tag, &pkt, &sender_name, &sender))
|
||||
return;
|
||||
- ASSERT (sender != 0);
|
||||
-#ifndef ROUTING_ONLY
|
||||
+ if (!sender)
|
||||
+ {
|
||||
+ log_message ("unshare_all: error: received unshare message from server %s",
|
||||
+ sender_name);
|
||||
+ return;
|
||||
+ }
|
||||
if (ISUSER (con))
|
||||
{
|
||||
- if (!con->uopt->files)
|
||||
- {
|
||||
- ASSERT (sender->shared == 0);
|
||||
- return; /* nothing shared */
|
||||
- }
|
||||
+ if (sender->shared == 0)
|
||||
+ return; /* nothing to unshare */
|
||||
send_cmd (con, tag, "%d", sender->shared);
|
||||
- free_hash (con->uopt->files);
|
||||
- con->uopt->files = 0;
|
||||
- ASSERT (Local_Files >= sender->shared);
|
||||
- Local_Files -= sender->shared;
|
||||
}
|
||||
-#endif /* !ROUTING_ONLY */
|
||||
- if (sender->libsize > Num_Gigs)
|
||||
- {
|
||||
- log_message ("unshare_all: sender->libsize=%u Num_Gigs=%f",
|
||||
- sender->libsize, Num_Gigs);
|
||||
- Num_Gigs = sender->libsize;
|
||||
- }
|
||||
- ASSERT (Num_Gigs >= sender->libsize);
|
||||
- Num_Gigs -= sender->libsize;
|
||||
- ASSERT (Num_Files >= sender->shared);
|
||||
- Num_Files -= sender->shared;
|
||||
- sender->libsize = 0;
|
||||
- sender->shared = 0;
|
||||
+ unshare_all_internal (sender);
|
||||
pass_message_args (con, tag, ":%s", sender->nick);
|
||||
}
|
30
audio/opennap/patches/patch-browse_c
Normal file
30
audio/opennap/patches/patch-browse_c
Normal file
@ -0,0 +1,30 @@
|
||||
$OpenBSD: patch-browse_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- browse.c.orig Sat Sep 22 00:54:13 2001
|
||||
+++ browse.c Tue Oct 16 18:14:04 2001
|
||||
@@ -87,6 +87,12 @@ HANDLER (browse)
|
||||
}
|
||||
ASSERT (validate_user (user));
|
||||
|
||||
+ if (sender->level == LEVEL_LEECH)
|
||||
+ {
|
||||
+ send_user (sender, MSG_SERVER_BROWSE_END, "%s 0", nick);
|
||||
+ return;
|
||||
+ }
|
||||
+
|
||||
if (pkt)
|
||||
{
|
||||
result = atoi (pkt);
|
||||
@@ -349,6 +355,13 @@ HANDLER (browse_direct)
|
||||
if (!user)
|
||||
{
|
||||
nosuchuser (con);
|
||||
+ return;
|
||||
+ }
|
||||
+
|
||||
+ if (sender->level == LEVEL_LEECH)
|
||||
+ {
|
||||
+ send_user(sender,MSG_SERVER_BROWSE_DIRECT_ERR,
|
||||
+ "%s \"permission denied: you are a leech\"", user->nick);
|
||||
return;
|
||||
}
|
||||
|
12
audio/opennap/patches/patch-channel_c
Normal file
12
audio/opennap/patches/patch-channel_c
Normal file
@ -0,0 +1,12 @@
|
||||
$OpenBSD: patch-channel_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- channel.c.orig Sat Sep 22 00:54:13 2001
|
||||
+++ channel.c Mon Oct 15 15:18:44 2001
|
||||
@@ -155,7 +155,7 @@ dump_channels (void)
|
||||
HANDLER (channel_ban)
|
||||
{
|
||||
CHANNEL *chan;
|
||||
- char *av[2], *sender;
|
||||
+ char *av[3], *sender;
|
||||
int ac = -1;
|
||||
LIST **list, *tmp;
|
||||
BAN *b = 0;
|
11
audio/opennap/patches/patch-config_c
Normal file
11
audio/opennap/patches/patch-config_c
Normal file
@ -0,0 +1,11 @@
|
||||
$OpenBSD: patch-config_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- config.c.orig Sat Sep 22 01:04:26 2001
|
||||
+++ config.c Tue Oct 16 16:13:02 2001
|
||||
@@ -65,6 +65,7 @@ static struct config Vars[] = {
|
||||
#endif
|
||||
{"auto_link", VAR_TYPE_BOOL, ON_AUTO_LINK, 0, 0},
|
||||
{"auto_register", VAR_TYPE_BOOL, ON_AUTO_REGISTER, 0, 0},
|
||||
+ {"block_winmx", VAR_TYPE_INT, UL & gBlockWinMX, 0, 0},
|
||||
{"client_queue_length", VAR_TYPE_INT, UL & Client_Queue_Length, 102400,
|
||||
0},
|
||||
{"compression_level", VAR_TYPE_INT, UL & Compression_Level, 1, CF_ONCE},
|
13
audio/opennap/patches/patch-config_h_in
Normal file
13
audio/opennap/patches/patch-config_h_in
Normal file
@ -0,0 +1,13 @@
|
||||
$OpenBSD: patch-config_h_in,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- config.h.in.orig Sat Sep 22 02:23:14 2001
|
||||
+++ config.h.in Tue Oct 16 16:13:03 2001
|
||||
@@ -24,6 +24,9 @@
|
||||
/* Define if you have the alarm function. */
|
||||
#undef HAVE_ALARM
|
||||
|
||||
+/* Define if you have the getloadavg function. */
|
||||
+#undef HAVE_GETLOADAVG
|
||||
+
|
||||
/* Define if you have the getopt function. */
|
||||
#undef HAVE_GETOPT
|
||||
|
@ -1,12 +1,30 @@
|
||||
$OpenBSD: patch-configure,v 1.2 2001/07/11 02:10:06 brad Exp $
|
||||
--- configure.orig Tue Mar 6 01:49:52 2001
|
||||
+++ configure Tue Jul 10 21:15:04 2001
|
||||
@@ -1875,7 +1875,7 @@ EOF
|
||||
$OpenBSD: patch-configure,v 1.3 2002/08/10 01:14:04 naddy Exp $
|
||||
--- configure.orig Sun Sep 30 17:12:46 2001
|
||||
+++ configure Mon Aug 5 19:59:27 2002
|
||||
@@ -1802,7 +1802,7 @@ else
|
||||
echo "$ac_t""no" 1>&6
|
||||
fi
|
||||
|
||||
-for ac_func in mlockall poll
|
||||
+for ac_func in mlockall poll getloadavg
|
||||
do
|
||||
echo $ac_n "checking for $ac_func""... $ac_c" 1>&6
|
||||
echo "configure:1809: checking for $ac_func" >&5
|
||||
@@ -2003,7 +2003,7 @@ EOF
|
||||
|
||||
else
|
||||
rm -rf conftest*
|
||||
- SHAREDIR=\${pkgdatadir}
|
||||
+ SHAREDIR=\${sysconfdir}
|
||||
fi
|
||||
rm -f conftest*
|
||||
cat >> confdefs.h <<EOF
|
||||
-#define USE_UID "nobody"
|
||||
+#define USE_UID "opennap"
|
||||
EOF
|
||||
|
||||
fi
|
||||
@@ -2017,7 +2017,7 @@ EOF
|
||||
|
||||
else
|
||||
cat >> confdefs.h <<EOF
|
||||
-#define USE_GID "nobody"
|
||||
+#define USE_GID "opennap"
|
||||
EOF
|
||||
|
||||
fi
|
||||
|
24
audio/opennap/patches/patch-configure_in
Normal file
24
audio/opennap/patches/patch-configure_in
Normal file
@ -0,0 +1,24 @@
|
||||
$OpenBSD: patch-configure_in,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- configure.in.orig Sat Sep 29 00:21:51 2001
|
||||
+++ configure.in Sun Aug 4 00:09:53 2002
|
||||
@@ -28,7 +28,7 @@ fi
|
||||
AC_CHECK_LIB(xnet,gethostbyname)
|
||||
AC_CHECK_LIB(nsl,socket)
|
||||
AC_CHECK_LIB(socket,gethostbyname)
|
||||
-AC_CHECK_FUNCS(mlockall poll)
|
||||
+AC_CHECK_FUNCS(mlockall poll getloadavg)
|
||||
|
||||
dnl see if we are compiling under Win32 or Unix
|
||||
AC_MSG_CHECKING(for default config directory)
|
||||
@@ -97,9 +97,9 @@ AC_ARG_ENABLE(chroot, [ --enable-chroot
|
||||
|
||||
AC_ARG_WITH(uid, [ --with-uid=UID Switch to UID if run as root],
|
||||
[AC_DEFINE_UNQUOTED(USE_UID,"$withval")],
|
||||
- [AC_DEFINE_UNQUOTED(USE_UID,"nobody")])
|
||||
+ [AC_DEFINE_UNQUOTED(USE_UID,"opennap")])
|
||||
AC_ARG_WITH(gid, [ --with-gid=GID Switch to GID if run as root],
|
||||
[AC_DEFINE_UNQUOTED(USE_GID,"$withval")],
|
||||
- [AC_DEFINE_UNQUOTED(USE_GID,"nobody")])
|
||||
+ [AC_DEFINE_UNQUOTED(USE_GID,"opennap")])
|
||||
|
||||
AC_OUTPUT(Makefile)
|
75
audio/opennap/patches/patch-discipline_c
Normal file
75
audio/opennap/patches/patch-discipline_c
Normal file
@ -0,0 +1,75 @@
|
||||
$OpenBSD: patch-discipline_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- discipline.c.orig Fri Aug 2 22:15:44 2002
|
||||
+++ discipline.c Wed Oct 17 13:19:27 2001
|
||||
@@ -0,0 +1,71 @@
|
||||
+/* discipline.c,v 1.3 2001/10/17 18:19:27 drscholl Exp
|
||||
+ *
|
||||
+ * Open Source Napster Server - Peer-To-Peer Indexing/Chat Daemon
|
||||
+ * Copyright (C) 2001 drscholl@users.sourceforge.net
|
||||
+ *
|
||||
+ * This program is free software; you can redistribute it and/or modify
|
||||
+ * it under the terms of the GNU General Public License as published by
|
||||
+ * the Free Software Foundation; either version 2 of the License, or
|
||||
+ * (at your option) any later version.
|
||||
+ *
|
||||
+ * This program is distributed in the hope that it will be useful,
|
||||
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
+ * GNU General Public License for more details.
|
||||
+ *
|
||||
+ * You should have received a copy of the GNU General Public License
|
||||
+ * along with this program; if not, write to the Free Software
|
||||
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||
+ */
|
||||
+
|
||||
+#include "opennap.h"
|
||||
+
|
||||
+#ifndef NULL
|
||||
+#define NULL ((void*)0)
|
||||
+#endif
|
||||
+
|
||||
+void
|
||||
+discipline_user (USER * user)
|
||||
+{
|
||||
+ USERDB *db;
|
||||
+
|
||||
+ if (gBlockWinMX > 1)
|
||||
+ kill_user_internal (user->con, user, Server_Name, 0, "");
|
||||
+ else
|
||||
+ {
|
||||
+ /* set the user to LEECH */
|
||||
+
|
||||
+ if (ISUSER (user->con))
|
||||
+ {
|
||||
+ /* remove from local mods+ list */
|
||||
+ if (user->level > LEVEL_USER)
|
||||
+ Mods = list_delete (Mods, user->con);
|
||||
+ }
|
||||
+
|
||||
+ /* if the user is sharing any files, remove them now */
|
||||
+ if (user->shared)
|
||||
+ {
|
||||
+ unshare_all_internal (user);
|
||||
+ pass_message_args (NULL, MSG_CLIENT_UNSHARE_ALL, ":%s",
|
||||
+ user->nick);
|
||||
+ }
|
||||
+
|
||||
+ user->level = LEVEL_LEECH;
|
||||
+ if (user->cloaked)
|
||||
+ {
|
||||
+ notify_mods (CHANGELOG_MODE, "%s has decloaked", user->nick);
|
||||
+ user->cloaked = 0;
|
||||
+ }
|
||||
+
|
||||
+ db = hash_lookup (User_Db, user->nick);
|
||||
+ if (!db)
|
||||
+ db = create_db (user); /* not registered, force it now */
|
||||
+ db->level = LEVEL_LEECH;
|
||||
+
|
||||
+ notify_mods (LEVELLOG_MODE, "Server %s set %s's level to Leech (0)",
|
||||
+ Server_Name, user->nick);
|
||||
+
|
||||
+ pass_message_args (NULL, MSG_CLIENT_SETUSERLEVEL, ":%s %s Leech",
|
||||
+ Server_Name, user->nick);
|
||||
+ }
|
||||
+}
|
16
audio/opennap/patches/patch-download_c
Normal file
16
audio/opennap/patches/patch-download_c
Normal file
@ -0,0 +1,16 @@
|
||||
$OpenBSD: patch-download_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- download.c.orig Sat Sep 22 00:54:13 2001
|
||||
+++ download.c Tue Oct 16 18:14:04 2001
|
||||
@@ -35,6 +35,12 @@ HANDLER (download)
|
||||
return;
|
||||
}
|
||||
|
||||
+ if (sender->level == LEVEL_LEECH)
|
||||
+ {
|
||||
+ send_user (sender, MSG_SERVER_NOSUCH, "permission denied: you are a leech");
|
||||
+ return;
|
||||
+ }
|
||||
+
|
||||
/* find the user to download from */
|
||||
user = hash_lookup (Users, av[0]);
|
||||
if (!user)
|
239
audio/opennap/patches/patch-fast_snprintf_c
Normal file
239
audio/opennap/patches/patch-fast_snprintf_c
Normal file
@ -0,0 +1,239 @@
|
||||
$OpenBSD: patch-fast_snprintf_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- fast_snprintf.c.orig Fri Aug 2 22:15:44 2002
|
||||
+++ fast_snprintf.c Tue Mar 6 00:49:52 2001
|
||||
@@ -0,0 +1,235 @@
|
||||
+/* Copyright (C) 2000-1 drscholl@users.sourceforge.net
|
||||
+ This is free software distributed under the terms of the
|
||||
+ GNU Public License. See the file COPYING for details.
|
||||
+
|
||||
+ fast_snprintf.c,v 1.12 2001/03/06 06:49:52 drscholl Exp */
|
||||
+
|
||||
+#ifdef HAVE_CONFIG_H
|
||||
+#include "config.h"
|
||||
+#endif
|
||||
+
|
||||
+#include <stdarg.h>
|
||||
+#include <assert.h>
|
||||
+#include <sys/types.h>
|
||||
+#include <sys/time.h>
|
||||
+#include <stdio.h>
|
||||
+
|
||||
+#define DIGIT(n,ui) \
|
||||
+ if(ui>=(n)) { *out++ = '0' + (ui / (n)) % 10; if (--outsize == 0) break; }
|
||||
+
|
||||
+void fast_vsnprintf (char *out, size_t outsize, const char *fmt, va_list ap);
|
||||
+void fast_snprintf (char *out, size_t outsize, const char *fmt, ...);
|
||||
+
|
||||
+void
|
||||
+fast_vsnprintf (char *out, size_t outsize, const char *fmt, va_list ap)
|
||||
+{
|
||||
+ unsigned int ui;
|
||||
+ unsigned short us;
|
||||
+ int i, len;
|
||||
+ char *s;
|
||||
+ char c;
|
||||
+
|
||||
+ if (outsize == 0)
|
||||
+ return;
|
||||
+
|
||||
+ outsize--;
|
||||
+
|
||||
+ while (*fmt && outsize > 0)
|
||||
+ {
|
||||
+ if ((c = *fmt++) != '%')
|
||||
+ {
|
||||
+ *out++ = c;
|
||||
+ outsize--;
|
||||
+ }
|
||||
+ else
|
||||
+ {
|
||||
+ c = *fmt++;
|
||||
+ if (c == 's')
|
||||
+ {
|
||||
+ s = va_arg (ap, char *);
|
||||
+
|
||||
+ if (s == NULL)
|
||||
+ {
|
||||
+ if (outsize < 6)
|
||||
+ break;
|
||||
+ strcpy (out, "{null}");
|
||||
+ out+=6;
|
||||
+ outsize-=6;
|
||||
+ }
|
||||
+ else
|
||||
+ while (*s && outsize > 0)
|
||||
+ {
|
||||
+ *out++ = *s++;
|
||||
+ outsize--;
|
||||
+ }
|
||||
+ }
|
||||
+ else if (c == 'd')
|
||||
+ {
|
||||
+ i = va_arg (ap, int);
|
||||
+
|
||||
+ if (i == 0)
|
||||
+ {
|
||||
+ /* zero occurs often, so optimize for it */
|
||||
+ *out++ = '0';
|
||||
+ outsize--;
|
||||
+ }
|
||||
+ else
|
||||
+ {
|
||||
+ /* optimized for small ints */
|
||||
+ if (i < 0)
|
||||
+ {
|
||||
+ /* handle negative numbers */
|
||||
+ *out++ = '-';
|
||||
+ if (--outsize == 0)
|
||||
+ break;
|
||||
+ i *= -1;
|
||||
+ }
|
||||
+ DIGIT (100000000, i);
|
||||
+ DIGIT (10000000, i);
|
||||
+ DIGIT (1000000, i);
|
||||
+ DIGIT (100000, i);
|
||||
+ DIGIT (10000, i);
|
||||
+ DIGIT (1000, i);
|
||||
+ DIGIT (100, i);
|
||||
+ DIGIT (10, i);
|
||||
+ *out++ = '0' + i % 10;
|
||||
+ outsize--;
|
||||
+ }
|
||||
+ }
|
||||
+ else if (c == 'h' && *fmt == 'u')
|
||||
+ {
|
||||
+ fmt++;
|
||||
+ /* have to promote short to int */
|
||||
+ us = (unsigned short) va_arg (ap, unsigned int);
|
||||
+
|
||||
+ DIGIT (10000, us);
|
||||
+ DIGIT (1000, us);
|
||||
+ DIGIT (100, us);
|
||||
+ DIGIT (10, us);
|
||||
+ *out++ = '0' + us % 10;
|
||||
+ outsize--;
|
||||
+ }
|
||||
+ /* %u . assume 10 digit number. this is typically used
|
||||
+ * to either print a time_t or an ip address.
|
||||
+ */
|
||||
+ else if (c == 'u')
|
||||
+ {
|
||||
+ ui = va_arg (ap, unsigned int);
|
||||
+
|
||||
+#if 1
|
||||
+ /* this appears to be faster than the other way. my guess
|
||||
+ * is that the store of the leading 0's takes much longer
|
||||
+ * than doing ten if() evaluations. The performance is only
|
||||
+ * slightly better, and solves the problem of those ugly
|
||||
+ * leading zeros
|
||||
+ */
|
||||
+ DIGIT (1000000000, ui);
|
||||
+ DIGIT (100000000, ui);
|
||||
+ DIGIT (10000000, ui);
|
||||
+ DIGIT (1000000, ui);
|
||||
+ DIGIT (100000, ui);
|
||||
+ DIGIT (10000, ui);
|
||||
+ DIGIT (1000, ui);
|
||||
+ DIGIT (100, ui);
|
||||
+ DIGIT (10, ui);
|
||||
+ *out++ = '0' + ui % 10;
|
||||
+ outsize--;
|
||||
+#else
|
||||
+ if (outsize < 10)
|
||||
+ break;
|
||||
+ *out++ = '0' + (ui / 1000000000) % 10;
|
||||
+ *out++ = '0' + (ui / 100000000) % 10;
|
||||
+ *out++ = '0' + (ui / 10000000) % 10;
|
||||
+ *out++ = '0' + (ui / 1000000) % 10;
|
||||
+ *out++ = '0' + (ui / 100000) % 10;
|
||||
+ *out++ = '0' + (ui / 10000) % 10;
|
||||
+ *out++ = '0' + (ui / 1000) % 10;
|
||||
+ *out++ = '0' + (ui / 100) % 10;
|
||||
+ *out++ = '0' + (ui / 10) % 10;
|
||||
+ *out++ = '0' + ui % 10;
|
||||
+ outsize -= 10;
|
||||
+#endif
|
||||
+ }
|
||||
+ else if (c == 'c')
|
||||
+ {
|
||||
+ /* va_arg only takes fully promoted types, so we need
|
||||
+ * a cast here
|
||||
+ */
|
||||
+ c = (char) va_arg (ap, int);
|
||||
+
|
||||
+ *out++ = c;
|
||||
+ outsize--;
|
||||
+ }
|
||||
+ /* %f is typically used to print an integer larger than a %u */
|
||||
+ else if (c == 'f')
|
||||
+ {
|
||||
+ double f = va_arg (ap, double);
|
||||
+
|
||||
+ snprintf (out, outsize, "%.0f", f);
|
||||
+ len = strlen (out);
|
||||
+ out += len;
|
||||
+ outsize -= len;
|
||||
+ }
|
||||
+ else
|
||||
+ assert (0); /* not supported */
|
||||
+ }
|
||||
+ }
|
||||
+ *out = 0;
|
||||
+}
|
||||
+
|
||||
+void
|
||||
+fast_snprintf (char *out, size_t outsize, const char *fmt, ...)
|
||||
+{
|
||||
+ va_list ap;
|
||||
+
|
||||
+ va_start (ap, fmt);
|
||||
+ fast_vsnprintf (out, outsize, fmt, ap);
|
||||
+ va_end (ap);
|
||||
+}
|
||||
+
|
||||
+#if TEST
|
||||
+
|
||||
+#if 1
|
||||
+#define FUNC fast_snprintf
|
||||
+#else
|
||||
+#define FUNC snprintf
|
||||
+#endif
|
||||
+
|
||||
+int
|
||||
+main (int argc, char **argv)
|
||||
+{
|
||||
+ char buf[1024];
|
||||
+ char *fmt1 = "The %s brown %s jumped %s the %s dogs.";
|
||||
+ char *fmt2 = "%d %d %d %d";
|
||||
+ char *fmt3 = "blah blah blah";
|
||||
+ char *fmt4 = "%u %hu";
|
||||
+ char *fmt5 = "%d";
|
||||
+ char *fmt6 = "%u %u %u %u";
|
||||
+ int i;
|
||||
+ struct timeval s, e;
|
||||
+ char small[16];
|
||||
+
|
||||
+ memset(small,0xff,sizeof(small));
|
||||
+ fast_snprintf(small,sizeof(small)-1,"this is a very long string");
|
||||
+ memset(small,0xff,sizeof(small));
|
||||
+ fast_snprintf(small,sizeof(small)-1,"this is a ver%d", 123456);
|
||||
+ memset(small,0xff,sizeof(small));
|
||||
+ fast_snprintf(small,sizeof(small)-1,"this is a ver%s", "blah blah blah");
|
||||
+
|
||||
+ gettimeofday (&s, 0);
|
||||
+ for (i = 0; i < 10000; i++)
|
||||
+ {
|
||||
+ //FUNC (buf, sizeof (buf), fmt1, "quick", "fox", "over", "lazy");
|
||||
+ //FUNC (buf, sizeof (buf), fmt2, 1, 11, 111, 1111);
|
||||
+ //FUNC (buf, sizeof (buf), fmt3);
|
||||
+ //FUNC (buf, sizeof (buf), fmt4, 0x7fffffff, 0xffff);
|
||||
+ //FUNC (buf, sizeof (buf), fmt5, -10134);
|
||||
+ FUNC(buf,sizeof(buf),fmt6,0x7fffffff,0x0fffffff,0x00ffffff,0x000fffff);
|
||||
+ puts(buf);
|
||||
+ }
|
||||
+ gettimeofday (&e, 0);
|
||||
+
|
||||
+ printf ("%d\n",
|
||||
+ (e.tv_sec - s.tv_sec) * 1000000 + (e.tv_usec - s.tv_usec));
|
||||
+}
|
||||
+#endif
|
33
audio/opennap/patches/patch-init_c
Normal file
33
audio/opennap/patches/patch-init_c
Normal file
@ -0,0 +1,33 @@
|
||||
$OpenBSD: patch-init_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- init.c.orig Sun Sep 23 18:09:04 2001
|
||||
+++ init.c Fri Aug 2 23:11:23 2002
|
||||
@@ -121,8 +121,8 @@ drop_privs (void)
|
||||
struct passwd *pw;
|
||||
struct group *gr;
|
||||
|
||||
- n = strtol (USE_GID, &p, 10);
|
||||
- if (p)
|
||||
+ n = strtoul (USE_GID, &p, 10);
|
||||
+ if (*p)
|
||||
{
|
||||
/* probably a string */
|
||||
gr = getgrnam (USE_GID);
|
||||
@@ -139,8 +139,8 @@ drop_privs (void)
|
||||
return -1;
|
||||
}
|
||||
|
||||
- n = strtol (USE_UID, &p, 10);
|
||||
- if (p)
|
||||
+ n = strtoul (USE_UID, &p, 10);
|
||||
+ if (*p)
|
||||
{
|
||||
/* probably a string */
|
||||
pw = getpwnam (USE_UID);
|
||||
@@ -317,6 +317,7 @@ init_server (void)
|
||||
hash_set_hash_func (File_Table, hash_string, hash_compare_string);
|
||||
#if RESUME
|
||||
MD5 = hash_init (4001, 0);
|
||||
+ hash_set_hash_func (MD5, hash_string, hash_compare_string);
|
||||
#endif
|
||||
load_bans ();
|
||||
load_block ();
|
22
audio/opennap/patches/patch-level_c
Normal file
22
audio/opennap/patches/patch-level_c
Normal file
@ -0,0 +1,22 @@
|
||||
$OpenBSD: patch-level_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- level.c.orig Sat Sep 22 00:54:13 2001
|
||||
+++ level.c Wed Oct 17 13:19:27 2001
|
||||
@@ -84,7 +84,8 @@ HANDLER (level)
|
||||
else
|
||||
{
|
||||
ASSERT (ISSERVER (con));
|
||||
- log_message ("level: invalid level %s from server %s", av[1], con->host);
|
||||
+ log_message ("level: invalid level %s from server %s", av[1],
|
||||
+ con->host);
|
||||
}
|
||||
return;
|
||||
}
|
||||
@@ -144,7 +145,7 @@ HANDLER (level)
|
||||
{
|
||||
log_message ("level: %s is desynched", con->host);
|
||||
log_message ("level: %s -> %s %s", sender->nick, av[0],
|
||||
- Levels[level]);
|
||||
+ Levels[level]);
|
||||
if (curlevel != -1)
|
||||
{
|
||||
/* reset the user's level on the remote site
|
43
audio/opennap/patches/patch-main_c
Normal file
43
audio/opennap/patches/patch-main_c
Normal file
@ -0,0 +1,43 @@
|
||||
$OpenBSD: patch-main_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- main.c.orig Sun Sep 30 17:12:37 2001
|
||||
+++ main.c Tue Oct 16 18:14:04 2001
|
||||
@@ -51,6 +51,7 @@ LIST *UserClass = 0;
|
||||
|
||||
char Buf[2048]; /* global scratch buffer */
|
||||
|
||||
+int gBlockWinMX;
|
||||
HASH *Channel_Db;
|
||||
int Client_Queue_Length;
|
||||
HASH *Channels = 0; /* global channel list */
|
||||
@@ -330,7 +331,7 @@ report_stats (int fd)
|
||||
int n;
|
||||
struct sockaddr_in sin;
|
||||
socklen_t sinsize = sizeof (sin);
|
||||
- float loadavg = 0;
|
||||
+ double loadavg = 0;
|
||||
|
||||
n = accept (fd, (struct sockaddr *) &sin, &sinsize);
|
||||
if (n == -1)
|
||||
@@ -340,7 +341,10 @@ report_stats (int fd)
|
||||
}
|
||||
log_message ("report_stats: connection from %s:%d", inet_ntoa (sin.sin_addr),
|
||||
htons (sin.sin_port));
|
||||
-#ifdef linux
|
||||
+#if HAVE_GETLOADAVG
|
||||
+ if (getloadavg (&loadavg, 1) < 0)
|
||||
+ log_message ("report_stats: getloadavg: %s (errno %d)", strerror (errno), errno);
|
||||
+#elif defined(linux)
|
||||
{
|
||||
FILE *f = fopen ("/proc/loadavg", "r");
|
||||
|
||||
@@ -356,8 +360,8 @@ report_stats (int fd)
|
||||
}
|
||||
}
|
||||
#endif /* linux */
|
||||
- snprintf (Buf, sizeof (Buf), "%d %d %.2f %.0f 0\n", Users->dbsize,
|
||||
- Num_Files, loadavg, Num_Gigs * 1024.);
|
||||
+ snprintf (Buf, sizeof (Buf), "%d %d %0.2f %.0f %d\n", Users->dbsize,
|
||||
+ Num_Files, loadavg, Num_Gigs * 1024., global.clients_num - list_count(Servers));
|
||||
WRITE (n, Buf, strlen (Buf));
|
||||
CLOSE (n);
|
||||
}
|
110
audio/opennap/patches/patch-metaserver_dsp
Normal file
110
audio/opennap/patches/patch-metaserver_dsp
Normal file
@ -0,0 +1,110 @@
|
||||
$OpenBSD: patch-metaserver_dsp,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- metaserver.dsp.orig Fri Aug 2 22:15:44 2002
|
||||
+++ metaserver.dsp Sun Sep 30 17:07:07 2001
|
||||
@@ -0,0 +1,106 @@
|
||||
+# Microsoft Developer Studio Project File - Name="metaserver" - Package Owner=<4>
|
||||
+# Microsoft Developer Studio Generated Build File, Format Version 6.00
|
||||
+# ** DO NOT EDIT **
|
||||
+
|
||||
+# TARGTYPE "Win32 (x86) Console Application" 0x0103
|
||||
+
|
||||
+CFG=metaserver - Win32 Debug
|
||||
+!MESSAGE This is not a valid makefile. To build this project using NMAKE,
|
||||
+!MESSAGE use the Export Makefile command and run
|
||||
+!MESSAGE
|
||||
+!MESSAGE NMAKE /f "metaserver.mak".
|
||||
+!MESSAGE
|
||||
+!MESSAGE You can specify a configuration when running NMAKE
|
||||
+!MESSAGE by defining the macro CFG on the command line. For example:
|
||||
+!MESSAGE
|
||||
+!MESSAGE NMAKE /f "metaserver.mak" CFG="metaserver - Win32 Debug"
|
||||
+!MESSAGE
|
||||
+!MESSAGE Possible choices for configuration are:
|
||||
+!MESSAGE
|
||||
+!MESSAGE "metaserver - Win32 Release" (based on "Win32 (x86) Console Application")
|
||||
+!MESSAGE "metaserver - Win32 Debug" (based on "Win32 (x86) Console Application")
|
||||
+!MESSAGE
|
||||
+
|
||||
+# Begin Project
|
||||
+# PROP AllowPerConfigDependencies 0
|
||||
+# PROP Scc_ProjName ""
|
||||
+# PROP Scc_LocalPath ""
|
||||
+CPP=cl.exe
|
||||
+RSC=rc.exe
|
||||
+
|
||||
+!IF "$(CFG)" == "metaserver - Win32 Release"
|
||||
+
|
||||
+# PROP BASE Use_MFC 0
|
||||
+# PROP BASE Use_Debug_Libraries 0
|
||||
+# PROP BASE Output_Dir "metaserver___Win32_Release"
|
||||
+# PROP BASE Intermediate_Dir "metaserver___Win32_Release"
|
||||
+# PROP BASE Target_Dir ""
|
||||
+# PROP Use_MFC 0
|
||||
+# PROP Use_Debug_Libraries 0
|
||||
+# PROP Output_Dir "metaserver___Win32_Release"
|
||||
+# PROP Intermediate_Dir "metaserver___Win32_Release"
|
||||
+# PROP Ignore_Export_Lib 0
|
||||
+# PROP Target_Dir ""
|
||||
+# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /D "_MBCS" /YX /FD /c
|
||||
+# ADD CPP /nologo /W3 /GX /O2 /I "../zlib/zlib-1.1.3" /D "NDEBUG" /D "WIN32" /D "_CONSOLE" /D "_MBCS" /D STDC_HEADERS=1 /D REGEX_MALLOC=1 /D FD_SETSIZE=4096 /YX /FD /c
|
||||
+# ADD BASE RSC /l 0x409 /d "NDEBUG"
|
||||
+# ADD RSC /l 0x409 /d "NDEBUG"
|
||||
+BSC32=bscmake.exe
|
||||
+# ADD BASE BSC32 /nologo
|
||||
+# ADD BSC32 /nologo
|
||||
+LINK32=link.exe
|
||||
+# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /machine:I386
|
||||
+# ADD LINK32 zlib.lib wsock32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /machine:I386 /libpath:"../zlib/dll32"
|
||||
+
|
||||
+!ELSEIF "$(CFG)" == "metaserver - Win32 Debug"
|
||||
+
|
||||
+# PROP BASE Use_MFC 0
|
||||
+# PROP BASE Use_Debug_Libraries 1
|
||||
+# PROP BASE Output_Dir "metaserver___Win32_Debug"
|
||||
+# PROP BASE Intermediate_Dir "metaserver___Win32_Debug"
|
||||
+# PROP BASE Target_Dir ""
|
||||
+# PROP Use_MFC 0
|
||||
+# PROP Use_Debug_Libraries 1
|
||||
+# PROP Output_Dir "metaserver___Win32_Debug"
|
||||
+# PROP Intermediate_Dir "metaserver___Win32_Debug"
|
||||
+# PROP Ignore_Export_Lib 0
|
||||
+# PROP Target_Dir ""
|
||||
+# ADD BASE CPP /nologo /W3 /Gm /GX /ZI /Od /D "WIN32" /D "_DEBUG" /D "_CONSOLE" /D "_MBCS" /YX /FD /GZ /c
|
||||
+# ADD CPP /nologo /W3 /Gm /GX /ZI /Od /I "../zlib/" /D "_DEBUG" /D "WIN32" /D "_CONSOLE" /D "_MBCS" /D STDC_HEADERS=1 /D REGEX_MALLOC=1 /D FD_SETSIZE=4096 /YX /FD /GZ /c
|
||||
+# ADD BASE RSC /l 0x409 /d "_DEBUG"
|
||||
+# ADD RSC /l 0x409 /d "_DEBUG"
|
||||
+BSC32=bscmake.exe
|
||||
+# ADD BASE BSC32 /nologo
|
||||
+# ADD BSC32 /nologo
|
||||
+LINK32=link.exe
|
||||
+# ADD BASE LINK32 kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /debug /machine:I386 /pdbtype:sept
|
||||
+# ADD LINK32 zlib.lib wsock32.lib kernel32.lib user32.lib gdi32.lib winspool.lib comdlg32.lib advapi32.lib shell32.lib ole32.lib oleaut32.lib uuid.lib odbc32.lib odbccp32.lib /nologo /subsystem:console /debug /machine:I386 /pdbtype:sept /libpath:"../zlib/dll32"
|
||||
+
|
||||
+!ENDIF
|
||||
+
|
||||
+# Begin Target
|
||||
+
|
||||
+# Name "metaserver - Win32 Release"
|
||||
+# Name "metaserver - Win32 Debug"
|
||||
+# Begin Group "Source Files"
|
||||
+
|
||||
+# PROP Default_Filter "cpp;c;cxx;rc;def;r;odl;idl;hpj;bat"
|
||||
+# Begin Source File
|
||||
+
|
||||
+SOURCE=.\getopt.c
|
||||
+# End Source File
|
||||
+# Begin Source File
|
||||
+
|
||||
+SOURCE=.\metaserver.c
|
||||
+# End Source File
|
||||
+# End Group
|
||||
+# Begin Group "Header Files"
|
||||
+
|
||||
+# PROP Default_Filter "h;hpp;hxx;hm;inl"
|
||||
+# End Group
|
||||
+# Begin Group "Resource Files"
|
||||
+
|
||||
+# PROP Default_Filter "ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe"
|
||||
+# End Group
|
||||
+# End Target
|
||||
+# End Project
|
66
audio/opennap/patches/patch-opennap_h
Normal file
66
audio/opennap/patches/patch-opennap_h
Normal file
@ -0,0 +1,66 @@
|
||||
$OpenBSD: patch-opennap_h,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- opennap.h.orig Sun Sep 30 17:12:37 2001
|
||||
+++ opennap.h Tue Oct 16 18:14:04 2001
|
||||
@@ -143,8 +143,25 @@ struct _user
|
||||
NOTE. this is a pointer to an entry in
|
||||
Server_Names, and not malloc'd. */
|
||||
|
||||
+ time_t connected; /* time at which the user connected */
|
||||
+ LIST *channels; /* channels of which this user is a member */
|
||||
+ CONNECTION *con; /* local connection, or server which this
|
||||
+ user is behind */
|
||||
+
|
||||
+ unsigned int libsize; /* approximate size of shared files in kB */
|
||||
+ unsigned int ip; /* ip of user in network byte order */
|
||||
+
|
||||
unsigned short uploads; /* no. of uploads in progress */
|
||||
unsigned short downloads; /* no. of downloads in progress */
|
||||
+ unsigned short port; /* data port client is listening on */
|
||||
+ unsigned short conport; /* remote port for connection to server */
|
||||
+ unsigned short totalup; /* total number of uploads */
|
||||
+ unsigned short totaldown; /* total number of downloads */
|
||||
+
|
||||
+ unsigned short shared; /* # of shared files */
|
||||
+ unsigned short wantPong; /* # of outstanding PONGs */
|
||||
+
|
||||
+ unsigned short yyy; /* unused */
|
||||
|
||||
unsigned int level:3; /* user level */
|
||||
unsigned int speed:4; /* link speed */
|
||||
@@ -154,20 +171,6 @@ struct _user
|
||||
unsigned int unsharing:1;
|
||||
unsigned int cloaked:1;
|
||||
unsigned int xxx:4; /* unused */
|
||||
- unsigned short shared; /* # of shared files */
|
||||
-
|
||||
- unsigned short totalup; /* total number of uploads */
|
||||
- unsigned short totaldown; /* total number of downloads */
|
||||
-
|
||||
- unsigned int libsize; /* approximate size of shared files in kB */
|
||||
- unsigned int ip; /* ip of user in network byte order */
|
||||
-
|
||||
- unsigned short port; /* data port client is listening on */
|
||||
- unsigned short conport; /* remote port for connection to server */
|
||||
- time_t connected; /* time at which the user connected */
|
||||
- LIST *channels; /* channels of which this user is a member */
|
||||
- CONNECTION *con; /* local connection, or server which this
|
||||
- user is behind */
|
||||
};
|
||||
|
||||
enum
|
||||
@@ -486,6 +489,7 @@ extern HASH *MD5;
|
||||
extern int Stats_Port;
|
||||
#endif
|
||||
|
||||
+extern int gBlockWinMX;
|
||||
extern HASH *Channel_Db;
|
||||
extern int Client_Queue_Length;
|
||||
extern HASH *Client_Versions;
|
||||
@@ -835,6 +839,7 @@ int config (int);
|
||||
void config_defaults (void);
|
||||
USERDB *create_db (USER *);
|
||||
void destroy_connection (CONNECTION *);
|
||||
+void discipline_user (USER *);
|
||||
void dump_channels (void);
|
||||
void exec_timers (time_t);
|
||||
void expand_hex (char *, int);
|
33
audio/opennap/patches/patch-ping_c
Normal file
33
audio/opennap/patches/patch-ping_c
Normal file
@ -0,0 +1,33 @@
|
||||
$OpenBSD: patch-ping_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- ping.c.orig Tue Mar 6 00:49:53 2001
|
||||
+++ ping.c Wed Oct 17 13:19:27 2001
|
||||
@@ -39,11 +39,29 @@ HANDLER (ping)
|
||||
return;
|
||||
}
|
||||
|
||||
+ if (gBlockWinMX > 0 && user != orig)
|
||||
+ {
|
||||
+ if (tag == MSG_CLIENT_PING)
|
||||
+ user->wantPong++;
|
||||
+ else if (orig->wantPong == 0)
|
||||
+ {
|
||||
+ if (orig->level < LEVEL_MODERATOR)
|
||||
+ {
|
||||
+ discipline_user (orig);
|
||||
+ return;
|
||||
+ }
|
||||
+ }
|
||||
+ else
|
||||
+ orig->wantPong--;
|
||||
+ }
|
||||
+
|
||||
if (ISUSER (user->con))
|
||||
{
|
||||
if (!is_ignoring (user->con->uopt->ignore, orig->nick))
|
||||
+ {
|
||||
send_cmd (user->con, tag, "%s%s%s", orig->nick, pkt ? " " : "",
|
||||
NONULL (pkt));
|
||||
+ }
|
||||
else
|
||||
send_user (orig, MSG_SERVER_NOSUCH, "%s is ignoring you",
|
||||
user->nick);
|
27
audio/opennap/patches/patch-privmsg_c
Normal file
27
audio/opennap/patches/patch-privmsg_c
Normal file
@ -0,0 +1,27 @@
|
||||
$OpenBSD: patch-privmsg_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- privmsg.c.orig Sat Sep 22 00:54:13 2001
|
||||
+++ privmsg.c Tue Oct 16 23:02:48 2001
|
||||
@@ -348,7 +348,7 @@ HANDLER (privmsg)
|
||||
/* prevent DoS attack againt windows napster client */
|
||||
if (len - (pkt - ptr) > 180)
|
||||
{
|
||||
- log_message ("privmsg(): truncated %d byte message from %s", len,
|
||||
+ log_message ("privmsg: truncated %d byte message from %s", len,
|
||||
sender->nick);
|
||||
pkt[180] = 0;
|
||||
}
|
||||
@@ -385,6 +385,14 @@ HANDLER (privmsg)
|
||||
if (!user)
|
||||
{
|
||||
nosuchuser (con);
|
||||
+ return;
|
||||
+ }
|
||||
+
|
||||
+ if (gBlockWinMX > 0 &&
|
||||
+ !strncmp ("//WantQueue", pkt, sizeof("//WantQueue")-1))
|
||||
+ {
|
||||
+ if (sender->level < LEVEL_MODERATOR)
|
||||
+ discipline_user (sender);
|
||||
return;
|
||||
}
|
||||
|
183
audio/opennap/patches/patch-proxy-client_c
Normal file
183
audio/opennap/patches/patch-proxy-client_c
Normal file
@ -0,0 +1,183 @@
|
||||
$OpenBSD: patch-proxy-client_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- proxy-client.c.orig Fri Aug 2 22:15:44 2002
|
||||
+++ proxy-client.c Tue Mar 6 00:49:53 2001
|
||||
@@ -0,0 +1,179 @@
|
||||
+/* Copyright (C) 2000-1 drscholl@users.sourceforge.net
|
||||
+ This is free software distributed under the terms of the
|
||||
+ GNU Public License. See the file COPYING for details.
|
||||
+
|
||||
+ proxy-client.c,v 1.3 2001/03/06 06:49:53 drscholl Exp */
|
||||
+
|
||||
+/* a simple proxy server to spy on the traffic between clients. this
|
||||
+ is a lot easier than using tcpdump. */
|
||||
+
|
||||
+#ifdef HAVE_CONFIG_H
|
||||
+#include "config.h"
|
||||
+#endif
|
||||
+
|
||||
+#include <sys/socket.h>
|
||||
+#include <netinet/in.h>
|
||||
+#include <unistd.h>
|
||||
+#include <stdio.h>
|
||||
+#include <stdlib.h>
|
||||
+#include <arpa/inet.h>
|
||||
+#include <errno.h>
|
||||
+
|
||||
+unsigned char buf[2048];
|
||||
+
|
||||
+int
|
||||
+pass_message (const char *id, int s, int d)
|
||||
+{
|
||||
+ int len;
|
||||
+ int i;
|
||||
+
|
||||
+ len = read (s, buf, sizeof (buf));
|
||||
+ if (len <= 0)
|
||||
+ {
|
||||
+ if (len == -1)
|
||||
+ printf ("%s: %s\n", id, strerror (errno));
|
||||
+ else
|
||||
+ printf ("%s: EOF\n", id);
|
||||
+ return -1;
|
||||
+ }
|
||||
+ buf[len] = 0;
|
||||
+
|
||||
+ for (i = 0; i < len; i++)
|
||||
+ if (buf[i] == '\r')
|
||||
+ buf[i] = 'M';
|
||||
+
|
||||
+ printf ("%s: len=%d, data=%s\n", id, len, buf);
|
||||
+
|
||||
+ write (d, buf, len);
|
||||
+
|
||||
+ return 0;
|
||||
+}
|
||||
+
|
||||
+static void
|
||||
+usage (void)
|
||||
+{
|
||||
+ puts ("usage: spyserv [ -s client ] [ -p clientport ] [ -l localport ]");
|
||||
+ exit (0);
|
||||
+}
|
||||
+
|
||||
+int
|
||||
+main (int argc, char **argv)
|
||||
+{
|
||||
+ int s;
|
||||
+ int c;
|
||||
+ int r;
|
||||
+ int localport = 6699;
|
||||
+ size_t sinsize;
|
||||
+ struct sockaddr_in sin;
|
||||
+ fd_set fds;
|
||||
+ char *host = "192.168.0.101";
|
||||
+ int port = 6699;
|
||||
+
|
||||
+ while ((r = getopt (argc, argv, "hs:p:l:")) != EOF)
|
||||
+ {
|
||||
+ switch (r)
|
||||
+ {
|
||||
+ case 'l':
|
||||
+ localport = atoi (optarg);
|
||||
+ break;
|
||||
+ case 's':
|
||||
+ host = optarg;
|
||||
+ break;
|
||||
+ case 'p':
|
||||
+ port = atoi (optarg);
|
||||
+ break;
|
||||
+ default:
|
||||
+ usage ();
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ /* accept connection from client */
|
||||
+ s = socket (PF_INET, SOCK_STREAM, IPPROTO_TCP);
|
||||
+ if (s < 0)
|
||||
+ {
|
||||
+ perror ("socket");
|
||||
+ exit (1);
|
||||
+ }
|
||||
+ c = 1;
|
||||
+ if (setsockopt (s, SOL_SOCKET, SO_REUSEADDR, &c, sizeof (c)) != 0)
|
||||
+ {
|
||||
+ perror ("setsockopt");
|
||||
+ exit (1);
|
||||
+ }
|
||||
+ memset (&sin, 0, sizeof (sin));
|
||||
+ sin.sin_port = htons (localport);
|
||||
+ sin.sin_family = AF_INET;
|
||||
+ sin.sin_addr.s_addr = INADDR_ANY;
|
||||
+ if (bind (s, &sin, sizeof (sin)) < 0)
|
||||
+ {
|
||||
+ perror ("bind");
|
||||
+ exit (1);
|
||||
+ }
|
||||
+ if (listen (s, 1) < 0)
|
||||
+ {
|
||||
+ perror ("listen");
|
||||
+ exit (1);
|
||||
+ }
|
||||
+
|
||||
+ for (;;)
|
||||
+ {
|
||||
+ puts ("waiting for connection");
|
||||
+ sinsize = sizeof (sin);
|
||||
+ c = accept (s, &sin, &sinsize);
|
||||
+ if (c < 0)
|
||||
+ {
|
||||
+ perror ("accept");
|
||||
+ exit (1);
|
||||
+ }
|
||||
+ puts ("got incoming connection");
|
||||
+
|
||||
+ /* make connection to server */
|
||||
+ printf ("connecting to client...");
|
||||
+ fflush (stdout);
|
||||
+ r = socket (PF_INET, SOCK_STREAM, IPPROTO_TCP);
|
||||
+ if (r < 0)
|
||||
+ {
|
||||
+ perror ("socket");
|
||||
+ exit (1);
|
||||
+ }
|
||||
+ memset (&sin, 0, sizeof (sin));
|
||||
+ sin.sin_port = htons (port);
|
||||
+ sin.sin_family = AF_INET;
|
||||
+ sin.sin_addr.s_addr = inet_addr (host);
|
||||
+ if (connect (r, &sin, sizeof (sin)) < 0)
|
||||
+ {
|
||||
+ perror ("connect");
|
||||
+ exit (1);
|
||||
+ }
|
||||
+ puts ("connected");
|
||||
+
|
||||
+ for (;;)
|
||||
+ {
|
||||
+ FD_ZERO (&fds);
|
||||
+ FD_SET (r, &fds);
|
||||
+ FD_SET (c, &fds);
|
||||
+ puts ("Waiting for input");
|
||||
+ if (select (((r > c) ? r : c) + 1, &fds, 0, 0, 0) < 0)
|
||||
+ {
|
||||
+ perror ("select");
|
||||
+ break;
|
||||
+ }
|
||||
+ if (FD_ISSET (c, &fds))
|
||||
+ {
|
||||
+ if (pass_message ("remote", c, r) != 0)
|
||||
+ break;
|
||||
+ }
|
||||
+ if (FD_ISSET (r, &fds))
|
||||
+ {
|
||||
+ if (pass_message ("local", r, c) != 0)
|
||||
+ break;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ close (r);
|
||||
+ close (c);
|
||||
+ }
|
||||
+ close (s);
|
||||
+
|
||||
+ exit (0);
|
||||
+}
|
24
audio/opennap/patches/patch-resume_c
Normal file
24
audio/opennap/patches/patch-resume_c
Normal file
@ -0,0 +1,24 @@
|
||||
$OpenBSD: patch-resume_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- resume.c.orig Tue Mar 6 00:49:53 2001
|
||||
+++ resume.c Mon Oct 1 12:06:34 2001
|
||||
@@ -17,8 +17,8 @@ HANDLER (resume)
|
||||
{
|
||||
#if RESUME
|
||||
char *av[2];
|
||||
- FLIST *flist;
|
||||
- LIST *ptr;
|
||||
+ FileList *flist;
|
||||
+ DList *ptr;
|
||||
DATUM *d;
|
||||
int fsize;
|
||||
#endif /* RESUME */
|
||||
@@ -41,6 +41,9 @@ HANDLER (resume)
|
||||
send_cmd (con, MSG_SERVER_NOSUCH, "invalid file size");
|
||||
return;
|
||||
}
|
||||
+
|
||||
+ /* md5 value is stored using all lowercase hex */
|
||||
+ strlower (av[0]);
|
||||
|
||||
/* search the database for a list of all files which match this hash */
|
||||
flist = hash_lookup (MD5, av[0]);
|
75
audio/opennap/patches/patch-search_c
Normal file
75
audio/opennap/patches/patch-search_c
Normal file
@ -0,0 +1,75 @@
|
||||
$OpenBSD: patch-search_c,v 1.1 2002/08/10 01:14:04 naddy Exp $
|
||||
--- search.c.orig Fri Sep 28 23:34:23 2001
|
||||
+++ search.c Tue Oct 16 18:14:04 2001
|
||||
@@ -304,6 +304,9 @@ free_datum (DATUM * d)
|
||||
{
|
||||
int i;
|
||||
TokenRef *ref;
|
||||
+#if RESUME
|
||||
+ FileList *flist;
|
||||
+#endif
|
||||
|
||||
for (i = 0; i < d->numTokens; i++)
|
||||
{
|
||||
@@ -342,13 +345,31 @@ free_datum (DATUM * d)
|
||||
|
||||
FREE (d->tokens);
|
||||
|
||||
- /* XXX broken */
|
||||
#if RESUME
|
||||
flist = hash_lookup (MD5, d->hash);
|
||||
if (flist)
|
||||
{
|
||||
+ DList *list;
|
||||
+
|
||||
ASSERT (validate_flist (flist));
|
||||
- flist->list = list_delete (flist->list, d);
|
||||
+ for (list = flist->list; list; list = list->next)
|
||||
+ {
|
||||
+ if (list->data == d)
|
||||
+ {
|
||||
+ if (list->prev)
|
||||
+ list->prev->next = list->next;
|
||||
+ else
|
||||
+ {
|
||||
+ /* element is head of list, update the flist pointer */
|
||||
+ flist->list = list->next;
|
||||
+ }
|
||||
+ if (list->next)
|
||||
+ list->next->prev = list->prev;
|
||||
+ FREE (list);
|
||||
+ break;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
flist->count--;
|
||||
/* if there are no more files in this bin, erase it */
|
||||
if (flist->count == 0)
|
||||
@@ -944,6 +965,13 @@ HANDLER (search)
|
||||
return;
|
||||
}
|
||||
|
||||
+ /* NO SOUP FOR YOU!!! */
|
||||
+ if (con->user->level == LEVEL_LEECH)
|
||||
+ {
|
||||
+ send_cmd (con, MSG_SERVER_SEARCH_END, "");
|
||||
+ return;
|
||||
+ }
|
||||
+
|
||||
/* if Max_Searches is > 0, we only allow clients to have a certain small
|
||||
* number of pending search requests. Some abusive clients will tend
|
||||
* to issues multiple search requests at a time.
|
||||
@@ -1015,6 +1043,13 @@ HANDLER (remote_search)
|
||||
if (! option (ON_ALLOW_SHARE))
|
||||
{
|
||||
/* sharing is not allowed on this server */
|
||||
+ send_cmd (con, MSG_SERVER_REMOTE_SEARCH_END, "%s", id);
|
||||
+ return;
|
||||
+ }
|
||||
+
|
||||
+ if (user->level == LEVEL_LEECH)
|
||||
+ {
|
||||
+ /* user is not allowed to search this server */
|
||||
send_cmd (con, MSG_SERVER_REMOTE_SEARCH_END, "%s", id);
|
||||
return;
|
||||
}
|
@ -1,12 +1,14 @@
|
||||
#!/bin/sh
|
||||
# $OpenBSD: DEINSTALL,v 1.1 2001/03/31 22:41:49 brad Exp $
|
||||
# $OpenBSD: DEINSTALL,v 1.2 2002/08/10 01:14:04 naddy Exp $
|
||||
#
|
||||
# opennap de-installation
|
||||
|
||||
set -e
|
||||
PATH=/bin:/usr/bin:/sbin:/usr/sbin
|
||||
PREFIX=${PKG_PREFIX:-/usr/local}
|
||||
CONFIG_DIR=${SYSCONFDIR}
|
||||
CONFIG_DIR=${SYSCONFDIR}/opennap
|
||||
OPENNAPUSER=opennap
|
||||
OPENNAPGROUP=opennap
|
||||
|
||||
if [ -d $CONFIG_DIR ]; then
|
||||
echo
|
||||
@ -14,7 +16,9 @@ if [ -d $CONFIG_DIR ]; then
|
||||
echo "| To completely deinstall the $1 package you need to perform"
|
||||
echo "| this step as root:"
|
||||
echo "|"
|
||||
echo "| rm -rf $CONFIG_DIR"
|
||||
echo "| userdel $OPENNAPUSER"
|
||||
echo "| groupdel $OPENNAPGROUP"
|
||||
echo "| rm -rf $CONFIG_DIR"
|
||||
echo "|"
|
||||
echo "| Do not do this if you plan on re-installing $1"
|
||||
echo "| at some future time."
|
||||
|
@ -1,21 +1,40 @@
|
||||
#!/bin/sh
|
||||
# $OpenBSD: INSTALL,v 1.1 2001/03/31 22:41:49 brad Exp $
|
||||
# $OpenBSD: INSTALL,v 1.2 2002/08/10 01:14:04 naddy Exp $
|
||||
#
|
||||
# Pre/post-installation setup of opennap
|
||||
|
||||
# exit on errors, use a sane path and install prefix
|
||||
#
|
||||
set -e
|
||||
PATH=/bin:/usr/bin:/sbin:/usr/sbin
|
||||
PREFIX=${PKG_PREFIX:-/usr/local}
|
||||
CONFIG_DIR=${SYSCONFDIR}
|
||||
CONFIG_DIR=${SYSCONFDIR}/opennap
|
||||
SAMPLE_CONFIG_DIR=$PREFIX/share/examples/opennap
|
||||
OPENNAPUSER=opennap
|
||||
OPENNAPGROUP=opennap
|
||||
|
||||
do_usergroup_install()
|
||||
{
|
||||
# Create Opennap user and group
|
||||
groupinfo -e $OPENNAPGROUP
|
||||
if [ $? -eq 0 ]; then
|
||||
echo "===> Using $OPENNAPGROUP group for Opennap"
|
||||
else
|
||||
echo "===> Creating $OPENNAPGROUP group for Opennap"
|
||||
groupadd $OPENNAPGROUP
|
||||
fi
|
||||
userinfo -e $OPENNAPUSER
|
||||
if [ $? -eq 0 ]; then
|
||||
echo "===> Using $OPENNAPUSER user for Opennap"
|
||||
else
|
||||
echo "===> Creating $OPENNAPUSER user for Opennap"
|
||||
useradd -g $OPENNAPGROUP -d /nonexistent -L daemon -c 'Opennap Account' -s /sbin/nologin $OPENNAPUSER
|
||||
fi
|
||||
}
|
||||
|
||||
|
||||
do_notice()
|
||||
{
|
||||
echo
|
||||
echo "+---------------"
|
||||
echo "| The existing $1 configuration files in $CONFIG_DIR,"
|
||||
echo "| The existing opennap configuration files in $CONFIG_DIR,"
|
||||
echo "| have NOT been changed. You may want to compare them to the"
|
||||
echo "| current sample files in $SAMPLE_CONFIG_DIR,"
|
||||
echo "| and update your configuration as needed."
|
||||
@ -25,9 +44,9 @@ do_notice()
|
||||
|
||||
do_install()
|
||||
{
|
||||
install -d -o nobody -g nogroup -m 700 $CONFIG_DIR
|
||||
install -d -o opennap -g opennap -m 700 $CONFIG_DIR
|
||||
echo "admin opennap email@here.com Elite 0 0" > $CONFIG_DIR/users
|
||||
chown nobody:nogroup $CONFIG_DIR/users
|
||||
chown opennap:opennap $CONFIG_DIR/users
|
||||
chmod 600 $CONFIG_DIR/users
|
||||
echo
|
||||
echo "+---------------"
|
||||
@ -54,7 +73,7 @@ fi
|
||||
#
|
||||
case $2 in
|
||||
PRE-INSTALL)
|
||||
: nothing to pre-install for this port
|
||||
do_usergroup_install
|
||||
;;
|
||||
POST-INSTALL)
|
||||
if [ ! -d $CONFIG_DIR ]; then
|
||||
|
14
audio/opennap/pkg/MESSAGE
Normal file
14
audio/opennap/pkg/MESSAGE
Normal file
@ -0,0 +1,14 @@
|
||||
Configuring Opennap on OpenBSD
|
||||
------------------------------
|
||||
|
||||
- configuration files are in ${SYSCONFDIR}/opennap
|
||||
- documentation is installed in ${PREFIX}/doc/opennap
|
||||
- sample configuration files are in ${PREFIX}/share/examples/opennap
|
||||
|
||||
|
||||
Additionally, you may wish to start opennap at system start-up
|
||||
via the /etc/rc.local script:
|
||||
|
||||
if [ -x ${PREFIX}/sbin/opennap ]; then
|
||||
echo -n ' opennap'; ${PREFIX}/sbin/opennap -b > /dev/null
|
||||
fi
|
@ -1,8 +1,10 @@
|
||||
@comment $OpenBSD: PLIST,v 1.4 2001/07/11 02:10:07 brad Exp $
|
||||
@comment $OpenBSD: PLIST,v 1.5 2002/08/10 01:14:04 naddy Exp $
|
||||
sbin/metaserver
|
||||
sbin/opennap
|
||||
sbin/setup
|
||||
share/doc/opennap/FAQ
|
||||
share/doc/opennap/README
|
||||
share/doc/opennap/manual.html
|
||||
share/doc/opennap/napster.txt
|
||||
share/examples/opennap/sample.block
|
||||
share/examples/opennap/sample.channels
|
||||
|
Loading…
Reference in New Issue
Block a user