Mercurial > dovecot > original-hg > dovecot-1.2
annotate src/plugins/mail-log/mail-log-plugin.c @ 5205:f33e5ce7a73c HEAD
Fixed deleted/undeleted logging.
author | Timo Sirainen <tss@iki.fi> |
---|---|
date | Wed, 28 Feb 2007 23:00:39 +0200 |
parents | 24f4a959a24c |
children | 1fffd36401eb |
rev | line source |
---|---|
5034
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
1 /* Copyright (C) 2007 Timo Sirainen */ |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
2 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
3 #include "lib.h" |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
4 #include "array.h" |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
5 #include "str-sanitize.h" |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
6 #include "mail-storage-private.h" |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
7 #include "mail-log-plugin.h" |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
8 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
9 #define MAILBOX_NAME_LOG_LEN 64 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
10 #define MSGID_LOG_LEN 80 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
11 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
12 #define MAIL_LOG_CONTEXT(obj) \ |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
13 *((void **)array_idx_modifiable(&(obj)->module_contexts, \ |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
14 mail_log_storage_module_id)) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
15 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
16 struct mail_log_mail_storage { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
17 struct mail_storage_vfuncs super; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
18 }; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
19 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
20 struct mail_log_mailbox { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
21 struct mailbox_vfuncs super; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
22 }; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
23 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
24 struct mail_log_mail { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
25 struct mail_vfuncs super; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
26 }; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
27 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
28 /* defined by imap, pop3, lda */ |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
29 extern void (*hook_mail_storage_created)(struct mail_storage *storage); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
30 |
5185
24f4a959a24c
Added <plugin_name>_version string.
Timo Sirainen <tss@iki.fi>
parents:
5117
diff
changeset
|
31 const char *mail_log_plugin_version = PACKAGE_VERSION; |
24f4a959a24c
Added <plugin_name>_version string.
Timo Sirainen <tss@iki.fi>
parents:
5117
diff
changeset
|
32 |
5034
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
33 static void (*mail_log_next_hook_mail_storage_created) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
34 (struct mail_storage *storage); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
35 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
36 static unsigned int mail_log_storage_module_id = 0; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
37 static bool mail_log_storage_module_id_set = FALSE; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
38 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
39 static void mail_log_action(struct mail *mail, const char *action) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
40 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
41 const char *msgid; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
42 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
43 msgid = mail_get_first_header(mail, "Message-ID"); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
44 i_info("%s: uid=%u, msgid=%s", action, mail->uid, |
5117
02f7ce1e75f6
Don't crash with expunging mails with non-existing message-id header.
Timo Sirainen <tss@iki.fi>
parents:
5034
diff
changeset
|
45 msgid == NULL ? "(null)" : str_sanitize(msgid, MSGID_LOG_LEN)); |
5034
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
46 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
47 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
48 static int mail_log_mail_expunge(struct mail *_mail) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
49 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
50 struct mail_private *mail = (struct mail_private *)_mail; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
51 struct mail_log_mail *lmail = MAIL_LOG_CONTEXT(mail); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
52 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
53 if (lmail->super.expunge(_mail) < 0) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
54 return -1; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
55 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
56 mail_log_action(_mail, "expunged"); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
57 return 0; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
58 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
59 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
60 static int |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
61 mail_log_mail_update_flags(struct mail *_mail, enum modify_type modify_type, |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
62 enum mail_flags flags) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
63 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
64 struct mail_private *mail = (struct mail_private *)_mail; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
65 struct mail_log_mail *lmail = MAIL_LOG_CONTEXT(mail); |
5205
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
66 enum mail_flags old_flags, new_flags; |
5034
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
67 |
5205
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
68 old_flags = mail_get_flags(_mail); |
5034
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
69 if (lmail->super.update_flags(_mail, modify_type, flags) < 0) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
70 return -1; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
71 |
5205
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
72 new_flags = old_flags; |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
73 switch (modify_type) { |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
74 case MODIFY_ADD: |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
75 new_flags |= flags; |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
76 break; |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
77 case MODIFY_REMOVE: |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
78 new_flags &= ~flags; |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
79 break; |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
80 case MODIFY_REPLACE: |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
81 new_flags = flags; |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
82 break; |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
83 } |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
84 if (((old_flags ^ new_flags) & MAIL_DELETED) == 0) |
5034
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
85 return 0; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
86 |
5205
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
87 mail_log_action(_mail, (new_flags & MAIL_DELETED) != 0 ? |
f33e5ce7a73c
Fixed deleted/undeleted logging.
Timo Sirainen <tss@iki.fi>
parents:
5185
diff
changeset
|
88 "deleted" : "undeleted"); |
5034
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
89 return 0; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
90 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
91 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
92 static struct mail * |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
93 mail_log_mail_alloc(struct mailbox_transaction_context *t, |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
94 enum mail_fetch_field wanted_fields, |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
95 struct mailbox_header_lookup_ctx *wanted_headers) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
96 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
97 struct mail_log_mailbox *lbox = MAIL_LOG_CONTEXT(t->box); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
98 struct mail_log_mail *lmail; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
99 struct mail *_mail; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
100 struct mail_private *mail; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
101 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
102 _mail = lbox->super.mail_alloc(t, wanted_fields, wanted_headers); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
103 mail = (struct mail_private *)_mail; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
104 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
105 lmail = p_new(mail->pool, struct mail_log_mail, 1); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
106 lmail->super = mail->v; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
107 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
108 mail->v.update_flags = mail_log_mail_update_flags; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
109 mail->v.expunge = mail_log_mail_expunge; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
110 array_idx_set(&mail->module_contexts, |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
111 mail_log_storage_module_id, &lmail); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
112 return _mail; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
113 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
114 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
115 static int |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
116 mail_log_copy(struct mailbox_transaction_context *t, struct mail *mail, |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
117 enum mail_flags flags, struct mail_keywords *keywords, |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
118 struct mail *dest_mail) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
119 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
120 struct mail_log_mailbox *lbox = MAIL_LOG_CONTEXT(t->box); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
121 const char *name; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
122 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
123 if (lbox->super.copy(t, mail, flags, keywords, dest_mail) < 0) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
124 return -1; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
125 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
126 t_push(); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
127 name = str_sanitize(mailbox_get_name(t->box), MAILBOX_NAME_LOG_LEN); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
128 mail_log_action(mail, t_strdup_printf("copy -> %s", name)); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
129 t_pop(); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
130 return 0; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
131 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
132 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
133 static struct mailbox * |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
134 mail_log_mailbox_open(struct mail_storage *storage, const char *name, |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
135 struct istream *input, enum mailbox_open_flags flags) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
136 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
137 struct mail_log_mail_storage *lstorage = MAIL_LOG_CONTEXT(storage); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
138 struct mailbox *box; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
139 struct mail_log_mailbox *lbox; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
140 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
141 box = lstorage->super.mailbox_open(storage, name, input, flags); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
142 if (box == NULL) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
143 return NULL; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
144 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
145 lbox = p_new(box->pool, struct mail_log_mailbox, 1); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
146 lbox->super = box->v; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
147 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
148 box->v.mail_alloc = mail_log_mail_alloc; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
149 box->v.copy = mail_log_copy; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
150 array_idx_set(&box->module_contexts, mail_log_storage_module_id, &lbox); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
151 return box; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
152 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
153 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
154 static int |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
155 mail_log_mailbox_delete(struct mail_storage *storage, const char *name) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
156 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
157 struct mail_log_mail_storage *lstorage = MAIL_LOG_CONTEXT(storage); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
158 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
159 if (lstorage->super.mailbox_delete(storage, name) < 0) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
160 return -1; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
161 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
162 i_info("Mailbox deleted: %s", str_sanitize(name, MAILBOX_NAME_LOG_LEN)); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
163 return 0; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
164 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
165 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
166 static void mail_log_mail_storage_created(struct mail_storage *storage) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
167 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
168 struct mail_log_mail_storage *lstorage; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
169 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
170 if (mail_log_next_hook_mail_storage_created != NULL) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
171 mail_log_next_hook_mail_storage_created(storage); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
172 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
173 lstorage = p_new(storage->pool, struct mail_log_mail_storage, 1); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
174 lstorage->super = storage->v; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
175 storage->v.mailbox_open = mail_log_mailbox_open; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
176 storage->v.mailbox_delete = mail_log_mailbox_delete; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
177 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
178 if (!mail_log_storage_module_id_set) { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
179 mail_log_storage_module_id = mail_storage_module_id++; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
180 mail_log_storage_module_id_set = TRUE; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
181 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
182 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
183 array_idx_set(&storage->module_contexts, |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
184 mail_log_storage_module_id, &lstorage); |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
185 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
186 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
187 void mail_log_plugin_init(void) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
188 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
189 mail_log_next_hook_mail_storage_created = |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
190 hook_mail_storage_created; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
191 hook_mail_storage_created = mail_log_mail_storage_created; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
192 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
193 |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
194 void mail_log_plugin_deinit(void) |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
195 { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
196 if (mail_log_storage_module_id_set) { |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
197 hook_mail_storage_created = |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
198 mail_log_next_hook_mail_storage_created; |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
199 } |
1b28e0434d85
Added mail_log plugin to log various mail operations. Currently it logs mail
Timo Sirainen <tss@iki.fi>
parents:
diff
changeset
|
200 } |