Hi list

I ported the -T option from netbsd syslogd.c to freebsd syslog.

"Add a -T flag to syslogd, which causes it to use local time for
messages received from the network. Useful for collecting logs from
devices which do not have correct time or if you need localtime anyway.
It does not replace original timestamp. It just adds the localtime at
the beginning of the string"

Is this done correctly? I had no trouble during my tests with remote
logging from several router and switches from cisco and foundry.

If everything is correct, any chance we can add this to freebsd syslogd?

Regards,
Tom
--- syslogd.c.orig      2008-02-20 14:00:11.000000000 +0100
+++ syslogd.c   2008-02-20 14:00:27.000000000 +0100
@@ -292,6 +292,7 @@
 
 struct allowedpeer *AllowedPeers; /* List of allowed peers */
 static int     NumAllowed;     /* Number of entries in AllowedPeers */
+static int      RemoteAddDate;  /* always add date to messages from network */
 
 static int     UniquePriority; /* Only log specified priority? */
 static int     LogFacPri;      /* Put facility and priority in log message: */
@@ -321,7 +322,7 @@
 static void    log_deadchild(pid_t, int, const char *);
 static void    markit(void);
 static int     skip_message(const char *, const char *, int);
-static void    printline(const char *, char *);
+static void    printline(const char *, char *, int);
 static void    printsys(char *);
 static int     p_open(const char *, pid_t *);
 static void    readklog(void);
@@ -351,7 +352,7 @@
        socklen_t len;
 
        bindhostname = NULL;
-       while ((ch = getopt(argc, argv, "46Aa:b:cCdf:kl:m:nop:P:sS:uv")) != -1)
+       while ((ch = getopt(argc, argv, "46Aa:b:cCdf:kl:m:nop:P:sS:Tuv")) != -1)
                switch (ch) {
                case '4':
                        family = PF_INET;
@@ -448,6 +449,9 @@
                                errx(1, "%s path too long, exiting", optarg);
                        funix_secure.name = optarg;
                        break;
+               case 'T':
+                       RemoteAddDate = 1;
+                       break;
                case 'u':               /* only log specified priority */
                        UniquePriority++;
                        break;
@@ -640,7 +644,7 @@
                                                hname = cvthname((struct 
sockaddr *)&frominet);
                                                unmapped((struct sockaddr 
*)&frominet);
                                                if (validate((struct sockaddr 
*)&frominet, hname))
-                                                       printline(hname, line);
+                                                       printline(hname, line, 
RemoteAddDate ? ADDDATE : 0);
                                        } else if (l < 0 && errno != EINTR)
                                                logerror("recvfrom inet");
                                }
@@ -653,7 +657,7 @@
                                    (struct sockaddr *)&fromunix, &len);
                                if (l > 0) {
                                        line[l] = '\0';
-                                       printline(LocalHostName, line);
+                                       printline(LocalHostName, line, 0);
                                } else if (l < 0 && errno != EINTR)
                                        logerror("recvfrom unix");
                        }
@@ -693,7 +697,7 @@
 {
 
        fprintf(stderr, "%s\n%s\n%s\n%s\n",
-               "usage: syslogd [-46ACcdknosuv] [-a allowed_peer]",
+               "usage: syslogd [-46ACcdknosTuv] [-a allowed_peer]",
                "               [-b bind_address] [-f config_file]",
                "               [-l [mode:]path] [-m mark_interval]",
                "               [-P pid_file] [-p log_socket]");
@@ -705,7 +709,7 @@
  * on the appropriate log files.
  */
 static void
-printline(const char *hname, char *msg)
+printline(const char *hname, char *msg, int flags)
 {
        char *p, *q;
        long n;
@@ -758,7 +762,7 @@
        }
        *q = '\0';
 
-       logmsg(pri, line, hname, 0);
+       logmsg(pri, line, hname, flags);
 }
 
 /*
--- syslogd.8.orig      2008-02-20 14:18:55.000000000 +0100
+++ syslogd.8   2008-02-20 14:18:59.000000000 +0100
@@ -225,6 +225,12 @@
 If
 specified twice, no network socket will be opened at all, which also
 disables logging to remote machines.
+.It Fl T
+Always use the local time and date for messages received from the
+network, instead of the timestamp field supplied in the message
+by the remote host.
+This is useful if some of the originating hosts can't keep time
+properly or are unable to generate a correct timestamp.
 .It Fl u
 Unique priority logging.
 Only log messages at the specified priority.
@@ -291,6 +297,14 @@
 option is specified);
 therefore, they must be created manually before running
 .Nm .
+.Pp
+The date and time are taken from the received message.
+If the format of the timestamp field is incorrect, time obtained from
+the local host is used instead.
+This can be overriden by the
+.Fl T
+flag.
+.Pp
 .Sh FILES
 .Bl -tag -width /var/run/syslog.pid -compact
 .It Pa /etc/syslog.conf
_______________________________________________
freebsd-hackers@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-hackers
To unsubscribe, send any mail to "[EMAIL PROTECTED]"

Reply via email to