diff options
-rw-r--r-- | usr.sbin/inetd/inetd.c | 266 |
1 files changed, 2 insertions, 264 deletions
diff --git a/usr.sbin/inetd/inetd.c b/usr.sbin/inetd/inetd.c index 281e95f7fc4..bfb7165620a 100644 --- a/usr.sbin/inetd/inetd.c +++ b/usr.sbin/inetd/inetd.c @@ -1,4 +1,4 @@ -/* $OpenBSD: inetd.c,v 1.70 2000/11/09 02:55:42 deraadt Exp $ */ +/* $OpenBSD: inetd.c,v 1.71 2000/11/21 07:23:24 deraadt Exp $ */ /* $NetBSD: inetd.c,v 1.11 1996/02/22 11:14:41 mycroft Exp $ */ /* * Copyright (c) 1983,1991 The Regents of the University of California. @@ -41,7 +41,7 @@ char copyright[] = #ifndef lint /*static char sccsid[] = "from: @(#)inetd.c 5.30 (Berkeley) 6/3/91";*/ -static char rcsid[] = "$OpenBSD: inetd.c,v 1.70 2000/11/09 02:55:42 deraadt Exp $"; +static char rcsid[] = "$OpenBSD: inetd.c,v 1.71 2000/11/21 07:23:24 deraadt Exp $"; #endif /* not lint */ /* @@ -238,10 +238,6 @@ struct servtab { int se_max; /* max # of instances of this service */ int se_count; /* number started since se_time */ struct timeval se_time; /* start of se_count */ -#ifdef MULOG - int se_log; -#define MULOG_RFC931 0x40000000 -#endif struct servtab *se_next; } *servtab; @@ -580,10 +576,6 @@ main(argc, argv, envp) if (debug) fprintf(stderr, "%d execl %s\n", getpid(), sep->se_server); -#ifdef MULOG - if (sep->se_log) - dolog(sep, ctrl); -#endif dup2(ctrl, 0); close(ctrl); dup2(0, 1); @@ -1223,38 +1215,8 @@ getconfigent() more: freeconfig(sep); -#ifdef MULOG - while ((cp = nextline(fconfig)) && *cp == '#') { - /* Avoid use of `skip' if there is a danger of it looking - * at continuation lines. - */ - do { - cp++; - } while (*cp == ' ' || *cp == '\t'); - if (*cp == '\0') - continue; - if ((arg = skip(&cp, 0)) == NULL) - continue; - if (strcmp(arg, "DOMAIN")) - continue; - if (curdom) - free(curdom); - curdom = NULL; - while (*cp == ' ' || *cp == '\t') - cp++; - if (*cp == '\0') - continue; - arg = cp; - while (*cp && *cp != ' ' && *cp != '\t') - cp++; - if (*cp != '\0') - *cp++ = '\0'; - curdom = newstr(arg); - } -#else while ((cp = nextline(fconfig)) && *cp == '#') ; -#endif if (cp == NULL) { free(sep); return (NULL); @@ -1394,36 +1356,6 @@ more: sep->se_bi = NULL; argc = 0; for (arg = skip(&cp, 0); cp; arg = skip(&cp, 0)) { -#if MULOG - char *colon; - - if (argc == 0 && (colon = strrchr(arg, ':'))) { - while (arg < colon) { - int x; - char *ccp; - - switch (*arg++) { - case 'l': - x = 1; - if (isdigit(*arg)) { - x = strtol(arg, &ccp, 0); - if (ccp == arg) - break; - arg = ccp; - } - sep->se_log &= ~MULOG_RFC931; - sep->se_log |= x; - break; - case 'a': - sep->se_log |= MULOG_RFC931; - break; - default: - break; - } - } - arg = colon + 1; - } -#endif if (argc < MAXARGV) sep->se_argv[argc++] = newstr(arg); } @@ -1674,10 +1606,6 @@ dupconfig(sep) newstr(sep->se_argv[argc]) : NULL; newtab->se_max = sep->se_max; -#ifdef MULOG - newtab->se_log = sep->se_log; -#endif - return (newtab); } @@ -2028,193 +1956,3 @@ print_service(action, sep) sep->se_group ? sep->se_group : "wheel", (long)sep->se_bi, sep->se_server); } - -#ifdef MULOG -char *rfc931_name __P((struct sockaddr_in *, int)); - -dolog(sep, ctrl) - struct servtab *sep; - int ctrl; -{ - struct sockaddr sa; - struct sockaddr_in *sin = (struct sockaddr_in *)&sa; - int len = sizeof(sa); - struct hostent *hp; - char *host, *dp, buf[BUFSIZ]; - int connected = 1; - - if (sep->se_family != AF_INET) - return; - - if (getpeername(ctrl, &sa, &len) < 0) { - if (errno != ENOTCONN) { - syslog(LOG_ERR, "getpeername: %m"); - return; - } - if (recvfrom(ctrl, buf, sizeof(buf), MSG_PEEK, &sa, &len) < 0) { - syslog(LOG_ERR, "recvfrom: %m"); - return; - } - connected = 0; - } - if (sa.sa_family != AF_INET) { - syslog(LOG_ERR, "unexpected address family %u", sa.sa_family); - return; - } - - hp = gethostbyaddr((char *) &sin->sin_addr.s_addr, - sizeof (sin->sin_addr.s_addr), AF_INET); - - host = hp?hp->h_name:inet_ntoa(sin->sin_addr); - - switch (sep->se_log & ~MULOG_RFC931) { - case 0: - return; - case 1: - if (curdom == NULL || *curdom == '\0') - break; - dp = host + strlen(host) - strlen(curdom); - if (dp < host) - break; - if (debug) - fprintf(stderr, "check \"%s\" against curdom \"%s\"\n", - host, curdom); - if (strcasecmp(dp, curdom) == 0) - return; - break; - case 2: - default: - break; - } - - openlog("", LOG_NOWAIT, MULOG); - - if (connected && (sep->se_log & MULOG_RFC931)) - syslog(LOG_INFO, "%s@%s wants %s", rfc931_name(sin, ctrl), - host, sep->se_service); - else - syslog(LOG_INFO, "%s wants %s", host, sep->se_service); -} -/* - * From tcp_log by - * Wietse Venema, Eindhoven University of Technology, The Netherlands. - */ -#if 0 -static char sccsid[] = "@(#) rfc931.c 1.3 92/08/31 22:54:46"; -#endif - -#include <setjmp.h> - -#define RFC931_PORT 113 /* Semi-well-known port */ -#define TIMEOUT 4 -#define TIMEOUT2 10 - -static jmp_buf timebuf; - -/* timeout - handle timeouts */ -static void -timeout(sig) - int sig; -{ - longjmp(timebuf, sig); -} - -/* rfc931_name - return remote user name */ -char * -rfc931_name(there, ctrl) -struct sockaddr_in *there; /* remote link information */ -int ctrl; -{ - struct sockaddr_in here; /* local link information */ - struct sockaddr_in sin; /* for talking to RFC931 daemon */ - int length; - int s; - unsigned remote; - unsigned local; - static char user[256]; /* XXX */ - char buf[256]; - char *cp; - char *result = "USER_UNKNOWN"; - int len; - - /* Find out local port number of our stdin. */ - - length = sizeof(here); - if (getsockname(ctrl, (struct sockaddr *) &here, &length) == -1) { - syslog(LOG_ERR, "getsockname: %m"); - return (result); - } - /* Set up timer so we won't get stuck. */ - - if ((s = socket(AF_INET, SOCK_STREAM, 0)) == -1) { - syslog(LOG_ERR, "socket: %m"); - return (result); - } - - sin = here; - sin.sin_port = htons(0); - if (bind(s, (struct sockaddr *) &sin, sizeof(sin)) == -1) { - syslog(LOG_ERR, "bind: %m"); - return (result); - } - - signal(SIGALRM, timeout); - if (setjmp(timebuf)) { - close(s); /* not: fclose(fp) */ - return (result); - } - alarm(TIMEOUT); - - /* Connect to the RFC931 daemon. */ - sin = *there; - sin.sin_port = htons(RFC931_PORT); - if (connect(s, (struct sockaddr *) &sin, sizeof(sin)) == -1) { - close(s); - alarm(0); - return (result); - } - - /* Query the RFC 931 server. Would 13-byte writes ever be broken up? */ - sprintf(buf, "%u,%u\r\n", ntohs(there->sin_port), ntohs(here.sin_port)); - - for (len = 0, cp = buf; len < strlen(buf); ) { - int n; - - if ((n = write(s, cp, strlen(buf) - len)) == -1) { - close(s); - alarm(0); - return (result); - } - cp += n; - len += n; - } - - /* Read response */ - for (cp = buf; cp < buf + sizeof(buf) - 1; ) { - char c; - if (read(s, &c, 1) != 1) { - close(s); - alarm(0); - return (result); - } - if (c == '\n') - break; - *cp++ = c; - } - *cp = '\0'; - - if (sscanf(buf, "%u , %u : USERID :%*[^:]:%255s", &remote, - &local, user) == 3 && ntohs(there->sin_port) == remote && - ntohs(here.sin_port) == local) { - - /* Strip trailing carriage return. */ - if (cp = strchr(user, '\r')) - *cp = 0; - result = user; - } - - alarm(0); - close(s); - return (result); -} -#endif |