summaryrefslogtreecommitdiffstats
path: root/net/datapipe
diff options
context:
space:
mode:
Diffstat (limited to 'net/datapipe')
-rw-r--r--net/datapipe/files/patch-datapipe.c152
1 files changed, 152 insertions, 0 deletions
diff --git a/net/datapipe/files/patch-datapipe.c b/net/datapipe/files/patch-datapipe.c
new file mode 100644
index 0000000..04c9472
--- /dev/null
+++ b/net/datapipe/files/patch-datapipe.c
@@ -0,0 +1,152 @@
+--- datapipe.c.orig Tue Jan 4 09:48:55 2000
++++ datapipe.c Thu Jul 24 16:28:56 2003
+@@ -59,6 +59,7 @@
+ #include <unistd.h>
+ #include <netdb.h>
+ #include <strings.h>
++ #include <syslog.h>
+ #define recv(x,y,z,a) read(x,y,z)
+ #define send(x,y,z,a) write(x,y,z)
+ #define closesocket(s) close(s)
+@@ -77,7 +78,7 @@
+ time_t activity;
+ };
+
+-#define MAXCLIENTS 20
++#define MAXCLIENTS 128
+ #define IDLETIMEOUT 300
+
+
+@@ -88,7 +89,8 @@
+ SOCKET lsock;
+ char buf[4096];
+ struct sockaddr_in laddr, oaddr;
+- int i;
++ int i, lport, oport;
++ char *laddr_str, *oaddr_str;
+ struct client_t clients[MAXCLIENTS];
+
+
+@@ -114,7 +116,7 @@
+ /* determine the listener address and port */
+ bzero(&laddr, sizeof(struct sockaddr_in));
+ laddr.sin_family = AF_INET;
+- laddr.sin_port = htons((unsigned short) atol(argv[2]));
++ laddr.sin_port = htons((unsigned short) lport=atol(argv[2]));
+ laddr.sin_addr.s_addr = inet_addr(argv[1]);
+ if (!laddr.sin_port) {
+ fprintf(stderr, "invalid listener port\n");
+@@ -128,12 +130,13 @@
+ }
+ bcopy(n->h_addr, (char *) &laddr.sin_addr, n->h_length);
+ }
++ laddr_str=strdup(inet_ntoa(laddr.sin_addr));
+
+
+ /* determine the outgoing address and port */
+ bzero(&oaddr, sizeof(struct sockaddr_in));
+ oaddr.sin_family = AF_INET;
+- oaddr.sin_port = htons((unsigned short) atol(argv[4]));
++ oaddr.sin_port = htons((unsigned short) oport=atol(argv[4]));
+ if (!oaddr.sin_port) {
+ fprintf(stderr, "invalid target port\n");
+ return 25;
+@@ -147,6 +150,7 @@
+ }
+ bcopy(n->h_addr, (char *) &oaddr.sin_addr, n->h_length);
+ }
++ oaddr_str=strdup(inet_ntoa(oaddr.sin_addr));
+
+
+ /* create the listener socket */
+@@ -154,6 +158,15 @@
+ perror("socket");
+ return 20;
+ }
++ {
++ int j=1;
++ setsockopt(lsock, SOL_SOCKET, SO_REUSEADDR,
++ (const char *) &j, sizeof(j));
++ setsockopt(lsock, SOL_SOCKET, SO_KEEPALIVE,
++ (const char *) &j, sizeof(j));
++ setsockopt(lsock, SOL_SOCKET, SO_LINGER,
++ (const char *) &j, sizeof(j));
++ }
+ if (bind(lsock, (struct sockaddr *)&laddr, sizeof(laddr))) {
+ perror("bind");
+ return 20;
+@@ -180,7 +193,10 @@
+ setsid();
+ #endif
+
+-
++ openlog(argv[0], LOG_NDELAY|LOG_CONS|LOG_PID, LOG_LOCAL4);
++ syslog( LOG_INFO, "Datapipe started: %s:%i -> %s:%i",
++ laddr_str, lport, oaddr_str, oport);
++
+ /* main polling loop. */
+ while (1)
+ {
+@@ -203,15 +219,22 @@
+ maxsock = (int) clients[i].osock;
+ }
+ if (select(maxsock + 1, &fdsr, NULL, NULL, &tv) < 0) {
+- return 30;
++ syslog( LOG_INFO, "select, maxsock=%i", maxsock);
++ continue;
+ }
+
+
+ /* check if there are new connections to accept. */
+ if (FD_ISSET(lsock, &fdsr))
+ {
+- SOCKET csock = accept(lsock, NULL, 0);
+-
++ struct sockaddr_in raddr;
++ int len=sizeof(raddr);
++ SOCKET csock = accept(lsock, (struct sockaddr *)&raddr, &len);
++ if(csock >= 0) {
++ syslog( LOG_INFO, "Connection(%i) from %s:%i to %s:%i -> %s:%i",
++ csock, inet_ntoa(raddr.sin_addr), ntohs(raddr.sin_port),
++ laddr_str, lport, oaddr_str, oport);
++
+ for (i = 0; i < MAXCLIENTS; i++)
+ if (!clients[i].inuse) break;
+ if (i < MAXCLIENTS)
+@@ -219,16 +242,16 @@
+ /* connect a socket to the outgoing host/port */
+ SOCKET osock;
+ if ((osock = socket(AF_INET, SOCK_STREAM, 0)) == -1) {
+- perror("socket");
++ syslog( LOG_INFO, "socket\n");
+ closesocket(csock);
+ }
+ else if (bind(osock, (struct sockaddr *)&laddr, sizeof(laddr))) {
+- perror("bind");
++ syslog( LOG_INFO, "bind\n");
+ closesocket(csock);
+ closesocket(osock);
+ }
+ else if (connect(osock, (struct sockaddr *)&oaddr, sizeof(oaddr))) {
+- perror("connect");
++ syslog( LOG_INFO, "connect\n");
+ closesocket(csock);
+ closesocket(osock);
+ }
+@@ -239,9 +262,14 @@
+ clients[i].inuse = 1;
+ }
+ } else {
+- fprintf(stderr, "too many clients\n");
++ syslog( LOG_INFO, "too many clients\n");
+ closesocket(csock);
+- }
++ }
++ } else {
++ syslog( LOG_INFO, "Connection accept error(%i) from %s:%i to %s:%i -> %s:%i",
++ csock, inet_ntoa(raddr.sin_addr), ntohs(raddr.sin_port),
++ laddr_str, lport, oaddr_str, oport);
++ }
+ }
+
+
OpenPOWER on IntegriCloud