/** * 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.site.memberships.web.internal.portlet; import com.liferay.portal.kernel.model.Group; import com.liferay.portal.kernel.model.Portlet; import com.liferay.portal.kernel.portlet.BaseControlPanelEntry; import com.liferay.portal.kernel.portlet.ControlPanelEntry; import com.liferay.portal.kernel.security.permission.ActionKeys; import com.liferay.portal.kernel.security.permission.PermissionChecker; import com.liferay.portal.kernel.service.permission.GroupPermissionUtil; import com.liferay.site.memberships.web.internal.constants.SiteMembershipsPortletKeys; import org.osgi.service.component.annotations.Component; /** * @author Raymond Augé * @author Jorge Ferrer */ @Component( immediate = true, property = {"javax.portlet.name=" + SiteMembershipsPortletKeys.SITE_MEMBERSHIPS_ADMIN}, service = ControlPanelEntry.class ) public class SiteMembershipsControlPanelEntry extends BaseControlPanelEntry { @Override protected boolean hasAccessPermissionDenied( PermissionChecker permissionChecker, Group group, Portlet portlet) throws Exception { if (group.isCompany() || group.isLayoutSetPrototype() || !group.isManualMembership() || group.isUser()) { return true; } return super.hasAccessPermissionDenied( permissionChecker, group, portlet); } @Override protected boolean hasPermissionImplicitlyGranted( PermissionChecker permissionChecker, Group group, Portlet portlet) throws Exception { if (GroupPermissionUtil.contains( permissionChecker, group, ActionKeys.ASSIGN_MEMBERS)) { return true; } return super.hasPermissionImplicitlyGranted( permissionChecker, group, portlet); } }