aboutsummaryrefslogtreecommitdiff
path: root/contrib/pg_logger/pg_logger.c
blob: af56a249c662a0687a9e3d2128c9b0d56a0c4632 (plain)
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/* pg_logger: stdin-to-syslog gateway for postgresql.
 *
 * Copyright 2001 by Nathan Myers <ncm@nospam.cantrip.org>
 * This software is distributed free of charge with no warranty of any kind.
 * You have permission to make copies for any purpose, provided that (1) 
 * this copyright notice is retained unchanged, and (2) you agree to 
 * absolve the author of all responsibility for all consequences arising 
 * from any use.  
 */

#include <stdio.h>
#include <stddef.h>
#include <syslog.h>
#include <string.h>

struct {
    const char *tag;
    int size;
    int priority;
} tags[] = {
    { "",         0,                 LOG_NOTICE },
    { "emerg:",   sizeof("emerg"),   LOG_EMERG },
    { "alert:",   sizeof("alert"),   LOG_ALERT },
    { "crit:",    sizeof("crit"),    LOG_CRIT },
    { "err:",     sizeof("err"),     LOG_ERR },
    { "error:",   sizeof("error"),   LOG_ERR },
    { "warning:", sizeof("warning"), LOG_WARNING },
    { "notice:",  sizeof("notice"),  LOG_NOTICE },
    { "info:",    sizeof("info"),    LOG_INFO },
    { "debug:",   sizeof("debug"),   LOG_DEBUG }
};

int main()
{
    char buf[301];
    int c;
    char *pos = buf;
    const char *colon = 0;

#ifndef DEBUG
    openlog("postgresql", LOG_CONS, LOG_LOCAL1);
#endif
    while ( (c = getchar()) != EOF) {
        if (c == '\r') {
          continue;
        }
        if (c == '\n') {
            int level = sizeof(tags)/sizeof(*tags);
            char *bol;

            if (colon == 0 || (size_t)(colon - buf) > sizeof("warning")) {
                level = 1;
            }
            *pos = 0;
            while (--level) {
                if (pos - buf >= tags[level].size
                    && strncmp(buf, tags[level].tag, tags[level].size) == 0) {
                    break; 
                }
            }
            bol = buf + tags[level].size;
            if (bol > buf && *bol == ' ') {
                ++bol;
            }
            if (pos - bol > 0) {
#ifndef DEBUG
                syslog(tags[level].priority, "%s", bol);
#else
                printf("%d/%s\n", tags[level].priority, bol);
#endif
            }
            pos = buf;
            colon = (char const *)0;
            continue;
        }
        if (c == ':' && !colon) {
            colon = pos;
        }
        if ((size_t)(pos - buf) < sizeof(buf)-1) {
            *pos++ = c;
        }
    }
    return 0;
}