]> andersk Git - moira.git/blobdiff - update/update_server.c
Use krb5_error_code for return value of krb5 library functions.
[moira.git] / update / update_server.c
index a0832e6b2c13ee0b125f8ecb8cc1591f199e833c..eeab92cdadda2f29d485d43fd29b1aae47011cdf 100644 (file)
@@ -23,6 +23,7 @@
 #include <stdlib.h>
 #include <string.h>
 #include <unistd.h>
+#include <syslog.h>
 
 #include <des.h>
 #include "update.h"
@@ -36,12 +37,15 @@ des_cblock session;
 int uid = 0;
 
 void child_handler(int signal);
+static void syslog_com_err_proc(const char *progname, long code,
+                               const char *fmt, va_list args);
 
 struct _dt {
   char *str;
   void (*proc)(int, char *);
 } dispatch_table[] = {
   { "AUTH_002", auth_002 },
+  { "AUTH_003", auth_003 },
   { "XFER_002", xfer_002 },
   { "XFER_003", xfer_003 },
   { "EXEC_002", exec_002 },
@@ -117,6 +121,9 @@ int main(int argc, char **argv)
       exit(1);
     }
 
+  set_com_err_hook(syslog_com_err_proc);
+  openlog(whoami, LOG_PID, LOG_DAEMON);
+
   /* now loop waiting for connections */
   while (1)
     {
@@ -228,3 +235,16 @@ void child_handler(int signal)
   while (waitpid(-1, &status, WNOHANG) > 0)
     ;
 }
+
+static void syslog_com_err_proc(const char *progname, long code,
+                               const char *fmt, va_list args)
+{
+  char *buf;
+  int bufsiz = 1024;
+
+  buf = malloc(bufsiz + 1);
+  buf[bufsiz] = '\0';
+
+  vsnprintf(buf, bufsiz, fmt, args);
+  syslog(LOG_NOTICE, "%s", buf);
+}
This page took 0.030609 seconds and 4 git commands to generate.