supporting CC BCC when mailing.
Showing
8 changed files
with
29 additions
and
55 deletions
... | @@ -47,8 +47,7 @@ extern void mailer_destroy __P ((mailer_t *)); | ... | @@ -47,8 +47,7 @@ extern void mailer_destroy __P ((mailer_t *)); |
47 | extern int mailer_open __P ((mailer_t, int flags)); | 47 | extern int mailer_open __P ((mailer_t, int flags)); |
48 | extern int mailer_close __P ((mailer_t)); | 48 | extern int mailer_close __P ((mailer_t)); |
49 | 49 | ||
50 | extern int mailer_send_message __P ((mailer_t, const char *from, | 50 | extern int mailer_send_message __P ((mailer_t, message_t)); |
51 | const char *rcpt, int dsn, message_t)); | ||
52 | /* stream settings */ | 51 | /* stream settings */ |
53 | extern int mailer_get_stream __P ((mailer_t, stream_t *)); | 52 | extern int mailer_get_stream __P ((mailer_t, stream_t *)); |
54 | extern int mailer_set_stream __P ((mailer_t, stream_t)); | 53 | extern int mailer_set_stream __P ((mailer_t, stream_t)); | ... | ... |
... | @@ -50,6 +50,9 @@ extern int message_create __P ((message_t *, void *owner)); | ... | @@ -50,6 +50,9 @@ extern int message_create __P ((message_t *, void *owner)); |
50 | extern void message_destroy __P ((message_t *, void *owner)); | 50 | extern void message_destroy __P ((message_t *, void *owner)); |
51 | extern void * message_get_owner __P ((message_t)); | 51 | extern void * message_get_owner __P ((message_t)); |
52 | 52 | ||
53 | extern int message_ref __P ((message_t)); | ||
54 | #define message_unref(msg) message_destroy (&msg) | ||
55 | |||
53 | extern int message_get_header __P ((message_t, header_t *)); | 56 | extern int message_get_header __P ((message_t, header_t *)); |
54 | extern int message_set_header __P ((message_t, header_t, void *owner)); | 57 | extern int message_set_header __P ((message_t, header_t, void *owner)); |
55 | 58 | ... | ... |
... | @@ -74,8 +74,7 @@ struct _mailer | ... | @@ -74,8 +74,7 @@ struct _mailer |
74 | void (*_destroy) __P ((mailer_t)); | 74 | void (*_destroy) __P ((mailer_t)); |
75 | int (*_open) __P ((mailer_t, int flags)); | 75 | int (*_open) __P ((mailer_t, int flags)); |
76 | int (*_close) __P ((mailer_t)); | 76 | int (*_close) __P ((mailer_t)); |
77 | int (*_send_message) __P ((mailer_t, const char *from, const char *rcpt, | 77 | int (*_send_message) __P ((mailer_t, message_t)); |
78 | int dsn, message_t)); | ||
79 | }; | 78 | }; |
80 | 79 | ||
81 | /* Mail locks. */ | 80 | /* Mail locks. */ | ... | ... |
... | @@ -52,6 +52,9 @@ struct _message | ... | @@ -52,6 +52,9 @@ struct _message |
52 | mime_t mime; | 52 | mime_t mime; |
53 | observable_t observable; | 53 | observable_t observable; |
54 | 54 | ||
55 | /* Reference count. */ | ||
56 | int ref; | ||
57 | |||
55 | /* Holder for message_write. */ | 58 | /* Holder for message_write. */ |
56 | char *hdr_buf; | 59 | char *hdr_buf; |
57 | size_t hdr_buflen; | 60 | size_t hdr_buflen; | ... | ... |
... | @@ -156,12 +156,11 @@ mailer_close (mailer_t mailer) | ... | @@ -156,12 +156,11 @@ mailer_close (mailer_t mailer) |
156 | 156 | ||
157 | /* messages */ | 157 | /* messages */ |
158 | int | 158 | int |
159 | mailer_send_message (mailer_t mailer, const char *from, const char *rcpt, | 159 | mailer_send_message (mailer_t mailer, message_t msg) |
160 | int dsn, message_t msg) | ||
161 | { | 160 | { |
162 | if (mailer == NULL || mailer->_send_message == NULL) | 161 | if (mailer == NULL || mailer->_send_message == NULL) |
163 | return ENOSYS; | 162 | return ENOSYS; |
164 | return mailer->_send_message (mailer, from, rcpt, dsn, msg); | 163 | return mailer->_send_message (mailer, msg); |
165 | } | 164 | } |
166 | 165 | ||
167 | int | 166 | int | ... | ... |
... | @@ -50,6 +50,7 @@ message_create (message_t *pmsg, void *owner) | ... | @@ -50,6 +50,7 @@ message_create (message_t *pmsg, void *owner) |
50 | if (msg == NULL) | 50 | if (msg == NULL) |
51 | return ENOMEM; | 51 | return ENOMEM; |
52 | msg->owner = owner; | 52 | msg->owner = owner; |
53 | msg->ref = 1; | ||
53 | *pmsg = msg; | 54 | *pmsg = msg; |
54 | return 0; | 55 | return 0; |
55 | } | 56 | } |
... | @@ -61,6 +62,7 @@ message_destroy (message_t *pmsg, void *owner) | ... | @@ -61,6 +62,7 @@ message_destroy (message_t *pmsg, void *owner) |
61 | { | 62 | { |
62 | message_t msg = *pmsg; | 63 | message_t msg = *pmsg; |
63 | 64 | ||
65 | msg->ref--; | ||
64 | if (msg->owner == owner) | 66 | if (msg->owner == owner) |
65 | { | 67 | { |
66 | /* Notify the listeners. */ | 68 | /* Notify the listeners. */ |
... | @@ -91,13 +93,22 @@ message_destroy (message_t *pmsg, void *owner) | ... | @@ -91,13 +93,22 @@ message_destroy (message_t *pmsg, void *owner) |
91 | if (msg->mime) | 93 | if (msg->mime) |
92 | mime_destroy (&(msg->mime)); | 94 | mime_destroy (&(msg->mime)); |
93 | 95 | ||
94 | free (msg); | 96 | if (msg->ref <= 0) |
97 | free (msg); | ||
95 | } | 98 | } |
96 | /* Loose the link */ | 99 | /* Loose the link */ |
97 | *pmsg = NULL; | 100 | *pmsg = NULL; |
98 | } | 101 | } |
99 | } | 102 | } |
100 | 103 | ||
104 | int | ||
105 | message_ref (message_t msg) | ||
106 | { | ||
107 | if (msg) | ||
108 | msg->ref++; | ||
109 | return 0; | ||
110 | } | ||
111 | |||
101 | void * | 112 | void * |
102 | message_get_owner (message_t msg) | 113 | message_get_owner (message_t msg) |
103 | { | 114 | { |
... | @@ -132,7 +143,7 @@ message_set_header (message_t msg, header_t hdr, void *owner) | ... | @@ -132,7 +143,7 @@ message_set_header (message_t msg, header_t hdr, void *owner) |
132 | return EACCES; | 143 | return EACCES; |
133 | /* Make sure we destoy the old if it was own by the mesg */ | 144 | /* Make sure we destoy the old if it was own by the mesg */ |
134 | /* FIXME: I do not know if somebody has already a ref on this ? */ | 145 | /* FIXME: I do not know if somebody has already a ref on this ? */ |
135 | /* header_destroy (&(msg->header), msg); */ | 146 | header_destroy (&(msg->header), msg); |
136 | msg->header = hdr; | 147 | msg->header = hdr; |
137 | return 0; | 148 | return 0; |
138 | } | 149 | } |
... | @@ -165,7 +176,7 @@ message_set_body (message_t msg, body_t body, void *owner) | ... | @@ -165,7 +176,7 @@ message_set_body (message_t msg, body_t body, void *owner) |
165 | return EACCES; | 176 | return EACCES; |
166 | /* Make sure we destoy the old if it was own by the mesg. */ | 177 | /* Make sure we destoy the old if it was own by the mesg. */ |
167 | /* FIXME: I do not know if somebody has already a ref on this ? */ | 178 | /* FIXME: I do not know if somebody has already a ref on this ? */ |
168 | /* body_destroy (&(msg->body), msg); */ | 179 | body_destroy (&(msg->body), msg); |
169 | msg->body = body; | 180 | msg->body = body; |
170 | return 0; | 181 | return 0; |
171 | } | 182 | } |
... | @@ -177,6 +188,9 @@ message_set_stream (message_t msg, stream_t stream, void *owner) | ... | @@ -177,6 +188,9 @@ message_set_stream (message_t msg, stream_t stream, void *owner) |
177 | return EINVAL; | 188 | return EINVAL; |
178 | if (msg->owner != owner) | 189 | if (msg->owner != owner) |
179 | return EACCES; | 190 | return EACCES; |
191 | /* Make sure we destoy the old if it was own by the mesg. */ | ||
192 | /* FIXME: I do not know if somebody has already a ref on this ? */ | ||
193 | stream_destroy (&(msg->stream), msg); | ||
180 | msg->stream = stream; | 194 | msg->stream = stream; |
181 | return 0; | 195 | return 0; |
182 | } | 196 | } | ... | ... |
... | @@ -72,8 +72,7 @@ typedef struct _sendmail * sendmail_t; | ... | @@ -72,8 +72,7 @@ typedef struct _sendmail * sendmail_t; |
72 | static void sendmail_destroy (mailer_t); | 72 | static void sendmail_destroy (mailer_t); |
73 | static int sendmail_open (mailer_t, int); | 73 | static int sendmail_open (mailer_t, int); |
74 | static int sendmail_close (mailer_t); | 74 | static int sendmail_close (mailer_t); |
75 | static int sendmail_send_message (mailer_t, const char *from, const char *rcpt, | 75 | static int sendmail_send_message (mailer_t, message_t); |
76 | int dsn, message_t); | ||
77 | 76 | ||
78 | int | 77 | int |
79 | sendmail_init (mailer_t mailer) | 78 | sendmail_init (mailer_t mailer) |
... | @@ -148,8 +147,7 @@ sendmail_close (mailer_t mailer) | ... | @@ -148,8 +147,7 @@ sendmail_close (mailer_t mailer) |
148 | } | 147 | } |
149 | 148 | ||
150 | static int | 149 | static int |
151 | sendmail_send_message (mailer_t mailer, const char *from, const char *rcpt, | 150 | sendmail_send_message (mailer_t mailer, message_t msg) |
152 | int dsn, message_t msg) | ||
153 | { | 151 | { |
154 | sendmail_t sendmail = mailer->data; | 152 | sendmail_t sendmail = mailer->data; |
155 | int status = 0; | 153 | int status = 0; |
... | @@ -157,8 +155,6 @@ sendmail_send_message (mailer_t mailer, const char *from, const char *rcpt, | ... | @@ -157,8 +155,6 @@ sendmail_send_message (mailer_t mailer, const char *from, const char *rcpt, |
157 | if (sendmail == NULL || msg == NULL) | 155 | if (sendmail == NULL || msg == NULL) |
158 | return EINVAL; | 156 | return EINVAL; |
159 | 157 | ||
160 | sendmail->dsn = dsn; | ||
161 | |||
162 | switch (sendmail->state) | 158 | switch (sendmail->state) |
163 | { | 159 | { |
164 | case SENDMAIL_NO_STATE: | 160 | case SENDMAIL_NO_STATE: |
... | @@ -173,45 +169,6 @@ sendmail_send_message (mailer_t mailer, const char *from, const char *rcpt, | ... | @@ -173,45 +169,6 @@ sendmail_send_message (mailer_t mailer, const char *from, const char *rcpt, |
173 | argvec[1] = strdup ("-oi"); | 169 | argvec[1] = strdup ("-oi"); |
174 | argvec[2] = strdup ("-t"); | 170 | argvec[2] = strdup ("-t"); |
175 | 171 | ||
176 | if (from) | ||
177 | { | ||
178 | size_t len = strlen (from) + 1; | ||
179 | char *addr = calloc (len, sizeof (char)); | ||
180 | if (parseaddr (from, addr, len) == 0) | ||
181 | { | ||
182 | argc++; | ||
183 | argvec = realloc (argvec, argc * (sizeof (*argvec))); | ||
184 | argvec[argc - 1] = strdup ("-f"); | ||
185 | argc++; | ||
186 | argvec = realloc (argvec, argc * (sizeof (*argvec))); | ||
187 | argvec[argc - 1] = addr; | ||
188 | } | ||
189 | else | ||
190 | free (addr); | ||
191 | } | ||
192 | |||
193 | if (rcpt) | ||
194 | { | ||
195 | const char *p = rcpt; | ||
196 | do | ||
197 | { | ||
198 | size_t len = strlen (p) + 1; | ||
199 | char *addr = calloc (len, sizeof (char)); | ||
200 | if (parseaddr (rcpt, addr, len) == 0) | ||
201 | { | ||
202 | argc++; | ||
203 | argvec = realloc (argvec, argc * (sizeof (*argvec))); | ||
204 | argvec[argc - 1] = addr; | ||
205 | } | ||
206 | else | ||
207 | free (addr); | ||
208 | p = strchr (p, ','); | ||
209 | if (p != NULL) | ||
210 | p++; | ||
211 | } | ||
212 | while (p != NULL && *p != '\0'); | ||
213 | } | ||
214 | |||
215 | argc++; | 172 | argc++; |
216 | argvec = realloc (argvec, argc * (sizeof (*argvec))); | 173 | argvec = realloc (argvec, argc * (sizeof (*argvec))); |
217 | argvec[argc - 1] = NULL; | 174 | argvec[argc - 1] = NULL; | ... | ... |
This diff is collapsed.
Click to expand it.
-
Please register or sign in to post a comment