/** * Check that email body is cached. * If do not, load it using appropriate email extension add it to a cache. * * @param Email $email * * @throws LoadEmailBodyException if a body of the given email cannot be loaded */ public function ensureEmailBodyCached(Email $email) { if ($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->selector->select($origin); try { $emailBody = $loader->loadEmailBody($folder, $email, $this->em); } 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); } $email->setEmailBody($emailBody); $this->em->persist($email); $this->em->flush(); $event = new EmailBodyAdded($email); $this->eventDispatcher->dispatch(EmailBodyAdded::NAME, $event); } $this->eventDispatcher->dispatch(EmailBodyLoaded::NAME, new EmailBodyLoaded($email)); }
/** * Check that email body is cached. * If do not, load it using appropriate email extension add it to a cache. * * @param Email $email * * @throws LoadEmailBodyException if a body of the given email cannot be loaded */ public function ensureEmailBodyCached(Email $email) { if ($email->getEmailBody() !== null) { // The email body is already cached return; } // body loader can load email from any folder $folder = $email->getEmailUsers()->first()->getFolder(); $origin = $folder->getOrigin(); $loader = $this->selector->select($origin); try { $emailBody = $loader->loadEmailBody($folder, $email, $this->em); } 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); } $email->setEmailBody($emailBody); $this->em->persist($email); $this->em->flush(); $event = new EmailBodyAdded($email); $this->eventDispatcher->dispatch(EmailBodyAdded::NAME, $event); }