1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
#include <u.h>
#include <libc.h>
#include <authsrv.h>
#include <bio.h>
#include "authcmdlib.h"
static void
record(char *db, char *user, char *msg)
{
char buf[Maxpath];
int fd;
snprint(buf, sizeof buf, "%s/%s/log", db, user);
fd = open(buf, OWRITE);
if(fd < 0)
return;
write(fd, msg, strlen(msg));
close(fd);
return;
}
void
logfail(char *user)
{
if(!user)
return;
record(KEYDB, user, "bad");
record(NETKEYDB, user, "bad");
}
void
succeed(char *user)
{
if(!user)
return;
record(KEYDB, user, "good");
record(NETKEYDB, user, "good");
}
void
fail(char *user)
{
logfail(user);
exits("failure");
}
|