. * * The interactive user interfaces in modified source and object code versions * of this program must display Appropriate Legal Notices, as required under * Section 5 of the GNU Affero General Public License version 3. * * In accordance with Section 7(b) of the GNU Affero General Public License version 3, * these Appropriate Legal Notices must retain the display of the "EspoCRM" word. ************************************************************************/ namespace Espo\Tools\EmailTemplate; use Espo\Core\Acl; use Espo\Core\Exceptions\ForbiddenSilent; use Espo\Core\Exceptions\NotFound; use Espo\Entities\EmailTemplate; use Espo\Entities\User; use Espo\ORM\EntityManager; class Service { public function __construct( private Processor $processor, private User $user, private Acl $acl, private EntityManager $entityManager ) {} /** * Prepare an email data with an applied template. * * @throws NotFound * @throws ForbiddenSilent */ public function process(string $emailTemplateId, Data $data, ?Params $params = null): Result { /** @var ?EmailTemplate $emailTemplate */ $emailTemplate = $this->entityManager->getEntityById(EmailTemplate::ENTITY_TYPE, $emailTemplateId); if (!$emailTemplate) { throw new NotFound(); } $params ??= Params::create() ->withApplyAcl(true) ->withCopyAttachments(true); if ( $params->applyAcl() && !$this->acl->checkEntityRead($emailTemplate) ) { throw new ForbiddenSilent(); } if (!$data->getUser()) { $data = $data->withUser($this->user); } return $this->processor->process($emailTemplate, $params, $data); } }