home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / bsd_srcs / usr.sbin / implogd / implogd.c < prev    next >
Encoding:
C/C++ Source or Header  |  1991-04-19  |  3.7 KB  |  127 lines

  1. /*
  2.  * Copyright (c) 1983, 1988 Regents of the University of California.
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice, this list of conditions and the following disclaimer.
  10.  * 2. Redistributions in binary form must reproduce the above copyright
  11.  *    notice, this list of conditions and the following disclaimer in the
  12.  *    documentation and/or other materials provided with the distribution.
  13.  * 3. All advertising materials mentioning features or use of this software
  14.  *    must display the following acknowledgement:
  15.  *    This product includes software developed by the University of
  16.  *    California, Berkeley and its contributors.
  17.  * 4. Neither the name of the University nor the names of its contributors
  18.  *    may be used to endorse or promote products derived from this software
  19.  *    without specific prior written permission.
  20.  *
  21.  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  22.  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  23.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  24.  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  25.  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  26.  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  27.  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  28.  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  29.  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  30.  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  31.  * SUCH DAMAGE.
  32.  */
  33.  
  34. #ifndef lint
  35. char copyright[] =
  36. "@(#) Copyright (c) 1983, 1988 Regents of the University of California.\n\
  37.  All rights reserved.\n";
  38. #endif /* not lint */
  39.  
  40. #ifndef lint
  41. static char sccsid[] = "@(#)implogd.c    5.10 (Berkeley) 3/2/91";
  42. #endif /* not lint */
  43.  
  44. #include <sys/param.h>
  45. #include <sys/time.h>
  46. #include <sys/socket.h>
  47. #include <sys/syslog.h>
  48. #include <sys/file.h>
  49.  
  50. #include <net/if.h>
  51.  
  52. #include <netinet/in.h>
  53. #include <netimp/if_imp.h>
  54.  
  55. #include <sgtty.h>
  56. #include "pathnames.h"
  57.  
  58. /*
  59.  * Socket address, internet style, with
  60.  * unused space taken by timestamp and packet
  61.  * size.
  62.  */
  63. struct sockstamp {
  64.     short    sin_family;
  65.     u_short    sin_port;
  66.     struct    in_addr sin_addr;
  67.     time_t    sin_time;
  68.     int    sin_len;
  69. };
  70.  
  71. main()
  72. {
  73.     register int len, log, s;
  74.     struct sockstamp from;
  75.     int fromlen;
  76.     u_char request[1024];
  77.     time_t time();
  78.  
  79.     openlog("implogd", LOG_PID|LOG_ODELAY|LOG_PERROR, LOG_DAEMON);
  80.     log = open(_PATH_IMPLOG, O_CREAT|O_WRONLY|O_APPEND, 0644);
  81.     if (log < 0) {
  82.         syslog(LOG_ERR, "%s: %m\n", _PATH_IMPLOG);
  83.         exit(1);
  84.     }
  85.     from.sin_time = time((time_t *)NULL);
  86.     from.sin_len = sizeof(time_t);
  87.     (void)write(log, (char *)&from, sizeof(from));
  88.     if ((s = socket(AF_IMPLINK, SOCK_RAW, 0)) < 0) {
  89.         syslog(LOG_ERR, "socket: %m\n");
  90.         exit(1);
  91.     }
  92. #ifndef DEBUG
  93.     {
  94.         register int i, tt;
  95.  
  96.         if (fork())
  97.             exit(0);
  98.         for (i = 0; i < 10; i++)
  99.             if (i != log && i != s)
  100.                 (void) close(i);
  101.         (void) open("/", O_RDONLY, 0);
  102.         (void) dup2(0, 1);
  103.         (void) dup2(0, 2);
  104.         tt = open(_PATH_TTY, O_RDWR, 0);
  105.         if (tt > 0) {
  106.             ioctl(tt, TIOCNOTTY, 0);
  107.             (void)close(tt);
  108.         }
  109.     }
  110. #endif
  111.     for (fromlen = sizeof(from);;) {
  112.         len = recvfrom(s, request, sizeof(request), 0,
  113.             (struct sockaddr *)&from, &fromlen);
  114.         if (len < 0) {
  115.             syslog(LOG_ERR, "recvfrom: %m\n");
  116.             continue;
  117.         }
  118.         if (len == 0 || len > IMPMTU)        /* sanity */
  119.             continue;
  120.         from.sin_len = len;
  121.         from.sin_time = time((time_t *)NULL);
  122.         (void)write(log, (char *)&from, sizeof(from));
  123.         (void)write(log, request, len);
  124.     }
  125.     /*NOTREACHED*/
  126. }
  127.