. * * 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\UserSecurity\Api; use Espo\Core\AclManager; 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\User; use Espo\ORM\EntityManager; /** * User ACL data. */ class GetUserAcl implements Action { public function __construct( private EntityManager $entityManager, private AclManager $aclManager, private User $user ) {} public function process(Request $request): Response { $userId = $request->getRouteParam('id'); if (!$userId) { throw new BadRequest(); } if ( !$this->user->isAdmin() && $this->user->getId() !== $userId ) { throw new Forbidden(); } $user = $this->entityManager->getEntityById(User::ENTITY_TYPE, $userId); if (!$user) { throw new NotFound(); } $data = $this->aclManager->getMapData($user); return ResponseComposer::json($data); } }