. * * 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\Email\Api; use Espo\Core\Acl; use Espo\Core\Api\Action; use Espo\Core\Api\Request; use Espo\Core\Api\Response; use Espo\Core\Api\ResponseComposer; use Espo\Core\Exceptions\BadRequest; use Espo\Core\Exceptions\Forbidden; use Espo\Core\Exceptions\NotFound; use Espo\Entities\Attachment; use Espo\Entities\Email; use Espo\Entities\User; use Espo\ORM\EntityManager; use Espo\Tools\Email\ImportEmlService; /** * @noinspection PhpUnused */ class PostImportEml implements Action { public function __construct( private Acl $acl, private User $user, private ImportEmlService $service, private EntityManager $entityManager, ) {} public function process(Request $request): Response { $this->checkAccess(); $fileId = $request->getParsedBody()->fileId ?? null; if (!is_string($fileId)) { throw new BadRequest("No 'fileId'."); } $attachment = $this->getAttachment($fileId); $email = $this->service->import($attachment, $this->user->getId()); return ResponseComposer::json(['id' => $email->getId()]); } /** * @throws NotFound * @throws Forbidden */ private function getAttachment(string $fileId): Attachment { $attachment = $this->entityManager->getRDBRepositoryByClass(Attachment::class)->getById($fileId); if (!$attachment) { throw new NotFound("Attachment not found."); } if (!$this->acl->checkEntityRead($attachment)) { throw new Forbidden("No access to attachment."); } return $attachment; } /** * @throws Forbidden */ private function checkAccess(): void { if (!$this->acl->checkScope(Email::ENTITY_TYPE, Acl\Table::ACTION_CREATE)) { throw new Forbidden("No 'create' access."); } if (!$this->acl->checkScope('Import')) { throw new Forbidden("No access to 'Import'."); } } }