Added unformatted logging

This commit is contained in:
Michiel Broek 2006-03-06 19:55:10 +00:00
parent f71bd8113a
commit 49a8f5ed69
5 changed files with 156 additions and 66 deletions

View File

@ -38,6 +38,7 @@ v0.83.14 23-Feb-2006
mbtask: mbtask:
Safer code for chat. Safer code for chat.
Added unformatted logging.
lang: lang:
New prompts 86, 87, 88 and 89. New prompts 86, 87, 88 and 89.

View File

@ -270,7 +270,6 @@ int join(pid_t pid, char *channel, int sysop)
*/ */
snprintf(buf, 81, "*** Cannot create chat channel %s, no free channels", channel); snprintf(buf, 81, "*** Cannot create chat channel %s, no free channels", channel);
system_msg(pid, buf); system_msg(pid, buf);
Syslog('+', "%s", buf);
return FALSE; return FALSE;
} }
@ -800,7 +799,6 @@ void chat_get_r(char *data, char *buf)
/* /*
* Message is for us * Message is for us
*/ */
// snprintf(buf, 200, "100:2,0,%s;", clencode(chat_messages[tmpu->pointer].message));
p = xstrcpy((char *)"100:2,0,"); p = xstrcpy((char *)"100:2,0,");
p = xstrcat(p, clencode(chat_messages[tmpu->pointer].message)); p = xstrcat(p, clencode(chat_messages[tmpu->pointer].message));
p = xstrcat(p, (char *)";"); p = xstrcat(p, (char *)";");

View File

@ -88,7 +88,7 @@ void tidy_servers(srv_list **);
int add_server(srv_list **, char *, int, char *, char *, char *, char *); int add_server(srv_list **, char *, int, char *, char *, char *, char *);
void del_server(srv_list **, char *); void del_server(srv_list **, char *);
void del_router(srv_list **, char *); void del_router(srv_list **, char *);
int send_msg(ncs_list *, const char *, ...); int send_msg(ncs_list *, char *);
void broadcast(char *, char *); void broadcast(char *, char *);
void check_servers(void); void check_servers(void);
int command_pass(char *, char *); int command_pass(char *, char *);
@ -620,21 +620,24 @@ void broadcast(char *origin, char *msg)
/* /*
* Send message to a server * Send message to a server
*/ */
int send_msg(ncs_list *tnsl, const char *format, ...) int send_msg(ncs_list *tnsl, char *msg)
{ {
char buf[512]; char *p;
va_list va_ptr;
va_start(va_ptr, format);
vsnprintf(buf, 512, format, va_ptr);
va_end(va_ptr);
#ifndef PING_PONG_LOG #ifndef PING_PONG_LOG
if (strcmp(buf, "PING\r\n") && strcmp(buf, "PONG\r\n")) if (strcmp(msg, "PING\r\n") && strcmp(msg, "PONG\r\n")) {
#endif
p = xstrcpy((char *)"IBC: > ");
p = xstrcat(p, tnsl->server);
p = xstrcat(p, (char *)": ");
p = xstrcat(p, printable(msg, 0));
Syslogp('r', p);
free(p);
#ifndef PING_PONG_LOG
}
#endif #endif
Syslog('r', "IBC: > %s: %s", tnsl->server, printable(buf, 0));
if (sendto(tnsl->socket, buf, strlen(buf), 0, (struct sockaddr *)&tnsl->servaddr_in, sizeof(struct sockaddr_in)) == -1) { if (sendto(tnsl->socket, msg, strlen(msg), 0, (struct sockaddr *)&tnsl->servaddr_in, sizeof(struct sockaddr_in)) == -1) {
Syslog('!', "$IBC: can't send message"); Syslog('!', "$IBC: can't send message");
return -1; return -1;
} }
@ -908,9 +911,13 @@ void check_servers(void)
break; break;
} }
tnsl->token = gettoken(); tnsl->token = gettoken();
send_msg(tnsl, "PASS %s 0100 %s\r\n", tnsl->passwd, tnsl->compress ? "Z":""); p = calloc(512, sizeof(char));
send_msg(tnsl, "SERVER %s 0 %ld mbsebbs %s %s\r\n", tnsl->myname, tnsl->token, snprintf(p, 512, "PASS %s 0100 %s\r\n", tnsl->passwd, tnsl->compress ? "Z":"");
send_msg(tnsl, p);
snprintf(p, 512, "SERVER %s 0 %d mbsebbs %s %s\r\n", tnsl->myname, tnsl->token,
VERSION, CFG.bbs_name); VERSION, CFG.bbs_name);
send_msg(tnsl, p);
free(p);
tnsl->action = now + (time_t)10; tnsl->action = now + (time_t)10;
tnsl->state = NCS_WAITPWD; tnsl->state = NCS_WAITPWD;
callchg = TRUE; callchg = TRUE;
@ -988,12 +995,12 @@ void check_servers(void)
*/ */
if (((int)now - (int)tnsl->last) > 120) { if (((int)now - (int)tnsl->last) > 120) {
Syslog('r', "IBC: sending 3rd PING at 120 seconds"); Syslog('r', "IBC: sending 3rd PING at 120 seconds");
send_msg(tnsl, "PING\r\n"); send_msg(tnsl, (char *)"PING\r\n");
} else if (((int)now - (int)tnsl->last) > 90) { } else if (((int)now - (int)tnsl->last) > 90) {
Syslog('r', "IBC: sending 2nd PING at 90 seconds"); Syslog('r', "IBC: sending 2nd PING at 90 seconds");
send_msg(tnsl, "PING\r\n"); send_msg(tnsl, (char *)"PING\r\n");
} else if (((int)now - (int)tnsl->last) > 60) { } else if (((int)now - (int)tnsl->last) > 60) {
send_msg(tnsl, "PING\r\n"); send_msg(tnsl, (char *)"PING\r\n");
} }
tnsl->action = now + (time_t)10; tnsl->action = now + (time_t)10;
break; break;
@ -1044,12 +1051,12 @@ int command_pass(char *hostname, char *parameters)
lnk = strtok(NULL, " \0"); lnk = strtok(NULL, " \0");
if (strcmp(passwd, "0100") == 0) { if (strcmp(passwd, "0100") == 0) {
send_msg(tnsl, "414 PASS: Got empty password\r\n"); send_msg(tnsl, (char *)"414 PASS: Got empty password\r\n");
return 414; return 414;
} }
if (version == NULL) { if (version == NULL) {
send_msg(tnsl, "400 PASS: Not enough parameters\r\n"); send_msg(tnsl, (char *)"400 PASS: Not enough parameters\r\n");
return 400; return 400;
} }
@ -1059,7 +1066,7 @@ int command_pass(char *hostname, char *parameters)
} }
if (tnsl->state == NCS_CONNECT) { if (tnsl->state == NCS_CONNECT) {
send_msg(tnsl, "401: PASS: Already registered\r\n"); send_msg(tnsl, (char *)"401: PASS: Already registered\r\n");
tnsl->halfdead++; /* Count them */ tnsl->halfdead++; /* Count them */
srvchg = TRUE; srvchg = TRUE;
return 401; return 401;
@ -1100,7 +1107,7 @@ int command_server(char *hostname, char *parameters)
} }
if (fullname == NULL) { if (fullname == NULL) {
send_msg(tnsl, "400 SERVER: Not enough parameters\r\n"); send_msg(tnsl, (char *)"400 SERVER: Not enough parameters\r\n");
return 400; return 400;
} }
@ -1129,25 +1136,42 @@ int command_server(char *hostname, char *parameters)
*/ */
for (ta = servers; ta; ta = ta->next) { for (ta = servers; ta; ta = ta->next) {
if (ta->hops) { if (ta->hops) {
send_msg(tnsl, "SERVER %s %d 0 %s %s %s\r\n", ta->server, ta->hops, ta->prod, ta->vers, ta->fullname); p = calloc(512, sizeof(char));
snprintf(p, 512, "SERVER %s %d 0 %s %s %s\r\n", ta->server, ta->hops, ta->prod, ta->vers, ta->fullname);
send_msg(tnsl, p);
free(p);
} }
} }
/* /*
* Send all known users, nicknames and join channels * Send all known users, nicknames and join channels
*/ */
for (tmp = users; tmp; tmp = tmp->next) { for (tmp = users; tmp; tmp = tmp->next) {
send_msg(tnsl, "USER %s@%s %s\r\n", tmp->name, tmp->server, tmp->realname); p = calloc(512, sizeof(char));
if (strcmp(tmp->name, tmp->nick)) snprintf(p, 512, "USER %s@%s %s\r\n", tmp->name, tmp->server, tmp->realname);
send_msg(tnsl, "NICK %s %s %s %s\r\n", tmp->nick, tmp->name, tmp->server, tmp->realname); send_msg(tnsl, p);
if (strlen(tmp->channel)) if (strcmp(tmp->name, tmp->nick)) {
send_msg(tnsl, "JOIN %s@%s %s\r\n", tmp->name, tmp->server, tmp->channel); snprintf(p, 512, "NICK %s %s %s %s\r\n", tmp->nick, tmp->name, tmp->server, tmp->realname);
send_msg(tnsl, p);
}
if (strlen(tmp->channel)) {
snprintf(p, 512, "JOIN %s@%s %s\r\n", tmp->name, tmp->server, tmp->channel);
send_msg(tnsl, p);
}
free(p);
} }
/* /*
* Send all known channel topics * Send all known channel topics
*/ */
for (tmpc = channels; tmpc; tmpc = tmpc->next) { for (tmpc = channels; tmpc; tmpc = tmpc->next) {
if (strlen(tmpc->topic) && (strcmp(tmpc->server, CFG.myfqdn) == 0)) if (strlen(tmpc->topic) && (strcmp(tmpc->server, CFG.myfqdn) == 0)) {
send_msg(tnsl, "TOPIC %s %s\r\n", tmpc->name, tmpc->topic); p = xstrcpy((char *)"TOPIC ");
p = xstrcat(p, tmpc->name);
p = xstrcat(p, (char *)" ");
p = xstrcat(p, tmpc->topic);
p = xstrcat(p, (char *)"\r\n");
send_msg(tnsl, p);
free(p);
}
} }
add_server(&servers, tnsl->server, ihops, prod, vers, fullname, hostname); add_server(&servers, tnsl->server, ihops, prod, vers, fullname, hostname);
return 0; return 0;
@ -1163,12 +1187,13 @@ int command_server(char *hostname, char *parameters)
* valid PASS command. * valid PASS command.
*/ */
if (found && tnsl->gotpass) { if (found && tnsl->gotpass) {
send_msg(tnsl, "PASS %s 0100 %s\r\n", tnsl->passwd, tnsl->compress ? "Z":"");
send_msg(tnsl, "SERVER %s 0 %ld mbsebbs %s %s\r\n", tnsl->myname, token, VERSION, CFG.bbs_name);
p = calloc(512, sizeof(char)); p = calloc(512, sizeof(char));
snprintf(p, 512, "PASS %s 0100 %s\r\n", tnsl->passwd, tnsl->compress ? "Z":"");
send_msg(tnsl, p);
snprintf(p, 512, "SERVER %s 0 %d mbsebbs %s %s\r\n", tnsl->myname, token, VERSION, CFG.bbs_name);
send_msg(tnsl, p);
snprintf(p, 512, "SERVER %s %d %s %s %s %s\r\n", name, ihops, id, prod, vers, fullname); snprintf(p, 512, "SERVER %s %d %s %s %s %s\r\n", name, ihops, id, prod, vers, fullname);
broadcast(tnsl->server, p); broadcast(tnsl->server, p);
free(p);
system_shout("* New server: %s, %s", name, fullname); system_shout("* New server: %s, %s", name, fullname);
tnsl->gotserver = TRUE; tnsl->gotserver = TRUE;
tnsl->state = NCS_CONNECT; tnsl->state = NCS_CONNECT;
@ -1179,7 +1204,8 @@ int command_server(char *hostname, char *parameters)
*/ */
for (ta = servers; ta; ta = ta->next) { for (ta = servers; ta; ta = ta->next) {
if (ta->hops) { if (ta->hops) {
send_msg(tnsl, "SERVER %s %d 0 %s %s %s\r\n", ta->server, ta->hops, ta->prod, ta->vers, ta->fullname); snprintf(p, 512, "SERVER %s %d 0 %s %s %s\r\n", ta->server, ta->hops, ta->prod, ta->vers, ta->fullname);
send_msg(tnsl, p);
} }
} }
/* /*
@ -1187,15 +1213,28 @@ int command_server(char *hostname, char *parameters)
* If the user is one of our own and has set a channel topic, send it. * If the user is one of our own and has set a channel topic, send it.
*/ */
for (tmp = users; tmp; tmp = tmp->next) { for (tmp = users; tmp; tmp = tmp->next) {
send_msg(tnsl, "USER %s@%s %s\r\n", tmp->name, tmp->server, tmp->realname); snprintf(p, 512, "USER %s@%s %s\r\n", tmp->name, tmp->server, tmp->realname);
if (strcmp(tmp->name, tmp->nick)) send_msg(tnsl, p);
send_msg(tnsl, "NICK %s %s %s %s\r\n", tmp->nick, tmp->name, tmp->server, tmp->realname); if (strcmp(tmp->name, tmp->nick)) {
if (strlen(tmp->channel)) snprintf(p, 512, "NICK %s %s %s %s\r\n", tmp->nick, tmp->name, tmp->server, tmp->realname);
send_msg(tnsl, "JOIN %s@%s %s\r\n", tmp->name, tmp->server, tmp->channel); send_msg(tnsl, p);
}
if (strlen(tmp->channel)) {
snprintf(p, 512, "JOIN %s@%s %s\r\n", tmp->name, tmp->server, tmp->channel);
send_msg(tnsl, p);
}
} }
free(p);
for (tmpc = channels; tmpc; tmpc = tmpc->next) { for (tmpc = channels; tmpc; tmpc = tmpc->next) {
if (strlen(tmpc->topic) && (strcmp(tmpc->server, CFG.myfqdn) == 0)) if (strlen(tmpc->topic) && (strcmp(tmpc->server, CFG.myfqdn) == 0)) {
send_msg(tnsl, "TOPIC %s %s\r\n", tmpc->name, tmpc->topic); p = xstrcpy((char *)"TOPIC ");
p = xstrcat(p, tmpc->name);
p = xstrcat(p, (char *)" ");
p = xstrcat(p, tmpc->topic);
p = xstrcat(p, (char *)"\r\n");
send_msg(tnsl, p);
free(p);
}
} }
add_server(&servers, tnsl->server, ihops, prod, vers, fullname, hostname); add_server(&servers, tnsl->server, ihops, prod, vers, fullname, hostname);
srvchg = TRUE; srvchg = TRUE;
@ -1279,7 +1318,7 @@ int command_user(char *hostname, char *parameters)
realname = strtok(NULL, "\0"); realname = strtok(NULL, "\0");
if (realname == NULL) { if (realname == NULL) {
send_msg(tnsl, "400 USER: Not enough parameters\r\n"); send_msg(tnsl, (char *)"400 USER: Not enough parameters\r\n");
return 400; return 400;
} }
@ -1311,7 +1350,7 @@ int command_quit(char *hostname, char *parameters)
message = strtok(NULL, "\0"); message = strtok(NULL, "\0");
if (server == NULL) { if (server == NULL) {
send_msg(tnsl, "400 QUIT: Not enough parameters\r\n"); send_msg(tnsl, (char *)"400 QUIT: Not enough parameters\r\n");
return 400; return 400;
} }
@ -1349,12 +1388,15 @@ int command_nick(char *hostname, char *parameters)
realname = strtok(NULL, "\0"); realname = strtok(NULL, "\0");
if (realname == NULL) { if (realname == NULL) {
send_msg(tnsl, "400 NICK: Not enough parameters\r\n"); send_msg(tnsl, (char *)"400 NICK: Not enough parameters\r\n");
return 1; return 1;
} }
if (strlen(nick) > 9) { if (strlen(nick) > 9) {
send_msg(tnsl, "402 %s: Erroneous nickname\r\n", nick); p = calloc(81, sizeof(char));
snprintf(p, 81, "402 %s: Erroneous nickname\r\n", nick);
send_msg(tnsl, p);
free(p);
return 402; return 402;
} }
@ -1368,7 +1410,10 @@ int command_nick(char *hostname, char *parameters)
} }
} }
if (found) { if (found) {
send_msg(tnsl, "403 %s: Nickname is already in use\r\n", nick); p = calloc(81, sizeof(char));
snprintf(p, 81, "403 %s: Nickname is already in use\r\n", nick);
send_msg(tnsl, p);
free(p);
return 403; return 403;
} }
@ -1381,7 +1426,10 @@ int command_nick(char *hostname, char *parameters)
} }
} }
if (!found) { if (!found) {
send_msg(tnsl, "404 %s@%s: Can't change nick\r\n", name, server); p = calloc(81, sizeof(char));
snprintf(p, 81, "404 %s@%s: Can't change nick\r\n", name, server);
send_msg(tnsl, p);
free(p);
return 404; return 404;
} }
@ -1413,12 +1461,15 @@ int command_join(char *hostname, char *parameters)
channel = strtok(NULL, "\0"); channel = strtok(NULL, "\0");
if (channel == NULL) { if (channel == NULL) {
send_msg(tnsl, "400 JOIN: Not enough parameters\r\n"); send_msg(tnsl, (char *)"400 JOIN: Not enough parameters\r\n");
return 400; return 400;
} }
if (strlen(channel) > 20) { if (strlen(channel) > 20) {
send_msg(tnsl, "402 %s: Erroneous channelname\r\n", nick); p = calloc(81, sizeof(char));
snprintf(p, 81, "402 %s: Erroneous channelname\r\n", nick);
send_msg(tnsl, p);
free(p);
return 402; return 402;
} }
@ -1480,7 +1531,7 @@ int command_part(char *hostname, char *parameters)
message = strtok(NULL, "\0"); message = strtok(NULL, "\0");
if (channel == NULL) { if (channel == NULL) {
send_msg(tnsl, "400 PART: Not enough parameters\r\n"); send_msg(tnsl, (char *)"400 PART: Not enough parameters\r\n");
return 400; return 400;
} }
@ -1550,7 +1601,7 @@ int command_topic(char *hostname, char *parameters)
topic = strtok(NULL, "\0"); topic = strtok(NULL, "\0");
if (topic == NULL) { if (topic == NULL) {
send_msg(tnsl, "400 TOPIC: Not enough parameters\r\n"); send_msg(tnsl, (char *)"400 TOPIC: Not enough parameters\r\n");
return 400; return 400;
} }
@ -1593,12 +1644,12 @@ int command_privmsg(char *hostname, char *parameters)
msg = strtok(NULL, "\0"); msg = strtok(NULL, "\0");
if (msg == NULL) { if (msg == NULL) {
send_msg(tnsl, "412 PRIVMSG: No text to send\r\n"); send_msg(tnsl, (char *)"412 PRIVMSG: No text to send\r\n");
return 412; return 412;
} }
if (channel[0] != '#') { if (channel[0] != '#') {
send_msg(tnsl, "499 PRIVMSG: Not for a channel\r\n"); // FIXME: also check users send_msg(tnsl, (char *)"499 PRIVMSG: Not for a channel\r\n"); // FIXME: also check users
return 499; return 499;
} }
@ -1617,7 +1668,10 @@ int command_privmsg(char *hostname, char *parameters)
} }
} }
send_msg(tnsl, "409 %s: Cannot sent to channel\r\n", channel); p = calloc(81, sizeof(char));
snprintf(p, 81, "409 %s: Cannot sent to channel\r\n", channel);
send_msg(tnsl, p);
free(p);
return 409; return 409;
} }
@ -1626,6 +1680,7 @@ int command_privmsg(char *hostname, char *parameters)
int do_command(char *hostname, char *command, char *parameters) int do_command(char *hostname, char *command, char *parameters)
{ {
ncs_list *tnsl; ncs_list *tnsl;
char *p;
for (tnsl = ncsl; tnsl; tnsl = tnsl->next) { for (tnsl = ncsl; tnsl; tnsl = tnsl->next) {
if (strcmp(tnsl->server, hostname) == 0) { if (strcmp(tnsl->server, hostname) == 0) {
@ -1637,7 +1692,7 @@ int do_command(char *hostname, char *command, char *parameters)
* First the commands that don't have parameters * First the commands that don't have parameters
*/ */
if (! strcmp(command, (char *)"PING")) { if (! strcmp(command, (char *)"PING")) {
send_msg(tnsl, "PONG\r\n"); send_msg(tnsl, (char *)"PONG\r\n");
return 0; return 0;
} }
if (! strcmp(command, (char *)"PONG")) { if (! strcmp(command, (char *)"PONG")) {
@ -1656,7 +1711,10 @@ int do_command(char *hostname, char *command, char *parameters)
* Commands with parameters * Commands with parameters
*/ */
if (parameters == NULL) { if (parameters == NULL) {
send_msg(tnsl, "400 %s: Not enough parameters\r\n", command); p = calloc(81, sizeof(char));
snprintf(p, 81, "400 %s: Not enough parameters\r\n", command);
send_msg(tnsl, p);
free(p);
return 400; return 400;
} }
@ -1691,7 +1749,10 @@ int do_command(char *hostname, char *command, char *parameters)
return command_privmsg(hostname, parameters); return command_privmsg(hostname, parameters);
} }
send_msg(tnsl, "413 %s: Unknown command\r\n", command); p = calloc(81, sizeof(char));
snprintf(p, 81, "413 %s: Unknown command\r\n", command);
send_msg(tnsl, p);
free(p);
return 413; return 413;
} }
@ -1828,11 +1889,14 @@ void ibc_shutdown(void)
} }
} }
p = calloc(512, sizeof(char));
for (tnsl = ncsl; tnsl; tnsl = tnsl->next) { for (tnsl = ncsl; tnsl; tnsl = tnsl->next) {
if (tnsl->state == NCS_CONNECT) { if (tnsl->state == NCS_CONNECT) {
send_msg(tnsl, "SQUIT %s System shutdown\r\n", tnsl->myname); snprintf(p, 512, "SQUIT %s System shutdown\r\n", tnsl->myname);
send_msg(tnsl, p);
} }
} }
free(p);
tidy_servers(&servers); tidy_servers(&servers);
} }

View File

@ -80,16 +80,28 @@ void WriteError(const char *format, ...)
void Syslog(int grade, const char *format, ...) void Syslog(int grade, const char *format, ...)
{ {
va_list va_ptr; va_list va_ptr;
char outstr[1024], datestr[21], lname[PATH_MAX]; char outstr[1024];
int oldmask, debug;
va_start(va_ptr, format);
vsnprintf(outstr, 1024, format, va_ptr);
va_end(va_ptr);
Syslogp(grade, outstr);
}
/*
* Logging without string formatting
*/
void Syslogp(int grade, char *outstr)
{
char datestr[21], lname[PATH_MAX];
int i, oldmask, debug;
FILE *logfile = NULL, *debugfile; FILE *logfile = NULL, *debugfile;
time_t now; time_t now;
struct tm ptm; struct tm ptm;
debug = isalpha(grade); debug = isalpha(grade);
va_start(va_ptr, format);
vsnprintf(outstr, 1024, format, va_ptr);
va_end(va_ptr);
tcrc = StringCRC32(outstr); tcrc = StringCRC32(outstr);
if (tcrc == lcrc) { if (tcrc == lcrc) {
@ -136,7 +148,14 @@ void Syslog(int grade, const char *format, ...)
if (!debug) { if (!debug) {
fprintf(logfile, "%c %s mbtask[%d] ", grade, datestr, mypid); fprintf(logfile, "%c %s mbtask[%d] ", grade, datestr, mypid);
fprintf(logfile, *outstr == '$' ? outstr+1 : outstr); for (i = *outstr == '$' ? 1 : 0; i < strlen(outstr); i++) {
if (iscntrl(outstr[i])) {
fputc('^', logfile);
fputc(outstr[i] + 64, logfile);
} else {
fputc(outstr[i], logfile);
}
}
if (*outstr == '$') if (*outstr == '$')
fprintf(logfile, ": %s\n", strerror(errno)); fprintf(logfile, ": %s\n", strerror(errno));
else else
@ -148,7 +167,14 @@ void Syslog(int grade, const char *format, ...)
} }
fprintf(debugfile, "%c %s mbtask[%d] ", grade, datestr, mypid); fprintf(debugfile, "%c %s mbtask[%d] ", grade, datestr, mypid);
fprintf(debugfile, *outstr == '$' ? outstr+1 : outstr); for (i = *outstr == '$' ? 1 : 0; i < strlen(outstr); i++) {
if (iscntrl(outstr[i])) {
fputc('^', debugfile);
fputc(outstr[i] + 64, debugfile);
} else {
fputc(outstr[i], debugfile);
}
}
if (*outstr == '$') if (*outstr == '$')
fprintf(debugfile, ": %s\n", strerror(errno)); fprintf(debugfile, ": %s\n", strerror(errno));
else else

View File

@ -22,6 +22,7 @@ typedef struct _srv_auth {
* Function prototypes * Function prototypes
*/ */
void WriteError(const char *, ...); void WriteError(const char *, ...);
void Syslogp(int, char *);
void Syslog(int, const char *, ...); void Syslog(int, const char *, ...);
int ulog(char *, char *, char *, char *, char*); int ulog(char *, char *, char *, char *, char*);
char *xstrcpy(char *); char *xstrcpy(char *);