/** * 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); } } }