Ejemplo n.º 1
0
 /**
  * Syncs email body for one email
  *
  * @param Email $email
  */
 public function syncOneEmailBody(Email $email)
 {
     if ($email->isBodySynced() !== true && $email->getEmailBody() === null) {
         // body loader can load email from any folder
         // todo: refactor to use correct emailuser and origin
         // to use active origin and get correct folder from this origin
         $emailUser = $email->getEmailUsers()->first();
         $folder = $emailUser->getFolders()->first();
         $origin = $emailUser->getOrigin();
         if (!$origin) {
             throw new LoadEmailBodyFailedException($email);
         }
         $loader = $this->getBodyLoader($origin);
         $email->setBodySynced(true);
         $emailBody = null;
         try {
             $emailBody = $loader->loadEmailBody($folder, $email, $this->getManager());
             $email->setEmailBody($emailBody);
         } catch (LoadEmailBodyException $loadEx) {
             $this->logger->notice(sprintf('Load email body failed. Email id: %d. Error: %s', $email->getId(), $loadEx->getMessage()), ['exception' => $loadEx]);
             throw $loadEx;
         } catch (\Exception $ex) {
             $this->logger->warning(sprintf('Load email body failed. Email id: %d. Error: %s.', $email->getId(), $ex->getMessage()), ['exception' => $ex]);
             throw new LoadEmailBodyFailedException($email, $ex);
         }
         $this->getManager()->persist($email);
         if ($emailBody) {
             $event = new EmailBodyAdded($email);
             $this->eventDispatcher->dispatch(EmailBodyAdded::NAME, $event);
         }
     }
 }