ExternalFeaturesJspBean.java
/*
* Copyright (c) 2002-2022, City of Paris
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright notice
* and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice
* and the following disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* 3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
* License 1.0
*/
package fr.paris.lutece.portal.web.features;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import fr.paris.lutece.portal.business.right.FeatureGroup;
import fr.paris.lutece.portal.business.right.FeatureGroupHome;
import fr.paris.lutece.portal.business.right.Level;
import fr.paris.lutece.portal.business.right.LevelHome;
import fr.paris.lutece.portal.business.right.Right;
import fr.paris.lutece.portal.business.right.RightHome;
import fr.paris.lutece.portal.business.user.AdminUser;
import fr.paris.lutece.portal.service.admin.AccessDeniedException;
import fr.paris.lutece.portal.service.admin.AdminUserService;
import fr.paris.lutece.portal.service.message.AdminMessage;
import fr.paris.lutece.portal.service.message.AdminMessageService;
import fr.paris.lutece.portal.service.security.SecurityTokenService;
import fr.paris.lutece.portal.service.template.AppTemplateService;
import fr.paris.lutece.portal.web.admin.AdminFeaturesPageJspBean;
import fr.paris.lutece.util.ReferenceList;
import fr.paris.lutece.util.html.HtmlTemplate;
/**
*
* @author closea
*/
public class ExternalFeaturesJspBean extends AdminFeaturesPageJspBean
{
private static final long serialVersionUID = -5179996626579180810L;
// Properties
private static final String PROPERTY_CREATE_EXTERNAL_FEATURE_PAGETITLE = "portal.features.create_external_feature.pageTitle";
private static final String PROPERTY_MODIFY_EXTERNAL_FEATURE_PAGETITLE = "portal.features.modify_external_feature.pageTitle";
// Templates
private static final String TEMPLATE_CREATE_EXTERNAL_FEATURE = "admin/features/create_external_feature.html";
private static final String TEMPLATE_MODIFY_EXTERNAL_FEATURE = "admin/features/modify_external_feature.html";
// Messages
private static final String MESSAGE_CONFIRM_DELETE = "portal.features.delete_external_feature.confirmDeleteExternalFeature";
// Parameters
private static final String PARAMETER_ID_FEATURE_GROUP = "feature_group_id";
private static final String PARAMETER_ID_EXTERNAL_FEATURE = "external_feature_id";
private static final String PARAMETER_ID_LEVEL = "level_id";
// JSP
private static final String JSP_DELETE_EXTERNAL_FEATURE = "jsp/admin/features/DoRemoveExternalFeature.jsp";
// Rights
public static final String RIGHT_EXTERNAL_FEATURES_MANAGEMENT = "CORE_FEATURES_MANAGEMENT";
// Markers
private static final String MARK_EXTERNAL_FEATURE = "external_feature";
private static final String MARK_FEATURES_GROUPS_REFERENCE_LIST = "features_groups_labels_list";
private static final String MARK_RIGHT_LEVELS_REFERENCE_LIST = "right_levels_labels_list";
private static final String ANCHOR_ADMIN_DASHBOARDS = "external_features";
private Right _externalFeature;
public String getCreateExternalFeature( HttpServletRequest request )
{
setPageTitleProperty( PROPERTY_CREATE_EXTERNAL_FEATURE_PAGETITLE );
Map<String, Object> model = new HashMap<>( );
Collection<FeatureGroup> featureGroups = FeatureGroupHome.getFeatureGroupsList( );
ReferenceList featureGroupsReferenceList = new ReferenceList( );
for ( FeatureGroup featureGroup : featureGroups )
{
featureGroup.setLocale( getUser( ).getLocale( ) );
featureGroupsReferenceList.add( featureGroup.getReferenceItem( ) );
}
model.put( MARK_FEATURES_GROUPS_REFERENCE_LIST, featureGroupsReferenceList );
Collection<Level> rightLevels = LevelHome.getLevelsList( );
ReferenceList rightLevelsReferenceList = new ReferenceList( );
for ( Level rightLevel : rightLevels )
{
rightLevelsReferenceList.add( rightLevel.getReferenceItem( ) );
}
model.put( MARK_RIGHT_LEVELS_REFERENCE_LIST, rightLevelsReferenceList );
model.put( SecurityTokenService.MARK_TOKEN, SecurityTokenService.getInstance( ).getToken( request, TEMPLATE_CREATE_EXTERNAL_FEATURE ) );
HtmlTemplate template = AppTemplateService.getTemplate( TEMPLATE_CREATE_EXTERNAL_FEATURE, getLocale( ), model );
return getAdminPage( template.getHtml( ) );
}
public String doCreateExternalFeature( HttpServletRequest request ) throws AccessDeniedException
{
if ( !SecurityTokenService.getInstance( ).validate( request, TEMPLATE_CREATE_EXTERNAL_FEATURE ) )
{
throw new AccessDeniedException( ERROR_INVALID_TOKEN );
}
_externalFeature = new Right( );
populate( _externalFeature, request );
_externalFeature.setFeatureGroup( FeatureGroupHome.findByPrimaryKey( request.getParameter( PARAMETER_ID_FEATURE_GROUP ) ).getId( ) );
_externalFeature.setExternalFeature( true );
_externalFeature.setLevel( Integer.parseInt( request.getParameter( PARAMETER_ID_LEVEL ) ) );
RightHome.create( _externalFeature );
return getAdminDashboardsUrl( request, ANCHOR_ADMIN_DASHBOARDS );
}
public String getRemoveExternalFeature( HttpServletRequest request )
{
String strExternalFeatureId = request.getParameter( PARAMETER_ID_EXTERNAL_FEATURE );
_externalFeature = RightHome.findByPrimaryKey( strExternalFeatureId );
_externalFeature.setLocale( getUser( ).getLocale( ) );
Object [ ] messageArgs = {
_externalFeature.getName( )
};
Map<String, Object> parameters = new HashMap<>( );
parameters.put( PARAMETER_ID_EXTERNAL_FEATURE, strExternalFeatureId );
parameters.put( SecurityTokenService.PARAMETER_TOKEN, SecurityTokenService.getInstance( ).getToken( request, JSP_DELETE_EXTERNAL_FEATURE ) );
return AdminMessageService.getMessageUrl( request, MESSAGE_CONFIRM_DELETE, messageArgs, null, JSP_DELETE_EXTERNAL_FEATURE, "",
AdminMessage.TYPE_CONFIRMATION, parameters );
}
public String doRemoveExternalFeature( HttpServletRequest request ) throws AccessDeniedException
{
if ( !SecurityTokenService.getInstance( ).validate( request, JSP_DELETE_EXTERNAL_FEATURE ) )
{
throw new AccessDeniedException( ERROR_INVALID_TOKEN );
}
RightHome.remove( _externalFeature.getId( ) );
return getAdminDashboardsUrl( request, ANCHOR_ADMIN_DASHBOARDS );
}
public String getModifyExternalFeature( HttpServletRequest request )
{
setPageTitleProperty( PROPERTY_MODIFY_EXTERNAL_FEATURE_PAGETITLE );
Map<String, Object> model = new HashMap<>( );
String strExternalFeatureId = request.getParameter( PARAMETER_ID_EXTERNAL_FEATURE );
_externalFeature = RightHome.findByPrimaryKey( strExternalFeatureId );
model.put( MARK_EXTERNAL_FEATURE, _externalFeature );
Collection<FeatureGroup> featureGroups = FeatureGroupHome.getFeatureGroupsList( );
ReferenceList featureGroupsReferenceList = new ReferenceList( );
for ( FeatureGroup featureGroup : featureGroups )
{
featureGroup.setLocale( getUser( ).getLocale( ) );
featureGroupsReferenceList.add( featureGroup.getReferenceItem( ) );
}
model.put( MARK_FEATURES_GROUPS_REFERENCE_LIST, featureGroupsReferenceList );
Collection<Level> rightLevels = LevelHome.getLevelsList( );
ReferenceList rightLevelsReferenceList = new ReferenceList( );
for ( Level rightLevel : rightLevels )
{
rightLevelsReferenceList.add( rightLevel.getReferenceItem( ) );
}
model.put( MARK_RIGHT_LEVELS_REFERENCE_LIST, rightLevelsReferenceList );
model.put( SecurityTokenService.MARK_TOKEN, SecurityTokenService.getInstance( ).getToken( request, TEMPLATE_MODIFY_EXTERNAL_FEATURE ) );
HtmlTemplate template = AppTemplateService.getTemplate( TEMPLATE_MODIFY_EXTERNAL_FEATURE, getLocale( ), model );
return getAdminPage( template.getHtml( ) );
}
public String doModifyExternalFeature( HttpServletRequest request ) throws AccessDeniedException
{
if ( !SecurityTokenService.getInstance( ).validate( request, TEMPLATE_MODIFY_EXTERNAL_FEATURE ) )
{
throw new AccessDeniedException( ERROR_INVALID_TOKEN );
}
int nIdOrder = _externalFeature.getOrder( );
String strIdExternalFeature = _externalFeature.getId( );
_externalFeature = new Right( );
populate( _externalFeature, request );
_externalFeature.setId( strIdExternalFeature );
_externalFeature.setFeatureGroup( FeatureGroupHome.findByPrimaryKey( request.getParameter( PARAMETER_ID_FEATURE_GROUP ) ).getId( ) );
_externalFeature.setExternalFeature( true );
_externalFeature.setOrder( nIdOrder );
_externalFeature.setLevel( Integer.parseInt( request.getParameter( PARAMETER_ID_LEVEL ) ) );
RightHome.update( _externalFeature );
// update this right for user if he or she already have it
AdminUser user = AdminUserService.getAdminUser( request );
if ( user.checkRight( _externalFeature.getId( ) ) )
{
user.updateRight( _externalFeature );
}
return getAdminDashboardsUrl( request, ANCHOR_ADMIN_DASHBOARDS );
}
}