-rw-r--r-- | noncore/net/mailit/emailclient.cpp | 8 | ||||
-rw-r--r-- | noncore/net/mailit/emailhandler.cpp | 8 | ||||
-rw-r--r-- | noncore/net/mailit/mailitwindow.cpp | 22 | ||||
-rw-r--r-- | noncore/unsupported/mailit/emailclient.cpp | 8 | ||||
-rw-r--r-- | noncore/unsupported/mailit/emailhandler.cpp | 8 | ||||
-rw-r--r-- | noncore/unsupported/mailit/mailitwindow.cpp | 22 |
6 files changed, 42 insertions, 34 deletions
diff --git a/noncore/net/mailit/emailclient.cpp b/noncore/net/mailit/emailclient.cpp index 2102ba7..da1226c 100644 --- a/noncore/net/mailit/emailclient.cpp +++ b/noncore/net/mailit/emailclient.cpp | |||
@@ -280,388 +280,388 @@ void EmailClient::sendQuedMail() | |||
280 | { | 280 | { |
281 | int count = 0; | 281 | int count = 0; |
282 | 282 | ||
283 | if (accountList.count() == 0) { | 283 | if (accountList.count() == 0) { |
284 | QMessageBox::warning(qApp->activeWindow(), "No account selected", "You must create an account", "OK\n"); | 284 | QMessageBox::warning(qApp->activeWindow(), "No account selected", "You must create an account", "OK\n"); |
285 | return; | 285 | return; |
286 | } | 286 | } |
287 | //traverse listview, find messages to send | 287 | //traverse listview, find messages to send |
288 | if (! sending) { | 288 | if (! sending) { |
289 | item = (EmailListItem *) outboxView->firstChild(); | 289 | item = (EmailListItem *) outboxView->firstChild(); |
290 | if (item != NULL) { | 290 | if (item != NULL) { |
291 | while (item != NULL) { | 291 | while (item != NULL) { |
292 | quedMessages.append(item->getMail()); | 292 | quedMessages.append(item->getMail()); |
293 | item = (EmailListItem *) item->nextSibling(); | 293 | item = (EmailListItem *) item->nextSibling(); |
294 | count++; | 294 | count++; |
295 | } | 295 | } |
296 | setMailAccount(); | 296 | setMailAccount(); |
297 | emailHandler->sendMail(&quedMessages); | 297 | emailHandler->sendMail(&quedMessages); |
298 | sending = TRUE; | 298 | sending = TRUE; |
299 | sendMailButton->setEnabled(FALSE); | 299 | sendMailButton->setEnabled(FALSE); |
300 | cancelButton->setEnabled(TRUE); | 300 | cancelButton->setEnabled(TRUE); |
301 | } else { | 301 | } else { |
302 | qWarning("sendQuedMail(): no messages to send"); | 302 | qWarning("sendQuedMail(): no messages to send"); |
303 | } | 303 | } |
304 | } | 304 | } |
305 | } | 305 | } |
306 | 306 | ||
307 | void EmailClient::setMailAccount() | 307 | void EmailClient::setMailAccount() |
308 | { | 308 | { |
309 | emailHandler->setAccount(*currentAccount); | 309 | emailHandler->setAccount(*currentAccount); |
310 | } | 310 | } |
311 | 311 | ||
312 | void EmailClient::mailSent() | 312 | void EmailClient::mailSent() |
313 | { | 313 | { |
314 | sending = FALSE; | 314 | sending = FALSE; |
315 | sendMailButton->setEnabled(TRUE); | 315 | sendMailButton->setEnabled(TRUE); |
316 | 316 | ||
317 | quedMessages.clear(); | 317 | quedMessages.clear(); |
318 | outboxView->clear(); //should be moved to an sentBox | 318 | outboxView->clear(); //should be moved to an sentBox |
319 | } | 319 | } |
320 | 320 | ||
321 | void EmailClient::getNewMail() { | 321 | void EmailClient::getNewMail() { |
322 | 322 | ||
323 | if (accountList.count() == 0) { | 323 | if (accountList.count() == 0) { |
324 | QMessageBox::warning(qApp->activeWindow(),"No account selected", | 324 | QMessageBox::warning(qApp->activeWindow(),"No account selected", |
325 | "You must create an account", "OK\n"); | 325 | "You must create an account", "OK\n"); |
326 | return; | 326 | return; |
327 | } | 327 | } |
328 | 328 | ||
329 | setMailAccount(); | 329 | setMailAccount(); |
330 | 330 | ||
331 | receiving = TRUE; | 331 | receiving = TRUE; |
332 | previewingMail = TRUE; | 332 | previewingMail = TRUE; |
333 | getMailButton->setEnabled(FALSE); | 333 | getMailButton->setEnabled(FALSE); |
334 | cancelButton->setEnabled(TRUE); | 334 | cancelButton->setEnabled(TRUE); |
335 | selectAccountMenu->setEnabled(FALSE); | 335 | selectAccountMenu->setEnabled(FALSE); |
336 | 336 | ||
337 | status1Label->setText(currentAccount->accountName + " headers"); | 337 | status1Label->setText(currentAccount->accountName + " headers"); |
338 | progressBar->reset(); | 338 | progressBar->reset(); |
339 | 339 | ||
340 | //get any previous mails not downloaded and add to queue | 340 | //get any previous mails not downloaded and add to queue |
341 | /*mailDownloadList.clear(); | 341 | /*mailDownloadList.clear(); |
342 | Email *mailPtr; | 342 | Email *mailPtr; |
343 | item = (EmailListItem *) inboxView->firstChild(); | 343 | item = (EmailListItem *) inboxView->firstChild(); |
344 | while (item != NULL) { | 344 | while (item != NULL) { |
345 | mailPtr = item->getMail(); | 345 | mailPtr = item->getMail(); |
346 | if ( (!mailPtr->downloaded) && (mailPtr->fromAccountId == currentAccount->id) ) { | 346 | if ( (!mailPtr->downloaded) && (mailPtr->fromAccountId == currentAccount->id) ) { |
347 | mailDownloadList.sizeInsert(mailPtr->serverId, mailPtr->size); | 347 | mailDownloadList.sizeInsert(mailPtr->serverId, mailPtr->size); |
348 | } | 348 | } |
349 | item = (EmailListItem *) item->nextSibling(); | 349 | item = (EmailListItem *) item->nextSibling(); |
350 | }*/ | 350 | }*/ |
351 | 351 | ||
352 | emailHandler->getMailHeaders(); | 352 | emailHandler->getMailHeaders(); |
353 | 353 | ||
354 | } | 354 | } |
355 | 355 | ||
356 | void EmailClient::getAllNewMail() | 356 | void EmailClient::getAllNewMail() |
357 | { | 357 | { |
358 | allAccounts = TRUE; | 358 | allAccounts = TRUE; |
359 | currentAccount = accountList.first(); | 359 | currentAccount = accountList.first(); |
360 | getNewMail(); | 360 | getNewMail(); |
361 | } | 361 | } |
362 | 362 | ||
363 | void EmailClient::mailArrived(const Email &mail, bool fromDisk) | 363 | void EmailClient::mailArrived(const Email &mail, bool fromDisk) |
364 | { | 364 | { |
365 | Enclosure *ePtr; | 365 | Enclosure *ePtr; |
366 | Email newMail; | 366 | Email newMail; |
367 | int thisMailId; | 367 | int thisMailId; |
368 | emailHandler->parse( mail.rawMail, lineShift, &newMail); | 368 | emailHandler->parse( mail.rawMail, lineShift, &newMail); |
369 | mailconf->setGroup(newMail.id); | 369 | mailconf->setGroup(newMail.id); |
370 | 370 | ||
371 | if (fromDisk) | 371 | if (fromDisk) |
372 | { | 372 | { |
373 | 373 | ||
374 | newMail.downloaded = mailconf->readBoolEntry("downloaded"); | 374 | newMail.downloaded = mailconf->readBoolEntry("downloaded"); |
375 | newMail.size = mailconf->readNumEntry("size"); | 375 | newMail.size = mailconf->readNumEntry("size"); |
376 | newMail.serverId = mailconf->readNumEntry("serverid"); | 376 | newMail.serverId = mailconf->readNumEntry("serverid"); |
377 | newMail.fromAccountId = mailconf->readNumEntry("fromaccountid"); | 377 | newMail.fromAccountId = mailconf->readNumEntry("fromaccountid"); |
378 | } | 378 | } |
379 | else | 379 | else |
380 | { //mail arrived from server | 380 | { //mail arrived from server |
381 | 381 | ||
382 | newMail.serverId = mail.serverId; | 382 | newMail.serverId = mail.serverId; |
383 | newMail.size = mail.size; | 383 | newMail.size = mail.size; |
384 | newMail.downloaded = mail.downloaded; | 384 | newMail.downloaded = mail.downloaded; |
385 | 385 | ||
386 | newMail.fromAccountId = emailHandler->getAccount()->id; | 386 | newMail.fromAccountId = emailHandler->getAccount()->id; |
387 | mailconf->writeEntry("fromaccountid", newMail.fromAccountId); | 387 | mailconf->writeEntry("fromaccountid", newMail.fromAccountId); |
388 | } | 388 | } |
389 | 389 | ||
390 | //add if read or not | 390 | //add if read or not |
391 | newMail.read = mailconf->readBoolEntry("mailread"); | 391 | newMail.read = mailconf->readBoolEntry("mailread"); |
392 | 392 | ||
393 | //check if new mail | 393 | //check if new mail |
394 | if ( (thisMailId = mailconf->readNumEntry("internalmailid", -1)) == -1) { | 394 | if ( (thisMailId = mailconf->readNumEntry("internalmailid", -1)) == -1) { |
395 | thisMailId = mailIdCount; | 395 | thisMailId = mailIdCount; |
396 | mailIdCount++; | 396 | mailIdCount++; |
397 | 397 | ||
398 | //set server count, so that if the user aborts, the new | 398 | //set server count, so that if the user aborts, the new |
399 | //header is not reloaded | 399 | //header is not reloaded |
400 | if ((currentAccount)&&(currentAccount->synchronize)) | 400 | if ((currentAccount)&&(currentAccount->synchronize)) |
401 | currentAccount->lastServerMailCount++; | 401 | currentAccount->lastServerMailCount++; |
402 | 402 | ||
403 | mailconf->writeEntry("internalmailid", thisMailId); | 403 | mailconf->writeEntry("internalmailid", thisMailId); |
404 | mailconf->writeEntry("downloaded", newMail.downloaded); | 404 | mailconf->writeEntry("downloaded", newMail.downloaded); |
405 | mailconf->writeEntry("size", (int) newMail.size); | 405 | mailconf->writeEntry("size", (int) newMail.size); |
406 | mailconf->writeEntry("serverid", newMail.serverId); | 406 | mailconf->writeEntry("serverid", newMail.serverId); |
407 | 407 | ||
408 | //addressList->addContact(newMail.fromMail, newMail.from); | 408 | //addressList->addContact(newMail.fromMail, newMail.from); |
409 | } | 409 | } |
410 | 410 | ||
411 | mailconf->writeEntry("downloaded", newMail.downloaded); | 411 | mailconf->writeEntry("downloaded", newMail.downloaded); |
412 | 412 | ||
413 | QString stringMailId; | 413 | QString stringMailId; |
414 | stringMailId.setNum(thisMailId); | 414 | stringMailId.setNum(thisMailId); |
415 | //see if any attatchments needs to be stored | 415 | //see if any attatchments needs to be stored |
416 | 416 | ||
417 | for ( ePtr=newMail.files.first(); ePtr != 0; ePtr=newMail.files.next() ) { | 417 | for ( ePtr=newMail.files.first(); ePtr != 0; ePtr=newMail.files.next() ) { |
418 | QString stringId; | 418 | QString stringId; |
419 | stringId.setNum(ePtr->id); | 419 | stringId.setNum(ePtr->id); |
420 | 420 | ||
421 | int id = mailconf->readNumEntry("enclosureid_" + stringId); | 421 | int id = mailconf->readNumEntry("enclosureid_" + stringId); |
422 | if (id != ePtr->id) { //new entry | 422 | if (id != ePtr->id) { //new entry |
423 | mailconf->writeEntry("enclosureid_" + stringId, ePtr->id); | 423 | mailconf->writeEntry("enclosureid_" + stringId, ePtr->id); |
424 | mailconf->writeEntry("name_" + stringId, ePtr->originalName); | 424 | mailconf->writeEntry("name_" + stringId, ePtr->originalName); |
425 | mailconf->writeEntry("contenttype_" + stringId, ePtr->contentType); | 425 | mailconf->writeEntry("contenttype_" + stringId, ePtr->contentType); |
426 | mailconf->writeEntry("contentattribute_" + stringId, ePtr->contentAttribute); | 426 | mailconf->writeEntry("contentattribute_" + stringId, ePtr->contentAttribute); |
427 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); | 427 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); |
428 | mailconf->writeEntry("installed_" + stringId, FALSE); | 428 | mailconf->writeEntry("installed_" + stringId, FALSE); |
429 | 429 | ||
430 | ePtr->name = stringMailId + "_" + stringId; | 430 | ePtr->name = stringMailId + "_" + stringId; |
431 | ePtr->path = getPath(TRUE); | 431 | ePtr->path = getPath(TRUE); |
432 | if (emailHandler->getEnclosure(ePtr)) { //file saved | 432 | if (emailHandler->getEnclosure(ePtr)) { //file saved |
433 | ePtr->saved = TRUE; | 433 | ePtr->saved = TRUE; |
434 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); | 434 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); |
435 | mailconf->writeEntry("filename_" + stringId, ePtr->name); | 435 | mailconf->writeEntry("filename_" + stringId, ePtr->name); |
436 | mailconf->writeEntry("path_" + stringId, ePtr->path); | 436 | mailconf->writeEntry("path_" + stringId, ePtr->path); |
437 | } else { | 437 | } else { |
438 | ePtr->saved = FALSE; | 438 | ePtr->saved = FALSE; |
439 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); | 439 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); |
440 | } | 440 | } |
441 | } else { | 441 | } else { |
442 | ePtr->saved = mailconf->readBoolEntry("saved_" + stringId); | 442 | ePtr->saved = mailconf->readBoolEntry("saved_" + stringId); |
443 | ePtr->installed = mailconf->readBoolEntry("installed_" + stringId); | 443 | ePtr->installed = mailconf->readBoolEntry("installed_" + stringId); |
444 | if (ePtr->saved) { | 444 | if (ePtr->saved) { |
445 | ePtr->name = mailconf->readEntry("filename_" + stringId); | 445 | ePtr->name = mailconf->readEntry("filename_" + stringId); |
446 | ePtr->path = mailconf->readEntry("path_" + stringId); | 446 | ePtr->path = mailconf->readEntry("path_" + stringId); |
447 | } | 447 | } |
448 | } | 448 | } |
449 | } | 449 | } |
450 | 450 | ||
451 | bool found=false; | 451 | bool found=false; |
452 | 452 | ||
453 | if (!fromDisk) | 453 | if (!fromDisk) |
454 | { | 454 | { |
455 | 455 | ||
456 | Email *mailPtr; | 456 | Email *mailPtr; |
457 | item = (EmailListItem *) inboxView->firstChild(); | 457 | item = (EmailListItem *) inboxView->firstChild(); |
458 | while ((item != NULL)&&(!found)) | 458 | while ((item != NULL)&&(!found)) |
459 | { | 459 | { |
460 | mailPtr = item->getMail(); | 460 | mailPtr = item->getMail(); |
461 | if (mailPtr->id == newMail.id) { | 461 | if (mailPtr->id == newMail.id) { |
462 | item->setMail(newMail); | 462 | item->setMail(newMail); |
463 | emit mailUpdated(item->getMail()); | 463 | emit mailUpdated(item->getMail()); |
464 | found = true; | 464 | found = true; |
465 | } | 465 | } |
466 | item = (EmailListItem *) item->nextSibling(); | 466 | item = (EmailListItem *) item->nextSibling(); |
467 | } | 467 | } |
468 | } | 468 | } |
469 | if ((!found)||(fromDisk)) { | 469 | if ((!found)||(fromDisk)) { |
470 | item = new EmailListItem(inboxView, newMail, TRUE); | 470 | item = new EmailListItem(inboxView, newMail, TRUE); |
471 | } | 471 | } |
472 | if (item->getMail()->files.count()>0) | 472 | // if (item->getMail()->files.count()>0) |
473 | { | 473 | // { |
474 | item->setPixmap(0, Resource::loadPixmap("mailit/attach")); | 474 | // item->setPixmap(0, Resource::loadPixmap("mailit/attach")); |
475 | } | 475 | // } |
476 | /*if (!newMail.downloaded) | 476 | /*if (!newMail.downloaded) |
477 | mailDownloadList.sizeInsert(newMail.serverId, newMail.size);*/ | 477 | mailDownloadList.sizeInsert(newMail.serverId, newMail.size);*/ |
478 | 478 | ||
479 | mailboxView->setCurrentTab(0); | 479 | mailboxView->setCurrentTab(0); |
480 | 480 | ||
481 | } | 481 | } |
482 | 482 | ||
483 | void EmailClient::allMailArrived(int count) | 483 | void EmailClient::allMailArrived(int count) |
484 | { | 484 | { |
485 | // not previewing means all mailtransfer has been done | 485 | // not previewing means all mailtransfer has been done |
486 | /*if (!previewingMail) {*/ | 486 | /*if (!previewingMail) {*/ |
487 | if ( (allAccounts) && ( (currentAccount = accountList.next()) !=0 ) ) { | 487 | if ( (allAccounts) && ( (currentAccount = accountList.next()) !=0 ) ) { |
488 | emit newCaption("Mailit - " + currentAccount->accountName); | 488 | emit newCaption("Mailit - " + currentAccount->accountName); |
489 | getNewMail(); | 489 | getNewMail(); |
490 | return; | 490 | return; |
491 | } else { | 491 | } else { |
492 | allAccounts = FALSE; | 492 | allAccounts = FALSE; |
493 | receiving = FALSE; | 493 | receiving = FALSE; |
494 | getMailButton->setEnabled(TRUE); | 494 | getMailButton->setEnabled(TRUE); |
495 | cancelButton->setEnabled(FALSE); | 495 | cancelButton->setEnabled(FALSE); |
496 | selectAccountMenu->setEnabled(TRUE); | 496 | selectAccountMenu->setEnabled(TRUE); |
497 | status1Label->setText("Idle"); | 497 | status1Label->setText("Idle"); |
498 | 498 | ||
499 | progressBar->reset(); | 499 | progressBar->reset(); |
500 | return; | 500 | return; |
501 | } | 501 | } |
502 | //} | 502 | //} |
503 | 503 | ||
504 | // all headers downloaded from server, start downloading remaining mails | 504 | // all headers downloaded from server, start downloading remaining mails |
505 | previewingMail = FALSE; | 505 | previewingMail = FALSE; |
506 | status1Label->setText(currentAccount->accountName); | 506 | status1Label->setText(currentAccount->accountName); |
507 | progressBar->reset(); | 507 | progressBar->reset(); |
508 | 508 | ||
509 | 509 | ||
510 | mailboxView->setCurrentTab(0); | 510 | mailboxView->setCurrentTab(0); |
511 | } | 511 | } |
512 | 512 | ||
513 | 513 | ||
514 | void EmailClient::moveMailFront(Email *mailPtr) | 514 | void EmailClient::moveMailFront(Email *mailPtr) |
515 | { | 515 | { |
516 | if ( (receiving) && (mailPtr->fromAccountId == currentAccount->id) ) { | 516 | if ( (receiving) && (mailPtr->fromAccountId == currentAccount->id) ) { |
517 | mailDownloadList.moveFront(mailPtr->serverId, mailPtr->size); | 517 | mailDownloadList.moveFront(mailPtr->serverId, mailPtr->size); |
518 | } | 518 | } |
519 | } | 519 | } |
520 | 520 | ||
521 | void EmailClient::smtpError(int code) | 521 | void EmailClient::smtpError(int code) |
522 | { | 522 | { |
523 | QString temp; | 523 | QString temp; |
524 | 524 | ||
525 | if (code == ErrUnknownResponse) | 525 | if (code == ErrUnknownResponse) |
526 | temp = "Unknown response from server"; | 526 | temp = "Unknown response from server"; |
527 | 527 | ||
528 | if (code == QSocket::ErrHostNotFound) | 528 | if (code == QSocket::ErrHostNotFound) |
529 | temp = "host not found"; | 529 | temp = "host not found"; |
530 | if (code == QSocket::ErrConnectionRefused) | 530 | if (code == QSocket::ErrConnectionRefused) |
531 | temp = "connection refused"; | 531 | temp = "connection refused"; |
532 | if (code == QSocket::ErrSocketRead) | 532 | if (code == QSocket::ErrSocketRead) |
533 | temp = "socket packet error"; | 533 | temp = "socket packet error"; |
534 | 534 | ||
535 | if (code != ErrCancel) { | 535 | if (code != ErrCancel) { |
536 | QMessageBox::warning(qApp->activeWindow(), "Sending error", temp, "OK\n"); | 536 | QMessageBox::warning(qApp->activeWindow(), "Sending error", temp, "OK\n"); |
537 | } else { | 537 | } else { |
538 | status2Label->setText("Aborted by user"); | 538 | status2Label->setText("Aborted by user"); |
539 | } | 539 | } |
540 | 540 | ||
541 | sending = FALSE; | 541 | sending = FALSE; |
542 | sendMailButton->setEnabled(TRUE); | 542 | sendMailButton->setEnabled(TRUE); |
543 | cancelButton->setEnabled(FALSE); | 543 | cancelButton->setEnabled(FALSE); |
544 | quedMessages.clear(); | 544 | quedMessages.clear(); |
545 | } | 545 | } |
546 | 546 | ||
547 | void EmailClient::popError(int code) | 547 | void EmailClient::popError(int code) |
548 | { | 548 | { |
549 | QString temp; | 549 | QString temp; |
550 | 550 | ||
551 | if (code == ErrUnknownResponse) | 551 | if (code == ErrUnknownResponse) |
552 | temp = "Unknown response from server"; | 552 | temp = "Unknown response from server"; |
553 | if (code == ErrLoginFailed) | 553 | if (code == ErrLoginFailed) |
554 | temp = "Login failed\nCheck user name and password"; | 554 | temp = "Login failed\nCheck user name and password"; |
555 | 555 | ||
556 | if (code == QSocket::ErrHostNotFound) | 556 | if (code == QSocket::ErrHostNotFound) |
557 | temp = "host not found"; | 557 | temp = "host not found"; |
558 | if (code == QSocket::ErrConnectionRefused) | 558 | if (code == QSocket::ErrConnectionRefused) |
559 | temp = "connection refused"; | 559 | temp = "connection refused"; |
560 | if (code == QSocket::ErrSocketRead) | 560 | if (code == QSocket::ErrSocketRead) |
561 | temp = "socket packet error"; | 561 | temp = "socket packet error"; |
562 | 562 | ||
563 | if (code != ErrCancel) { | 563 | if (code != ErrCancel) { |
564 | QMessageBox::warning(qApp->activeWindow(), "Receiving error", temp, "OK\n"); | 564 | QMessageBox::warning(qApp->activeWindow(), "Receiving error", temp, "OK\n"); |
565 | } else { | 565 | } else { |
566 | status2Label->setText("Aborted by user"); | 566 | status2Label->setText("Aborted by user"); |
567 | } | 567 | } |
568 | 568 | ||
569 | receiving = FALSE; | 569 | receiving = FALSE; |
570 | getMailButton->setEnabled(TRUE); | 570 | getMailButton->setEnabled(TRUE); |
571 | cancelButton->setEnabled(FALSE); | 571 | cancelButton->setEnabled(FALSE); |
572 | selectAccountMenu->setEnabled(TRUE); | 572 | selectAccountMenu->setEnabled(TRUE); |
573 | } | 573 | } |
574 | 574 | ||
575 | void EmailClient::inboxItemSelected() | 575 | void EmailClient::inboxItemSelected() |
576 | { | 576 | { |
577 | //killTimer(timerID); | 577 | //killTimer(timerID); |
578 | 578 | ||
579 | item = (EmailListItem*) inboxView->selectedItem(); | 579 | item = (EmailListItem*) inboxView->selectedItem(); |
580 | if (item != NULL) { | 580 | if (item != NULL) { |
581 | emit viewEmail(inboxView, item->getMail()); | 581 | emit viewEmail(inboxView, item->getMail()); |
582 | } | 582 | } |
583 | } | 583 | } |
584 | 584 | ||
585 | void EmailClient::outboxItemSelected() | 585 | void EmailClient::outboxItemSelected() |
586 | { | 586 | { |
587 | //killTimer(timerID); | 587 | //killTimer(timerID); |
588 | 588 | ||
589 | item = (EmailListItem*) outboxView->selectedItem(); | 589 | item = (EmailListItem*) outboxView->selectedItem(); |
590 | if (item != NULL) { | 590 | if (item != NULL) { |
591 | emit viewEmail(outboxView, item->getMail()); | 591 | emit viewEmail(outboxView, item->getMail()); |
592 | } | 592 | } |
593 | 593 | ||
594 | } | 594 | } |
595 | 595 | ||
596 | void EmailClient::readMail() | 596 | void EmailClient::readMail() |
597 | { | 597 | { |
598 | Email mail; | 598 | Email mail; |
599 | int start, stop; | 599 | int start, stop; |
600 | QString s, del; | 600 | QString s, del; |
601 | 601 | ||
602 | QFile f(getPath(FALSE) + "inbox.txt"); | 602 | QFile f(getPath(FALSE) + "inbox.txt"); |
603 | 603 | ||
604 | if ( f.open(IO_ReadOnly) ) { // file opened successfully | 604 | if ( f.open(IO_ReadOnly) ) { // file opened successfully |
605 | QTextStream t( &f ); // use a text stream | 605 | QTextStream t( &f ); // use a text stream |
606 | s = t.read(); | 606 | s = t.read(); |
607 | f.close(); | 607 | f.close(); |
608 | 608 | ||
609 | start = 0; | 609 | start = 0; |
610 | del = "\n.\n"; | 610 | del = "\n.\n"; |
611 | while ((uint) start < s.length()) { | 611 | while ((uint) start < s.length()) { |
612 | stop = s.find(del, start); | 612 | stop = s.find(del, start); |
613 | if (stop == -1) | 613 | if (stop == -1) |
614 | stop = s.length() - del.length(); | 614 | stop = s.length() - del.length(); |
615 | 615 | ||
616 | mail.rawMail = s.mid(start, stop + del.length() - start ); | 616 | mail.rawMail = s.mid(start, stop + del.length() - start ); |
617 | start = stop + del.length(); | 617 | start = stop + del.length(); |
618 | mailArrived(mail, TRUE); | 618 | mailArrived(mail, TRUE); |
619 | } | 619 | } |
620 | } | 620 | } |
621 | 621 | ||
622 | QFile fo(getPath(FALSE) + "outbox.txt"); | 622 | QFile fo(getPath(FALSE) + "outbox.txt"); |
623 | if ( fo.open(IO_ReadOnly) ) { // file opened successfully | 623 | if ( fo.open(IO_ReadOnly) ) { // file opened successfully |
624 | QTextStream t( &fo ); // use a text stream | 624 | QTextStream t( &fo ); // use a text stream |
625 | s = t.read(); | 625 | s = t.read(); |
626 | fo.close(); | 626 | fo.close(); |
627 | 627 | ||
628 | start = 0; | 628 | start = 0; |
629 | del = "\n.\n"; | 629 | del = "\n.\n"; |
630 | while ((uint) start < s.length()) { | 630 | while ((uint) start < s.length()) { |
631 | stop = s.find(del, start); | 631 | stop = s.find(del, start); |
632 | if (stop == -1) | 632 | if (stop == -1) |
633 | stop = s.length() - del.length(); | 633 | stop = s.length() - del.length(); |
634 | 634 | ||
635 | mail.rawMail = s.mid(start, stop + del.length() - start ); | 635 | mail.rawMail = s.mid(start, stop + del.length() - start ); |
636 | start = stop + del.length(); | 636 | start = stop + del.length(); |
637 | emailHandler->parse(mail.rawMail, lineShift, &mail); | 637 | emailHandler->parse(mail.rawMail, lineShift, &mail); |
638 | mail.sent = false; | 638 | mail.sent = false; |
639 | mail.received = false; | 639 | mail.received = false; |
640 | enqueMail(mail); | 640 | enqueMail(mail); |
641 | 641 | ||
642 | } | 642 | } |
643 | } | 643 | } |
644 | } | 644 | } |
645 | 645 | ||
646 | void EmailClient::saveMail(const QString &fileName, QListView *view) | 646 | void EmailClient::saveMail(const QString &fileName, QListView *view) |
647 | { | 647 | { |
648 | QFile f(fileName); | 648 | QFile f(fileName); |
649 | Email *mail; | 649 | Email *mail; |
650 | 650 | ||
651 | if (! f.open(IO_WriteOnly) ) { | 651 | if (! f.open(IO_WriteOnly) ) { |
652 | qWarning("could not open file"); | 652 | qWarning("could not open file"); |
653 | return; | 653 | return; |
654 | } | 654 | } |
655 | item = (EmailListItem *) view->firstChild(); | 655 | item = (EmailListItem *) view->firstChild(); |
656 | QTextStream t(&f); | 656 | QTextStream t(&f); |
657 | while (item != NULL) { | 657 | while (item != NULL) { |
658 | mail = item->getMail(); | 658 | mail = item->getMail(); |
659 | t << mail->rawMail; | 659 | t << mail->rawMail; |
660 | 660 | ||
661 | mailconf->setGroup(mail->id); | 661 | mailconf->setGroup(mail->id); |
662 | mailconf->writeEntry("mailread", mail->read); | 662 | mailconf->writeEntry("mailread", mail->read); |
663 | 663 | ||
664 | item = (EmailListItem *) item->nextSibling(); | 664 | item = (EmailListItem *) item->nextSibling(); |
665 | } | 665 | } |
666 | f.close(); | 666 | f.close(); |
667 | } | 667 | } |
diff --git a/noncore/net/mailit/emailhandler.cpp b/noncore/net/mailit/emailhandler.cpp index 59ccd90..39f693d 100644 --- a/noncore/net/mailit/emailhandler.cpp +++ b/noncore/net/mailit/emailhandler.cpp | |||
@@ -1,532 +1,536 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2001 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2001 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qt Palmtop Environment. | 4 | ** This file is part of Qt Palmtop Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #include <qfileinfo.h> | 20 | #include <qfileinfo.h> |
21 | #include <stdlib.h> | 21 | #include <stdlib.h> |
22 | #include <qapplication.h> | 22 | #include <qapplication.h> |
23 | #include <qmessagebox.h> | 23 | #include <qmessagebox.h> |
24 | #include <qcstring.h> | 24 | #include <qcstring.h> |
25 | #include "emailhandler.h" | 25 | #include "emailhandler.h" |
26 | #include <qpe/applnk.h> | 26 | #include <qpe/applnk.h> |
27 | #include <qpe/filemanager.h> | 27 | #include <qpe/filemanager.h> |
28 | 28 | ||
29 | QCollection::Item EnclosureList::newItem(QCollection::Item d) | 29 | QCollection::Item EnclosureList::newItem(QCollection::Item d) |
30 | { | 30 | { |
31 | return dupl( (Enclosure *) d); | 31 | return dupl( (Enclosure *) d); |
32 | } | 32 | } |
33 | 33 | ||
34 | Enclosure* EnclosureList::dupl(Enclosure *in) | 34 | Enclosure* EnclosureList::dupl(Enclosure *in) |
35 | { | 35 | { |
36 | ac = new Enclosure(*in); | 36 | ac = new Enclosure(*in); |
37 | return ac; | 37 | return ac; |
38 | } | 38 | } |
39 | 39 | ||
40 | EmailHandler::EmailHandler() | 40 | EmailHandler::EmailHandler() |
41 | { | 41 | { |
42 | qDebug("EMailHandler::EmailHandler"); | 42 | qDebug("EMailHandler::EmailHandler"); |
43 | 43 | ||
44 | smtpClient = new SmtpClient(); | 44 | smtpClient = new SmtpClient(); |
45 | popClient = new PopClient(); | 45 | popClient = new PopClient(); |
46 | 46 | ||
47 | connect(smtpClient, SIGNAL(errorOccurred(int)), this, | 47 | connect(smtpClient, SIGNAL(errorOccurred(int)), this, |
48 | SIGNAL(smtpError(int)) ); | 48 | SIGNAL(smtpError(int)) ); |
49 | connect(smtpClient, SIGNAL(mailSent()), this, SIGNAL(mailSent()) ); | 49 | connect(smtpClient, SIGNAL(mailSent()), this, SIGNAL(mailSent()) ); |
50 | connect(smtpClient, SIGNAL(updateStatus(const QString &)), this, | 50 | connect(smtpClient, SIGNAL(updateStatus(const QString &)), this, |
51 | SIGNAL(updateSmtpStatus(const QString &)) ); | 51 | SIGNAL(updateSmtpStatus(const QString &)) ); |
52 | 52 | ||
53 | connect(popClient, SIGNAL(errorOccurred(int)), this, | 53 | connect(popClient, SIGNAL(errorOccurred(int)), this, |
54 | SIGNAL(popError(int)) ); | 54 | SIGNAL(popError(int)) ); |
55 | connect(popClient, SIGNAL(newMessage(const QString &, int, uint, bool)), | 55 | connect(popClient, SIGNAL(newMessage(const QString &, int, uint, bool)), |
56 | this, SLOT(messageArrived(const QString &, int, uint, bool)) ); | 56 | this, SLOT(messageArrived(const QString &, int, uint, bool)) ); |
57 | connect(popClient, SIGNAL(updateStatus(const QString &)), this, | 57 | connect(popClient, SIGNAL(updateStatus(const QString &)), this, |
58 | SIGNAL(updatePopStatus(const QString &)) ); | 58 | SIGNAL(updatePopStatus(const QString &)) ); |
59 | connect(popClient, SIGNAL(mailTransfered(int)), this, | 59 | connect(popClient, SIGNAL(mailTransfered(int)), this, |
60 | SIGNAL(mailTransfered(int)) ); | 60 | SIGNAL(mailTransfered(int)) ); |
61 | 61 | ||
62 | 62 | ||
63 | //relaying size information | 63 | //relaying size information |
64 | connect(popClient, SIGNAL(currentMailSize(int)), | 64 | connect(popClient, SIGNAL(currentMailSize(int)), |
65 | this, SIGNAL(currentMailSize(int)) ); | 65 | this, SIGNAL(currentMailSize(int)) ); |
66 | connect(popClient, SIGNAL(downloadedSize(int)), | 66 | connect(popClient, SIGNAL(downloadedSize(int)), |
67 | this, SIGNAL(downloadedSize(int)) ); | 67 | this, SIGNAL(downloadedSize(int)) ); |
68 | } | 68 | } |
69 | 69 | ||
70 | void EmailHandler::sendMail(QList<Email> *mailList) | 70 | void EmailHandler::sendMail(QList<Email> *mailList) |
71 | { | 71 | { |
72 | Email *currentMail; | 72 | Email *currentMail; |
73 | QString temp; | 73 | QString temp; |
74 | QString userName = mailAccount.name; | 74 | QString userName = mailAccount.name; |
75 | userName += " <" + mailAccount.emailAddress + ">"; | 75 | userName += " <" + mailAccount.emailAddress + ">"; |
76 | 76 | ||
77 | for (currentMail = mailList->first(); currentMail != 0; | 77 | for (currentMail = mailList->first(); currentMail != 0; |
78 | currentMail = mailList->next()) { | 78 | currentMail = mailList->next()) { |
79 | 79 | ||
80 | if (encodeMime(currentMail) == 0) { | 80 | if (encodeMime(currentMail) == 0) { |
81 | smtpClient->addMail(userName, currentMail->subject, | 81 | smtpClient->addMail(userName, currentMail->subject, |
82 | currentMail->recipients, currentMail->rawMail); | 82 | currentMail->recipients, currentMail->rawMail); |
83 | } else { //error | 83 | } else { //error |
84 | temp = tr("Could not locate all files in \nmail with subject: ") + | 84 | temp = tr("Could not locate all files in \nmail with subject: ") + |
85 | currentMail->subject; | 85 | currentMail->subject; |
86 | temp += tr("\nMail has NOT been sent"); | 86 | temp += tr("\nMail has NOT been sent"); |
87 | QMessageBox::warning(qApp->activeWindow(), tr("Attachment error"), temp, tr("OK\n")); | 87 | QMessageBox::warning(qApp->activeWindow(), tr("Attachment error"), temp, tr("OK\n")); |
88 | 88 | ||
89 | } | 89 | } |
90 | } | 90 | } |
91 | smtpClient->newConnection(mailAccount.smtpServer, 25); | 91 | smtpClient->newConnection(mailAccount.smtpServer, 25); |
92 | } | 92 | } |
93 | 93 | ||
94 | void EmailHandler::setAccount(MailAccount account) | 94 | void EmailHandler::setAccount(MailAccount account) |
95 | { | 95 | { |
96 | mailAccount = account; | 96 | mailAccount = account; |
97 | } | 97 | } |
98 | 98 | ||
99 | void EmailHandler::getMail() | 99 | void EmailHandler::getMail() |
100 | { | 100 | { |
101 | popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); | 101 | popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); |
102 | if (mailAccount.synchronize) { | 102 | if (mailAccount.synchronize) { |
103 | popClient->setSynchronize(mailAccount.lastServerMailCount); | 103 | popClient->setSynchronize(mailAccount.lastServerMailCount); |
104 | } else { | 104 | } else { |
105 | popClient->removeSynchronize(); | 105 | popClient->removeSynchronize(); |
106 | } | 106 | } |
107 | 107 | ||
108 | headers = FALSE; | 108 | headers = FALSE; |
109 | //popClient->headersOnly(headers, 0); | 109 | //popClient->headersOnly(headers, 0); |
110 | popClient->newConnection(mailAccount.popServer, 110); | 110 | popClient->newConnection(mailAccount.popServer, 110); |
111 | } | 111 | } |
112 | 112 | ||
113 | void EmailHandler::getMailHeaders() | 113 | void EmailHandler::getMailHeaders() |
114 | { | 114 | { |
115 | popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); | 115 | popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); |
116 | mailAccount.synchronize ? popClient->setSynchronize(mailAccount.lastServerMailCount): popClient->removeSynchronize(); | 116 | mailAccount.synchronize ? popClient->setSynchronize(mailAccount.lastServerMailCount): popClient->removeSynchronize(); |
117 | 117 | ||
118 | headers = TRUE; | 118 | headers = TRUE; |
119 | popClient->headersOnly(headers, mailAccount.syncLimit); //less than requested syncLimit, download all | 119 | popClient->headersOnly(headers, mailAccount.syncLimit); //less than requested syncLimit, download all |
120 | qDebug("Initiating connection"); | 120 | qDebug("Initiating connection"); |
121 | popClient->newConnection(mailAccount.popServer, 110); | 121 | popClient->newConnection(mailAccount.popServer, 110); |
122 | } | 122 | } |
123 | 123 | ||
124 | void EmailHandler::getMailByList(MailList *mailList) | 124 | void EmailHandler::getMailByList(MailList *mailList) |
125 | { | 125 | { |
126 | if (mailList->count() == 0) { //should not occur though | 126 | if (mailList->count() == 0) { //should not occur though |
127 | emit mailTransfered(0); | 127 | emit mailTransfered(0); |
128 | return; | 128 | return; |
129 | } | 129 | } |
130 | 130 | ||
131 | headers = FALSE; | 131 | headers = FALSE; |
132 | popClient->headersOnly(FALSE, 0); | 132 | popClient->headersOnly(FALSE, 0); |
133 | 133 | ||
134 | popClient->setAccount(mailAccount.popUserName,mailAccount.popPasswd); | 134 | popClient->setAccount(mailAccount.popUserName,mailAccount.popPasswd); |
135 | popClient->setSelectedMails(mailList); | 135 | popClient->setSelectedMails(mailList); |
136 | popClient->newConnection(mailAccount.popServer, 110); | 136 | popClient->newConnection(mailAccount.popServer, 110); |
137 | } | 137 | } |
138 | 138 | ||
139 | void EmailHandler::messageArrived(const QString &message, int id, uint size, bool complete) | 139 | void EmailHandler::messageArrived(const QString &message, int id, uint size, bool complete) |
140 | { | 140 | { |
141 | Email mail; | 141 | Email mail; |
142 | 142 | ||
143 | mail.rawMail = message; | 143 | mail.rawMail = message; |
144 | mail.serverId = id; | 144 | mail.serverId = id; |
145 | mail.size = size; | 145 | mail.size = size; |
146 | mail.downloaded = complete; | 146 | mail.downloaded = complete; |
147 | 147 | ||
148 | emit mailArrived(mail, FALSE); | 148 | emit mailArrived(mail, FALSE); |
149 | } | 149 | } |
150 | 150 | ||
151 | bool EmailHandler::parse(const QString &in, const QString &lineShift, Email *mail) | 151 | bool EmailHandler::parse(const QString &in, const QString &lineShift, Email *mail) |
152 | { | 152 | { |
153 | QString temp, boundary; | 153 | QString temp, boundary; |
154 | int pos; | 154 | int pos; |
155 | QString delimiter, header, body, mimeHeader, mimeBody; | 155 | QString delimiter, header, body, mimeHeader, mimeBody; |
156 | QString content, contentType, contentAttribute, id, encoding; | 156 | QString content, contentType, contentAttribute, id, encoding; |
157 | QString fileName, storedName; | 157 | QString fileName, storedName; |
158 | int enclosureId = 0; | 158 | int enclosureId = 0; |
159 | 159 | ||
160 | mail->rawMail = in; | 160 | mail->rawMail = in; |
161 | mail->received = TRUE; | 161 | mail->received = TRUE; |
162 | mail->files.setAutoDelete(TRUE); | 162 | mail->files.setAutoDelete(TRUE); |
163 | 163 | ||
164 | temp = lineShift + "." + lineShift; | 164 | temp = lineShift + "." + lineShift; |
165 | 165 | ||
166 | if (in.right(temp.length()) != temp) { | 166 | if (in.right(temp.length()) != temp) { |
167 | mail->rawMail += temp; | 167 | mail->rawMail += temp; |
168 | } | 168 | } |
169 | 169 | ||
170 | 170 | ||
171 | delimiter = lineShift + lineShift; // "\n\n" or "\r\n\r\n" | 171 | delimiter = lineShift + lineShift; // "\n\n" or "\r\n\r\n" |
172 | pos = in.find(delimiter, 0, FALSE); | 172 | pos = in.find(delimiter, 0, FALSE); |
173 | header = in.left(pos); | 173 | header = in.left(pos); |
174 | body = in.right(in.length() - pos - delimiter.length()); | 174 | body = in.right(in.length() - pos - delimiter.length()); |
175 | if ((body.at(body.length()-2) == '.') && (body.at(body.length()-3) == '\n')) | 175 | if ((body.at(body.length()-2) == '.') && (body.at(body.length()-3) == '\n')) |
176 | body.truncate(body.length()-2); | 176 | body.truncate(body.length()-2); |
177 | 177 | ||
178 | TextParser p(header, lineShift); | 178 | // TextParser p(header, lineShift); |
179 | 179 | TextParser * lp = new TextParser(header, lineShift); | |
180 | #define p (*lp) | ||
181 | |||
180 | if ((pos = p.find("FROM",':', 0, TRUE)) != -1) { | 182 | if ((pos = p.find("FROM",':', 0, TRUE)) != -1) { |
181 | pos++; | 183 | pos++; |
182 | if (p.separatorAt(pos) == ' ') { | 184 | if (p.separatorAt(pos) == ' ') { |
183 | mail->from = p.getString(&pos, '<', false); | 185 | mail->from = p.getString(&pos, '<', false); |
184 | mail->from = mail->from.stripWhiteSpace(); | 186 | mail->from = mail->from.stripWhiteSpace(); |
185 | if ( (mail->from.length() > 2) && (mail->from[0] == '"') ) { | 187 | if ( (mail->from.length() > 2) && (mail->from[0] == '"') ) { |
186 | mail->from = mail->from.left(mail->from.length() - 1); | 188 | mail->from = mail->from.left(mail->from.length() - 1); |
187 | mail->from = mail->from.right(mail->from.length() - 1); | 189 | mail->from = mail->from.right(mail->from.length() - 1); |
188 | } | 190 | } |
189 | pos++; | 191 | pos++; |
190 | mail->fromMail = p.getString(&pos, '>', false); | 192 | mail->fromMail = p.getString(&pos, '>', false); |
191 | } else { | 193 | } else { |
192 | if (p.separatorAt(pos) == '<') //No name.. nasty | 194 | if (p.separatorAt(pos) == '<') //No name.. nasty |
193 | pos++; | 195 | pos++; |
194 | //pos++; | 196 | //pos++; |
195 | mail->fromMail = p.getString(&pos, 'z', TRUE); | 197 | mail->fromMail = p.getString(&pos, 'z', TRUE); |
196 | if (mail->fromMail.at(mail->fromMail.length()-1) == '>') | 198 | if (mail->fromMail.at(mail->fromMail.length()-1) == '>') |
197 | mail->fromMail.truncate(mail->fromMail.length() - 1); | 199 | mail->fromMail.truncate(mail->fromMail.length() - 1); |
198 | mail->from=mail->fromMail; | 200 | mail->from=mail->fromMail; |
199 | } | 201 | } |
200 | } | 202 | } |
201 | 203 | ||
202 | pos=0; | 204 | pos=0; |
203 | 205 | ||
204 | //Search for To: after the FROM: attribute to prevent hitting the Delivered-To: | 206 | //Search for To: after the FROM: attribute to prevent hitting the Delivered-To: |
205 | while((pos = p.find("TO",':', pos+1, TRUE))!=-1) | 207 | while((pos = p.find("TO",':', pos+1, TRUE))!=-1) |
206 | { | 208 | { |
207 | QString rec; | 209 | QString rec; |
208 | 210 | ||
209 | if (p.separatorAt(pos-1)!='-') //The - separator means that this is a Delivered-To: or Reply-To: | 211 | if (p.separatorAt(pos-1)!='-') //The - separator means that this is a Delivered-To: or Reply-To: |
210 | { | 212 | { |
211 | pos++; | 213 | pos++; |
212 | mail->recipients.append(p.getString(&pos, '\r', TRUE)); | 214 | mail->recipients.append(p.getString(&pos, '\r', TRUE)); |
213 | } | 215 | } |
214 | } | 216 | } |
215 | // | 217 | // |
216 | //if (pos==-1) mail->recipients.append (tr("undisclosed recipients") ); | 218 | //if (pos==-1) mail->recipients.append (tr("undisclosed recipients") ); |
217 | 219 | ||
218 | if ((pos = p.find("CC",':', 0, TRUE)) != -1) | 220 | if ((pos = p.find("CC",':', 0, TRUE)) != -1) |
219 | { | 221 | { |
220 | pos++; | 222 | pos++; |
221 | mail->carbonCopies.append (p.getString(&pos, 'z', TRUE) ); | 223 | mail->carbonCopies.append (p.getString(&pos, 'z', TRUE) ); |
222 | } | 224 | } |
223 | 225 | ||
224 | if ((pos = p.find("SUBJECT",':', 0, TRUE)) != -1) { | 226 | if ((pos = p.find("SUBJECT",':', 0, TRUE)) != -1) { |
225 | pos++; | 227 | pos++; |
226 | mail->subject = p.getString(&pos, 'z', TRUE); | 228 | mail->subject = p.getString(&pos, 'z', TRUE); |
227 | } | 229 | } |
228 | 230 | ||
229 | if ((pos = p.find("DATE",':', 0, TRUE)) != -1) { | 231 | if ((pos = p.find("DATE",':', 0, TRUE)) != -1) { |
230 | pos++; | 232 | pos++; |
231 | mail->date = p.getString(&pos, 'z', TRUE); | 233 | mail->date = p.getString(&pos, 'z', TRUE); |
232 | } | 234 | } |
233 | 235 | ||
234 | 236 | ||
235 | 237 | ||
236 | if ((pos = p.find("MESSAGE",'-', 0, TRUE)) != -1) { | 238 | if ((pos = p.find("MESSAGE",'-', 0, TRUE)) != -1) { |
237 | pos++; | 239 | pos++; |
238 | if ( (p.wordAt(pos).upper() == "ID") && | 240 | if ( (p.wordAt(pos).upper() == "ID") && |
239 | (p.separatorAt(pos) == ':') ) { | 241 | (p.separatorAt(pos) == ':') ) { |
240 | 242 | ||
241 | id = p.getString(&pos, 'z', TRUE); | 243 | id = p.getString(&pos, 'z', TRUE); |
242 | mail->id = id; | 244 | mail->id = id; |
243 | } | 245 | } |
244 | } | 246 | } |
245 | 247 | ||
246 | pos = 0; | 248 | pos = 0; |
247 | while ( ((pos = p.find("MIME",'-', pos, TRUE)) != -1) ) { | 249 | while ( ((pos = p.find("MIME",'-', pos, TRUE)) != -1) ) { |
248 | pos++; | 250 | pos++; |
249 | if ( (p.wordAt(pos).upper() == "VERSION") && | 251 | if ( (p.wordAt(pos).upper() == "VERSION") && |
250 | (p.separatorAt(pos) == ':') ) { | 252 | (p.separatorAt(pos) == ':') ) { |
251 | pos++; | 253 | pos++; |
252 | if (p.getString(&pos, 'z', true) == "1.0") { | 254 | if (p.getString(&pos, 'z', true) == "1.0") { |
253 | mail->mimeType = 1; | 255 | mail->mimeType = 1; |
254 | } | 256 | } |
255 | } | 257 | } |
256 | } | 258 | } |
257 | 259 | ||
258 | if (mail->mimeType == 1) { | 260 | if (mail->mimeType == 1) { |
259 | boundary = ""; | 261 | boundary = ""; |
260 | if ((pos = p.find("BOUNDARY", '=', 0, TRUE)) != -1) { | 262 | if ((pos = p.find("BOUNDARY", '=', 0, TRUE)) != -1) { |
261 | pos++; | 263 | pos++; |
262 | boundary = p.getString(&pos, 'z', true); | 264 | boundary = p.getString(&pos, 'z', true); |
263 | if (boundary[0] == '"') { | 265 | if (boundary[0] == '"') { |
264 | boundary = boundary.left(boundary.length() - 1); //strip " | 266 | boundary = boundary.left(boundary.length() - 1); //strip " |
265 | boundary = boundary.right(boundary.length() - 1); //strip " | 267 | boundary = boundary.right(boundary.length() - 1); //strip " |
266 | } | 268 | } |
267 | boundary = "--" + boundary; //create boundary field | 269 | boundary = "--" + boundary; //create boundary field |
268 | } | 270 | } |
269 | 271 | ||
270 | if (boundary == "") { //fooled by Mime-Version | 272 | if (boundary == "") { //fooled by Mime-Version |
271 | mail->body = body; | 273 | mail->body = body; |
272 | mail->bodyPlain = body; | 274 | mail->bodyPlain = body; |
275 | delete lp; | ||
273 | return mail; | 276 | return mail; |
274 | } | 277 | } |
275 | 278 | ||
276 | while (body.length() > 0) { | 279 | while (body.length() > 0) { |
277 | pos = body.find(boundary, 0, FALSE); | 280 | pos = body.find(boundary, 0, FALSE); |
278 | pos = body.find(delimiter, pos, FALSE); | 281 | pos = body.find(delimiter, pos, FALSE); |
279 | mimeHeader = body.left(pos); | 282 | mimeHeader = body.left(pos); |
280 | mimeBody = body.right(body.length() - pos - delimiter.length()); | 283 | mimeBody = body.right(body.length() - pos - delimiter.length()); |
281 | TextParser bp(mimeHeader, lineShift); | 284 | TextParser bp(mimeHeader, lineShift); |
282 | 285 | ||
283 | contentType = ""; | 286 | contentType = ""; |
284 | contentAttribute = ""; | 287 | contentAttribute = ""; |
285 | fileName = ""; | 288 | fileName = ""; |
286 | if ((pos = bp.find("CONTENT",'-', 0, TRUE)) != -1) { | 289 | if ((pos = bp.find("CONTENT",'-', 0, TRUE)) != -1) { |
287 | pos++; | 290 | pos++; |
288 | if ( (bp.wordAt(pos).upper() == "TYPE") && | 291 | if ( (bp.wordAt(pos).upper() == "TYPE") && |
289 | (bp.separatorAt(pos) == ':') ) { | 292 | (bp.separatorAt(pos) == ':') ) { |
290 | contentType = bp.nextWord().upper(); | 293 | contentType = bp.nextWord().upper(); |
291 | if (bp.nextSeparator() == '/') | 294 | if (bp.nextSeparator() == '/') |
292 | contentAttribute = bp.nextWord().upper(); | 295 | contentAttribute = bp.nextWord().upper(); |
293 | content = contentType + "/" + contentAttribute; | 296 | content = contentType + "/" + contentAttribute; |
294 | } | 297 | } |
295 | if ((pos = bp.find("ENCODING",':', 0, TRUE)) != -1) { | 298 | if ((pos = bp.find("ENCODING",':', 0, TRUE)) != -1) { |
296 | pos++; | 299 | pos++; |
297 | encoding = bp.getString(&pos, 'z', TRUE); | 300 | encoding = bp.getString(&pos, 'z', TRUE); |
298 | } | 301 | } |
299 | 302 | ||
300 | if ( (pos = bp.find("FILENAME",'=', 0, TRUE)) != -1) { | 303 | if ( (pos = bp.find("FILENAME",'=', 0, TRUE)) != -1) { |
301 | pos++; | 304 | pos++; |
302 | fileName = bp.getString(&pos, 'z', TRUE); | 305 | fileName = bp.getString(&pos, 'z', TRUE); |
303 | fileName = fileName.right(fileName.length() - 1); | 306 | fileName = fileName.right(fileName.length() - 1); |
304 | fileName = fileName.left(fileName.length() - 1); | 307 | fileName = fileName.left(fileName.length() - 1); |
305 | } | 308 | } |
306 | 309 | ||
307 | } | 310 | } |
308 | pos = mimeBody.find(boundary, 0, FALSE); | 311 | pos = mimeBody.find(boundary, 0, FALSE); |
309 | if (pos == -1) //should not occur, malformed mail | 312 | if (pos == -1) //should not occur, malformed mail |
310 | pos = mimeBody.length(); | 313 | pos = mimeBody.length(); |
311 | body = mimeBody.right(mimeBody.length() - pos); | 314 | body = mimeBody.right(mimeBody.length() - pos); |
312 | mimeBody = mimeBody.left(pos); | 315 | mimeBody = mimeBody.left(pos); |
313 | 316 | ||
314 | if (fileName != "") { //attatchments of some type, audio, image etc. | 317 | if (fileName != "") { //attatchments of some type, audio, image etc. |
315 | 318 | ||
316 | Enclosure e; | 319 | Enclosure e; |
317 | e.id = enclosureId; | 320 | e.id = enclosureId; |
318 | e.originalName = fileName; | 321 | e.originalName = fileName; |
319 | e.contentType = contentType; | 322 | e.contentType = contentType; |
320 | e.contentAttribute = contentAttribute; | 323 | e.contentAttribute = contentAttribute; |
321 | e.encoding = encoding; | 324 | e.encoding = encoding; |
322 | e.body = mimeBody; | 325 | e.body = mimeBody; |
323 | e.saved = FALSE; | 326 | e.saved = FALSE; |
324 | mail->addEnclosure(&e); | 327 | mail->addEnclosure(&e); |
325 | enclosureId++; | 328 | enclosureId++; |
326 | 329 | ||
327 | } else if (contentType == "TEXT") { | 330 | } else if (contentType == "TEXT") { |
328 | if (contentAttribute == "PLAIN") { | 331 | if (contentAttribute == "PLAIN") { |
329 | mail->body = mimeBody; | 332 | mail->body = mimeBody; |
330 | mail->bodyPlain = mimeBody; | 333 | mail->bodyPlain = mimeBody; |
331 | } | 334 | } |
332 | if (contentAttribute == "HTML") { | 335 | if (contentAttribute == "HTML") { |
333 | mail->body = mimeBody; | 336 | mail->body = mimeBody; |
334 | } | 337 | } |
335 | } | 338 | } |
336 | } | 339 | } |
337 | } else { | 340 | } else { |
338 | mail->bodyPlain = body; | 341 | mail->bodyPlain = body; |
339 | mail->body = body; | 342 | mail->body = body; |
340 | } | 343 | } |
344 | delete lp; | ||
341 | return TRUE; | 345 | return TRUE; |
342 | } | 346 | } |
343 | 347 | ||
344 | bool EmailHandler::getEnclosure(Enclosure *ePtr) | 348 | bool EmailHandler::getEnclosure(Enclosure *ePtr) |
345 | { | 349 | { |
346 | QFile f(ePtr->path + ePtr->name); | 350 | QFile f(ePtr->path + ePtr->name); |
347 | char src[4]; | 351 | char src[4]; |
348 | char *destPtr; | 352 | char *destPtr; |
349 | QByteArray buffer; | 353 | QByteArray buffer; |
350 | uint bufCount, pos, decodedCount, size, x; | 354 | uint bufCount, pos, decodedCount, size, x; |
351 | 355 | ||
352 | if (! f.open(IO_WriteOnly) ) { | 356 | if (! f.open(IO_WriteOnly) ) { |
353 | qWarning("could not save: " + ePtr->path + ePtr->name); | 357 | qWarning("could not save: " + ePtr->path + ePtr->name); |
354 | return FALSE; | 358 | return FALSE; |
355 | } | 359 | } |
356 | 360 | ||
357 | if (ePtr->encoding.upper() == "BASE64") { | 361 | if (ePtr->encoding.upper() == "BASE64") { |
358 | size = (ePtr->body.length() * 3 / 4); //approximate size (always above) | 362 | size = (ePtr->body.length() * 3 / 4); //approximate size (always above) |
359 | buffer.resize(size); | 363 | buffer.resize(size); |
360 | bufCount = 0; | 364 | bufCount = 0; |
361 | pos = 0; | 365 | pos = 0; |
362 | destPtr = buffer.data(); | 366 | destPtr = buffer.data(); |
363 | 367 | ||
364 | while (pos < ePtr->body.length()) { | 368 | while (pos < ePtr->body.length()) { |
365 | decodedCount = 4; | 369 | decodedCount = 4; |
366 | x = 0; | 370 | x = 0; |
367 | while ( (x < 4) && (pos < ePtr->body.length()) ) { | 371 | while ( (x < 4) && (pos < ePtr->body.length()) ) { |
368 | src[x] = ePtr->body[pos].latin1(); | 372 | src[x] = ePtr->body[pos].latin1(); |
369 | pos++; | 373 | pos++; |
370 | if (src[x] == '\r' || src[x] == '\n' || src[x] == ' ') | 374 | if (src[x] == '\r' || src[x] == '\n' || src[x] == ' ') |
371 | x--; | 375 | x--; |
372 | x++; | 376 | x++; |
373 | } | 377 | } |
374 | if (x > 1) { | 378 | if (x > 1) { |
375 | decodedCount = parse64base(src, destPtr); | 379 | decodedCount = parse64base(src, destPtr); |
376 | destPtr += decodedCount; | 380 | destPtr += decodedCount; |
377 | bufCount += decodedCount; | 381 | bufCount += decodedCount; |
378 | } | 382 | } |
379 | } | 383 | } |
380 | 384 | ||
381 | buffer.resize(bufCount); //set correct length of file | 385 | buffer.resize(bufCount); //set correct length of file |
382 | f.writeBlock(buffer); | 386 | f.writeBlock(buffer); |
383 | } else { | 387 | } else { |
384 | QTextStream t(&f); | 388 | QTextStream t(&f); |
385 | t << ePtr->body; | 389 | t << ePtr->body; |
386 | } | 390 | } |
387 | return TRUE; | 391 | return TRUE; |
388 | } | 392 | } |
389 | 393 | ||
390 | int EmailHandler::parse64base(char *src, char *bufOut) { | 394 | int EmailHandler::parse64base(char *src, char *bufOut) { |
391 | 395 | ||
392 | char c, z; | 396 | char c, z; |
393 | char li[4]; | 397 | char li[4]; |
394 | int processed; | 398 | int processed; |
395 | 399 | ||
396 | //conversion table withouth table... | 400 | //conversion table withouth table... |
397 | for (int x = 0; x < 4; x++) { | 401 | for (int x = 0; x < 4; x++) { |
398 | c = src[x]; | 402 | c = src[x]; |
399 | 403 | ||
400 | if ( (int) c >= 'A' && (int) c <= 'Z') | 404 | if ( (int) c >= 'A' && (int) c <= 'Z') |
401 | li[x] = (int) c - (int) 'A'; | 405 | li[x] = (int) c - (int) 'A'; |
402 | if ( (int) c >= 'a' && (int) c <= 'z') | 406 | if ( (int) c >= 'a' && (int) c <= 'z') |
403 | li[x] = (int) c - (int) 'a' + 26; | 407 | li[x] = (int) c - (int) 'a' + 26; |
404 | if ( (int) c >= '0' && (int) c <= '9') | 408 | if ( (int) c >= '0' && (int) c <= '9') |
405 | li[x] = (int) c - (int) '0' + 52; | 409 | li[x] = (int) c - (int) '0' + 52; |
406 | if (c == '+') | 410 | if (c == '+') |
407 | li[x] = 62; | 411 | li[x] = 62; |
408 | if (c == '/') | 412 | if (c == '/') |
409 | li[x] = 63; | 413 | li[x] = 63; |
410 | } | 414 | } |
411 | 415 | ||
412 | processed = 1; | 416 | processed = 1; |
413 | bufOut[0] = (char) li[0] & (32+16+8+4+2+1); //mask out top 2 bits | 417 | bufOut[0] = (char) li[0] & (32+16+8+4+2+1); //mask out top 2 bits |
414 | bufOut[0] <<= 2; | 418 | bufOut[0] <<= 2; |
415 | z = li[1] >> 4; | 419 | z = li[1] >> 4; |
416 | bufOut[0] = bufOut[0] | z; //first byte retrived | 420 | bufOut[0] = bufOut[0] | z; //first byte retrived |
417 | 421 | ||
418 | if (src[2] != '=') { | 422 | if (src[2] != '=') { |
419 | bufOut[1] = (char) li[1] & (8+4+2+1); //mask out top 4 bits | 423 | bufOut[1] = (char) li[1] & (8+4+2+1); //mask out top 4 bits |
420 | bufOut[1] <<= 4; | 424 | bufOut[1] <<= 4; |
421 | z = li[2] >> 2; | 425 | z = li[2] >> 2; |
422 | bufOut[1] = bufOut[1] | z; //second byte retrived | 426 | bufOut[1] = bufOut[1] | z; //second byte retrived |
423 | processed++; | 427 | processed++; |
424 | 428 | ||
425 | if (src[3] != '=') { | 429 | if (src[3] != '=') { |
426 | bufOut[2] = (char) li[2] & (2+1); //mask out top 6 bits | 430 | bufOut[2] = (char) li[2] & (2+1); //mask out top 6 bits |
427 | bufOut[2] <<= 6; | 431 | bufOut[2] <<= 6; |
428 | z = li[3]; | 432 | z = li[3]; |
429 | bufOut[2] = bufOut[2] | z; //third byte retrieved | 433 | bufOut[2] = bufOut[2] | z; //third byte retrieved |
430 | processed++; | 434 | processed++; |
431 | } | 435 | } |
432 | } | 436 | } |
433 | return processed; | 437 | return processed; |
434 | } | 438 | } |
435 | 439 | ||
436 | int EmailHandler::encodeMime(Email *mail) | 440 | int EmailHandler::encodeMime(Email *mail) |
437 | { | 441 | { |
438 | 442 | ||
439 | QString fileName, fileType, contentType, newBody, boundary; | 443 | QString fileName, fileType, contentType, newBody, boundary; |
440 | Enclosure *ePtr; | 444 | Enclosure *ePtr; |
441 | 445 | ||
442 | QString userName = mailAccount.name; | 446 | QString userName = mailAccount.name; |
443 | if (userName.length()>0) //only embrace it if there is a user name | 447 | if (userName.length()>0) //only embrace it if there is a user name |
444 | userName += " <" + mailAccount.emailAddress + ">"; | 448 | userName += " <" + mailAccount.emailAddress + ">"; |
445 | 449 | ||
446 | //add standard headers | 450 | //add standard headers |
447 | newBody = "From: " + userName + "\r\nTo: "; | 451 | newBody = "From: " + userName + "\r\nTo: "; |
448 | for (QStringList::Iterator it = mail->recipients.begin(); it != mail->recipients.end(); ++it ) { | 452 | for (QStringList::Iterator it = mail->recipients.begin(); it != mail->recipients.end(); ++it ) { |
449 | newBody += *it + " "; | 453 | newBody += *it + " "; |
450 | } | 454 | } |
451 | 455 | ||
452 | newBody += "\r\nCC: "; | 456 | newBody += "\r\nCC: "; |
453 | 457 | ||
454 | for (QStringList::Iterator it = mail->carbonCopies.begin(); it != mail->carbonCopies.end(); ++it ) { | 458 | for (QStringList::Iterator it = mail->carbonCopies.begin(); it != mail->carbonCopies.end(); ++it ) { |
455 | newBody += *it + " "; | 459 | newBody += *it + " "; |
456 | } | 460 | } |
457 | 461 | ||
458 | newBody += "\r\nSubject: " + mail->subject + "\r\n"; | 462 | newBody += "\r\nSubject: " + mail->subject + "\r\n"; |
459 | 463 | ||
460 | if (mail->files.count() == 0) { //just a simple mail | 464 | if (mail->files.count() == 0) { //just a simple mail |
461 | newBody += "\r\n" + mail->body; | 465 | newBody += "\r\n" + mail->body; |
462 | mail->rawMail = newBody; | 466 | mail->rawMail = newBody; |
463 | return 0; | 467 | return 0; |
464 | } | 468 | } |
465 | 469 | ||
466 | //Build mime encoded mail | 470 | //Build mime encoded mail |
467 | boundary = "-----4345=next_bound=0495----"; | 471 | boundary = "-----4345=next_bound=0495----"; |
468 | 472 | ||
469 | newBody += "Mime-Version: 1.0\r\n"; | 473 | newBody += "Mime-Version: 1.0\r\n"; |
470 | newBody += "Content-Type: multipart/mixed; boundary=\"" + | 474 | newBody += "Content-Type: multipart/mixed; boundary=\"" + |
471 | boundary + "\"\r\n\r\n"; | 475 | boundary + "\"\r\n\r\n"; |
472 | 476 | ||
473 | newBody += "This is a multipart message in Mime 1.0 format\r\n\r\n"; | 477 | newBody += "This is a multipart message in Mime 1.0 format\r\n\r\n"; |
474 | newBody += "--" + boundary + "\r\nContent-Type: text/plain\r\n\r\n"; | 478 | newBody += "--" + boundary + "\r\nContent-Type: text/plain\r\n\r\n"; |
475 | newBody += mail->body; | 479 | newBody += mail->body; |
476 | 480 | ||
477 | for ( ePtr=mail->files.first(); ePtr != 0; ePtr=mail->files.next() ) { | 481 | for ( ePtr=mail->files.first(); ePtr != 0; ePtr=mail->files.next() ) { |
478 | fileName = ePtr->originalName; | 482 | fileName = ePtr->originalName; |
479 | fileType = ePtr->contentType; | 483 | fileType = ePtr->contentType; |
480 | QFileInfo fi(fileName); | 484 | QFileInfo fi(fileName); |
481 | 485 | ||
482 | // This specification of contentType is temporary | 486 | // This specification of contentType is temporary |
483 | contentType = ""; | 487 | contentType = ""; |
484 | if (fileType == "Picture") { | 488 | if (fileType == "Picture") { |
485 | contentType = "image/x-image"; | 489 | contentType = "image/x-image"; |
486 | } else if (fileType == "Document") { | 490 | } else if (fileType == "Document") { |
487 | contentType = "text/plain"; | 491 | contentType = "text/plain"; |
488 | } else if (fileType == "Sound") { | 492 | } else if (fileType == "Sound") { |
489 | contentType = "audio/x-wav"; | 493 | contentType = "audio/x-wav"; |
490 | } else if (fileType == "Movie") { | 494 | } else if (fileType == "Movie") { |
491 | contentType = "video/mpeg"; | 495 | contentType = "video/mpeg"; |
492 | } else { | 496 | } else { |
493 | contentType = "application/octet-stream"; | 497 | contentType = "application/octet-stream"; |
494 | } | 498 | } |
495 | 499 | ||
496 | newBody += "\r\n\r\n--" + boundary + "\r\n"; | 500 | newBody += "\r\n\r\n--" + boundary + "\r\n"; |
497 | newBody += "Content-Type: " + contentType + "; name=\"" + | 501 | newBody += "Content-Type: " + contentType + "; name=\"" + |
498 | fi.fileName() + "\"\r\n"; | 502 | fi.fileName() + "\"\r\n"; |
499 | newBody += "Content-Transfer-Encoding: base64\r\n"; | 503 | newBody += "Content-Transfer-Encoding: base64\r\n"; |
500 | newBody += "Content-Disposition: inline; filename=\"" + | 504 | newBody += "Content-Disposition: inline; filename=\"" + |
501 | fi.fileName() + "\"\r\n\r\n"; | 505 | fi.fileName() + "\"\r\n\r\n"; |
502 | 506 | ||
503 | if (encodeFile(fileName, &newBody) == -1) //file not found? | 507 | if (encodeFile(fileName, &newBody) == -1) //file not found? |
504 | return -1; | 508 | return -1; |
505 | } | 509 | } |
506 | 510 | ||
507 | newBody += "\r\n\r\n--" + boundary + "--"; | 511 | newBody += "\r\n\r\n--" + boundary + "--"; |
508 | mail->rawMail = newBody; | 512 | mail->rawMail = newBody; |
509 | 513 | ||
510 | return 0; | 514 | return 0; |
511 | } | 515 | } |
512 | 516 | ||
513 | int EmailHandler::encodeFile(const QString &fileName, QString *toBody) | 517 | int EmailHandler::encodeFile(const QString &fileName, QString *toBody) |
514 | { | 518 | { |
515 | char *fileData; | 519 | char *fileData; |
516 | char *dataPtr; | 520 | char *dataPtr; |
517 | QString temp; | 521 | QString temp; |
518 | uint dataSize, count; | 522 | uint dataSize, count; |
519 | QFile f(fileName); | 523 | QFile f(fileName); |
520 | 524 | ||
521 | if (! f.open(IO_ReadOnly) ) { | 525 | if (! f.open(IO_ReadOnly) ) { |
522 | qWarning("could not open file: " + fileName); | 526 | qWarning("could not open file: " + fileName); |
523 | return -1; | 527 | return -1; |
524 | } | 528 | } |
525 | QTextStream s(&f); | 529 | QTextStream s(&f); |
526 | dataSize = f.size(); | 530 | dataSize = f.size(); |
527 | fileData = (char *) malloc(dataSize + 3); | 531 | fileData = (char *) malloc(dataSize + 3); |
528 | s.readRawBytes(fileData, dataSize); | 532 | s.readRawBytes(fileData, dataSize); |
529 | 533 | ||
530 | temp = ""; | 534 | temp = ""; |
531 | dataPtr = fileData; | 535 | dataPtr = fileData; |
532 | count = 0; | 536 | count = 0; |
diff --git a/noncore/net/mailit/mailitwindow.cpp b/noncore/net/mailit/mailitwindow.cpp index a111241..f945a0f 100644 --- a/noncore/net/mailit/mailitwindow.cpp +++ b/noncore/net/mailit/mailitwindow.cpp | |||
@@ -1,168 +1,168 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2001 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2001 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qt Palmtop Environment. | 4 | ** This file is part of Qt Palmtop Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #include <qwhatsthis.h> | 20 | #include <qwhatsthis.h> |
21 | #include <qmessagebox.h> | 21 | #include <qmessagebox.h> |
22 | #include "mailitwindow.h" | 22 | #include "mailitwindow.h" |
23 | 23 | ||
24 | MailItWindow::MailItWindow(QWidget *parent, const char *name, WFlags fl) | 24 | MailItWindow::MailItWindow(QWidget *parent, const char *name, WFlags fl) |
25 | : QMainWindow(parent, name, WStyle_ContextHelp) | 25 | : QMainWindow(parent, name, WStyle_ContextHelp) |
26 | { | 26 | { |
27 | currentCaption = "Mailit"; | 27 | currentCaption = "Mailit"; |
28 | setCaption(tr(currentCaption)); | 28 | setCaption(tr(currentCaption)); |
29 | views = new QWidgetStack(this); | 29 | views = new QWidgetStack(this); |
30 | setCentralWidget(views); | 30 | setCentralWidget(views); |
31 | QWhatsThis::add(views,tr("Central view area")); | 31 | QWhatsThis::add(views,tr("Central view area")); |
32 | emailClient = new EmailClient(views, "client"); | 32 | emailClient = new EmailClient(views, "client"); |
33 | writeMail = new WriteMail(views, "writing"); | 33 | writeMail = new WriteMail(views, "writing"); |
34 | readMail = new ReadMail(views, "reading"); | 34 | readMail = new ReadMail(views, "reading"); |
35 | 35 | ||
36 | views->raiseWidget(emailClient); | 36 | views->raiseWidget(emailClient); |
37 | 37 | ||
38 | connect(emailClient, SIGNAL(composeRequested()), | 38 | connect(emailClient, SIGNAL(composeRequested()), |
39 | this, SLOT(compose()) ); | 39 | this, SLOT(compose()) ); |
40 | connect(emailClient, SIGNAL(viewEmail(QListView *, Email *)), this, | 40 | connect(emailClient, SIGNAL(viewEmail(QListView *, Email *)), this, |
41 | SLOT(viewMail(QListView *, Email *)) ); | 41 | SLOT(viewMail(QListView *, Email *)) ); |
42 | connect(emailClient, SIGNAL(mailUpdated(Email *)), this, | 42 | connect(emailClient, SIGNAL(mailUpdated(Email *)), this, |
43 | SLOT(updateMailView(Email *)) ); | 43 | SLOT(updateMailView(Email *)) ); |
44 | 44 | ||
45 | connect(writeMail, SIGNAL(cancelMail()), this, SLOT(showEmailClient()) ); | 45 | connect(writeMail, SIGNAL(cancelMail()), this, SLOT(showEmailClient()) ); |
46 | connect(writeMail, SIGNAL(sendMailRequested(const Email &)), this, | 46 | connect(writeMail, SIGNAL(sendMailRequested(const Email &)), this, |
47 | SLOT(showEmailClient()) ); | 47 | SLOT(showEmailClient()) ); |
48 | connect(writeMail, SIGNAL(sendMailRequested(const Email &)), emailClient, | 48 | connect(writeMail, SIGNAL(sendMailRequested(const Email &)), emailClient, |
49 | SLOT(enqueMail(const Email &)) ); | 49 | SLOT(enqueMail(const Email &)) ); |
50 | 50 | ||
51 | connect(readMail, SIGNAL(cancelView()), this, SLOT(showEmailClient()) ); | 51 | connect(readMail, SIGNAL(cancelView()), this, SLOT(showEmailClient()) ); |
52 | connect(readMail, SIGNAL(replyRequested(Email &, bool&)), this, | 52 | connect(readMail, SIGNAL(replyRequested(Email &, bool&)), this, |
53 | SLOT(composeReply(Email &, bool&)) ); | 53 | SLOT(composeReply(Email &, bool&)) ); |
54 | connect(readMail, SIGNAL(forwardRequested(Email &)), this, | 54 | connect(readMail, SIGNAL(forwardRequested(Email &)), this, |
55 | SLOT(composeForward(Email &)) ); | 55 | SLOT(composeForward(Email &)) ); |
56 | 56 | ||
57 | connect(readMail, SIGNAL(removeItem(EmailListItem *, bool &)), emailClient, | 57 | connect(readMail, SIGNAL(removeItem(EmailListItem *, bool &)), emailClient, |
58 | SLOT(deleteMail(EmailListItem *, bool &)) ); | 58 | SLOT(deleteMail(EmailListItem *, bool &)) ); |
59 | connect(readMail, SIGNAL(viewingMail(Email *)), emailClient, | 59 | connect(readMail, SIGNAL(viewingMail(Email *)), emailClient, |
60 | SLOT(moveMailFront(Email *)) ); | 60 | SLOT(moveMailFront(Email *)) ); |
61 | 61 | ||
62 | connect(emailClient, SIGNAL(newCaption(const QString &)), | 62 | connect(emailClient, SIGNAL(newCaption(const QString &)), |
63 | this, SLOT(updateCaption(const QString &)) ); | 63 | this, SLOT(updateCaption(const QString &)) ); |
64 | 64 | ||
65 | connect(readMail, SIGNAL(download(Email *)), emailClient, SLOT(download(Email*)) ); | 65 | connect(readMail, SIGNAL(download(Email *)), emailClient, SLOT(download(Email*)) ); |
66 | 66 | ||
67 | viewingMail = FALSE; | 67 | viewingMail = FALSE; |
68 | } | 68 | } |
69 | 69 | ||
70 | MailItWindow::~MailItWindow() | 70 | MailItWindow::~MailItWindow() |
71 | { | 71 | { |
72 | } | 72 | } |
73 | 73 | ||
74 | void MailItWindow::closeEvent(QCloseEvent *e) | 74 | void MailItWindow::closeEvent(QCloseEvent *e) |
75 | { | 75 | { |
76 | if (views->visibleWidget() == emailClient) { | 76 | if (views->visibleWidget() == emailClient) { |
77 | e->accept(); | 77 | e->accept(); |
78 | } else { | 78 | } else { |
79 | showEmailClient(); | 79 | showEmailClient(); |
80 | } | 80 | } |
81 | } | 81 | } |
82 | 82 | ||
83 | void MailItWindow::compose() | 83 | void MailItWindow::compose() |
84 | { | 84 | { |
85 | viewingMail = FALSE; | 85 | viewingMail = FALSE; |
86 | emailClient->hide(); | 86 | emailClient->hide(); |
87 | readMail->hide(); | 87 | readMail->hide(); |
88 | views->raiseWidget(writeMail); | 88 | views->raiseWidget(writeMail); |
89 | writeMail->setAddressList(emailClient->getAdrListRef()); | 89 | writeMail->setAddressList(emailClient->getAdrListRef()); |
90 | writeMail->newMail(); | 90 | writeMail->newMail(); |
91 | setCaption( tr( "Write mail" ) ); | 91 | setCaption( tr( "Write mail" ) ); |
92 | } | 92 | } |
93 | 93 | ||
94 | void MailItWindow::composeReply(Email &mail, bool& replyAll) | 94 | void MailItWindow::composeReply(Email &mail, bool& replyAll) |
95 | { | 95 | { |
96 | compose(); | 96 | compose(); |
97 | writeMail->reply(mail,replyAll) ; | 97 | writeMail->reply(mail,replyAll) ; |
98 | } | 98 | } |
99 | 99 | ||
100 | void MailItWindow::composeForward(Email &mail) | 100 | void MailItWindow::composeForward(Email &mail) |
101 | { | 101 | { |
102 | compose(); | 102 | compose(); |
103 | writeMail->forward(mail) ; | 103 | writeMail->forward(mail) ; |
104 | } | 104 | } |
105 | 105 | ||
106 | 106 | ||
107 | void MailItWindow::showEmailClient() | 107 | void MailItWindow::showEmailClient() |
108 | { | 108 | { |
109 | viewingMail = FALSE; | 109 | viewingMail = FALSE; |
110 | writeMail->hide(); | 110 | writeMail->hide(); |
111 | readMail->hide(); | 111 | readMail->hide(); |
112 | views->raiseWidget(emailClient); | 112 | views->raiseWidget(emailClient); |
113 | setCaption( tr(currentCaption) ); | 113 | setCaption( tr(currentCaption) ); |
114 | } | 114 | } |
115 | 115 | ||
116 | void MailItWindow::viewMail(QListView *view, Email *mail) | 116 | void MailItWindow::viewMail(QListView *view, Email *mail) |
117 | { | 117 | { |
118 | viewingMail = TRUE; | 118 | viewingMail = TRUE; |
119 | emailClient->hide(); | 119 | emailClient->hide(); |
120 | 120 | ||
121 | int result=0; | 121 | int result=0; |
122 | 122 | ||
123 | if ((mail->received)&&(!mail->downloaded)) | 123 | if ((mail->received)&&(!mail->downloaded)) |
124 | { | 124 | { |
125 | QMessageBox mb( tr("Mail not downloaded"), | 125 | QMessageBox mb( tr("Mail not downloaded"), |
126 | tr("The mail you have clicked \n" | 126 | tr("The mail you have clicked \n" |
127 | "has not been downloaded yet.\n " | 127 | "has not been downloaded yet.\n " |
128 | "Would you like to do it now ?"), | 128 | "Would you like to do it now ?"), |
129 | QMessageBox::Information, | 129 | QMessageBox::Information, |
130 | QMessageBox::Yes | QMessageBox::Default, | 130 | QMessageBox::Yes | QMessageBox::Default, |
131 | QMessageBox::No | QMessageBox::Escape,0 ); | 131 | QMessageBox::No | QMessageBox::Escape,0 ); |
132 | 132 | ||
133 | result=mb.exec(); | 133 | result=mb.exec(); |
134 | 134 | ||
135 | if (result==QMessageBox::Yes) | 135 | if (result==QMessageBox::Yes) |
136 | { | 136 | { |
137 | emailClient->download(mail); | 137 | emailClient->download(mail); |
138 | } | 138 | } |
139 | } | 139 | } |
140 | 140 | ||
141 | readMail->update(view, mail); | 141 | readMail->update(view, mail); |
142 | views->raiseWidget(readMail); | 142 | views->raiseWidget(readMail); |
143 | setCaption( tr( "Examine mail" ) ); | 143 | setCaption( tr( "Read Mail" ) ); |
144 | } | 144 | } |
145 | 145 | ||
146 | void MailItWindow::updateMailView(Email *mail) | 146 | void MailItWindow::updateMailView(Email *mail) |
147 | { | 147 | { |
148 | if (viewingMail) { | 148 | if (viewingMail) { |
149 | readMail->mailUpdated(mail); | 149 | readMail->mailUpdated(mail); |
150 | } | 150 | } |
151 | } | 151 | } |
152 | 152 | ||
153 | void MailItWindow::updateCaption(const QString &newCaption) | 153 | void MailItWindow::updateCaption(const QString &newCaption) |
154 | { | 154 | { |
155 | currentCaption = newCaption; | 155 | currentCaption = newCaption; |
156 | setCaption(tr(currentCaption)); | 156 | setCaption(tr(currentCaption)); |
157 | } | 157 | } |
158 | 158 | ||
159 | void MailItWindow::setDocument(const QString &_address) | 159 | void MailItWindow::setDocument(const QString &_address) |
160 | { | 160 | { |
161 | // strip leading 'mailto:' | 161 | // strip leading 'mailto:' |
162 | QString address = _address; | 162 | QString address = _address; |
163 | if (address.startsWith("mailto:")) | 163 | if (address.startsWith("mailto:")) |
164 | address = address.mid(6); | 164 | address = address.mid(6); |
165 | 165 | ||
166 | compose(); | 166 | compose(); |
167 | writeMail->setRecipient(address); | 167 | writeMail->setRecipient(address); |
168 | } | 168 | } |
diff --git a/noncore/unsupported/mailit/emailclient.cpp b/noncore/unsupported/mailit/emailclient.cpp index 2102ba7..da1226c 100644 --- a/noncore/unsupported/mailit/emailclient.cpp +++ b/noncore/unsupported/mailit/emailclient.cpp | |||
@@ -280,388 +280,388 @@ void EmailClient::sendQuedMail() | |||
280 | { | 280 | { |
281 | int count = 0; | 281 | int count = 0; |
282 | 282 | ||
283 | if (accountList.count() == 0) { | 283 | if (accountList.count() == 0) { |
284 | QMessageBox::warning(qApp->activeWindow(), "No account selected", "You must create an account", "OK\n"); | 284 | QMessageBox::warning(qApp->activeWindow(), "No account selected", "You must create an account", "OK\n"); |
285 | return; | 285 | return; |
286 | } | 286 | } |
287 | //traverse listview, find messages to send | 287 | //traverse listview, find messages to send |
288 | if (! sending) { | 288 | if (! sending) { |
289 | item = (EmailListItem *) outboxView->firstChild(); | 289 | item = (EmailListItem *) outboxView->firstChild(); |
290 | if (item != NULL) { | 290 | if (item != NULL) { |
291 | while (item != NULL) { | 291 | while (item != NULL) { |
292 | quedMessages.append(item->getMail()); | 292 | quedMessages.append(item->getMail()); |
293 | item = (EmailListItem *) item->nextSibling(); | 293 | item = (EmailListItem *) item->nextSibling(); |
294 | count++; | 294 | count++; |
295 | } | 295 | } |
296 | setMailAccount(); | 296 | setMailAccount(); |
297 | emailHandler->sendMail(&quedMessages); | 297 | emailHandler->sendMail(&quedMessages); |
298 | sending = TRUE; | 298 | sending = TRUE; |
299 | sendMailButton->setEnabled(FALSE); | 299 | sendMailButton->setEnabled(FALSE); |
300 | cancelButton->setEnabled(TRUE); | 300 | cancelButton->setEnabled(TRUE); |
301 | } else { | 301 | } else { |
302 | qWarning("sendQuedMail(): no messages to send"); | 302 | qWarning("sendQuedMail(): no messages to send"); |
303 | } | 303 | } |
304 | } | 304 | } |
305 | } | 305 | } |
306 | 306 | ||
307 | void EmailClient::setMailAccount() | 307 | void EmailClient::setMailAccount() |
308 | { | 308 | { |
309 | emailHandler->setAccount(*currentAccount); | 309 | emailHandler->setAccount(*currentAccount); |
310 | } | 310 | } |
311 | 311 | ||
312 | void EmailClient::mailSent() | 312 | void EmailClient::mailSent() |
313 | { | 313 | { |
314 | sending = FALSE; | 314 | sending = FALSE; |
315 | sendMailButton->setEnabled(TRUE); | 315 | sendMailButton->setEnabled(TRUE); |
316 | 316 | ||
317 | quedMessages.clear(); | 317 | quedMessages.clear(); |
318 | outboxView->clear(); //should be moved to an sentBox | 318 | outboxView->clear(); //should be moved to an sentBox |
319 | } | 319 | } |
320 | 320 | ||
321 | void EmailClient::getNewMail() { | 321 | void EmailClient::getNewMail() { |
322 | 322 | ||
323 | if (accountList.count() == 0) { | 323 | if (accountList.count() == 0) { |
324 | QMessageBox::warning(qApp->activeWindow(),"No account selected", | 324 | QMessageBox::warning(qApp->activeWindow(),"No account selected", |
325 | "You must create an account", "OK\n"); | 325 | "You must create an account", "OK\n"); |
326 | return; | 326 | return; |
327 | } | 327 | } |
328 | 328 | ||
329 | setMailAccount(); | 329 | setMailAccount(); |
330 | 330 | ||
331 | receiving = TRUE; | 331 | receiving = TRUE; |
332 | previewingMail = TRUE; | 332 | previewingMail = TRUE; |
333 | getMailButton->setEnabled(FALSE); | 333 | getMailButton->setEnabled(FALSE); |
334 | cancelButton->setEnabled(TRUE); | 334 | cancelButton->setEnabled(TRUE); |
335 | selectAccountMenu->setEnabled(FALSE); | 335 | selectAccountMenu->setEnabled(FALSE); |
336 | 336 | ||
337 | status1Label->setText(currentAccount->accountName + " headers"); | 337 | status1Label->setText(currentAccount->accountName + " headers"); |
338 | progressBar->reset(); | 338 | progressBar->reset(); |
339 | 339 | ||
340 | //get any previous mails not downloaded and add to queue | 340 | //get any previous mails not downloaded and add to queue |
341 | /*mailDownloadList.clear(); | 341 | /*mailDownloadList.clear(); |
342 | Email *mailPtr; | 342 | Email *mailPtr; |
343 | item = (EmailListItem *) inboxView->firstChild(); | 343 | item = (EmailListItem *) inboxView->firstChild(); |
344 | while (item != NULL) { | 344 | while (item != NULL) { |
345 | mailPtr = item->getMail(); | 345 | mailPtr = item->getMail(); |
346 | if ( (!mailPtr->downloaded) && (mailPtr->fromAccountId == currentAccount->id) ) { | 346 | if ( (!mailPtr->downloaded) && (mailPtr->fromAccountId == currentAccount->id) ) { |
347 | mailDownloadList.sizeInsert(mailPtr->serverId, mailPtr->size); | 347 | mailDownloadList.sizeInsert(mailPtr->serverId, mailPtr->size); |
348 | } | 348 | } |
349 | item = (EmailListItem *) item->nextSibling(); | 349 | item = (EmailListItem *) item->nextSibling(); |
350 | }*/ | 350 | }*/ |
351 | 351 | ||
352 | emailHandler->getMailHeaders(); | 352 | emailHandler->getMailHeaders(); |
353 | 353 | ||
354 | } | 354 | } |
355 | 355 | ||
356 | void EmailClient::getAllNewMail() | 356 | void EmailClient::getAllNewMail() |
357 | { | 357 | { |
358 | allAccounts = TRUE; | 358 | allAccounts = TRUE; |
359 | currentAccount = accountList.first(); | 359 | currentAccount = accountList.first(); |
360 | getNewMail(); | 360 | getNewMail(); |
361 | } | 361 | } |
362 | 362 | ||
363 | void EmailClient::mailArrived(const Email &mail, bool fromDisk) | 363 | void EmailClient::mailArrived(const Email &mail, bool fromDisk) |
364 | { | 364 | { |
365 | Enclosure *ePtr; | 365 | Enclosure *ePtr; |
366 | Email newMail; | 366 | Email newMail; |
367 | int thisMailId; | 367 | int thisMailId; |
368 | emailHandler->parse( mail.rawMail, lineShift, &newMail); | 368 | emailHandler->parse( mail.rawMail, lineShift, &newMail); |
369 | mailconf->setGroup(newMail.id); | 369 | mailconf->setGroup(newMail.id); |
370 | 370 | ||
371 | if (fromDisk) | 371 | if (fromDisk) |
372 | { | 372 | { |
373 | 373 | ||
374 | newMail.downloaded = mailconf->readBoolEntry("downloaded"); | 374 | newMail.downloaded = mailconf->readBoolEntry("downloaded"); |
375 | newMail.size = mailconf->readNumEntry("size"); | 375 | newMail.size = mailconf->readNumEntry("size"); |
376 | newMail.serverId = mailconf->readNumEntry("serverid"); | 376 | newMail.serverId = mailconf->readNumEntry("serverid"); |
377 | newMail.fromAccountId = mailconf->readNumEntry("fromaccountid"); | 377 | newMail.fromAccountId = mailconf->readNumEntry("fromaccountid"); |
378 | } | 378 | } |
379 | else | 379 | else |
380 | { //mail arrived from server | 380 | { //mail arrived from server |
381 | 381 | ||
382 | newMail.serverId = mail.serverId; | 382 | newMail.serverId = mail.serverId; |
383 | newMail.size = mail.size; | 383 | newMail.size = mail.size; |
384 | newMail.downloaded = mail.downloaded; | 384 | newMail.downloaded = mail.downloaded; |
385 | 385 | ||
386 | newMail.fromAccountId = emailHandler->getAccount()->id; | 386 | newMail.fromAccountId = emailHandler->getAccount()->id; |
387 | mailconf->writeEntry("fromaccountid", newMail.fromAccountId); | 387 | mailconf->writeEntry("fromaccountid", newMail.fromAccountId); |
388 | } | 388 | } |
389 | 389 | ||
390 | //add if read or not | 390 | //add if read or not |
391 | newMail.read = mailconf->readBoolEntry("mailread"); | 391 | newMail.read = mailconf->readBoolEntry("mailread"); |
392 | 392 | ||
393 | //check if new mail | 393 | //check if new mail |
394 | if ( (thisMailId = mailconf->readNumEntry("internalmailid", -1)) == -1) { | 394 | if ( (thisMailId = mailconf->readNumEntry("internalmailid", -1)) == -1) { |
395 | thisMailId = mailIdCount; | 395 | thisMailId = mailIdCount; |
396 | mailIdCount++; | 396 | mailIdCount++; |
397 | 397 | ||
398 | //set server count, so that if the user aborts, the new | 398 | //set server count, so that if the user aborts, the new |
399 | //header is not reloaded | 399 | //header is not reloaded |
400 | if ((currentAccount)&&(currentAccount->synchronize)) | 400 | if ((currentAccount)&&(currentAccount->synchronize)) |
401 | currentAccount->lastServerMailCount++; | 401 | currentAccount->lastServerMailCount++; |
402 | 402 | ||
403 | mailconf->writeEntry("internalmailid", thisMailId); | 403 | mailconf->writeEntry("internalmailid", thisMailId); |
404 | mailconf->writeEntry("downloaded", newMail.downloaded); | 404 | mailconf->writeEntry("downloaded", newMail.downloaded); |
405 | mailconf->writeEntry("size", (int) newMail.size); | 405 | mailconf->writeEntry("size", (int) newMail.size); |
406 | mailconf->writeEntry("serverid", newMail.serverId); | 406 | mailconf->writeEntry("serverid", newMail.serverId); |
407 | 407 | ||
408 | //addressList->addContact(newMail.fromMail, newMail.from); | 408 | //addressList->addContact(newMail.fromMail, newMail.from); |
409 | } | 409 | } |
410 | 410 | ||
411 | mailconf->writeEntry("downloaded", newMail.downloaded); | 411 | mailconf->writeEntry("downloaded", newMail.downloaded); |
412 | 412 | ||
413 | QString stringMailId; | 413 | QString stringMailId; |
414 | stringMailId.setNum(thisMailId); | 414 | stringMailId.setNum(thisMailId); |
415 | //see if any attatchments needs to be stored | 415 | //see if any attatchments needs to be stored |
416 | 416 | ||
417 | for ( ePtr=newMail.files.first(); ePtr != 0; ePtr=newMail.files.next() ) { | 417 | for ( ePtr=newMail.files.first(); ePtr != 0; ePtr=newMail.files.next() ) { |
418 | QString stringId; | 418 | QString stringId; |
419 | stringId.setNum(ePtr->id); | 419 | stringId.setNum(ePtr->id); |
420 | 420 | ||
421 | int id = mailconf->readNumEntry("enclosureid_" + stringId); | 421 | int id = mailconf->readNumEntry("enclosureid_" + stringId); |
422 | if (id != ePtr->id) { //new entry | 422 | if (id != ePtr->id) { //new entry |
423 | mailconf->writeEntry("enclosureid_" + stringId, ePtr->id); | 423 | mailconf->writeEntry("enclosureid_" + stringId, ePtr->id); |
424 | mailconf->writeEntry("name_" + stringId, ePtr->originalName); | 424 | mailconf->writeEntry("name_" + stringId, ePtr->originalName); |
425 | mailconf->writeEntry("contenttype_" + stringId, ePtr->contentType); | 425 | mailconf->writeEntry("contenttype_" + stringId, ePtr->contentType); |
426 | mailconf->writeEntry("contentattribute_" + stringId, ePtr->contentAttribute); | 426 | mailconf->writeEntry("contentattribute_" + stringId, ePtr->contentAttribute); |
427 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); | 427 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); |
428 | mailconf->writeEntry("installed_" + stringId, FALSE); | 428 | mailconf->writeEntry("installed_" + stringId, FALSE); |
429 | 429 | ||
430 | ePtr->name = stringMailId + "_" + stringId; | 430 | ePtr->name = stringMailId + "_" + stringId; |
431 | ePtr->path = getPath(TRUE); | 431 | ePtr->path = getPath(TRUE); |
432 | if (emailHandler->getEnclosure(ePtr)) { //file saved | 432 | if (emailHandler->getEnclosure(ePtr)) { //file saved |
433 | ePtr->saved = TRUE; | 433 | ePtr->saved = TRUE; |
434 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); | 434 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); |
435 | mailconf->writeEntry("filename_" + stringId, ePtr->name); | 435 | mailconf->writeEntry("filename_" + stringId, ePtr->name); |
436 | mailconf->writeEntry("path_" + stringId, ePtr->path); | 436 | mailconf->writeEntry("path_" + stringId, ePtr->path); |
437 | } else { | 437 | } else { |
438 | ePtr->saved = FALSE; | 438 | ePtr->saved = FALSE; |
439 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); | 439 | mailconf->writeEntry("saved_" + stringId, ePtr->saved); |
440 | } | 440 | } |
441 | } else { | 441 | } else { |
442 | ePtr->saved = mailconf->readBoolEntry("saved_" + stringId); | 442 | ePtr->saved = mailconf->readBoolEntry("saved_" + stringId); |
443 | ePtr->installed = mailconf->readBoolEntry("installed_" + stringId); | 443 | ePtr->installed = mailconf->readBoolEntry("installed_" + stringId); |
444 | if (ePtr->saved) { | 444 | if (ePtr->saved) { |
445 | ePtr->name = mailconf->readEntry("filename_" + stringId); | 445 | ePtr->name = mailconf->readEntry("filename_" + stringId); |
446 | ePtr->path = mailconf->readEntry("path_" + stringId); | 446 | ePtr->path = mailconf->readEntry("path_" + stringId); |
447 | } | 447 | } |
448 | } | 448 | } |
449 | } | 449 | } |
450 | 450 | ||
451 | bool found=false; | 451 | bool found=false; |
452 | 452 | ||
453 | if (!fromDisk) | 453 | if (!fromDisk) |
454 | { | 454 | { |
455 | 455 | ||
456 | Email *mailPtr; | 456 | Email *mailPtr; |
457 | item = (EmailListItem *) inboxView->firstChild(); | 457 | item = (EmailListItem *) inboxView->firstChild(); |
458 | while ((item != NULL)&&(!found)) | 458 | while ((item != NULL)&&(!found)) |
459 | { | 459 | { |
460 | mailPtr = item->getMail(); | 460 | mailPtr = item->getMail(); |
461 | if (mailPtr->id == newMail.id) { | 461 | if (mailPtr->id == newMail.id) { |
462 | item->setMail(newMail); | 462 | item->setMail(newMail); |
463 | emit mailUpdated(item->getMail()); | 463 | emit mailUpdated(item->getMail()); |
464 | found = true; | 464 | found = true; |
465 | } | 465 | } |
466 | item = (EmailListItem *) item->nextSibling(); | 466 | item = (EmailListItem *) item->nextSibling(); |
467 | } | 467 | } |
468 | } | 468 | } |
469 | if ((!found)||(fromDisk)) { | 469 | if ((!found)||(fromDisk)) { |
470 | item = new EmailListItem(inboxView, newMail, TRUE); | 470 | item = new EmailListItem(inboxView, newMail, TRUE); |
471 | } | 471 | } |
472 | if (item->getMail()->files.count()>0) | 472 | // if (item->getMail()->files.count()>0) |
473 | { | 473 | // { |
474 | item->setPixmap(0, Resource::loadPixmap("mailit/attach")); | 474 | // item->setPixmap(0, Resource::loadPixmap("mailit/attach")); |
475 | } | 475 | // } |
476 | /*if (!newMail.downloaded) | 476 | /*if (!newMail.downloaded) |
477 | mailDownloadList.sizeInsert(newMail.serverId, newMail.size);*/ | 477 | mailDownloadList.sizeInsert(newMail.serverId, newMail.size);*/ |
478 | 478 | ||
479 | mailboxView->setCurrentTab(0); | 479 | mailboxView->setCurrentTab(0); |
480 | 480 | ||
481 | } | 481 | } |
482 | 482 | ||
483 | void EmailClient::allMailArrived(int count) | 483 | void EmailClient::allMailArrived(int count) |
484 | { | 484 | { |
485 | // not previewing means all mailtransfer has been done | 485 | // not previewing means all mailtransfer has been done |
486 | /*if (!previewingMail) {*/ | 486 | /*if (!previewingMail) {*/ |
487 | if ( (allAccounts) && ( (currentAccount = accountList.next()) !=0 ) ) { | 487 | if ( (allAccounts) && ( (currentAccount = accountList.next()) !=0 ) ) { |
488 | emit newCaption("Mailit - " + currentAccount->accountName); | 488 | emit newCaption("Mailit - " + currentAccount->accountName); |
489 | getNewMail(); | 489 | getNewMail(); |
490 | return; | 490 | return; |
491 | } else { | 491 | } else { |
492 | allAccounts = FALSE; | 492 | allAccounts = FALSE; |
493 | receiving = FALSE; | 493 | receiving = FALSE; |
494 | getMailButton->setEnabled(TRUE); | 494 | getMailButton->setEnabled(TRUE); |
495 | cancelButton->setEnabled(FALSE); | 495 | cancelButton->setEnabled(FALSE); |
496 | selectAccountMenu->setEnabled(TRUE); | 496 | selectAccountMenu->setEnabled(TRUE); |
497 | status1Label->setText("Idle"); | 497 | status1Label->setText("Idle"); |
498 | 498 | ||
499 | progressBar->reset(); | 499 | progressBar->reset(); |
500 | return; | 500 | return; |
501 | } | 501 | } |
502 | //} | 502 | //} |
503 | 503 | ||
504 | // all headers downloaded from server, start downloading remaining mails | 504 | // all headers downloaded from server, start downloading remaining mails |
505 | previewingMail = FALSE; | 505 | previewingMail = FALSE; |
506 | status1Label->setText(currentAccount->accountName); | 506 | status1Label->setText(currentAccount->accountName); |
507 | progressBar->reset(); | 507 | progressBar->reset(); |
508 | 508 | ||
509 | 509 | ||
510 | mailboxView->setCurrentTab(0); | 510 | mailboxView->setCurrentTab(0); |
511 | } | 511 | } |
512 | 512 | ||
513 | 513 | ||
514 | void EmailClient::moveMailFront(Email *mailPtr) | 514 | void EmailClient::moveMailFront(Email *mailPtr) |
515 | { | 515 | { |
516 | if ( (receiving) && (mailPtr->fromAccountId == currentAccount->id) ) { | 516 | if ( (receiving) && (mailPtr->fromAccountId == currentAccount->id) ) { |
517 | mailDownloadList.moveFront(mailPtr->serverId, mailPtr->size); | 517 | mailDownloadList.moveFront(mailPtr->serverId, mailPtr->size); |
518 | } | 518 | } |
519 | } | 519 | } |
520 | 520 | ||
521 | void EmailClient::smtpError(int code) | 521 | void EmailClient::smtpError(int code) |
522 | { | 522 | { |
523 | QString temp; | 523 | QString temp; |
524 | 524 | ||
525 | if (code == ErrUnknownResponse) | 525 | if (code == ErrUnknownResponse) |
526 | temp = "Unknown response from server"; | 526 | temp = "Unknown response from server"; |
527 | 527 | ||
528 | if (code == QSocket::ErrHostNotFound) | 528 | if (code == QSocket::ErrHostNotFound) |
529 | temp = "host not found"; | 529 | temp = "host not found"; |
530 | if (code == QSocket::ErrConnectionRefused) | 530 | if (code == QSocket::ErrConnectionRefused) |
531 | temp = "connection refused"; | 531 | temp = "connection refused"; |
532 | if (code == QSocket::ErrSocketRead) | 532 | if (code == QSocket::ErrSocketRead) |
533 | temp = "socket packet error"; | 533 | temp = "socket packet error"; |
534 | 534 | ||
535 | if (code != ErrCancel) { | 535 | if (code != ErrCancel) { |
536 | QMessageBox::warning(qApp->activeWindow(), "Sending error", temp, "OK\n"); | 536 | QMessageBox::warning(qApp->activeWindow(), "Sending error", temp, "OK\n"); |
537 | } else { | 537 | } else { |
538 | status2Label->setText("Aborted by user"); | 538 | status2Label->setText("Aborted by user"); |
539 | } | 539 | } |
540 | 540 | ||
541 | sending = FALSE; | 541 | sending = FALSE; |
542 | sendMailButton->setEnabled(TRUE); | 542 | sendMailButton->setEnabled(TRUE); |
543 | cancelButton->setEnabled(FALSE); | 543 | cancelButton->setEnabled(FALSE); |
544 | quedMessages.clear(); | 544 | quedMessages.clear(); |
545 | } | 545 | } |
546 | 546 | ||
547 | void EmailClient::popError(int code) | 547 | void EmailClient::popError(int code) |
548 | { | 548 | { |
549 | QString temp; | 549 | QString temp; |
550 | 550 | ||
551 | if (code == ErrUnknownResponse) | 551 | if (code == ErrUnknownResponse) |
552 | temp = "Unknown response from server"; | 552 | temp = "Unknown response from server"; |
553 | if (code == ErrLoginFailed) | 553 | if (code == ErrLoginFailed) |
554 | temp = "Login failed\nCheck user name and password"; | 554 | temp = "Login failed\nCheck user name and password"; |
555 | 555 | ||
556 | if (code == QSocket::ErrHostNotFound) | 556 | if (code == QSocket::ErrHostNotFound) |
557 | temp = "host not found"; | 557 | temp = "host not found"; |
558 | if (code == QSocket::ErrConnectionRefused) | 558 | if (code == QSocket::ErrConnectionRefused) |
559 | temp = "connection refused"; | 559 | temp = "connection refused"; |
560 | if (code == QSocket::ErrSocketRead) | 560 | if (code == QSocket::ErrSocketRead) |
561 | temp = "socket packet error"; | 561 | temp = "socket packet error"; |
562 | 562 | ||
563 | if (code != ErrCancel) { | 563 | if (code != ErrCancel) { |
564 | QMessageBox::warning(qApp->activeWindow(), "Receiving error", temp, "OK\n"); | 564 | QMessageBox::warning(qApp->activeWindow(), "Receiving error", temp, "OK\n"); |
565 | } else { | 565 | } else { |
566 | status2Label->setText("Aborted by user"); | 566 | status2Label->setText("Aborted by user"); |
567 | } | 567 | } |
568 | 568 | ||
569 | receiving = FALSE; | 569 | receiving = FALSE; |
570 | getMailButton->setEnabled(TRUE); | 570 | getMailButton->setEnabled(TRUE); |
571 | cancelButton->setEnabled(FALSE); | 571 | cancelButton->setEnabled(FALSE); |
572 | selectAccountMenu->setEnabled(TRUE); | 572 | selectAccountMenu->setEnabled(TRUE); |
573 | } | 573 | } |
574 | 574 | ||
575 | void EmailClient::inboxItemSelected() | 575 | void EmailClient::inboxItemSelected() |
576 | { | 576 | { |
577 | //killTimer(timerID); | 577 | //killTimer(timerID); |
578 | 578 | ||
579 | item = (EmailListItem*) inboxView->selectedItem(); | 579 | item = (EmailListItem*) inboxView->selectedItem(); |
580 | if (item != NULL) { | 580 | if (item != NULL) { |
581 | emit viewEmail(inboxView, item->getMail()); | 581 | emit viewEmail(inboxView, item->getMail()); |
582 | } | 582 | } |
583 | } | 583 | } |
584 | 584 | ||
585 | void EmailClient::outboxItemSelected() | 585 | void EmailClient::outboxItemSelected() |
586 | { | 586 | { |
587 | //killTimer(timerID); | 587 | //killTimer(timerID); |
588 | 588 | ||
589 | item = (EmailListItem*) outboxView->selectedItem(); | 589 | item = (EmailListItem*) outboxView->selectedItem(); |
590 | if (item != NULL) { | 590 | if (item != NULL) { |
591 | emit viewEmail(outboxView, item->getMail()); | 591 | emit viewEmail(outboxView, item->getMail()); |
592 | } | 592 | } |
593 | 593 | ||
594 | } | 594 | } |
595 | 595 | ||
596 | void EmailClient::readMail() | 596 | void EmailClient::readMail() |
597 | { | 597 | { |
598 | Email mail; | 598 | Email mail; |
599 | int start, stop; | 599 | int start, stop; |
600 | QString s, del; | 600 | QString s, del; |
601 | 601 | ||
602 | QFile f(getPath(FALSE) + "inbox.txt"); | 602 | QFile f(getPath(FALSE) + "inbox.txt"); |
603 | 603 | ||
604 | if ( f.open(IO_ReadOnly) ) { // file opened successfully | 604 | if ( f.open(IO_ReadOnly) ) { // file opened successfully |
605 | QTextStream t( &f ); // use a text stream | 605 | QTextStream t( &f ); // use a text stream |
606 | s = t.read(); | 606 | s = t.read(); |
607 | f.close(); | 607 | f.close(); |
608 | 608 | ||
609 | start = 0; | 609 | start = 0; |
610 | del = "\n.\n"; | 610 | del = "\n.\n"; |
611 | while ((uint) start < s.length()) { | 611 | while ((uint) start < s.length()) { |
612 | stop = s.find(del, start); | 612 | stop = s.find(del, start); |
613 | if (stop == -1) | 613 | if (stop == -1) |
614 | stop = s.length() - del.length(); | 614 | stop = s.length() - del.length(); |
615 | 615 | ||
616 | mail.rawMail = s.mid(start, stop + del.length() - start ); | 616 | mail.rawMail = s.mid(start, stop + del.length() - start ); |
617 | start = stop + del.length(); | 617 | start = stop + del.length(); |
618 | mailArrived(mail, TRUE); | 618 | mailArrived(mail, TRUE); |
619 | } | 619 | } |
620 | } | 620 | } |
621 | 621 | ||
622 | QFile fo(getPath(FALSE) + "outbox.txt"); | 622 | QFile fo(getPath(FALSE) + "outbox.txt"); |
623 | if ( fo.open(IO_ReadOnly) ) { // file opened successfully | 623 | if ( fo.open(IO_ReadOnly) ) { // file opened successfully |
624 | QTextStream t( &fo ); // use a text stream | 624 | QTextStream t( &fo ); // use a text stream |
625 | s = t.read(); | 625 | s = t.read(); |
626 | fo.close(); | 626 | fo.close(); |
627 | 627 | ||
628 | start = 0; | 628 | start = 0; |
629 | del = "\n.\n"; | 629 | del = "\n.\n"; |
630 | while ((uint) start < s.length()) { | 630 | while ((uint) start < s.length()) { |
631 | stop = s.find(del, start); | 631 | stop = s.find(del, start); |
632 | if (stop == -1) | 632 | if (stop == -1) |
633 | stop = s.length() - del.length(); | 633 | stop = s.length() - del.length(); |
634 | 634 | ||
635 | mail.rawMail = s.mid(start, stop + del.length() - start ); | 635 | mail.rawMail = s.mid(start, stop + del.length() - start ); |
636 | start = stop + del.length(); | 636 | start = stop + del.length(); |
637 | emailHandler->parse(mail.rawMail, lineShift, &mail); | 637 | emailHandler->parse(mail.rawMail, lineShift, &mail); |
638 | mail.sent = false; | 638 | mail.sent = false; |
639 | mail.received = false; | 639 | mail.received = false; |
640 | enqueMail(mail); | 640 | enqueMail(mail); |
641 | 641 | ||
642 | } | 642 | } |
643 | } | 643 | } |
644 | } | 644 | } |
645 | 645 | ||
646 | void EmailClient::saveMail(const QString &fileName, QListView *view) | 646 | void EmailClient::saveMail(const QString &fileName, QListView *view) |
647 | { | 647 | { |
648 | QFile f(fileName); | 648 | QFile f(fileName); |
649 | Email *mail; | 649 | Email *mail; |
650 | 650 | ||
651 | if (! f.open(IO_WriteOnly) ) { | 651 | if (! f.open(IO_WriteOnly) ) { |
652 | qWarning("could not open file"); | 652 | qWarning("could not open file"); |
653 | return; | 653 | return; |
654 | } | 654 | } |
655 | item = (EmailListItem *) view->firstChild(); | 655 | item = (EmailListItem *) view->firstChild(); |
656 | QTextStream t(&f); | 656 | QTextStream t(&f); |
657 | while (item != NULL) { | 657 | while (item != NULL) { |
658 | mail = item->getMail(); | 658 | mail = item->getMail(); |
659 | t << mail->rawMail; | 659 | t << mail->rawMail; |
660 | 660 | ||
661 | mailconf->setGroup(mail->id); | 661 | mailconf->setGroup(mail->id); |
662 | mailconf->writeEntry("mailread", mail->read); | 662 | mailconf->writeEntry("mailread", mail->read); |
663 | 663 | ||
664 | item = (EmailListItem *) item->nextSibling(); | 664 | item = (EmailListItem *) item->nextSibling(); |
665 | } | 665 | } |
666 | f.close(); | 666 | f.close(); |
667 | } | 667 | } |
diff --git a/noncore/unsupported/mailit/emailhandler.cpp b/noncore/unsupported/mailit/emailhandler.cpp index 59ccd90..39f693d 100644 --- a/noncore/unsupported/mailit/emailhandler.cpp +++ b/noncore/unsupported/mailit/emailhandler.cpp | |||
@@ -1,532 +1,536 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2001 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2001 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qt Palmtop Environment. | 4 | ** This file is part of Qt Palmtop Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #include <qfileinfo.h> | 20 | #include <qfileinfo.h> |
21 | #include <stdlib.h> | 21 | #include <stdlib.h> |
22 | #include <qapplication.h> | 22 | #include <qapplication.h> |
23 | #include <qmessagebox.h> | 23 | #include <qmessagebox.h> |
24 | #include <qcstring.h> | 24 | #include <qcstring.h> |
25 | #include "emailhandler.h" | 25 | #include "emailhandler.h" |
26 | #include <qpe/applnk.h> | 26 | #include <qpe/applnk.h> |
27 | #include <qpe/filemanager.h> | 27 | #include <qpe/filemanager.h> |
28 | 28 | ||
29 | QCollection::Item EnclosureList::newItem(QCollection::Item d) | 29 | QCollection::Item EnclosureList::newItem(QCollection::Item d) |
30 | { | 30 | { |
31 | return dupl( (Enclosure *) d); | 31 | return dupl( (Enclosure *) d); |
32 | } | 32 | } |
33 | 33 | ||
34 | Enclosure* EnclosureList::dupl(Enclosure *in) | 34 | Enclosure* EnclosureList::dupl(Enclosure *in) |
35 | { | 35 | { |
36 | ac = new Enclosure(*in); | 36 | ac = new Enclosure(*in); |
37 | return ac; | 37 | return ac; |
38 | } | 38 | } |
39 | 39 | ||
40 | EmailHandler::EmailHandler() | 40 | EmailHandler::EmailHandler() |
41 | { | 41 | { |
42 | qDebug("EMailHandler::EmailHandler"); | 42 | qDebug("EMailHandler::EmailHandler"); |
43 | 43 | ||
44 | smtpClient = new SmtpClient(); | 44 | smtpClient = new SmtpClient(); |
45 | popClient = new PopClient(); | 45 | popClient = new PopClient(); |
46 | 46 | ||
47 | connect(smtpClient, SIGNAL(errorOccurred(int)), this, | 47 | connect(smtpClient, SIGNAL(errorOccurred(int)), this, |
48 | SIGNAL(smtpError(int)) ); | 48 | SIGNAL(smtpError(int)) ); |
49 | connect(smtpClient, SIGNAL(mailSent()), this, SIGNAL(mailSent()) ); | 49 | connect(smtpClient, SIGNAL(mailSent()), this, SIGNAL(mailSent()) ); |
50 | connect(smtpClient, SIGNAL(updateStatus(const QString &)), this, | 50 | connect(smtpClient, SIGNAL(updateStatus(const QString &)), this, |
51 | SIGNAL(updateSmtpStatus(const QString &)) ); | 51 | SIGNAL(updateSmtpStatus(const QString &)) ); |
52 | 52 | ||
53 | connect(popClient, SIGNAL(errorOccurred(int)), this, | 53 | connect(popClient, SIGNAL(errorOccurred(int)), this, |
54 | SIGNAL(popError(int)) ); | 54 | SIGNAL(popError(int)) ); |
55 | connect(popClient, SIGNAL(newMessage(const QString &, int, uint, bool)), | 55 | connect(popClient, SIGNAL(newMessage(const QString &, int, uint, bool)), |
56 | this, SLOT(messageArrived(const QString &, int, uint, bool)) ); | 56 | this, SLOT(messageArrived(const QString &, int, uint, bool)) ); |
57 | connect(popClient, SIGNAL(updateStatus(const QString &)), this, | 57 | connect(popClient, SIGNAL(updateStatus(const QString &)), this, |
58 | SIGNAL(updatePopStatus(const QString &)) ); | 58 | SIGNAL(updatePopStatus(const QString &)) ); |
59 | connect(popClient, SIGNAL(mailTransfered(int)), this, | 59 | connect(popClient, SIGNAL(mailTransfered(int)), this, |
60 | SIGNAL(mailTransfered(int)) ); | 60 | SIGNAL(mailTransfered(int)) ); |
61 | 61 | ||
62 | 62 | ||
63 | //relaying size information | 63 | //relaying size information |
64 | connect(popClient, SIGNAL(currentMailSize(int)), | 64 | connect(popClient, SIGNAL(currentMailSize(int)), |
65 | this, SIGNAL(currentMailSize(int)) ); | 65 | this, SIGNAL(currentMailSize(int)) ); |
66 | connect(popClient, SIGNAL(downloadedSize(int)), | 66 | connect(popClient, SIGNAL(downloadedSize(int)), |
67 | this, SIGNAL(downloadedSize(int)) ); | 67 | this, SIGNAL(downloadedSize(int)) ); |
68 | } | 68 | } |
69 | 69 | ||
70 | void EmailHandler::sendMail(QList<Email> *mailList) | 70 | void EmailHandler::sendMail(QList<Email> *mailList) |
71 | { | 71 | { |
72 | Email *currentMail; | 72 | Email *currentMail; |
73 | QString temp; | 73 | QString temp; |
74 | QString userName = mailAccount.name; | 74 | QString userName = mailAccount.name; |
75 | userName += " <" + mailAccount.emailAddress + ">"; | 75 | userName += " <" + mailAccount.emailAddress + ">"; |
76 | 76 | ||
77 | for (currentMail = mailList->first(); currentMail != 0; | 77 | for (currentMail = mailList->first(); currentMail != 0; |
78 | currentMail = mailList->next()) { | 78 | currentMail = mailList->next()) { |
79 | 79 | ||
80 | if (encodeMime(currentMail) == 0) { | 80 | if (encodeMime(currentMail) == 0) { |
81 | smtpClient->addMail(userName, currentMail->subject, | 81 | smtpClient->addMail(userName, currentMail->subject, |
82 | currentMail->recipients, currentMail->rawMail); | 82 | currentMail->recipients, currentMail->rawMail); |
83 | } else { //error | 83 | } else { //error |
84 | temp = tr("Could not locate all files in \nmail with subject: ") + | 84 | temp = tr("Could not locate all files in \nmail with subject: ") + |
85 | currentMail->subject; | 85 | currentMail->subject; |
86 | temp += tr("\nMail has NOT been sent"); | 86 | temp += tr("\nMail has NOT been sent"); |
87 | QMessageBox::warning(qApp->activeWindow(), tr("Attachment error"), temp, tr("OK\n")); | 87 | QMessageBox::warning(qApp->activeWindow(), tr("Attachment error"), temp, tr("OK\n")); |
88 | 88 | ||
89 | } | 89 | } |
90 | } | 90 | } |
91 | smtpClient->newConnection(mailAccount.smtpServer, 25); | 91 | smtpClient->newConnection(mailAccount.smtpServer, 25); |
92 | } | 92 | } |
93 | 93 | ||
94 | void EmailHandler::setAccount(MailAccount account) | 94 | void EmailHandler::setAccount(MailAccount account) |
95 | { | 95 | { |
96 | mailAccount = account; | 96 | mailAccount = account; |
97 | } | 97 | } |
98 | 98 | ||
99 | void EmailHandler::getMail() | 99 | void EmailHandler::getMail() |
100 | { | 100 | { |
101 | popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); | 101 | popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); |
102 | if (mailAccount.synchronize) { | 102 | if (mailAccount.synchronize) { |
103 | popClient->setSynchronize(mailAccount.lastServerMailCount); | 103 | popClient->setSynchronize(mailAccount.lastServerMailCount); |
104 | } else { | 104 | } else { |
105 | popClient->removeSynchronize(); | 105 | popClient->removeSynchronize(); |
106 | } | 106 | } |
107 | 107 | ||
108 | headers = FALSE; | 108 | headers = FALSE; |
109 | //popClient->headersOnly(headers, 0); | 109 | //popClient->headersOnly(headers, 0); |
110 | popClient->newConnection(mailAccount.popServer, 110); | 110 | popClient->newConnection(mailAccount.popServer, 110); |
111 | } | 111 | } |
112 | 112 | ||
113 | void EmailHandler::getMailHeaders() | 113 | void EmailHandler::getMailHeaders() |
114 | { | 114 | { |
115 | popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); | 115 | popClient->setAccount(mailAccount.popUserName, mailAccount.popPasswd); |
116 | mailAccount.synchronize ? popClient->setSynchronize(mailAccount.lastServerMailCount): popClient->removeSynchronize(); | 116 | mailAccount.synchronize ? popClient->setSynchronize(mailAccount.lastServerMailCount): popClient->removeSynchronize(); |
117 | 117 | ||
118 | headers = TRUE; | 118 | headers = TRUE; |
119 | popClient->headersOnly(headers, mailAccount.syncLimit); //less than requested syncLimit, download all | 119 | popClient->headersOnly(headers, mailAccount.syncLimit); //less than requested syncLimit, download all |
120 | qDebug("Initiating connection"); | 120 | qDebug("Initiating connection"); |
121 | popClient->newConnection(mailAccount.popServer, 110); | 121 | popClient->newConnection(mailAccount.popServer, 110); |
122 | } | 122 | } |
123 | 123 | ||
124 | void EmailHandler::getMailByList(MailList *mailList) | 124 | void EmailHandler::getMailByList(MailList *mailList) |
125 | { | 125 | { |
126 | if (mailList->count() == 0) { //should not occur though | 126 | if (mailList->count() == 0) { //should not occur though |
127 | emit mailTransfered(0); | 127 | emit mailTransfered(0); |
128 | return; | 128 | return; |
129 | } | 129 | } |
130 | 130 | ||
131 | headers = FALSE; | 131 | headers = FALSE; |
132 | popClient->headersOnly(FALSE, 0); | 132 | popClient->headersOnly(FALSE, 0); |
133 | 133 | ||
134 | popClient->setAccount(mailAccount.popUserName,mailAccount.popPasswd); | 134 | popClient->setAccount(mailAccount.popUserName,mailAccount.popPasswd); |
135 | popClient->setSelectedMails(mailList); | 135 | popClient->setSelectedMails(mailList); |
136 | popClient->newConnection(mailAccount.popServer, 110); | 136 | popClient->newConnection(mailAccount.popServer, 110); |
137 | } | 137 | } |
138 | 138 | ||
139 | void EmailHandler::messageArrived(const QString &message, int id, uint size, bool complete) | 139 | void EmailHandler::messageArrived(const QString &message, int id, uint size, bool complete) |
140 | { | 140 | { |
141 | Email mail; | 141 | Email mail; |
142 | 142 | ||
143 | mail.rawMail = message; | 143 | mail.rawMail = message; |
144 | mail.serverId = id; | 144 | mail.serverId = id; |
145 | mail.size = size; | 145 | mail.size = size; |
146 | mail.downloaded = complete; | 146 | mail.downloaded = complete; |
147 | 147 | ||
148 | emit mailArrived(mail, FALSE); | 148 | emit mailArrived(mail, FALSE); |
149 | } | 149 | } |
150 | 150 | ||
151 | bool EmailHandler::parse(const QString &in, const QString &lineShift, Email *mail) | 151 | bool EmailHandler::parse(const QString &in, const QString &lineShift, Email *mail) |
152 | { | 152 | { |
153 | QString temp, boundary; | 153 | QString temp, boundary; |
154 | int pos; | 154 | int pos; |
155 | QString delimiter, header, body, mimeHeader, mimeBody; | 155 | QString delimiter, header, body, mimeHeader, mimeBody; |
156 | QString content, contentType, contentAttribute, id, encoding; | 156 | QString content, contentType, contentAttribute, id, encoding; |
157 | QString fileName, storedName; | 157 | QString fileName, storedName; |
158 | int enclosureId = 0; | 158 | int enclosureId = 0; |
159 | 159 | ||
160 | mail->rawMail = in; | 160 | mail->rawMail = in; |
161 | mail->received = TRUE; | 161 | mail->received = TRUE; |
162 | mail->files.setAutoDelete(TRUE); | 162 | mail->files.setAutoDelete(TRUE); |
163 | 163 | ||
164 | temp = lineShift + "." + lineShift; | 164 | temp = lineShift + "." + lineShift; |
165 | 165 | ||
166 | if (in.right(temp.length()) != temp) { | 166 | if (in.right(temp.length()) != temp) { |
167 | mail->rawMail += temp; | 167 | mail->rawMail += temp; |
168 | } | 168 | } |
169 | 169 | ||
170 | 170 | ||
171 | delimiter = lineShift + lineShift; // "\n\n" or "\r\n\r\n" | 171 | delimiter = lineShift + lineShift; // "\n\n" or "\r\n\r\n" |
172 | pos = in.find(delimiter, 0, FALSE); | 172 | pos = in.find(delimiter, 0, FALSE); |
173 | header = in.left(pos); | 173 | header = in.left(pos); |
174 | body = in.right(in.length() - pos - delimiter.length()); | 174 | body = in.right(in.length() - pos - delimiter.length()); |
175 | if ((body.at(body.length()-2) == '.') && (body.at(body.length()-3) == '\n')) | 175 | if ((body.at(body.length()-2) == '.') && (body.at(body.length()-3) == '\n')) |
176 | body.truncate(body.length()-2); | 176 | body.truncate(body.length()-2); |
177 | 177 | ||
178 | TextParser p(header, lineShift); | 178 | // TextParser p(header, lineShift); |
179 | 179 | TextParser * lp = new TextParser(header, lineShift); | |
180 | #define p (*lp) | ||
181 | |||
180 | if ((pos = p.find("FROM",':', 0, TRUE)) != -1) { | 182 | if ((pos = p.find("FROM",':', 0, TRUE)) != -1) { |
181 | pos++; | 183 | pos++; |
182 | if (p.separatorAt(pos) == ' ') { | 184 | if (p.separatorAt(pos) == ' ') { |
183 | mail->from = p.getString(&pos, '<', false); | 185 | mail->from = p.getString(&pos, '<', false); |
184 | mail->from = mail->from.stripWhiteSpace(); | 186 | mail->from = mail->from.stripWhiteSpace(); |
185 | if ( (mail->from.length() > 2) && (mail->from[0] == '"') ) { | 187 | if ( (mail->from.length() > 2) && (mail->from[0] == '"') ) { |
186 | mail->from = mail->from.left(mail->from.length() - 1); | 188 | mail->from = mail->from.left(mail->from.length() - 1); |
187 | mail->from = mail->from.right(mail->from.length() - 1); | 189 | mail->from = mail->from.right(mail->from.length() - 1); |
188 | } | 190 | } |
189 | pos++; | 191 | pos++; |
190 | mail->fromMail = p.getString(&pos, '>', false); | 192 | mail->fromMail = p.getString(&pos, '>', false); |
191 | } else { | 193 | } else { |
192 | if (p.separatorAt(pos) == '<') //No name.. nasty | 194 | if (p.separatorAt(pos) == '<') //No name.. nasty |
193 | pos++; | 195 | pos++; |
194 | //pos++; | 196 | //pos++; |
195 | mail->fromMail = p.getString(&pos, 'z', TRUE); | 197 | mail->fromMail = p.getString(&pos, 'z', TRUE); |
196 | if (mail->fromMail.at(mail->fromMail.length()-1) == '>') | 198 | if (mail->fromMail.at(mail->fromMail.length()-1) == '>') |
197 | mail->fromMail.truncate(mail->fromMail.length() - 1); | 199 | mail->fromMail.truncate(mail->fromMail.length() - 1); |
198 | mail->from=mail->fromMail; | 200 | mail->from=mail->fromMail; |
199 | } | 201 | } |
200 | } | 202 | } |
201 | 203 | ||
202 | pos=0; | 204 | pos=0; |
203 | 205 | ||
204 | //Search for To: after the FROM: attribute to prevent hitting the Delivered-To: | 206 | //Search for To: after the FROM: attribute to prevent hitting the Delivered-To: |
205 | while((pos = p.find("TO",':', pos+1, TRUE))!=-1) | 207 | while((pos = p.find("TO",':', pos+1, TRUE))!=-1) |
206 | { | 208 | { |
207 | QString rec; | 209 | QString rec; |
208 | 210 | ||
209 | if (p.separatorAt(pos-1)!='-') //The - separator means that this is a Delivered-To: or Reply-To: | 211 | if (p.separatorAt(pos-1)!='-') //The - separator means that this is a Delivered-To: or Reply-To: |
210 | { | 212 | { |
211 | pos++; | 213 | pos++; |
212 | mail->recipients.append(p.getString(&pos, '\r', TRUE)); | 214 | mail->recipients.append(p.getString(&pos, '\r', TRUE)); |
213 | } | 215 | } |
214 | } | 216 | } |
215 | // | 217 | // |
216 | //if (pos==-1) mail->recipients.append (tr("undisclosed recipients") ); | 218 | //if (pos==-1) mail->recipients.append (tr("undisclosed recipients") ); |
217 | 219 | ||
218 | if ((pos = p.find("CC",':', 0, TRUE)) != -1) | 220 | if ((pos = p.find("CC",':', 0, TRUE)) != -1) |
219 | { | 221 | { |
220 | pos++; | 222 | pos++; |
221 | mail->carbonCopies.append (p.getString(&pos, 'z', TRUE) ); | 223 | mail->carbonCopies.append (p.getString(&pos, 'z', TRUE) ); |
222 | } | 224 | } |
223 | 225 | ||
224 | if ((pos = p.find("SUBJECT",':', 0, TRUE)) != -1) { | 226 | if ((pos = p.find("SUBJECT",':', 0, TRUE)) != -1) { |
225 | pos++; | 227 | pos++; |
226 | mail->subject = p.getString(&pos, 'z', TRUE); | 228 | mail->subject = p.getString(&pos, 'z', TRUE); |
227 | } | 229 | } |
228 | 230 | ||
229 | if ((pos = p.find("DATE",':', 0, TRUE)) != -1) { | 231 | if ((pos = p.find("DATE",':', 0, TRUE)) != -1) { |
230 | pos++; | 232 | pos++; |
231 | mail->date = p.getString(&pos, 'z', TRUE); | 233 | mail->date = p.getString(&pos, 'z', TRUE); |
232 | } | 234 | } |
233 | 235 | ||
234 | 236 | ||
235 | 237 | ||
236 | if ((pos = p.find("MESSAGE",'-', 0, TRUE)) != -1) { | 238 | if ((pos = p.find("MESSAGE",'-', 0, TRUE)) != -1) { |
237 | pos++; | 239 | pos++; |
238 | if ( (p.wordAt(pos).upper() == "ID") && | 240 | if ( (p.wordAt(pos).upper() == "ID") && |
239 | (p.separatorAt(pos) == ':') ) { | 241 | (p.separatorAt(pos) == ':') ) { |
240 | 242 | ||
241 | id = p.getString(&pos, 'z', TRUE); | 243 | id = p.getString(&pos, 'z', TRUE); |
242 | mail->id = id; | 244 | mail->id = id; |
243 | } | 245 | } |
244 | } | 246 | } |
245 | 247 | ||
246 | pos = 0; | 248 | pos = 0; |
247 | while ( ((pos = p.find("MIME",'-', pos, TRUE)) != -1) ) { | 249 | while ( ((pos = p.find("MIME",'-', pos, TRUE)) != -1) ) { |
248 | pos++; | 250 | pos++; |
249 | if ( (p.wordAt(pos).upper() == "VERSION") && | 251 | if ( (p.wordAt(pos).upper() == "VERSION") && |
250 | (p.separatorAt(pos) == ':') ) { | 252 | (p.separatorAt(pos) == ':') ) { |
251 | pos++; | 253 | pos++; |
252 | if (p.getString(&pos, 'z', true) == "1.0") { | 254 | if (p.getString(&pos, 'z', true) == "1.0") { |
253 | mail->mimeType = 1; | 255 | mail->mimeType = 1; |
254 | } | 256 | } |
255 | } | 257 | } |
256 | } | 258 | } |
257 | 259 | ||
258 | if (mail->mimeType == 1) { | 260 | if (mail->mimeType == 1) { |
259 | boundary = ""; | 261 | boundary = ""; |
260 | if ((pos = p.find("BOUNDARY", '=', 0, TRUE)) != -1) { | 262 | if ((pos = p.find("BOUNDARY", '=', 0, TRUE)) != -1) { |
261 | pos++; | 263 | pos++; |
262 | boundary = p.getString(&pos, 'z', true); | 264 | boundary = p.getString(&pos, 'z', true); |
263 | if (boundary[0] == '"') { | 265 | if (boundary[0] == '"') { |
264 | boundary = boundary.left(boundary.length() - 1); //strip " | 266 | boundary = boundary.left(boundary.length() - 1); //strip " |
265 | boundary = boundary.right(boundary.length() - 1); //strip " | 267 | boundary = boundary.right(boundary.length() - 1); //strip " |
266 | } | 268 | } |
267 | boundary = "--" + boundary; //create boundary field | 269 | boundary = "--" + boundary; //create boundary field |
268 | } | 270 | } |
269 | 271 | ||
270 | if (boundary == "") { //fooled by Mime-Version | 272 | if (boundary == "") { //fooled by Mime-Version |
271 | mail->body = body; | 273 | mail->body = body; |
272 | mail->bodyPlain = body; | 274 | mail->bodyPlain = body; |
275 | delete lp; | ||
273 | return mail; | 276 | return mail; |
274 | } | 277 | } |
275 | 278 | ||
276 | while (body.length() > 0) { | 279 | while (body.length() > 0) { |
277 | pos = body.find(boundary, 0, FALSE); | 280 | pos = body.find(boundary, 0, FALSE); |
278 | pos = body.find(delimiter, pos, FALSE); | 281 | pos = body.find(delimiter, pos, FALSE); |
279 | mimeHeader = body.left(pos); | 282 | mimeHeader = body.left(pos); |
280 | mimeBody = body.right(body.length() - pos - delimiter.length()); | 283 | mimeBody = body.right(body.length() - pos - delimiter.length()); |
281 | TextParser bp(mimeHeader, lineShift); | 284 | TextParser bp(mimeHeader, lineShift); |
282 | 285 | ||
283 | contentType = ""; | 286 | contentType = ""; |
284 | contentAttribute = ""; | 287 | contentAttribute = ""; |
285 | fileName = ""; | 288 | fileName = ""; |
286 | if ((pos = bp.find("CONTENT",'-', 0, TRUE)) != -1) { | 289 | if ((pos = bp.find("CONTENT",'-', 0, TRUE)) != -1) { |
287 | pos++; | 290 | pos++; |
288 | if ( (bp.wordAt(pos).upper() == "TYPE") && | 291 | if ( (bp.wordAt(pos).upper() == "TYPE") && |
289 | (bp.separatorAt(pos) == ':') ) { | 292 | (bp.separatorAt(pos) == ':') ) { |
290 | contentType = bp.nextWord().upper(); | 293 | contentType = bp.nextWord().upper(); |
291 | if (bp.nextSeparator() == '/') | 294 | if (bp.nextSeparator() == '/') |
292 | contentAttribute = bp.nextWord().upper(); | 295 | contentAttribute = bp.nextWord().upper(); |
293 | content = contentType + "/" + contentAttribute; | 296 | content = contentType + "/" + contentAttribute; |
294 | } | 297 | } |
295 | if ((pos = bp.find("ENCODING",':', 0, TRUE)) != -1) { | 298 | if ((pos = bp.find("ENCODING",':', 0, TRUE)) != -1) { |
296 | pos++; | 299 | pos++; |
297 | encoding = bp.getString(&pos, 'z', TRUE); | 300 | encoding = bp.getString(&pos, 'z', TRUE); |
298 | } | 301 | } |
299 | 302 | ||
300 | if ( (pos = bp.find("FILENAME",'=', 0, TRUE)) != -1) { | 303 | if ( (pos = bp.find("FILENAME",'=', 0, TRUE)) != -1) { |
301 | pos++; | 304 | pos++; |
302 | fileName = bp.getString(&pos, 'z', TRUE); | 305 | fileName = bp.getString(&pos, 'z', TRUE); |
303 | fileName = fileName.right(fileName.length() - 1); | 306 | fileName = fileName.right(fileName.length() - 1); |
304 | fileName = fileName.left(fileName.length() - 1); | 307 | fileName = fileName.left(fileName.length() - 1); |
305 | } | 308 | } |
306 | 309 | ||
307 | } | 310 | } |
308 | pos = mimeBody.find(boundary, 0, FALSE); | 311 | pos = mimeBody.find(boundary, 0, FALSE); |
309 | if (pos == -1) //should not occur, malformed mail | 312 | if (pos == -1) //should not occur, malformed mail |
310 | pos = mimeBody.length(); | 313 | pos = mimeBody.length(); |
311 | body = mimeBody.right(mimeBody.length() - pos); | 314 | body = mimeBody.right(mimeBody.length() - pos); |
312 | mimeBody = mimeBody.left(pos); | 315 | mimeBody = mimeBody.left(pos); |
313 | 316 | ||
314 | if (fileName != "") { //attatchments of some type, audio, image etc. | 317 | if (fileName != "") { //attatchments of some type, audio, image etc. |
315 | 318 | ||
316 | Enclosure e; | 319 | Enclosure e; |
317 | e.id = enclosureId; | 320 | e.id = enclosureId; |
318 | e.originalName = fileName; | 321 | e.originalName = fileName; |
319 | e.contentType = contentType; | 322 | e.contentType = contentType; |
320 | e.contentAttribute = contentAttribute; | 323 | e.contentAttribute = contentAttribute; |
321 | e.encoding = encoding; | 324 | e.encoding = encoding; |
322 | e.body = mimeBody; | 325 | e.body = mimeBody; |
323 | e.saved = FALSE; | 326 | e.saved = FALSE; |
324 | mail->addEnclosure(&e); | 327 | mail->addEnclosure(&e); |
325 | enclosureId++; | 328 | enclosureId++; |
326 | 329 | ||
327 | } else if (contentType == "TEXT") { | 330 | } else if (contentType == "TEXT") { |
328 | if (contentAttribute == "PLAIN") { | 331 | if (contentAttribute == "PLAIN") { |
329 | mail->body = mimeBody; | 332 | mail->body = mimeBody; |
330 | mail->bodyPlain = mimeBody; | 333 | mail->bodyPlain = mimeBody; |
331 | } | 334 | } |
332 | if (contentAttribute == "HTML") { | 335 | if (contentAttribute == "HTML") { |
333 | mail->body = mimeBody; | 336 | mail->body = mimeBody; |
334 | } | 337 | } |
335 | } | 338 | } |
336 | } | 339 | } |
337 | } else { | 340 | } else { |
338 | mail->bodyPlain = body; | 341 | mail->bodyPlain = body; |
339 | mail->body = body; | 342 | mail->body = body; |
340 | } | 343 | } |
344 | delete lp; | ||
341 | return TRUE; | 345 | return TRUE; |
342 | } | 346 | } |
343 | 347 | ||
344 | bool EmailHandler::getEnclosure(Enclosure *ePtr) | 348 | bool EmailHandler::getEnclosure(Enclosure *ePtr) |
345 | { | 349 | { |
346 | QFile f(ePtr->path + ePtr->name); | 350 | QFile f(ePtr->path + ePtr->name); |
347 | char src[4]; | 351 | char src[4]; |
348 | char *destPtr; | 352 | char *destPtr; |
349 | QByteArray buffer; | 353 | QByteArray buffer; |
350 | uint bufCount, pos, decodedCount, size, x; | 354 | uint bufCount, pos, decodedCount, size, x; |
351 | 355 | ||
352 | if (! f.open(IO_WriteOnly) ) { | 356 | if (! f.open(IO_WriteOnly) ) { |
353 | qWarning("could not save: " + ePtr->path + ePtr->name); | 357 | qWarning("could not save: " + ePtr->path + ePtr->name); |
354 | return FALSE; | 358 | return FALSE; |
355 | } | 359 | } |
356 | 360 | ||
357 | if (ePtr->encoding.upper() == "BASE64") { | 361 | if (ePtr->encoding.upper() == "BASE64") { |
358 | size = (ePtr->body.length() * 3 / 4); //approximate size (always above) | 362 | size = (ePtr->body.length() * 3 / 4); //approximate size (always above) |
359 | buffer.resize(size); | 363 | buffer.resize(size); |
360 | bufCount = 0; | 364 | bufCount = 0; |
361 | pos = 0; | 365 | pos = 0; |
362 | destPtr = buffer.data(); | 366 | destPtr = buffer.data(); |
363 | 367 | ||
364 | while (pos < ePtr->body.length()) { | 368 | while (pos < ePtr->body.length()) { |
365 | decodedCount = 4; | 369 | decodedCount = 4; |
366 | x = 0; | 370 | x = 0; |
367 | while ( (x < 4) && (pos < ePtr->body.length()) ) { | 371 | while ( (x < 4) && (pos < ePtr->body.length()) ) { |
368 | src[x] = ePtr->body[pos].latin1(); | 372 | src[x] = ePtr->body[pos].latin1(); |
369 | pos++; | 373 | pos++; |
370 | if (src[x] == '\r' || src[x] == '\n' || src[x] == ' ') | 374 | if (src[x] == '\r' || src[x] == '\n' || src[x] == ' ') |
371 | x--; | 375 | x--; |
372 | x++; | 376 | x++; |
373 | } | 377 | } |
374 | if (x > 1) { | 378 | if (x > 1) { |
375 | decodedCount = parse64base(src, destPtr); | 379 | decodedCount = parse64base(src, destPtr); |
376 | destPtr += decodedCount; | 380 | destPtr += decodedCount; |
377 | bufCount += decodedCount; | 381 | bufCount += decodedCount; |
378 | } | 382 | } |
379 | } | 383 | } |
380 | 384 | ||
381 | buffer.resize(bufCount); //set correct length of file | 385 | buffer.resize(bufCount); //set correct length of file |
382 | f.writeBlock(buffer); | 386 | f.writeBlock(buffer); |
383 | } else { | 387 | } else { |
384 | QTextStream t(&f); | 388 | QTextStream t(&f); |
385 | t << ePtr->body; | 389 | t << ePtr->body; |
386 | } | 390 | } |
387 | return TRUE; | 391 | return TRUE; |
388 | } | 392 | } |
389 | 393 | ||
390 | int EmailHandler::parse64base(char *src, char *bufOut) { | 394 | int EmailHandler::parse64base(char *src, char *bufOut) { |
391 | 395 | ||
392 | char c, z; | 396 | char c, z; |
393 | char li[4]; | 397 | char li[4]; |
394 | int processed; | 398 | int processed; |
395 | 399 | ||
396 | //conversion table withouth table... | 400 | //conversion table withouth table... |
397 | for (int x = 0; x < 4; x++) { | 401 | for (int x = 0; x < 4; x++) { |
398 | c = src[x]; | 402 | c = src[x]; |
399 | 403 | ||
400 | if ( (int) c >= 'A' && (int) c <= 'Z') | 404 | if ( (int) c >= 'A' && (int) c <= 'Z') |
401 | li[x] = (int) c - (int) 'A'; | 405 | li[x] = (int) c - (int) 'A'; |
402 | if ( (int) c >= 'a' && (int) c <= 'z') | 406 | if ( (int) c >= 'a' && (int) c <= 'z') |
403 | li[x] = (int) c - (int) 'a' + 26; | 407 | li[x] = (int) c - (int) 'a' + 26; |
404 | if ( (int) c >= '0' && (int) c <= '9') | 408 | if ( (int) c >= '0' && (int) c <= '9') |
405 | li[x] = (int) c - (int) '0' + 52; | 409 | li[x] = (int) c - (int) '0' + 52; |
406 | if (c == '+') | 410 | if (c == '+') |
407 | li[x] = 62; | 411 | li[x] = 62; |
408 | if (c == '/') | 412 | if (c == '/') |
409 | li[x] = 63; | 413 | li[x] = 63; |
410 | } | 414 | } |
411 | 415 | ||
412 | processed = 1; | 416 | processed = 1; |
413 | bufOut[0] = (char) li[0] & (32+16+8+4+2+1); //mask out top 2 bits | 417 | bufOut[0] = (char) li[0] & (32+16+8+4+2+1); //mask out top 2 bits |
414 | bufOut[0] <<= 2; | 418 | bufOut[0] <<= 2; |
415 | z = li[1] >> 4; | 419 | z = li[1] >> 4; |
416 | bufOut[0] = bufOut[0] | z; //first byte retrived | 420 | bufOut[0] = bufOut[0] | z; //first byte retrived |
417 | 421 | ||
418 | if (src[2] != '=') { | 422 | if (src[2] != '=') { |
419 | bufOut[1] = (char) li[1] & (8+4+2+1); //mask out top 4 bits | 423 | bufOut[1] = (char) li[1] & (8+4+2+1); //mask out top 4 bits |
420 | bufOut[1] <<= 4; | 424 | bufOut[1] <<= 4; |
421 | z = li[2] >> 2; | 425 | z = li[2] >> 2; |
422 | bufOut[1] = bufOut[1] | z; //second byte retrived | 426 | bufOut[1] = bufOut[1] | z; //second byte retrived |
423 | processed++; | 427 | processed++; |
424 | 428 | ||
425 | if (src[3] != '=') { | 429 | if (src[3] != '=') { |
426 | bufOut[2] = (char) li[2] & (2+1); //mask out top 6 bits | 430 | bufOut[2] = (char) li[2] & (2+1); //mask out top 6 bits |
427 | bufOut[2] <<= 6; | 431 | bufOut[2] <<= 6; |
428 | z = li[3]; | 432 | z = li[3]; |
429 | bufOut[2] = bufOut[2] | z; //third byte retrieved | 433 | bufOut[2] = bufOut[2] | z; //third byte retrieved |
430 | processed++; | 434 | processed++; |
431 | } | 435 | } |
432 | } | 436 | } |
433 | return processed; | 437 | return processed; |
434 | } | 438 | } |
435 | 439 | ||
436 | int EmailHandler::encodeMime(Email *mail) | 440 | int EmailHandler::encodeMime(Email *mail) |
437 | { | 441 | { |
438 | 442 | ||
439 | QString fileName, fileType, contentType, newBody, boundary; | 443 | QString fileName, fileType, contentType, newBody, boundary; |
440 | Enclosure *ePtr; | 444 | Enclosure *ePtr; |
441 | 445 | ||
442 | QString userName = mailAccount.name; | 446 | QString userName = mailAccount.name; |
443 | if (userName.length()>0) //only embrace it if there is a user name | 447 | if (userName.length()>0) //only embrace it if there is a user name |
444 | userName += " <" + mailAccount.emailAddress + ">"; | 448 | userName += " <" + mailAccount.emailAddress + ">"; |
445 | 449 | ||
446 | //add standard headers | 450 | //add standard headers |
447 | newBody = "From: " + userName + "\r\nTo: "; | 451 | newBody = "From: " + userName + "\r\nTo: "; |
448 | for (QStringList::Iterator it = mail->recipients.begin(); it != mail->recipients.end(); ++it ) { | 452 | for (QStringList::Iterator it = mail->recipients.begin(); it != mail->recipients.end(); ++it ) { |
449 | newBody += *it + " "; | 453 | newBody += *it + " "; |
450 | } | 454 | } |
451 | 455 | ||
452 | newBody += "\r\nCC: "; | 456 | newBody += "\r\nCC: "; |
453 | 457 | ||
454 | for (QStringList::Iterator it = mail->carbonCopies.begin(); it != mail->carbonCopies.end(); ++it ) { | 458 | for (QStringList::Iterator it = mail->carbonCopies.begin(); it != mail->carbonCopies.end(); ++it ) { |
455 | newBody += *it + " "; | 459 | newBody += *it + " "; |
456 | } | 460 | } |
457 | 461 | ||
458 | newBody += "\r\nSubject: " + mail->subject + "\r\n"; | 462 | newBody += "\r\nSubject: " + mail->subject + "\r\n"; |
459 | 463 | ||
460 | if (mail->files.count() == 0) { //just a simple mail | 464 | if (mail->files.count() == 0) { //just a simple mail |
461 | newBody += "\r\n" + mail->body; | 465 | newBody += "\r\n" + mail->body; |
462 | mail->rawMail = newBody; | 466 | mail->rawMail = newBody; |
463 | return 0; | 467 | return 0; |
464 | } | 468 | } |
465 | 469 | ||
466 | //Build mime encoded mail | 470 | //Build mime encoded mail |
467 | boundary = "-----4345=next_bound=0495----"; | 471 | boundary = "-----4345=next_bound=0495----"; |
468 | 472 | ||
469 | newBody += "Mime-Version: 1.0\r\n"; | 473 | newBody += "Mime-Version: 1.0\r\n"; |
470 | newBody += "Content-Type: multipart/mixed; boundary=\"" + | 474 | newBody += "Content-Type: multipart/mixed; boundary=\"" + |
471 | boundary + "\"\r\n\r\n"; | 475 | boundary + "\"\r\n\r\n"; |
472 | 476 | ||
473 | newBody += "This is a multipart message in Mime 1.0 format\r\n\r\n"; | 477 | newBody += "This is a multipart message in Mime 1.0 format\r\n\r\n"; |
474 | newBody += "--" + boundary + "\r\nContent-Type: text/plain\r\n\r\n"; | 478 | newBody += "--" + boundary + "\r\nContent-Type: text/plain\r\n\r\n"; |
475 | newBody += mail->body; | 479 | newBody += mail->body; |
476 | 480 | ||
477 | for ( ePtr=mail->files.first(); ePtr != 0; ePtr=mail->files.next() ) { | 481 | for ( ePtr=mail->files.first(); ePtr != 0; ePtr=mail->files.next() ) { |
478 | fileName = ePtr->originalName; | 482 | fileName = ePtr->originalName; |
479 | fileType = ePtr->contentType; | 483 | fileType = ePtr->contentType; |
480 | QFileInfo fi(fileName); | 484 | QFileInfo fi(fileName); |
481 | 485 | ||
482 | // This specification of contentType is temporary | 486 | // This specification of contentType is temporary |
483 | contentType = ""; | 487 | contentType = ""; |
484 | if (fileType == "Picture") { | 488 | if (fileType == "Picture") { |
485 | contentType = "image/x-image"; | 489 | contentType = "image/x-image"; |
486 | } else if (fileType == "Document") { | 490 | } else if (fileType == "Document") { |
487 | contentType = "text/plain"; | 491 | contentType = "text/plain"; |
488 | } else if (fileType == "Sound") { | 492 | } else if (fileType == "Sound") { |
489 | contentType = "audio/x-wav"; | 493 | contentType = "audio/x-wav"; |
490 | } else if (fileType == "Movie") { | 494 | } else if (fileType == "Movie") { |
491 | contentType = "video/mpeg"; | 495 | contentType = "video/mpeg"; |
492 | } else { | 496 | } else { |
493 | contentType = "application/octet-stream"; | 497 | contentType = "application/octet-stream"; |
494 | } | 498 | } |
495 | 499 | ||
496 | newBody += "\r\n\r\n--" + boundary + "\r\n"; | 500 | newBody += "\r\n\r\n--" + boundary + "\r\n"; |
497 | newBody += "Content-Type: " + contentType + "; name=\"" + | 501 | newBody += "Content-Type: " + contentType + "; name=\"" + |
498 | fi.fileName() + "\"\r\n"; | 502 | fi.fileName() + "\"\r\n"; |
499 | newBody += "Content-Transfer-Encoding: base64\r\n"; | 503 | newBody += "Content-Transfer-Encoding: base64\r\n"; |
500 | newBody += "Content-Disposition: inline; filename=\"" + | 504 | newBody += "Content-Disposition: inline; filename=\"" + |
501 | fi.fileName() + "\"\r\n\r\n"; | 505 | fi.fileName() + "\"\r\n\r\n"; |
502 | 506 | ||
503 | if (encodeFile(fileName, &newBody) == -1) //file not found? | 507 | if (encodeFile(fileName, &newBody) == -1) //file not found? |
504 | return -1; | 508 | return -1; |
505 | } | 509 | } |
506 | 510 | ||
507 | newBody += "\r\n\r\n--" + boundary + "--"; | 511 | newBody += "\r\n\r\n--" + boundary + "--"; |
508 | mail->rawMail = newBody; | 512 | mail->rawMail = newBody; |
509 | 513 | ||
510 | return 0; | 514 | return 0; |
511 | } | 515 | } |
512 | 516 | ||
513 | int EmailHandler::encodeFile(const QString &fileName, QString *toBody) | 517 | int EmailHandler::encodeFile(const QString &fileName, QString *toBody) |
514 | { | 518 | { |
515 | char *fileData; | 519 | char *fileData; |
516 | char *dataPtr; | 520 | char *dataPtr; |
517 | QString temp; | 521 | QString temp; |
518 | uint dataSize, count; | 522 | uint dataSize, count; |
519 | QFile f(fileName); | 523 | QFile f(fileName); |
520 | 524 | ||
521 | if (! f.open(IO_ReadOnly) ) { | 525 | if (! f.open(IO_ReadOnly) ) { |
522 | qWarning("could not open file: " + fileName); | 526 | qWarning("could not open file: " + fileName); |
523 | return -1; | 527 | return -1; |
524 | } | 528 | } |
525 | QTextStream s(&f); | 529 | QTextStream s(&f); |
526 | dataSize = f.size(); | 530 | dataSize = f.size(); |
527 | fileData = (char *) malloc(dataSize + 3); | 531 | fileData = (char *) malloc(dataSize + 3); |
528 | s.readRawBytes(fileData, dataSize); | 532 | s.readRawBytes(fileData, dataSize); |
529 | 533 | ||
530 | temp = ""; | 534 | temp = ""; |
531 | dataPtr = fileData; | 535 | dataPtr = fileData; |
532 | count = 0; | 536 | count = 0; |
diff --git a/noncore/unsupported/mailit/mailitwindow.cpp b/noncore/unsupported/mailit/mailitwindow.cpp index a111241..f945a0f 100644 --- a/noncore/unsupported/mailit/mailitwindow.cpp +++ b/noncore/unsupported/mailit/mailitwindow.cpp | |||
@@ -1,168 +1,168 @@ | |||
1 | /********************************************************************** | 1 | /********************************************************************** |
2 | ** Copyright (C) 2001 Trolltech AS. All rights reserved. | 2 | ** Copyright (C) 2001 Trolltech AS. All rights reserved. |
3 | ** | 3 | ** |
4 | ** This file is part of Qt Palmtop Environment. | 4 | ** This file is part of Qt Palmtop Environment. |
5 | ** | 5 | ** |
6 | ** This file may be distributed and/or modified under the terms of the | 6 | ** This file may be distributed and/or modified under the terms of the |
7 | ** GNU General Public License version 2 as published by the Free Software | 7 | ** GNU General Public License version 2 as published by the Free Software |
8 | ** Foundation and appearing in the file LICENSE.GPL included in the | 8 | ** Foundation and appearing in the file LICENSE.GPL included in the |
9 | ** packaging of this file. | 9 | ** packaging of this file. |
10 | ** | 10 | ** |
11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE | 11 | ** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE |
12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. | 12 | ** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
13 | ** | 13 | ** |
14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. | 14 | ** See http://www.trolltech.com/gpl/ for GPL licensing information. |
15 | ** | 15 | ** |
16 | ** Contact info@trolltech.com if any conditions of this licensing are | 16 | ** Contact info@trolltech.com if any conditions of this licensing are |
17 | ** not clear to you. | 17 | ** not clear to you. |
18 | ** | 18 | ** |
19 | **********************************************************************/ | 19 | **********************************************************************/ |
20 | #include <qwhatsthis.h> | 20 | #include <qwhatsthis.h> |
21 | #include <qmessagebox.h> | 21 | #include <qmessagebox.h> |
22 | #include "mailitwindow.h" | 22 | #include "mailitwindow.h" |
23 | 23 | ||
24 | MailItWindow::MailItWindow(QWidget *parent, const char *name, WFlags fl) | 24 | MailItWindow::MailItWindow(QWidget *parent, const char *name, WFlags fl) |
25 | : QMainWindow(parent, name, WStyle_ContextHelp) | 25 | : QMainWindow(parent, name, WStyle_ContextHelp) |
26 | { | 26 | { |
27 | currentCaption = "Mailit"; | 27 | currentCaption = "Mailit"; |
28 | setCaption(tr(currentCaption)); | 28 | setCaption(tr(currentCaption)); |
29 | views = new QWidgetStack(this); | 29 | views = new QWidgetStack(this); |
30 | setCentralWidget(views); | 30 | setCentralWidget(views); |
31 | QWhatsThis::add(views,tr("Central view area")); | 31 | QWhatsThis::add(views,tr("Central view area")); |
32 | emailClient = new EmailClient(views, "client"); | 32 | emailClient = new EmailClient(views, "client"); |
33 | writeMail = new WriteMail(views, "writing"); | 33 | writeMail = new WriteMail(views, "writing"); |
34 | readMail = new ReadMail(views, "reading"); | 34 | readMail = new ReadMail(views, "reading"); |
35 | 35 | ||
36 | views->raiseWidget(emailClient); | 36 | views->raiseWidget(emailClient); |
37 | 37 | ||
38 | connect(emailClient, SIGNAL(composeRequested()), | 38 | connect(emailClient, SIGNAL(composeRequested()), |
39 | this, SLOT(compose()) ); | 39 | this, SLOT(compose()) ); |
40 | connect(emailClient, SIGNAL(viewEmail(QListView *, Email *)), this, | 40 | connect(emailClient, SIGNAL(viewEmail(QListView *, Email *)), this, |
41 | SLOT(viewMail(QListView *, Email *)) ); | 41 | SLOT(viewMail(QListView *, Email *)) ); |
42 | connect(emailClient, SIGNAL(mailUpdated(Email *)), this, | 42 | connect(emailClient, SIGNAL(mailUpdated(Email *)), this, |
43 | SLOT(updateMailView(Email *)) ); | 43 | SLOT(updateMailView(Email *)) ); |
44 | 44 | ||
45 | connect(writeMail, SIGNAL(cancelMail()), this, SLOT(showEmailClient()) ); | 45 | connect(writeMail, SIGNAL(cancelMail()), this, SLOT(showEmailClient()) ); |
46 | connect(writeMail, SIGNAL(sendMailRequested(const Email &)), this, | 46 | connect(writeMail, SIGNAL(sendMailRequested(const Email &)), this, |
47 | SLOT(showEmailClient()) ); | 47 | SLOT(showEmailClient()) ); |
48 | connect(writeMail, SIGNAL(sendMailRequested(const Email &)), emailClient, | 48 | connect(writeMail, SIGNAL(sendMailRequested(const Email &)), emailClient, |
49 | SLOT(enqueMail(const Email &)) ); | 49 | SLOT(enqueMail(const Email &)) ); |
50 | 50 | ||
51 | connect(readMail, SIGNAL(cancelView()), this, SLOT(showEmailClient()) ); | 51 | connect(readMail, SIGNAL(cancelView()), this, SLOT(showEmailClient()) ); |
52 | connect(readMail, SIGNAL(replyRequested(Email &, bool&)), this, | 52 | connect(readMail, SIGNAL(replyRequested(Email &, bool&)), this, |
53 | SLOT(composeReply(Email &, bool&)) ); | 53 | SLOT(composeReply(Email &, bool&)) ); |
54 | connect(readMail, SIGNAL(forwardRequested(Email &)), this, | 54 | connect(readMail, SIGNAL(forwardRequested(Email &)), this, |
55 | SLOT(composeForward(Email &)) ); | 55 | SLOT(composeForward(Email &)) ); |
56 | 56 | ||
57 | connect(readMail, SIGNAL(removeItem(EmailListItem *, bool &)), emailClient, | 57 | connect(readMail, SIGNAL(removeItem(EmailListItem *, bool &)), emailClient, |
58 | SLOT(deleteMail(EmailListItem *, bool &)) ); | 58 | SLOT(deleteMail(EmailListItem *, bool &)) ); |
59 | connect(readMail, SIGNAL(viewingMail(Email *)), emailClient, | 59 | connect(readMail, SIGNAL(viewingMail(Email *)), emailClient, |
60 | SLOT(moveMailFront(Email *)) ); | 60 | SLOT(moveMailFront(Email *)) ); |
61 | 61 | ||
62 | connect(emailClient, SIGNAL(newCaption(const QString &)), | 62 | connect(emailClient, SIGNAL(newCaption(const QString &)), |
63 | this, SLOT(updateCaption(const QString &)) ); | 63 | this, SLOT(updateCaption(const QString &)) ); |
64 | 64 | ||
65 | connect(readMail, SIGNAL(download(Email *)), emailClient, SLOT(download(Email*)) ); | 65 | connect(readMail, SIGNAL(download(Email *)), emailClient, SLOT(download(Email*)) ); |
66 | 66 | ||
67 | viewingMail = FALSE; | 67 | viewingMail = FALSE; |
68 | } | 68 | } |
69 | 69 | ||
70 | MailItWindow::~MailItWindow() | 70 | MailItWindow::~MailItWindow() |
71 | { | 71 | { |
72 | } | 72 | } |
73 | 73 | ||
74 | void MailItWindow::closeEvent(QCloseEvent *e) | 74 | void MailItWindow::closeEvent(QCloseEvent *e) |
75 | { | 75 | { |
76 | if (views->visibleWidget() == emailClient) { | 76 | if (views->visibleWidget() == emailClient) { |
77 | e->accept(); | 77 | e->accept(); |
78 | } else { | 78 | } else { |
79 | showEmailClient(); | 79 | showEmailClient(); |
80 | } | 80 | } |
81 | } | 81 | } |
82 | 82 | ||
83 | void MailItWindow::compose() | 83 | void MailItWindow::compose() |
84 | { | 84 | { |
85 | viewingMail = FALSE; | 85 | viewingMail = FALSE; |
86 | emailClient->hide(); | 86 | emailClient->hide(); |
87 | readMail->hide(); | 87 | readMail->hide(); |
88 | views->raiseWidget(writeMail); | 88 | views->raiseWidget(writeMail); |
89 | writeMail->setAddressList(emailClient->getAdrListRef()); | 89 | writeMail->setAddressList(emailClient->getAdrListRef()); |
90 | writeMail->newMail(); | 90 | writeMail->newMail(); |
91 | setCaption( tr( "Write mail" ) ); | 91 | setCaption( tr( "Write mail" ) ); |
92 | } | 92 | } |
93 | 93 | ||
94 | void MailItWindow::composeReply(Email &mail, bool& replyAll) | 94 | void MailItWindow::composeReply(Email &mail, bool& replyAll) |
95 | { | 95 | { |
96 | compose(); | 96 | compose(); |
97 | writeMail->reply(mail,replyAll) ; | 97 | writeMail->reply(mail,replyAll) ; |
98 | } | 98 | } |
99 | 99 | ||
100 | void MailItWindow::composeForward(Email &mail) | 100 | void MailItWindow::composeForward(Email &mail) |
101 | { | 101 | { |
102 | compose(); | 102 | compose(); |
103 | writeMail->forward(mail) ; | 103 | writeMail->forward(mail) ; |
104 | } | 104 | } |
105 | 105 | ||
106 | 106 | ||
107 | void MailItWindow::showEmailClient() | 107 | void MailItWindow::showEmailClient() |
108 | { | 108 | { |
109 | viewingMail = FALSE; | 109 | viewingMail = FALSE; |
110 | writeMail->hide(); | 110 | writeMail->hide(); |
111 | readMail->hide(); | 111 | readMail->hide(); |
112 | views->raiseWidget(emailClient); | 112 | views->raiseWidget(emailClient); |
113 | setCaption( tr(currentCaption) ); | 113 | setCaption( tr(currentCaption) ); |
114 | } | 114 | } |
115 | 115 | ||
116 | void MailItWindow::viewMail(QListView *view, Email *mail) | 116 | void MailItWindow::viewMail(QListView *view, Email *mail) |
117 | { | 117 | { |
118 | viewingMail = TRUE; | 118 | viewingMail = TRUE; |
119 | emailClient->hide(); | 119 | emailClient->hide(); |
120 | 120 | ||
121 | int result=0; | 121 | int result=0; |
122 | 122 | ||
123 | if ((mail->received)&&(!mail->downloaded)) | 123 | if ((mail->received)&&(!mail->downloaded)) |
124 | { | 124 | { |
125 | QMessageBox mb( tr("Mail not downloaded"), | 125 | QMessageBox mb( tr("Mail not downloaded"), |
126 | tr("The mail you have clicked \n" | 126 | tr("The mail you have clicked \n" |
127 | "has not been downloaded yet.\n " | 127 | "has not been downloaded yet.\n " |
128 | "Would you like to do it now ?"), | 128 | "Would you like to do it now ?"), |
129 | QMessageBox::Information, | 129 | QMessageBox::Information, |
130 | QMessageBox::Yes | QMessageBox::Default, | 130 | QMessageBox::Yes | QMessageBox::Default, |
131 | QMessageBox::No | QMessageBox::Escape,0 ); | 131 | QMessageBox::No | QMessageBox::Escape,0 ); |
132 | 132 | ||
133 | result=mb.exec(); | 133 | result=mb.exec(); |
134 | 134 | ||
135 | if (result==QMessageBox::Yes) | 135 | if (result==QMessageBox::Yes) |
136 | { | 136 | { |
137 | emailClient->download(mail); | 137 | emailClient->download(mail); |
138 | } | 138 | } |
139 | } | 139 | } |
140 | 140 | ||
141 | readMail->update(view, mail); | 141 | readMail->update(view, mail); |
142 | views->raiseWidget(readMail); | 142 | views->raiseWidget(readMail); |
143 | setCaption( tr( "Examine mail" ) ); | 143 | setCaption( tr( "Read Mail" ) ); |
144 | } | 144 | } |
145 | 145 | ||
146 | void MailItWindow::updateMailView(Email *mail) | 146 | void MailItWindow::updateMailView(Email *mail) |
147 | { | 147 | { |
148 | if (viewingMail) { | 148 | if (viewingMail) { |
149 | readMail->mailUpdated(mail); | 149 | readMail->mailUpdated(mail); |
150 | } | 150 | } |
151 | } | 151 | } |
152 | 152 | ||
153 | void MailItWindow::updateCaption(const QString &newCaption) | 153 | void MailItWindow::updateCaption(const QString &newCaption) |
154 | { | 154 | { |
155 | currentCaption = newCaption; | 155 | currentCaption = newCaption; |
156 | setCaption(tr(currentCaption)); | 156 | setCaption(tr(currentCaption)); |
157 | } | 157 | } |
158 | 158 | ||
159 | void MailItWindow::setDocument(const QString &_address) | 159 | void MailItWindow::setDocument(const QString &_address) |
160 | { | 160 | { |
161 | // strip leading 'mailto:' | 161 | // strip leading 'mailto:' |
162 | QString address = _address; | 162 | QString address = _address; |
163 | if (address.startsWith("mailto:")) | 163 | if (address.startsWith("mailto:")) |
164 | address = address.mid(6); | 164 | address = address.mid(6); |
165 | 165 | ||
166 | compose(); | 166 | compose(); |
167 | writeMail->setRecipient(address); | 167 | writeMail->setRecipient(address); |
168 | } | 168 | } |