001// -------------------------------------------------------------------------------- 002// Copyright 2002-2024 Echo Three, LLC 003// 004// Licensed under the Apache License, Version 2.0 (the "License"); 005// you may not use this file except in compliance with the License. 006// You may obtain a copy of the License at 007// 008// http://www.apache.org/licenses/LICENSE-2.0 009// 010// Unless required by applicable law or agreed to in writing, software 011// distributed under the License is distributed on an "AS IS" BASIS, 012// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013// See the License for the specific language governing permissions and 014// limitations under the License. 015// -------------------------------------------------------------------------------- 016 017package com.echothree.control.user.security.server.command; 018 019import com.echothree.control.user.security.common.form.GetSecurityRolesForm; 020import com.echothree.control.user.security.common.result.SecurityResultFactory; 021import com.echothree.model.control.party.common.PartyTypes; 022import com.echothree.model.control.security.common.SecurityRoleGroups; 023import com.echothree.model.control.security.common.SecurityRoles; 024import com.echothree.model.control.security.server.control.SecurityControl; 025import com.echothree.model.control.security.server.logic.SecurityRoleGroupLogic; 026import com.echothree.model.data.security.server.entity.SecurityRole; 027import com.echothree.model.data.security.server.entity.SecurityRoleGroup; 028import com.echothree.model.data.user.common.pk.UserVisitPK; 029import com.echothree.util.common.command.BaseResult; 030import com.echothree.util.common.validation.FieldDefinition; 031import com.echothree.util.common.validation.FieldType; 032import com.echothree.util.server.control.BasePaginatedMultipleEntitiesCommand; 033import com.echothree.util.server.control.CommandSecurityDefinition; 034import com.echothree.util.server.control.PartyTypeDefinition; 035import com.echothree.util.server.control.SecurityRoleDefinition; 036import com.echothree.util.server.persistence.Session; 037import java.util.Collection; 038import java.util.List; 039 040public class GetSecurityRolesCommand 041 extends BasePaginatedMultipleEntitiesCommand<SecurityRole, GetSecurityRolesForm> { 042 043 private final static CommandSecurityDefinition COMMAND_SECURITY_DEFINITION; 044 private final static List<FieldDefinition> FORM_FIELD_DEFINITIONS; 045 046 static { 047 COMMAND_SECURITY_DEFINITION = new CommandSecurityDefinition(List.of( 048 new PartyTypeDefinition(PartyTypes.UTILITY.name(), null), 049 new PartyTypeDefinition(PartyTypes.EMPLOYEE.name(), List.of( 050 new SecurityRoleDefinition(SecurityRoleGroups.SecurityRole.name(), SecurityRoles.List.name()) 051 )) 052 )); 053 054 FORM_FIELD_DEFINITIONS = List.of( 055 new FieldDefinition("SecurityRoleGroupName", FieldType.ENTITY_NAME, true, null, null) 056 ); 057 } 058 059 /** Creates a new instance of GetSecurityRolesCommand */ 060 public GetSecurityRolesCommand(UserVisitPK userVisitPK, GetSecurityRolesForm form) { 061 super(userVisitPK, form, COMMAND_SECURITY_DEFINITION, FORM_FIELD_DEFINITIONS, true); 062 } 063 064 SecurityRoleGroup securityRoleGroup; 065 066 @Override 067 protected void handleForm() { 068 var securityRoleGroupName = form.getSecurityRoleGroupName(); 069 070 securityRoleGroup = SecurityRoleGroupLogic.getInstance().getSecurityRoleGroupByName(this, securityRoleGroupName); 071 } 072 073 @Override 074 protected Long getTotalEntities() { 075 var securityControl = Session.getModelController(SecurityControl.class); 076 077 return hasExecutionErrors() ? null : 078 securityControl.countSecurityRolesBySecurityRoleGroup(securityRoleGroup); 079 } 080 081 @Override 082 protected Collection<SecurityRole> getEntities() { 083 Collection<SecurityRole> entities = null; 084 085 if(!hasExecutionErrors()) { 086 var securityControl = Session.getModelController(SecurityControl.class); 087 088 entities = securityControl.getSecurityRoles(securityRoleGroup); 089 } 090 091 return entities; 092 } 093 094 @Override 095 protected BaseResult getResult(Collection<SecurityRole> entities) { 096 var result = SecurityResultFactory.getGetSecurityRolesResult(); 097 var securityControl = Session.getModelController(SecurityControl.class); 098 var userVisit = getUserVisit(); 099 100 result.setSecurityRoleGroup(securityControl.getSecurityRoleGroupTransfer(userVisit, securityRoleGroup)); 101 102 if(entities != null) { 103 result.setSecurityRoles(securityControl.getSecurityRoleTransfers(userVisit, entities)); 104 } 105 106 return result; 107 } 108 109}