com.liferay.account.internal.security.permission.resource.AccountRoleModelResourcePermission Maven / Gradle / Ivy
/**
* SPDX-FileCopyrightText: (c) 2000 Liferay, Inc. https://liferay.com
* SPDX-License-Identifier: LGPL-2.1-or-later OR LicenseRef-Liferay-DXP-EULA-2.0.0-2023-06
*/
package com.liferay.account.internal.security.permission.resource;
import com.liferay.account.constants.AccountActionKeys;
import com.liferay.account.constants.AccountConstants;
import com.liferay.account.model.AccountEntry;
import com.liferay.account.model.AccountEntryOrganizationRel;
import com.liferay.account.model.AccountRole;
import com.liferay.account.role.AccountRolePermissionThreadLocal;
import com.liferay.account.service.AccountEntryLocalService;
import com.liferay.account.service.AccountEntryOrganizationRelLocalService;
import com.liferay.account.service.AccountRoleLocalService;
import com.liferay.portal.kernel.exception.PortalException;
import com.liferay.portal.kernel.model.Group;
import com.liferay.portal.kernel.model.Organization;
import com.liferay.portal.kernel.model.Role;
import com.liferay.portal.kernel.security.auth.PrincipalException;
import com.liferay.portal.kernel.security.permission.ActionKeys;
import com.liferay.portal.kernel.security.permission.PermissionChecker;
import com.liferay.portal.kernel.security.permission.resource.ModelResourcePermission;
import com.liferay.portal.kernel.security.permission.resource.PortletResourcePermission;
import com.liferay.portal.kernel.service.OrganizationLocalService;
import com.liferay.portal.kernel.service.permission.OrganizationPermissionUtil;
import com.liferay.portal.kernel.service.permission.RolePermissionUtil;
import com.liferay.portal.kernel.util.ArrayUtil;
import java.util.List;
import java.util.Objects;
import org.osgi.service.component.annotations.Component;
import org.osgi.service.component.annotations.Reference;
import org.osgi.service.component.annotations.ReferencePolicy;
import org.osgi.service.component.annotations.ReferencePolicyOption;
/**
* @author Pei-Jung Lan
*/
@Component(
property = "model.class.name=com.liferay.account.model.AccountRole",
service = ModelResourcePermission.class
)
public class AccountRoleModelResourcePermission
implements ModelResourcePermission {
@Override
public void check(
PermissionChecker permissionChecker, AccountRole accountRole,
String actionId)
throws PortalException {
if (!contains(permissionChecker, accountRole, actionId)) {
throw new PrincipalException.MustHavePermission(
permissionChecker, AccountRole.class.getName(),
accountRole.getAccountRoleId(), actionId);
}
}
@Override
public void check(
PermissionChecker permissionChecker, long accountRoleId,
String actionId)
throws PortalException {
if (!contains(permissionChecker, accountRoleId, actionId)) {
throw new PrincipalException.MustHavePermission(
permissionChecker, AccountRole.class.getName(), accountRoleId,
actionId);
}
}
@Override
public boolean contains(
PermissionChecker permissionChecker, AccountRole accountRole,
String actionId)
throws PortalException {
return contains(
permissionChecker, accountRole.getAccountRoleId(), actionId);
}
@Override
public boolean contains(
PermissionChecker permissionChecker, long accountRoleId,
String actionId)
throws PortalException {
Group group = null;
long contextAccountEntryId =
AccountRolePermissionThreadLocal.getAccountEntryId();
if (contextAccountEntryId > 0) {
AccountEntry accountEntry =
_accountEntryLocalService.getAccountEntry(
contextAccountEntryId);
group = accountEntry.getAccountEntryGroup();
}
AccountRole accountRole = _accountRoleLocalService.fetchAccountRole(
accountRoleId);
if (accountRole == null) {
return permissionChecker.hasPermission(
group, AccountRole.class.getName(), 0L, actionId);
}
Role role = accountRole.getRole();
if (permissionChecker.hasOwnerPermission(
permissionChecker.getCompanyId(), AccountRole.class.getName(),
accountRoleId, role.getUserId(), actionId)) {
return true;
}
long accountRoleAccountEntryId = accountRole.getAccountEntryId();
if ((accountRoleAccountEntryId >
AccountConstants.ACCOUNT_ENTRY_ID_DEFAULT) &&
(contextAccountEntryId >
AccountConstants.ACCOUNT_ENTRY_ID_DEFAULT) &&
!Objects.equals(accountRoleAccountEntryId, contextAccountEntryId)) {
return false;
}
for (long accountEntryId :
new long[] {accountRoleAccountEntryId, contextAccountEntryId}) {
if (Objects.equals(actionId, ActionKeys.VIEW) &&
RolePermissionUtil.contains(
permissionChecker, role.getRoleId(), ActionKeys.VIEW)) {
return true;
}
if (Objects.equals(actionId, AccountActionKeys.ASSIGN_USERS) &&
(accountEntryId > 0) &&
_accountEntryModelResourcePermission.contains(
permissionChecker, accountEntryId,
ActionKeys.MANAGE_USERS)) {
return true;
}
if (_checkOrganizationRolesPermission(
accountEntryId, accountRoleId, actionId,
permissionChecker)) {
return true;
}
}
if ((group == null) && (accountRoleAccountEntryId > 0)) {
AccountEntry accountEntry =
_accountEntryLocalService.getAccountEntry(
accountRoleAccountEntryId);
group = accountEntry.getAccountEntryGroup();
}
return permissionChecker.hasPermission(
group, AccountRole.class.getName(), accountRoleId, actionId);
}
@Override
public String getModelName() {
return AccountRole.class.getName();
}
@Override
public PortletResourcePermission getPortletResourcePermission() {
return _portletResourcePermission;
}
private boolean _checkOrganizationRolesPermission(
long accountEntryId, long accountRoleId, String actionId,
PermissionChecker permissionChecker)
throws PortalException {
if (accountEntryId == 0) {
return false;
}
long[] userOrganizationIds =
_organizationLocalService.getUserOrganizationIds(
permissionChecker.getUserId(), true);
List accountEntryOrganizationRels =
_accountEntryOrganizationRelLocalService.
getAccountEntryOrganizationRels(accountEntryId);
for (AccountEntryOrganizationRel accountEntryOrganizationRel :
accountEntryOrganizationRels) {
Organization organization =
_organizationLocalService.fetchOrganization(
accountEntryOrganizationRel.getOrganizationId());
Organization originalOrganization = organization;
while (organization != null) {
if (Objects.equals(organization, originalOrganization) &&
permissionChecker.hasPermission(
organization.getGroupId(), AccountRole.class.getName(),
accountRoleId, actionId)) {
return true;
}
if (!Objects.equals(organization, originalOrganization) &&
OrganizationPermissionUtil.contains(
permissionChecker, organization,
AccountActionKeys.MANAGE_SUBORGANIZATIONS_ACCOUNTS) &&
ArrayUtil.contains(
userOrganizationIds,
organization.getOrganizationId()) &&
permissionChecker.hasPermission(
organization.getGroupId(), AccountRole.class.getName(),
accountRoleId, actionId)) {
return true;
}
organization = organization.getParentOrganization();
}
}
return false;
}
@Reference
private AccountEntryLocalService _accountEntryLocalService;
@Reference(
policy = ReferencePolicy.DYNAMIC,
policyOption = ReferencePolicyOption.GREEDY,
target = "(model.class.name=com.liferay.account.model.AccountEntry)"
)
private volatile ModelResourcePermission
_accountEntryModelResourcePermission;
@Reference
private AccountEntryOrganizationRelLocalService
_accountEntryOrganizationRelLocalService;
@Reference
private AccountRoleLocalService _accountRoleLocalService;
@Reference
private OrganizationLocalService _organizationLocalService;
@Reference(
target = "(resource.name=" + AccountConstants.RESOURCE_NAME + ")"
)
private PortletResourcePermission _portletResourcePermission;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy