. * * 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\Modules\Crm\Classes\AclPortal\KnowledgeBaseArticle; use Espo\Core\Utils\Metadata; use Espo\Entities\User; use Espo\Modules\Crm\Entities\KnowledgeBaseArticle; use Espo\ORM\Entity; use Espo\Core\ORM\Entity as CoreEntity; use Espo\Core\Acl\AccessEntityCREDChecker; use Espo\Core\Acl\ScopeData; use Espo\Core\Portal\Acl\DefaultAccessChecker; use Espo\Core\Portal\Acl\Traits\DefaultAccessCheckerDependency; /** * @implements AccessEntityCREDChecker */ class AccessChecker implements AccessEntityCREDChecker { use DefaultAccessCheckerDependency; public function __construct( DefaultAccessChecker $defaultAccessChecker, private Metadata $metadata ) { $this->defaultAccessChecker = $defaultAccessChecker; } public function checkEntityRead(User $user, Entity $entity, ScopeData $data): bool { if (!$this->defaultAccessChecker->checkEntityRead($user, $entity, $data)) { return false; } $statusList = $this->metadata->get("entityDefs.KnowledgeBaseArticle.fields.status.activeOptions") ?? [KnowledgeBaseArticle::STATUS_PUBLISHED]; if (!in_array($entity->getStatus(), $statusList)) { return false; } assert($entity instanceof CoreEntity); $portalIdList = $entity->getLinkMultipleIdList('portals'); $portalId = $user->get('portalId'); if (!$portalId) { return false; } return in_array($portalId, $portalIdList); } }