diff options
author | dinoex <dinoex@FreeBSD.org> | 2018-04-30 18:23:32 +0800 |
---|---|---|
committer | dinoex <dinoex@FreeBSD.org> | 2018-04-30 18:23:32 +0800 |
commit | 9e7713b073699dabe376bc603376ff194173d3b8 (patch) | |
tree | c38e67afd248a0bd8f9c64f24627429555927b0b /news | |
parent | 6f980432e2274b42cc6b750fc51bc7d5c1b2f9a7 (diff) | |
download | freebsd-ports-gnome-9e7713b073699dabe376bc603376ff194173d3b8.tar.gz freebsd-ports-gnome-9e7713b073699dabe376bc603376ff194173d3b8.tar.zst freebsd-ports-gnome-9e7713b073699dabe376bc603376ff194173d3b8.zip |
- remove option INETD
- build both standalone and inetd version
- fix permissions on update
- add IPv6 support based on work from Gert Doering
If you used the inetd version, please change the path in /etc/inetd.conf
from /usr/local/sbin/nntpd to /usr/local/libexec/nntpd.
Diffstat (limited to 'news')
-rw-r--r-- | news/nntp/Makefile | 21 | ||||
-rw-r--r-- | news/nntp/files/patch-Makefile | 12 | ||||
-rw-r--r-- | news/nntp/files/patch-access.c | 100 | ||||
-rw-r--r-- | news/nntp/files/patch-get_tcp_conn.c | 67 | ||||
-rw-r--r-- | news/nntp/files/patch-netaux.c | 13 | ||||
-rw-r--r-- | news/nntp/files/patch-server-Makefile | 11 | ||||
-rw-r--r-- | news/nntp/pkg-plist | 5 |
7 files changed, 212 insertions, 17 deletions
diff --git a/news/nntp/Makefile b/news/nntp/Makefile index b9f415129096..b7abe4b2da8b 100644 --- a/news/nntp/Makefile +++ b/news/nntp/Makefile @@ -3,8 +3,8 @@ PORTNAME= nntp PORTVERSION= 1.5.12.2 -PORTREVISION= 9 -CATEGORIES= news +PORTREVISION= 10 +CATEGORIES= news ipv6 MASTER_SITES= ftp://ftp.dinoex.org/pub/c-news/ DISTNAME= ${PORTNAME}.${PORTVERSION} @@ -35,17 +35,12 @@ MAKE_ENV+= DBLIBS="${LOCALBASE}/lib/libcnews.a -lcrypt -lutil" MAKE_ENV+= ETCDIR="${STAGEDIR}${PREFIX}/sbin" MAKE_ENV+= BINDIR="${STAGEDIR}${NEWSBIN}" MAKE_ENV+= MANDIR="${STAGEDIR}${PREFIX}/man" +MAKE_ENV+= EXECDIR="${STAGEDIR}${PREFIX}/libexec" -OPTIONS_DEFINE= INETD DOCS -NO_OPTIONS_SORT=yes -INETD_DESC= build to run from inetd only +OPTIONS_DEFINE= DOCS .include <bsd.port.options.mk> -.if ${PORT_OPTIONS:MINETD} -ALONE= -e 's|\#define.ALONE|\#undef ALONE|' -.endif - post-extract: ${CP} ${WRKSRC}/conf.h.dist ${WRKSRC}/conf.h @@ -56,9 +51,15 @@ post-patch: ${REINPLACE_CMD} \ -e 's=reaper()=reaper(int unused)=' \ ${WRKSRC}/server/netaux.c + (cd ${WRKSRC} && ${CP} -pr server inetd) + ${REINPLACE_CMD} \ + -e 's|^CPPFLAGS|#CPPFLAGS|' \ + -e 's|ETCDIR|EXECDIR|g' \ + ${WRKSRC}/inetd/Makefile pre-configure: - ${REINPLACE_CMD} ${ALONE} \ + ${REINPLACE_CMD} \ + -e 's|\#define.ALONE.*||' \ -e "s=/usr/local/news/lib/bin/config=${NEWSBIN}/config=" \ -e "s=/usr/local/news/cnewsbin=${NEWSBIN}=" \ -e "s=/usr/local/news/lib=${NEWSCTL}=" \ diff --git a/news/nntp/files/patch-Makefile b/news/nntp/files/patch-Makefile index 2bd1e1215b1a..62eb3f6e73c4 100644 --- a/news/nntp/files/patch-Makefile +++ b/news/nntp/files/patch-Makefile @@ -1,5 +1,5 @@ ---- Makefile.orig 1996-01-09 08:30:24.000000000 +0100 -+++ Makefile 2013-09-03 20:32:47.000000000 +0200 +--- Makefile.orig 1996-01-09 07:30:24 UTC ++++ Makefile @@ -4,7 +4,7 @@ # The program that knows how to deal with makefiles. [Uncomment if needed.] # MAKE=make @@ -9,7 +9,7 @@ #Uncomment the following for Solaris (and similiar SVR4 systems) #NETLIBS = -lsocket -lnsl #Uncomment the following if the previous one does not work -@@ -20,11 +20,11 @@ +@@ -20,11 +20,11 @@ CFLAGS= -O #Uncomment the following for Solaris (and similiar SVR4 systems) #KVMLIB = -lelf # Where nntpd is going to live @@ -24,7 +24,7 @@ # LIBS = $(DBLIBS) $(RESLIB) $(NETLIBS) $(KVMLIB) SUBMAKEFLAGS="LIBS=${LIBS}" "CFLAGS=${CFLAGS}" "ETCDIR=${ETCDIR}" "BINDIR=${BINDIR}" "MANDIR=${MANDIR}" -@@ -42,11 +42,11 @@ +@@ -42,11 +42,12 @@ TYPE = server all: make_$(TYPE) make_server: /nowhere @@ -34,6 +34,7 @@ - cd xmit; $(MAKE) $(MFLAGS) $(SUBMAKEFLAGS) - cd xfer; $(MAKE) $(MFLAGS) $(SUBMAKEFLAGS) + $(MAKE) -C server $(MFLAGS) $(SUBMAKEFLAGS) ++ $(MAKE) -C inetd $(MFLAGS) $(SUBMAKEFLAGS) + $(MAKE) -C support $(MFLAGS) $(SUBMAKEFLAGS) + $(MAKE) -C doc $(MFLAGS) $(SUBMAKEFLAGS) + $(MAKE) -C xmit $(MFLAGS) $(SUBMAKEFLAGS) @@ -41,7 +42,7 @@ server: make_server -@@ -59,25 +59,25 @@ +@@ -59,25 +60,26 @@ client: make_client install: install_$(TYPE) install_server: @@ -51,6 +52,7 @@ - cd xmit; $(MAKE) $(MFLAGS) $(SUBMAKEFLAGS) install - cd xfer; $(MAKE) $(MFLAGS) $(SUBMAKEFLAGS) install + $(MAKE) -C server $(MFLAGS) $(SUBMAKEFLAGS) install ++ $(MAKE) -C inetd $(MFLAGS) $(SUBMAKEFLAGS) install + $(MAKE) -C support $(MFLAGS) $(SUBMAKEFLAGS) install + $(MAKE) -C doc $(MFLAGS) $(SUBMAKEFLAGS) install + $(MAKE) -C xmit $(MFLAGS) $(SUBMAKEFLAGS) install diff --git a/news/nntp/files/patch-access.c b/news/nntp/files/patch-access.c new file mode 100644 index 000000000000..a5fa190c5f98 --- /dev/null +++ b/news/nntp/files/patch-access.c @@ -0,0 +1,100 @@ +--- server/access.c.orig 2018-04-30 09:19:08 UTC ++++ server/access.c +@@ -11,6 +11,10 @@ static char sccsid[] = "@(#)$Id: access. + #endif + #include <sys/socket.h> + ++#ifdef __FreeBSD__ ++# include <netdb.h> ++#endif ++ + #define SNETMATCH 1 + #define NETMATCH 2 + +@@ -40,6 +44,12 @@ static char sccsid[] = "@(#)$Id: access. + * Side effects: None. + */ + ++typedef union { ++ struct sockaddr sa; ++ struct sockaddr_in sin; ++ struct sockaddr_in6 sin6; ++} nntp_sockaddr_union_t; ++ + #ifdef EXCELAN + extern struct sockaddr_in current_peer; + #endif +@@ -60,8 +70,7 @@ host_access(hcanread, hcanpost, hcanxfer + { + int sockt; + socklen_t length; +- struct sockaddr sa; +- struct sockaddr_in *sin = (struct sockaddr_in *) &sa; ++ nntp_sockaddr_union_t su; + #ifdef TLI + struct hostent *hp; + int argcnt = 0; +@@ -89,10 +98,11 @@ host_access(hcanread, hcanpost, hcanxfer + *hcanread = *hcanpost = *hcanxfer = 0; + + sockt = fileno(stdin); +- length = sizeof (sa); ++ length = sizeof (su); ++ int sa_len = (su.sa.sa_family == AF_INET) ? sizeof(struct sockaddr_in) : sizeof(struct sockaddr_in6); + + #ifdef TLI +- if (t_getpeername(sockt, &sa, &length) < 0) { ++ if (t_getpeername(sockt, &su.sa, &length) < 0) { + if (isatty(sockt)) { + (void) strcpy(hostname, "stdin"); + *hcanread = 1; +@@ -110,7 +120,7 @@ host_access(hcanread, hcanpost, hcanxfer + #ifdef EXCELAN + if (raddr(current_peer.sin_addr) == NULL) { + #else +- if (getpeername(sockt, &sa, &length) < 0) { ++ if (getpeername(sockt, &su.sa, &length) < 0) { + #endif + if (isatty(sockt)) { + (void) strcpy(hostname, "stdin"); +@@ -124,24 +134,35 @@ host_access(hcanread, hcanpost, hcanxfer + return; + } + #ifdef EXCELAN +- else bcopy(¤t_peer,&sa,length); ++ else bcopy(¤t_peer,&su.sa,length); + #endif + #endif /* !TLI */ + +- switch (sa.sa_family) { ++ switch (su.sa.sa_family) { + case AF_INET: +- inet_netnames(sockt, sin, net_name, snet_name, host_name); ++ inet_netnames(sockt, &su.sin, net_name, snet_name, host_name); + break; + ++ case AF_INET6: ++ ++ getnameinfo( (struct sockaddr *) &su.sa, su.sa.sa_len, ++ host_name, sizeof(host_name), NULL, 0, 0 ); ++ net_name[0] = snet_name[0] = '\0'; ++#ifdef SYSLOG ++ syslog(LOG_DEBUG, "IPv6 connect from %s (%ld->%d/%d)", ++ host_name, sizeof(su.sa), length, su.sa.sa_len ); ++#endif ++ break; ++ + #ifdef DECNET + case AF_DECnet: +- dnet_netnames(sockt, &sa, net_name, snet_name, host_name); ++ dnet_netnames(sockt, &su.sa, net_name, snet_name, host_name); + break; + #endif + + default: + #ifdef SYSLOG +- syslog(LOG_ERR, "unknown address family %ld", (long)(sa.sa_family)); ++ syslog(LOG_ERR, "unknown address family %ld", (long)(su.sa.sa_family)); + #endif + return; + }; diff --git a/news/nntp/files/patch-get_tcp_conn.c b/news/nntp/files/patch-get_tcp_conn.c new file mode 100644 index 000000000000..851d79dc5942 --- /dev/null +++ b/news/nntp/files/patch-get_tcp_conn.c @@ -0,0 +1,67 @@ +--- xmit/get_tcp_conn.c.orig 2018-04-20 08:58:07 UTC ++++ xmit/get_tcp_conn.c +@@ -33,6 +33,7 @@ static const char * rcsid = "$Id: get_tc + #ifndef NONETDB + #include <netdb.h> + #endif /* NONETDB */ ++#include <syslog.h> + + extern char *Pname; + #ifndef BSD_44 +@@ -286,6 +287,50 @@ const char *serv; + sp.sp_protocol = (u_short)IPPROTO_TCP; + #endif /* OLDSOCKET */ + ++#ifndef PRE_IPv6 ++ /* see "man getaddrinfo()" */ ++ struct addrinfo hints, *addrs, *ai_p; ++ int r; ++ ++ memset( &hints, 0, sizeof(hints) ); ++ hints.ai_family = PF_UNSPEC; ++ hints.ai_socktype = SOCK_STREAM; ++ if ( (r = getaddrinfo( host, "nntp", &hints, &addrs )) != 0 ) ++ { ++ fprintf( stderr, "getaddrinfo(%s/nntp): %s", host, ++ gai_strerror(r)); ++ return(NOHOST); ++ } ++ sock=-1; ++ for( ai_p = addrs; ai_p != NULL; ai_p = ai_p->ai_next ) ++ { ++ sock = socket( ai_p->ai_family, ai_p->ai_socktype, ++ ai_p->ai_protocol); ++ if ( sock < 0 ) {continue;} ++ if ( connect( sock, ai_p->ai_addr, ai_p->ai_addrlen ) < 0 ) ++ { ++ fprintf( stderr, "connect() failed: %s", strerror(errno)); ++ close(sock); ++ sock=-1; ++ continue; ++ } ++ if ( ai_p->ai_family == AF_INET6 ) ++ { ++ char addrbuf[100]; ++ inet_ntop( ai_p->ai_family, ai_p->ai_addr, ++ addrbuf, sizeof(addrbuf) ); ++ syslog(LOG_INFO, "IPv6 connect to %s (%s) - yeah!", ++ host, addrbuf ); ++ } ++ break; ++ } ++ freeaddrinfo(addrs); ++ if ( sock < 0 ) { return(FAIL); } ++ ++ /* TODO: keepalives! */ ++ return(sock); ++ ++#else /*PRE_IPv6*/ + if ((addrlist = name_to_address(host)) == (struct in_addr **)NULL) { + return(NOHOST); + } +@@ -330,4 +375,5 @@ const char *serv; + } + } + return(FAIL); ++#endif /* PRE_IPv6 */ + } diff --git a/news/nntp/files/patch-netaux.c b/news/nntp/files/patch-netaux.c new file mode 100644 index 000000000000..2dea3a1a852f --- /dev/null +++ b/news/nntp/files/patch-netaux.c @@ -0,0 +1,13 @@ +--- server/netaux.c.orig 2018-04-30 06:13:43 UTC ++++ server/netaux.c +@@ -281,10 +281,4 @@ reaper(int unused) + + #else /* !ALONE */ + +-/* Kludge for greenhill's C compiler */ +- +-static +-netaux_greenkludge() +-{ +-} + #endif /* not ALONE */ diff --git a/news/nntp/files/patch-server-Makefile b/news/nntp/files/patch-server-Makefile new file mode 100644 index 000000000000..295685958d0c --- /dev/null +++ b/news/nntp/files/patch-server-Makefile @@ -0,0 +1,11 @@ +--- server/Makefile.orig 1994-12-04 00:18:48 UTC ++++ server/Makefile +@@ -31,6 +31,8 @@ SRCS = ${SRVRSRC} + + LIBS = $(DBLIBS) $(NETLIBS) + ++CPPFLAGS+= -DALONE ++ + # Where nntpd is going to live + #DESTDIR = /etc + diff --git a/news/nntp/pkg-plist b/news/nntp/pkg-plist index 17d31e7133b3..2ba40d6b24d0 100644 --- a/news/nntp/pkg-plist +++ b/news/nntp/pkg-plist @@ -1,6 +1,7 @@ man/man1/nntpxmit.1.gz man/man8/nntpd.8c.gz man/man8/acttimes.8c.gz +libexec/nntpd sbin/nntpd %%NEWSBIN%%/acttimes %%NEWSBIN%%/nntpxmit @@ -17,5 +18,5 @@ sbin/nntpd %%PORTDOCS%%%%DOCSDIR%%/xfer-README %%PORTDOCS%%%%DOCSDIR%%/xmit-README %%VARBASE%%/%%NEWSCTL%%/overview.fmt -@dir %%VARBASE%%/%%NEWSCTL%% -@dir %%VARBASE%%/lib +@dir(news,news,755) %%VARBASE%%/%%NEWSCTL%% +@dir(news,news,755) %%VARBASE%%/lib |