Mercurial > dovecot > original-hg > dovecot-1.2
annotate src/login-common/client-common.c @ 7226:e6693a0ec8e1 HEAD
Renamed T_FRAME_BEGIN/END to T_BEGIN/END. Removed T_FRAME() macro and
replaced them with T_BEGIN/END calls. T_FRAME() made it difficult to debug
code with gdb.
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Mon, 11 Feb 2008 20:17:00 +0200 |
parents | eb71cda96663 |
children | 0bb3fc72a74f |
rev | line source |
---|---|
7086
7ed926ed7aa4
Updated copyright notices to include year 2008.
Timo Sirainen <tss@iki.fi>
parents:
6940
diff
changeset
|
1 /* Copyright (c) 2002-2008 Dovecot authors, see the included COPYING file */ |
2737 | 2 |
3 #include "common.h" | |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
4 #include "hostpid.h" |
7120
eb71cda96663
Use linked list macros for handling clients linked list.
Timo Sirainen <tss@iki.fi>
parents:
7117
diff
changeset
|
5 #include "llist.h" |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
6 #include "str.h" |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
7 #include "str-sanitize.h" |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
8 #include "var-expand.h" |
4570
cbbe2377f591
If SSL/TLS handshake didn't finish, show "TLS handshaking" instead of "TLS"
Timo Sirainen <tss@iki.fi>
parents:
3863
diff
changeset
|
9 #include "ssl-proxy.h" |
2737 | 10 #include "client-common.h" |
11 | |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
12 #include <stdlib.h> |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
13 |
7104
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
14 struct client *clients = NULL; |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
15 unsigned int clients_count = 0; |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
16 |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
17 void client_link(struct client *client) |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
18 { |
7120
eb71cda96663
Use linked list macros for handling clients linked list.
Timo Sirainen <tss@iki.fi>
parents:
7117
diff
changeset
|
19 DLLIST_PREPEND(&clients, client); |
7104
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
20 clients_count++; |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
21 } |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
22 |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
23 void client_unlink(struct client *client) |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
24 { |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
25 i_assert(clients_count > 0); |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
26 |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
27 clients_count--; |
7120
eb71cda96663
Use linked list macros for handling clients linked list.
Timo Sirainen <tss@iki.fi>
parents:
7117
diff
changeset
|
28 DLLIST_REMOVE(&clients, client); |
7104
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
29 } |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
30 |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
31 unsigned int clients_get_count(void) |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
32 { |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
33 return clients_count; |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
34 } |
db5f55daa002
Forgot from imap/pop3-login clients hash -> linked list commit.
Timo Sirainen <tss@iki.fi>
parents:
7086
diff
changeset
|
35 |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
36 static const struct var_expand_table * |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
37 get_var_expand_table(struct client *client) |
2737 | 38 { |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
39 static struct var_expand_table static_tab[] = { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
40 { 'u', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
41 { 'n', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
42 { 'd', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
43 { 's', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
44 { 'h', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
45 { 'l', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
46 { 'r', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
47 { 'p', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
48 { 'm', NULL }, |
4861
a688269c0dd4
Added %a=local port and %b=remote port variables for
Timo Sirainen <tss@iki.fi>
parents:
4570
diff
changeset
|
49 { 'a', NULL }, |
a688269c0dd4
Added %a=local port and %b=remote port variables for
Timo Sirainen <tss@iki.fi>
parents:
4570
diff
changeset
|
50 { 'b', NULL }, |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
51 { 'c', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
52 { '\0', NULL } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
53 }; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
54 struct var_expand_table *tab; |
7117
769181a20483
Make sure all user input is sanitized before it's logged.
Timo Sirainen <tss@iki.fi>
parents:
7104
diff
changeset
|
55 unsigned int i; |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
56 |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
57 tab = t_malloc(sizeof(static_tab)); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
58 memcpy(tab, static_tab, sizeof(static_tab)); |
2737 | 59 |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
60 if (client->virtual_user != NULL) { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
61 tab[0].value = client->virtual_user; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
62 tab[1].value = t_strcut(client->virtual_user, '@'); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
63 tab[2].value = strchr(client->virtual_user, '@'); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
64 if (tab[2].value != NULL) tab[2].value++; |
7117
769181a20483
Make sure all user input is sanitized before it's logged.
Timo Sirainen <tss@iki.fi>
parents:
7104
diff
changeset
|
65 |
769181a20483
Make sure all user input is sanitized before it's logged.
Timo Sirainen <tss@iki.fi>
parents:
7104
diff
changeset
|
66 for (i = 0; i < 3; i++) |
769181a20483
Make sure all user input is sanitized before it's logged.
Timo Sirainen <tss@iki.fi>
parents:
7104
diff
changeset
|
67 tab[i].value = str_sanitize(tab[i].value, 80); |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
68 } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
69 tab[3].value = login_protocol; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
70 tab[4].value = getenv("HOME"); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
71 tab[5].value = net_ip2addr(&client->local_ip); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
72 tab[6].value = net_ip2addr(&client->ip); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
73 tab[7].value = my_pid; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
74 tab[8].value = client->auth_mech_name == NULL ? NULL : |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
75 str_sanitize(client->auth_mech_name, MAX_MECH_NAME); |
4861
a688269c0dd4
Added %a=local port and %b=remote port variables for
Timo Sirainen <tss@iki.fi>
parents:
4570
diff
changeset
|
76 tab[9].value = dec2str(client->local_port); |
a688269c0dd4
Added %a=local port and %b=remote port variables for
Timo Sirainen <tss@iki.fi>
parents:
4570
diff
changeset
|
77 tab[10].value = dec2str(client->remote_port); |
4570
cbbe2377f591
If SSL/TLS handshake didn't finish, show "TLS handshaking" instead of "TLS"
Timo Sirainen <tss@iki.fi>
parents:
3863
diff
changeset
|
78 if (!client->tls) { |
4861
a688269c0dd4
Added %a=local port and %b=remote port variables for
Timo Sirainen <tss@iki.fi>
parents:
4570
diff
changeset
|
79 tab[11].value = client->secured ? "secured" : NULL; |
4570
cbbe2377f591
If SSL/TLS handshake didn't finish, show "TLS handshaking" instead of "TLS"
Timo Sirainen <tss@iki.fi>
parents:
3863
diff
changeset
|
80 } else { |
4861
a688269c0dd4
Added %a=local port and %b=remote port variables for
Timo Sirainen <tss@iki.fi>
parents:
4570
diff
changeset
|
81 tab[11].value = client->proxy != NULL && |
4570
cbbe2377f591
If SSL/TLS handshake didn't finish, show "TLS handshaking" instead of "TLS"
Timo Sirainen <tss@iki.fi>
parents:
3863
diff
changeset
|
82 ssl_proxy_is_handshaked(client->proxy) ? "TLS" : |
cbbe2377f591
If SSL/TLS handshake didn't finish, show "TLS handshaking" instead of "TLS"
Timo Sirainen <tss@iki.fi>
parents:
3863
diff
changeset
|
83 "TLS handshaking"; |
cbbe2377f591
If SSL/TLS handshake didn't finish, show "TLS handshaking" instead of "TLS"
Timo Sirainen <tss@iki.fi>
parents:
3863
diff
changeset
|
84 } |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
85 |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
86 return tab; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
87 } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
88 |
3863
55df57c028d4
Added "bool" type and changed all ints that were used as booleans to bool.
Timo Sirainen <tss@iki.fi>
parents:
3501
diff
changeset
|
89 static bool have_key(const struct var_expand_table *table, const char *str) |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
90 { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
91 char key; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
92 unsigned int i; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
93 |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
94 key = var_get_key(str); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
95 for (i = 0; table[i].key != '\0'; i++) { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
96 if (table[i].key == key) { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
97 return table[i].value != NULL && |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
98 table[i].value[0] != '\0'; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
99 } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
100 } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
101 return FALSE; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
102 } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
103 |
6940
414c9d631a81
Replaced t_push/t_pop calls with T_FRAME*() macros.
Timo Sirainen <tss@iki.fi>
parents:
6429
diff
changeset
|
104 static void client_syslog_real(struct client *client, const char *msg) |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
105 { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
106 static struct var_expand_table static_tab[3] = { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
107 { 's', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
108 { '$', NULL }, |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
109 { '\0', NULL } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
110 }; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
111 const struct var_expand_table *var_expand_table; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
112 struct var_expand_table *tab; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
113 const char *p, *const *e; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
114 string_t *str; |
2737 | 115 |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
116 var_expand_table = get_var_expand_table(client); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
117 |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
118 tab = t_malloc(sizeof(static_tab)); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
119 memcpy(tab, static_tab, sizeof(static_tab)); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
120 |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
121 str = t_str_new(256); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
122 for (e = log_format_elements; *e != NULL; e++) { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
123 for (p = *e; *p != '\0'; p++) { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
124 if (*p != '%' || p[1] == '\0') |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
125 continue; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
126 |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
127 p++; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
128 if (have_key(var_expand_table, p)) { |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
129 if (str_len(str) > 0) |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
130 str_append(str, ", "); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
131 var_expand(str, *e, var_expand_table); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
132 break; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
133 } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
134 } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
135 } |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
136 |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
137 tab[0].value = t_strdup(str_c(str)); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
138 tab[1].value = msg; |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
139 str_truncate(str, 0); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
140 |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
141 var_expand(str, log_format, tab); |
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
142 i_info("%s", str_c(str)); |
6940
414c9d631a81
Replaced t_push/t_pop calls with T_FRAME*() macros.
Timo Sirainen <tss@iki.fi>
parents:
6429
diff
changeset
|
143 } |
3384
3b75956d20c4
Added configurable logging for login process. Added configurable pop3 logout
Timo Sirainen <tss@iki.fi>
parents:
2737
diff
changeset
|
144 |
6940
414c9d631a81
Replaced t_push/t_pop calls with T_FRAME*() macros.
Timo Sirainen <tss@iki.fi>
parents:
6429
diff
changeset
|
145 void client_syslog(struct client *client, const char *msg) |
414c9d631a81
Replaced t_push/t_pop calls with T_FRAME*() macros.
Timo Sirainen <tss@iki.fi>
parents:
6429
diff
changeset
|
146 { |
7226
e6693a0ec8e1
Renamed T_FRAME_BEGIN/END to T_BEGIN/END. Removed T_FRAME() macro and
Timo Sirainen <tss@iki.fi>
parents:
7120
diff
changeset
|
147 T_BEGIN { |
6940
414c9d631a81
Replaced t_push/t_pop calls with T_FRAME*() macros.
Timo Sirainen <tss@iki.fi>
parents:
6429
diff
changeset
|
148 client_syslog_real(client, msg); |
7226
e6693a0ec8e1
Renamed T_FRAME_BEGIN/END to T_BEGIN/END. Removed T_FRAME() macro and
Timo Sirainen <tss@iki.fi>
parents:
7120
diff
changeset
|
149 } T_END; |
2737 | 150 } |