/**
  * Conflict incoming mail
  * 
  * @param void
  * @return void
  */
 function conflict()
 {
     if ($this->active_mail->isNew()) {
         $this->httpError(HTTP_ERR_NOT_FOUND);
     }
     // if
     require_once INCOMING_MAIL_MODULE_PATH . '/models/IncomingMailImporter.class.php';
     $mail_data = $this->request->post('mail');
     if (!is_foreachable($mail_data)) {
         flash_error(incoming_mail_module_get_status_description($this->active_mail->getState()));
         $mail_data = array('subject' => $this->active_mail->getSubject(), 'body' => $this->active_mail->getBody(), 'created_by_id' => $this->active_mail->getCreatedById(), 'project_id' => $this->active_mail->getProjectId());
     }
     // if
     if ($this->request->isSubmitted()) {
         $this->active_mail->setSubject(array_var($mail_data, 'subject'));
         $this->active_mail->setBody(array_var($mail_data, 'body'));
         $creator_id = array_var($mail_data, 'created_by_id');
         if ($creator_id && $creator_id != 'original_author') {
             $creator = Users::findById($creator_id);
             if (instance_of($creator, 'User')) {
                 $this->active_mail->setCreatedBy($creator);
             }
             // if
         }
         // if
         $this->active_mail->setCreatedById(array_var($mail_data, 'created_by_id'));
         $this->active_mail->setObjectType(array_var($mail_data, 'object_type'));
         if (array_var($mail_data, 'object_type') == 'comment') {
             $this->active_mail->setParentId(array_var($mail_data, 'parent_id'));
         }
         // if
         // import email
         if (instance_of($importing_result = IncomingMailImporter::importPendingEmail($this->active_mail, $creator_id == 'original_author'), 'ProjectObject')) {
             // we have successfully imported email
             $this->active_mail->delete();
             if ($this->request->isAsyncCall()) {
                 $this->renderText(lang('<p>Conflict Solved Successfully!</p><p>View created <a href=":url">:object</a>.</p>', array('object' => $this->active_mail->getObjectType(), 'url' => $importing_result->getViewUrl())));
             } else {
                 flash_success('Conflict Solved Successfully!');
                 $this->redirectTo('incoming_mail');
             }
             // if
         } else {
             if ($this->request->isAsyncCall()) {
                 $this->httpError(HTTP_ERR_INVALID_PROPERTIES, null, false, 2);
             } else {
                 flash_error($importing_result->getMessage());
             }
             // if
         }
         // if
     }
     // if
     $user = $this->active_mail->getCreatedBy();
     if (instance_of($user, 'User')) {
         $this->smarty->assign('object_user', $user);
     } else {
         $this->smarty->assign('object_user', $this->logged_user);
     }
     // if
     $this->smarty->assign(array('async' => $this->request->isAsyncCall(), 'form_url' => $this->active_mail->getImportUrl() . ($this->request->isAsyncCall() ? '?skip_layout=1&async=1' : ''), 'status_message' => incoming_mail_module_get_status_description($this->active_mail->getState()), 'mail_data' => $mail_data, 'project' => $this->active_mail->getProject()));
     $flash =& Flash::instance();
     $flash->init();
     js_assign('additional_fields_url', assemble_url('incoming_mail_additional_form_fields'));
 }
 /**
  * Open's connection to mailboxes and download emails with limit of $max_emails
  *
  * @param array $mailboxes
  * @param integer $max_emails
  */
 function importEmails(&$mailboxes, $max_emails = 20)
 {
     use_model('incoming_mail_activity_logs', INCOMING_MAIL_MODULE);
     $import_date = new DateTimeValue();
     $imported_emails_count = 0;
     if (is_foreachable($mailboxes)) {
         foreach ($mailboxes as $mailbox) {
             $manager = $mailbox->getMailboxManager();
             // open connection to mailbox
             $result = $manager->connect();
             if (!$result || is_error($result)) {
                 // we didn't connect, so we need to log it
                 $error_message = '';
                 if (is_error($result)) {
                     $error_message = ': ' . $result->getMessage();
                 }
                 // if
                 IncomingMailActivityLogs::log($mailbox->getId(), lang('Could Not Connect To Mailbox' . $error_message), null, INCOMING_MAIL_LOG_STATUS_ERROR, $import_date);
                 $mailbox->setLastStatus(2);
                 $mailbox->save();
                 continue;
             }
             // if
             $mailbox->setLastStatus(1);
             $mailbox->save();
             $email_count = $manager->countMessages();
             for ($mid = 1; $mid < $email_count + 1; $mid++) {
                 if ($imported_emails_count >= $max_emails) {
                     return true;
                 }
                 // if
                 $current_message_id = 1;
                 $email = $manager->getMessage($current_message_id, INCOMING_MAIL_ATTACHMENTS_FOLDER);
                 if (!instance_of($email, 'MailboxManagerEmail')) {
                     IncomingMailActivityLogs::log($mailbox->getId(), $email->getMessage(), null, INCOMING_MAIL_LOG_STATUS_ERROR, $import_date);
                     continue;
                 }
                 // if
                 $pending_email = IncomingMailImporter::createPendingEmail($email, $mailbox);
                 if (!instance_of($pending_email, 'IncomingMail')) {
                     IncomingMailActivityLogs::log($mailbox->getId(), $pending_email->getMessage(), $email, INCOMING_MAIL_LOG_STATUS_ERROR, $import_date);
                     continue;
                 }
                 // if
                 $manager->deleteMessage($current_message_id, true);
                 $project_object = IncomingMailImporter::importPendingEmail($pending_email, false, $email->getIsReport());
                 if (!instance_of($project_object, 'ProjectObject')) {
                     IncomingMailActivityLogs::log($mailbox->getId(), $project_object->getMessage(), $pending_email, INCOMING_MAIL_LOG_STATUS_ERROR, $import_date);
                     continue;
                 }
                 // if
                 IncomingMailActivityLogs::log($mailbox->getId(), lang('Imported Successfully'), $project_object, INCOMING_MAIL_LOG_STATUS_OK, $import_date);
                 $user = $project_object->getCreatedBy();
                 if (instance_of($user, 'User')) {
                     $user->setLastActivityOn(new DateTimeValue());
                     $user->save();
                 }
                 // if
                 $pending_email->delete();
                 $imported_emails_count++;
             }
             // for
         }
         // foreach
     }
     // if
 }