-rw-r--r-- | bin/kdepim/WhatsNew.txt | 7 | ||||
-rw-r--r-- | kmicromail/libmailwrapper/smtpwrapper.cpp | 13 |
2 files changed, 14 insertions, 6 deletions
diff --git a/bin/kdepim/WhatsNew.txt b/bin/kdepim/WhatsNew.txt index b44d6d1..6c1f664 100644 --- a/bin/kdepim/WhatsNew.txt +++ b/bin/kdepim/WhatsNew.txt | |||
@@ -1,74 +1,81 @@ | |||
1 | Info about the changes in new versions of KDE-Pim/Pi | 1 | Info about the changes in new versions of KDE-Pim/Pi |
2 | 2 | ||
3 | ********** VERSION 2.2.5 ************ | ||
4 | |||
5 | Bugfixes in KO/Pi, KA/Pi and OM/Pi. | ||
6 | Added possibility to disable auto saving in KO/Pi. | ||
7 | How to disable it? Good question! Next question, please? | ||
8 | |||
9 | |||
3 | ********** VERSION 2.2.4 ************ | 10 | ********** VERSION 2.2.4 ************ |
4 | 11 | ||
5 | KO/Pi alarm applet: Made font smaller and added a dealy before starting KO/Pi to avoid problems accessing data storage when an alarm did wake up the Z. | 12 | KO/Pi alarm applet: Made font smaller and added a dealy before starting KO/Pi to avoid problems accessing data storage when an alarm did wake up the Z. |
6 | Added 3 sec notification about a started timer. | 13 | Added 3 sec notification about a started timer. |
7 | 14 | ||
8 | KO/Pi: | 15 | KO/Pi: |
9 | Added export option for all data to File->Export menu. | 16 | Added export option for all data to File->Export menu. |
10 | Better management if a save error occours. | 17 | Better management if a save error occours. |
11 | Added 15 sec delay in automatic saving when Z wake up from suspend and the automatic save timer did expire - to avoid problems accessing data storage directly after wake up. | 18 | Added 15 sec delay in automatic saving when Z wake up from suspend and the automatic save timer did expire - to avoid problems accessing data storage directly after wake up. |
12 | Fix for displaying month names of an utf8 translated language (like Russian). I hope a Russian version of KO/Pi will be available soon. | 19 | Fix for displaying month names of an utf8 translated language (like Russian). I hope a Russian version of KO/Pi will be available soon. |
13 | 20 | ||
14 | Added duration info about multiday events. | 21 | Added duration info about multiday events. |
15 | Changed behaviour of "Set complete" in Todo viewer: Now Todo viewer closes not automatically. | 22 | Changed behaviour of "Set complete" in Todo viewer: Now Todo viewer closes not automatically. |
16 | 23 | ||
17 | KA/Pi: | 24 | KA/Pi: |
18 | Added for vCard import the option to import contact data in Latin1 format. | 25 | Added for vCard import the option to import contact data in Latin1 format. |
19 | 26 | ||
20 | ********** VERSION 2.2.3 ************ | 27 | ********** VERSION 2.2.3 ************ |
21 | 28 | ||
22 | KO/Pi: | 29 | KO/Pi: |
23 | Fixed a problem with (non empty) exception dates in the exception date edit dialog of recurring events for newly created events. | 30 | Fixed a problem with (non empty) exception dates in the exception date edit dialog of recurring events for newly created events. |
24 | 31 | ||
25 | Fixed usability problem in KA/Pi: | 32 | Fixed usability problem in KA/Pi: |
26 | Now searching works for "all phone numbers and all addresses" if "all fields" is selected as search option. | 33 | Now searching works for "all phone numbers and all addresses" if "all fields" is selected as search option. |
27 | 34 | ||
28 | Changed some behaviour in OM/Pi mail management to make it more usable. | 35 | Changed some behaviour in OM/Pi mail management to make it more usable. |
29 | 36 | ||
30 | 37 | ||
31 | ********** VERSION 2.2.2 ************ | 38 | ********** VERSION 2.2.2 ************ |
32 | 39 | ||
33 | KO/Pi: | 40 | KO/Pi: |
34 | Fixed a problem with the sort order of last modified date in list view. | 41 | Fixed a problem with the sort order of last modified date in list view. |
35 | KA/Pi: | 42 | KA/Pi: |
36 | Fixed a resource config read problem on windows. | 43 | Fixed a resource config read problem on windows. |
37 | 44 | ||
38 | 45 | ||
39 | ********** VERSION 2.2.1 ************ | 46 | ********** VERSION 2.2.1 ************ |
40 | 47 | ||
41 | KO/Pi: | 48 | KO/Pi: |
42 | Fixed a problem displaying very long allday events in agenda view in single day mode. | 49 | Fixed a problem displaying very long allday events in agenda view in single day mode. |
43 | Fixed a problem with the default settings for new todos. | 50 | Fixed a problem with the default settings for new todos. |
44 | Added an error message dialog if saving of calendar files is not possible. | 51 | Added an error message dialog if saving of calendar files is not possible. |
45 | Made it impossible to close KO/Pi if saving fails. | 52 | Made it impossible to close KO/Pi if saving fails. |
46 | Fixed a problem adding calendars on windows such that these calendars can be used on the memory stick. | 53 | Fixed a problem adding calendars on windows such that these calendars can be used on the memory stick. |
47 | Added config options for conflict detection. | 54 | Added config options for conflict detection. |
48 | 55 | ||
49 | KA/Pi: | 56 | KA/Pi: |
50 | Added a config option to turn on asking before a contact is deleted. | 57 | Added a config option to turn on asking before a contact is deleted. |
51 | Fixed a problem with the default view and view selection at startup. | 58 | Fixed a problem with the default view and view selection at startup. |
52 | Formatted name is now set on import, if formatted name is empty. | 59 | Formatted name is now set on import, if formatted name is empty. |
53 | Fixed a problem of displaying images in the contact details view: | 60 | Fixed a problem of displaying images in the contact details view: |
54 | Now the wid/hei ratio is not changed. | 61 | Now the wid/hei ratio is not changed. |
55 | I a picture is larger than 128 pixels in wid or hei it is downscaled to | 62 | I a picture is larger than 128 pixels in wid or hei it is downscaled to |
56 | max 128 pixels wid/hei. | 63 | max 128 pixels wid/hei. |
57 | 64 | ||
58 | ********** VERSION 2.2.0 ************ | 65 | ********** VERSION 2.2.0 ************ |
59 | 66 | ||
60 | New stable release! | 67 | New stable release! |
61 | Fixed some minor usability problems. | 68 | Fixed some minor usability problems. |
62 | Added writing of next alarm to a file for usage on pdaXrom. | 69 | Added writing of next alarm to a file for usage on pdaXrom. |
63 | 70 | ||
64 | 71 | ||
65 | ************************************* | 72 | ************************************* |
66 | 73 | ||
67 | You can find the complete changelog | 74 | You can find the complete changelog |
68 | from version 1.7.7 to 2.2.0 | 75 | from version 1.7.7 to 2.2.0 |
69 | in the source package or on | 76 | in the source package or on |
70 | 77 | ||
71 | http://www.pi-sync.net/html/changelog.html | 78 | http://www.pi-sync.net/html/changelog.html |
72 | 79 | ||
73 | 80 | ||
74 | 81 | ||
diff --git a/kmicromail/libmailwrapper/smtpwrapper.cpp b/kmicromail/libmailwrapper/smtpwrapper.cpp index a6c12e4..7c813cc 100644 --- a/kmicromail/libmailwrapper/smtpwrapper.cpp +++ b/kmicromail/libmailwrapper/smtpwrapper.cpp | |||
@@ -137,268 +137,269 @@ bool SMTPwrapper::smtpSend( mailmime *mail,bool later) { | |||
137 | cfg.setGroup( "Status" ); | 137 | cfg.setGroup( "Status" ); |
138 | cfg.writeEntry( "outgoing", ++m_queuedMail ); | 138 | cfg.writeEntry( "outgoing", ++m_queuedMail ); |
139 | emit queuedMails( m_queuedMail ); | 139 | emit queuedMails( m_queuedMail ); |
140 | return true; | 140 | return true; |
141 | } | 141 | } |
142 | from = getFrom( mail ); | 142 | from = getFrom( mail ); |
143 | rcpts = createRcptList( mail->mm_data.mm_message.mm_fields ); | 143 | rcpts = createRcptList( mail->mm_data.mm_message.mm_fields ); |
144 | bool result = smtpSend(from,rcpts,data,size); | 144 | bool result = smtpSend(from,rcpts,data,size); |
145 | if (data) { | 145 | if (data) { |
146 | free(data); | 146 | free(data); |
147 | } | 147 | } |
148 | if (from) { | 148 | if (from) { |
149 | free(from); | 149 | free(from); |
150 | } | 150 | } |
151 | if (rcpts) | 151 | if (rcpts) |
152 | smtp_address_list_free( rcpts ); | 152 | smtp_address_list_free( rcpts ); |
153 | return result; | 153 | return result; |
154 | } | 154 | } |
155 | 155 | ||
156 | void SMTPwrapper::storeFailedMail(const char*data,unsigned int size, const char*failuremessage) | 156 | void SMTPwrapper::storeFailedMail(const char*data,unsigned int size, const char*failuremessage) |
157 | { | 157 | { |
158 | if (data) { | 158 | if (data) { |
159 | storeMail(data,size,"Sendfailed"); | 159 | storeMail(data,size,"Sendfailed"); |
160 | } | 160 | } |
161 | if (failuremessage) { | 161 | if (failuremessage) { |
162 | QMessageBox::critical(0,i18n("Error sending mail"), | 162 | QMessageBox::critical(0,i18n("Error sending mail"), |
163 | failuremessage); | 163 | failuremessage); |
164 | } | 164 | } |
165 | } | 165 | } |
166 | 166 | ||
167 | int SMTPwrapper::start_smtp_tls() | 167 | int SMTPwrapper::start_smtp_tls() |
168 | { | 168 | { |
169 | if (!m_smtp) { | 169 | if (!m_smtp) { |
170 | return MAILSMTP_ERROR_IN_PROCESSING; | 170 | return MAILSMTP_ERROR_IN_PROCESSING; |
171 | } | 171 | } |
172 | int err = mailesmtp_starttls(m_smtp); | 172 | int err = mailesmtp_starttls(m_smtp); |
173 | if (err != MAILSMTP_NO_ERROR) return err; | 173 | if (err != MAILSMTP_NO_ERROR) return err; |
174 | mailstream_low * low; | 174 | mailstream_low * low; |
175 | mailstream_low * new_low; | 175 | mailstream_low * new_low; |
176 | low = mailstream_get_low(m_smtp->stream); | 176 | low = mailstream_get_low(m_smtp->stream); |
177 | if (!low) { | 177 | if (!low) { |
178 | return MAILSMTP_ERROR_IN_PROCESSING; | 178 | return MAILSMTP_ERROR_IN_PROCESSING; |
179 | } | 179 | } |
180 | int fd = mailstream_low_get_fd(low); | 180 | int fd = mailstream_low_get_fd(low); |
181 | if (fd > -1 && (new_low = mailstream_low_ssl_open(fd))!=0) { | 181 | if (fd > -1 && (new_low = mailstream_low_ssl_open(fd))!=0) { |
182 | mailstream_low_free(low); | 182 | mailstream_low_free(low); |
183 | mailstream_set_low(m_smtp->stream, new_low); | 183 | mailstream_set_low(m_smtp->stream, new_low); |
184 | } else { | 184 | } else { |
185 | return MAILSMTP_ERROR_IN_PROCESSING; | 185 | return MAILSMTP_ERROR_IN_PROCESSING; |
186 | } | 186 | } |
187 | return err; | 187 | return err; |
188 | } | 188 | } |
189 | 189 | ||
190 | void SMTPwrapper::connect_server() | 190 | void SMTPwrapper::connect_server() |
191 | { | 191 | { |
192 | QString server, user, pass; | 192 | QString server, user, pass; |
193 | bool ssl; | 193 | bool ssl; |
194 | uint16_t port; | 194 | uint16_t port; |
195 | ssl = false; | 195 | ssl = false; |
196 | bool try_tls = false; | 196 | bool try_tls = false; |
197 | bool force_tls=false; | 197 | bool force_tls=false; |
198 | QString failuretext = ""; | 198 | QString failuretext = ""; |
199 | 199 | ||
200 | if (m_smtp || !m_SmtpAccount) { | 200 | if (m_smtp || !m_SmtpAccount) { |
201 | return; | 201 | return; |
202 | } | 202 | } |
203 | server = m_SmtpAccount->getServer(); | 203 | server = m_SmtpAccount->getServer(); |
204 | if ( m_SmtpAccount->ConnectionType() == 3 ) { | 204 | if ( m_SmtpAccount->ConnectionType() == 3 ) { |
205 | ssl = true; | 205 | ssl = true; |
206 | try_tls = false; | 206 | try_tls = false; |
207 | } else if (m_SmtpAccount->ConnectionType() == 2) { | 207 | } else if (m_SmtpAccount->ConnectionType() == 2) { |
208 | force_tls = true; | 208 | force_tls = true; |
209 | try_tls = true; | 209 | try_tls = true; |
210 | } else if (m_SmtpAccount->ConnectionType() == 1) { | 210 | } else if (m_SmtpAccount->ConnectionType() == 1) { |
211 | try_tls = true; | 211 | try_tls = true; |
212 | } | 212 | } |
213 | int result = 1; | 213 | int result = 1; |
214 | port = m_SmtpAccount->getPort().toUInt(); | 214 | port = m_SmtpAccount->getPort().toUInt(); |
215 | 215 | ||
216 | m_smtp = mailsmtp_new( 20, &progress ); | 216 | m_smtp = mailsmtp_new( 20, &progress ); |
217 | if ( m_smtp == NULL ) { | 217 | if ( m_smtp == NULL ) { |
218 | /* no failure message cause this happens when problems with memory - than we | 218 | /* no failure message cause this happens when problems with memory - than we |
219 | we can not display any messagebox */ | 219 | we can not display any messagebox */ |
220 | return; | 220 | return; |
221 | } | 221 | } |
222 | //m_smtp->auth = MAILSMTP_AUTH_LOGIN; | 222 | //m_smtp->auth = MAILSMTP_AUTH_LOGIN; |
223 | 223 | ||
224 | int err = MAILSMTP_NO_ERROR; | 224 | int err = MAILSMTP_NO_ERROR; |
225 | ; // odebug << "Servername " << server << " at port " << port << "" << oendl; | 225 | ; // odebug << "Servername " << server << " at port " << port << "" << oendl; |
226 | if ( ssl ) { | 226 | if ( ssl ) { |
227 | qDebug("smtp: ssl_connect "); | 227 | qDebug("smtp: ssl_connect "); |
228 | err = mailsmtp_ssl_connect( m_smtp, server.latin1(), port ); | 228 | err = mailsmtp_ssl_connect( m_smtp, server.latin1(), port ); |
229 | } else { | 229 | } else { |
230 | ; // odebug << "No SSL session" << oendl; | 230 | ; // odebug << "No SSL session" << oendl; |
231 | err = mailsmtp_socket_connect( m_smtp, server.latin1(), port ); | 231 | err = mailsmtp_socket_connect( m_smtp, server.latin1(), port ); |
232 | } | 232 | } |
233 | if ( err != MAILSMTP_NO_ERROR ) { | 233 | if ( err != MAILSMTP_NO_ERROR ) { |
234 | qDebug("Error init SMTP connection" ); | 234 | qDebug("Error init SMTP connection" ); |
235 | failuretext = i18n("Error init SMTP connection:\n%1").arg(mailsmtpError(err)); | 235 | failuretext = i18n("Error init SMTP connection:\n%1").arg(mailsmtpError(err)); |
236 | result = 0; | 236 | result = 0; |
237 | } | 237 | } |
238 | 238 | ||
239 | qDebug("SMTP connection inited "); | 239 | qDebug("SMTP connection inited "); |
240 | /* switch to tls after init 'cause there it will send the ehlo */ | 240 | /* switch to tls after init 'cause there it will send the ehlo */ |
241 | if (result) { | 241 | if (result) { |
242 | err = mailsmtp_init( m_smtp ); | 242 | err = mailsmtp_init( m_smtp ); |
243 | if (err != MAILSMTP_NO_ERROR) { | 243 | if (err != MAILSMTP_NO_ERROR) { |
244 | result = 0; | 244 | result = 0; |
245 | qDebug("Error init SMTP connection "); | 245 | qDebug("Error init SMTP connection "); |
246 | failuretext = i18n("Error init SMTP connection:\n%1").arg(mailsmtpError(err)); | 246 | failuretext = i18n("Error init SMTP connection:\n%1").arg(mailsmtpError(err)); |
247 | } | 247 | } |
248 | } | 248 | } |
249 | if (result && try_tls) { | 249 | if (result && try_tls) { |
250 | qDebug("Smpt: Try TLS... "); | 250 | qDebug("Smpt: Try TLS... "); |
251 | err = start_smtp_tls(); | 251 | err = start_smtp_tls(); |
252 | if (err != MAILSMTP_NO_ERROR) { | 252 | if (err != MAILSMTP_NO_ERROR) { |
253 | try_tls = false; | 253 | try_tls = false; |
254 | qDebug("Smpt: No TLS possible "); | 254 | qDebug("Smpt: No TLS possible "); |
255 | } else { | 255 | } else { |
256 | qDebug("Smpt: Using TLS "); | 256 | qDebug("Smpt: Using TLS "); |
257 | } | 257 | } |
258 | } | 258 | } |
259 | 259 | ||
260 | //qDebug("mailesmtp_ehlo %d ",err ); | 260 | //qDebug("mailesmtp_ehlo %d ",err ); |
261 | if (!try_tls && force_tls) { | 261 | if (!try_tls && force_tls) { |
262 | result = 0; | 262 | result = 0; |
263 | failuretext = i18n("Error init SMTP tls:%1").arg(mailsmtpError(err)); | 263 | failuretext = i18n("Error init SMTP tls:%1").arg(mailsmtpError(err)); |
264 | } | 264 | } |
265 | if ( mailesmtp_ehlo(m_smtp) != MAILSMTP_NO_ERROR ) { | 265 | //LR 05-10-22 : qDebug("no elo any more "); |
266 | qDebug("Smpt: ehlo failed "); | 266 | // if ( false /*mailesmtp_ehlo(m_smtp) != MAILSMTP_NO_ERROR */) { |
267 | result = 0; | 267 | // qDebug("Smpt: ehlo failed "); |
268 | } | 268 | // result = 0; |
269 | else { | 269 | // } |
270 | // else { | ||
270 | //qDebug("Smpt: auth is %d -- %d %d",m_smtp->auth, MAILSMTP_AUTH_LOGIN, MAILSMTP_AUTH_PLAIN); | 271 | //qDebug("Smpt: auth is %d -- %d %d",m_smtp->auth, MAILSMTP_AUTH_LOGIN, MAILSMTP_AUTH_PLAIN); |
271 | if ( m_smtp->auth & MAILSMTP_AUTH_LOGIN && m_smtp->auth & MAILSMTP_AUTH_PLAIN ) { | 272 | if ( m_smtp->auth & MAILSMTP_AUTH_LOGIN && m_smtp->auth & MAILSMTP_AUTH_PLAIN ) { |
272 | qDebug("Smpt: Using MAILSMTP_AUTH_LOGIN "); | 273 | qDebug("Smpt: Using MAILSMTP_AUTH_LOGIN "); |
273 | m_smtp->auth -= MAILSMTP_AUTH_PLAIN; | 274 | m_smtp->auth -= MAILSMTP_AUTH_PLAIN; |
274 | //qDebug("Smpt: auth is %d -- %d %d",m_smtp->auth, MAILSMTP_AUTH_LOGIN, MAILSMTP_AUTH_PLAIN); | 275 | //qDebug("Smpt: auth is %d -- %d %d",m_smtp->auth, MAILSMTP_AUTH_LOGIN, MAILSMTP_AUTH_PLAIN); |
275 | } | 276 | } |
276 | } | 277 | // } |
277 | 278 | ||
278 | if (result==1 && m_SmtpAccount->getLogin() ) { | 279 | if (result==1 && m_SmtpAccount->getLogin() ) { |
279 | ; // odebug << "smtp with auth" << oendl; | 280 | ; // odebug << "smtp with auth" << oendl; |
280 | if ( m_SmtpAccount->getUser().isEmpty() || m_SmtpAccount->getPassword().isEmpty() ) { | 281 | if ( m_SmtpAccount->getUser().isEmpty() || m_SmtpAccount->getPassword().isEmpty() ) { |
281 | // get'em | 282 | // get'em |
282 | LoginDialog login( m_SmtpAccount->getUser(), | 283 | LoginDialog login( m_SmtpAccount->getUser(), |
283 | m_SmtpAccount->getPassword(), NULL, 0, true ); | 284 | m_SmtpAccount->getPassword(), NULL, 0, true ); |
284 | login.show(); | 285 | login.show(); |
285 | if ( QDialog::Accepted == login.exec() ) { | 286 | if ( QDialog::Accepted == login.exec() ) { |
286 | // ok | 287 | // ok |
287 | user = login.getUser(); | 288 | user = login.getUser(); |
288 | pass = login.getPassword(); | 289 | pass = login.getPassword(); |
289 | } else { | 290 | } else { |
290 | result = 0; | 291 | result = 0; |
291 | failuretext=i18n("Login aborted - \nstoring mail to localfolder"); | 292 | failuretext=i18n("Login aborted - \nstoring mail to localfolder"); |
292 | } | 293 | } |
293 | } else { | 294 | } else { |
294 | user = m_SmtpAccount->getUser(); | 295 | user = m_SmtpAccount->getUser(); |
295 | pass = m_SmtpAccount->getPassword(); | 296 | pass = m_SmtpAccount->getPassword(); |
296 | } | 297 | } |
297 | ; // odebug << "session->auth: " << m_smtp->auth << "" << oendl; | 298 | ; // odebug << "session->auth: " << m_smtp->auth << "" << oendl; |
298 | if (result) { | 299 | if (result) { |
299 | err = mailsmtp_auth( m_smtp, (char*)user.latin1(), (char*)pass.latin1() ); | 300 | err = mailsmtp_auth( m_smtp, (char*)user.latin1(), (char*)pass.latin1() ); |
300 | if ( err == MAILSMTP_NO_ERROR ) { | 301 | if ( err == MAILSMTP_NO_ERROR ) { |
301 | qDebug("Smtp authentification ok "); | 302 | qDebug("Smtp authentification ok "); |
302 | } else { | 303 | } else { |
303 | failuretext = i18n("Authentification failed"); | 304 | failuretext = i18n("Authentification failed"); |
304 | result = 0; | 305 | result = 0; |
305 | } | 306 | } |
306 | } | 307 | } |
307 | } | 308 | } |
308 | if ( result == 0 ) { | 309 | if ( result == 0 ) { |
309 | mailsmtp_free(m_smtp); | 310 | mailsmtp_free(m_smtp); |
310 | m_smtp = 0; | 311 | m_smtp = 0; |
311 | } | 312 | } |
312 | } | 313 | } |
313 | 314 | ||
314 | void SMTPwrapper::disc_server() | 315 | void SMTPwrapper::disc_server() |
315 | { | 316 | { |
316 | if (m_smtp) { | 317 | if (m_smtp) { |
317 | mailsmtp_quit( m_smtp ); | 318 | mailsmtp_quit( m_smtp ); |
318 | mailsmtp_free( m_smtp ); | 319 | mailsmtp_free( m_smtp ); |
319 | m_smtp = 0; | 320 | m_smtp = 0; |
320 | } | 321 | } |
321 | } | 322 | } |
322 | 323 | ||
323 | int SMTPwrapper::smtpSend(char*from,clist*rcpts,const char*data,size_t size ) | 324 | int SMTPwrapper::smtpSend(char*from,clist*rcpts,const char*data,size_t size ) |
324 | { | 325 | { |
325 | int err,result; | 326 | int err,result; |
326 | QString failuretext = ""; | 327 | QString failuretext = ""; |
327 | 328 | ||
328 | connect_server(); | 329 | connect_server(); |
329 | 330 | ||
330 | result = 1; | 331 | result = 1; |
331 | if (m_smtp) { | 332 | if (m_smtp) { |
332 | err = mailsmtp_send( m_smtp, from, rcpts, data, size ); | 333 | err = mailsmtp_send( m_smtp, from, rcpts, data, size ); |
333 | if ( err != MAILSMTP_NO_ERROR ) { | 334 | if ( err != MAILSMTP_NO_ERROR ) { |
334 | qDebug("Error sending mail"); | 335 | qDebug("Error sending mail"); |
335 | failuretext=i18n("Error sending mail:\n%1").arg(mailsmtpError(err)); | 336 | failuretext=i18n("Error sending mail:\n%1").arg(mailsmtpError(err)); |
336 | result = 0; | 337 | result = 0; |
337 | } | 338 | } |
338 | } else { | 339 | } else { |
339 | result = 0; | 340 | result = 0; |
340 | } | 341 | } |
341 | 342 | ||
342 | if (!result) { | 343 | if (!result) { |
343 | storeFailedMail(data,size,failuretext); | 344 | storeFailedMail(data,size,failuretext); |
344 | } else { | 345 | } else { |
345 | ; // odebug << "Mail sent." << oendl; | 346 | ; // odebug << "Mail sent." << oendl; |
346 | storeMail(data,size,"Sent"); | 347 | storeMail(data,size,"Sent"); |
347 | } | 348 | } |
348 | return result; | 349 | return result; |
349 | } | 350 | } |
350 | 351 | ||
351 | bool SMTPwrapper::sendMail(const Opie::Core::OSmartPointer<Mail>&mail,bool later ) | 352 | bool SMTPwrapper::sendMail(const Opie::Core::OSmartPointer<Mail>&mail,bool later ) |
352 | { | 353 | { |
353 | mailmime * mimeMail; | 354 | mailmime * mimeMail; |
354 | bool result = true; | 355 | bool result = true; |
355 | mimeMail = createMimeMail(mail ); | 356 | mimeMail = createMimeMail(mail ); |
356 | if ( mimeMail == 0 ) { | 357 | if ( mimeMail == 0 ) { |
357 | qDebug("SMTP wrapper:Error creating mail! "); | 358 | qDebug("SMTP wrapper:Error creating mail! "); |
358 | return false; | 359 | return false; |
359 | } else { | 360 | } else { |
360 | sendProgress = new progressMailSend(); | 361 | sendProgress = new progressMailSend(); |
361 | sendProgress->show(); | 362 | sendProgress->show(); |
362 | sendProgress->setMaxMails(1); | 363 | sendProgress->setMaxMails(1); |
363 | result = smtpSend( mimeMail,later); | 364 | result = smtpSend( mimeMail,later); |
364 | ; // odebug << "Clean up done" << oendl; | 365 | ; // odebug << "Clean up done" << oendl; |
365 | sendProgress->hide(); | 366 | sendProgress->hide(); |
366 | delete sendProgress; | 367 | delete sendProgress; |
367 | sendProgress = 0; | 368 | sendProgress = 0; |
368 | mailmime_free( mimeMail ); | 369 | mailmime_free( mimeMail ); |
369 | if ( m_smtp ) { | 370 | if ( m_smtp ) { |
370 | mailsmtp_free(m_smtp); | 371 | mailsmtp_free(m_smtp); |
371 | m_smtp = 0; | 372 | m_smtp = 0; |
372 | } | 373 | } |
373 | } | 374 | } |
374 | return result; | 375 | return result; |
375 | } | 376 | } |
376 | 377 | ||
377 | int SMTPwrapper::sendQueuedMail(AbstractMail*wrap,const RecMailP&which) { | 378 | int SMTPwrapper::sendQueuedMail(AbstractMail*wrap,const RecMailP&which) { |
378 | size_t curTok = 0; | 379 | size_t curTok = 0; |
379 | mailimf_fields *fields = 0; | 380 | mailimf_fields *fields = 0; |
380 | mailimf_field*ffrom = 0; | 381 | mailimf_field*ffrom = 0; |
381 | clist *rcpts = 0; | 382 | clist *rcpts = 0; |
382 | char*from = 0; | 383 | char*from = 0; |
383 | int res = 0; | 384 | int res = 0; |
384 | 385 | ||
385 | encodedString * data = wrap->fetchRawBody(which); | 386 | encodedString * data = wrap->fetchRawBody(which); |
386 | if (!data) | 387 | if (!data) |
387 | return 0; | 388 | return 0; |
388 | int err = mailimf_fields_parse( data->Content(), data->Length(), &curTok, &fields ); | 389 | int err = mailimf_fields_parse( data->Content(), data->Length(), &curTok, &fields ); |
389 | if (err != MAILIMF_NO_ERROR) { | 390 | if (err != MAILIMF_NO_ERROR) { |
390 | delete data; | 391 | delete data; |
391 | delete wrap; | 392 | delete wrap; |
392 | return 0; | 393 | return 0; |
393 | } | 394 | } |
394 | 395 | ||
395 | rcpts = createRcptList( fields ); | 396 | rcpts = createRcptList( fields ); |
396 | ffrom = getField(fields, MAILIMF_FIELD_FROM ); | 397 | ffrom = getField(fields, MAILIMF_FIELD_FROM ); |
397 | from = getFrom(ffrom); | 398 | from = getFrom(ffrom); |
398 | 399 | ||
399 | if (rcpts && from) { | 400 | if (rcpts && from) { |
400 | res = smtpSend(from,rcpts,data->Content(),data->Length()); | 401 | res = smtpSend(from,rcpts,data->Content(),data->Length()); |
401 | } | 402 | } |
402 | if (fields) { | 403 | if (fields) { |
403 | mailimf_fields_free(fields); | 404 | mailimf_fields_free(fields); |
404 | fields = 0; | 405 | fields = 0; |