/** * Copyright (c) 2000-present Liferay, Inc. All rights reserved. * * This library is free software; you can redistribute it and/or modify it under * the terms of the GNU Lesser General Public License as published by the Free * Software Foundation; either version 2.1 of the License, or (at your option) * any later version. * * This library is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more * details. */ package com.liferay.portal.kernel.portlet; import com.liferay.portal.kernel.exception.PortalException; import com.liferay.portal.kernel.model.Group; import com.liferay.portal.kernel.model.LayoutConstants; import com.liferay.portal.kernel.model.Portlet; import com.liferay.portal.kernel.security.permission.ActionKeys; import com.liferay.portal.kernel.security.permission.PermissionChecker; import com.liferay.portal.kernel.security.permission.ResourceActionsUtil; import com.liferay.portal.kernel.service.permission.PortletPermissionUtil; import com.liferay.portal.kernel.theme.ThemeDisplay; import com.liferay.portal.kernel.util.PortletCategoryKeys; import com.liferay.portal.kernel.util.StringPool; import java.util.List; /** * @author Jorge Ferrer */ public abstract class BaseControlPanelEntry implements ControlPanelEntry { @Override public boolean hasAccessPermission( PermissionChecker permissionChecker, Group group, Portlet portlet) throws Exception { if (hasAccessPermissionDenied(permissionChecker, group, portlet)) { return false; } if (hasAccessPermissionExplicitlyGranted( permissionChecker, group, portlet)) { return true; } return hasPermissionImplicitlyGranted( permissionChecker, group, portlet); } /** * @deprecated As of 6.2.0, with no direct replacement.<p>This method was * originally defined to determine if a portlet should be * displayed in the Control Panel. In this version, this method * should always return <code>false</code> and remains only to * preserve binary compatibility. This method will be * permanently removed in a future version.</p><p>In lieu of * this method, the Control Panel now uses {@link * #hasAccessPermission} to determine if a portlet should be * displayed in the Control Panel.</p> */ @Deprecated @Override public boolean isVisible( PermissionChecker permissionChecker, Portlet portlet) throws Exception { return false; } /** * @deprecated As of 6.2.0, with no direct replacement.<p>This method was * originally defined to determine if a portlet should be * displayed in the Control Panel. In this version, this method * should always return <code>false</code> and remains only to * preserve binary compatibility. This method will be * permanently removed in a future version.</p><p>In lieu of * this method, the Control Panel now uses {@link * #hasAccessPermission} to determine if a portlet should be * displayed in the Control Panel.</p> */ @Deprecated @Override public boolean isVisible( Portlet portlet, String category, ThemeDisplay themeDisplay) throws Exception { return false; } protected long getDefaultPlid(Group group, String category) { long plid = LayoutConstants.DEFAULT_PLID; if (category.startsWith(PortletCategoryKeys.SITE_ADMINISTRATION)) { plid = group.getDefaultPublicPlid(); if (plid == LayoutConstants.DEFAULT_PLID) { plid = group.getDefaultPrivatePlid(); } } return plid; } protected boolean hasAccessPermissionDenied( PermissionChecker permissionChecker, Group group, Portlet portlet) throws Exception { String category = portlet.getControlPanelEntryCategory(); if (category.startsWith(PortletCategoryKeys.SITE_ADMINISTRATION) && group.isLayoutPrototype()) { return true; } if (category.equals(PortletCategoryKeys.SITE_ADMINISTRATION_CONTENT) && group.isLayout() && !portlet.isScopeable()) { return true; } return false; } protected boolean hasAccessPermissionExplicitlyGranted( PermissionChecker permissionChecker, Group group, Portlet portlet) throws PortalException { if (permissionChecker.isCompanyAdmin()) { return true; } String category = portlet.getControlPanelEntryCategory(); if (category == null) { category = StringPool.BLANK; } if (category.startsWith(PortletCategoryKeys.SITE_ADMINISTRATION)) { if (permissionChecker.isGroupAdmin(group.getGroupId()) && !group.isUser()) { return true; } } long groupId = group.getGroupId(); if (category.equals(PortletCategoryKeys.CONTROL_PANEL_APPS) || category.equals(PortletCategoryKeys.CONTROL_PANEL_CONFIGURATION) || category.equals(PortletCategoryKeys.CONTROL_PANEL_SITES) || category.equals(PortletCategoryKeys.CONTROL_PANEL_SYSTEM) || category.equals(PortletCategoryKeys.CONTROL_PANEL_USERS)) { groupId = 0; } List<String> actions = ResourceActionsUtil.getResourceActions( portlet.getPortletId()); if (actions.contains(ActionKeys.ACCESS_IN_CONTROL_PANEL) && PortletPermissionUtil.contains( permissionChecker, groupId, 0, portlet.getRootPortletId(), ActionKeys.ACCESS_IN_CONTROL_PANEL, true)) { return true; } return false; } protected boolean hasPermissionImplicitlyGranted( PermissionChecker permissionChecker, Group group, Portlet portlet) throws Exception { return false; } }