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.SetDefaultSecurityRoleForm; 020import com.echothree.model.control.party.common.PartyTypes; 021import com.echothree.model.control.security.common.SecurityRoleGroups; 022import com.echothree.model.control.security.common.SecurityRoles; 023import com.echothree.model.control.security.server.control.SecurityControl; 024import com.echothree.model.data.security.server.entity.SecurityRoleGroup; 025import com.echothree.model.data.security.server.value.SecurityRoleDetailValue; 026import com.echothree.model.data.user.common.pk.UserVisitPK; 027import com.echothree.util.common.message.ExecutionErrors; 028import com.echothree.util.common.validation.FieldDefinition; 029import com.echothree.util.common.validation.FieldType; 030import com.echothree.util.common.command.BaseResult; 031import com.echothree.util.server.control.BaseSimpleCommand; 032import com.echothree.util.server.control.CommandSecurityDefinition; 033import com.echothree.util.server.control.PartyTypeDefinition; 034import com.echothree.util.server.control.SecurityRoleDefinition; 035import com.echothree.util.server.persistence.Session; 036import java.util.Arrays; 037import java.util.Collections; 038import java.util.List; 039 040public class SetDefaultSecurityRoleCommand 041 extends BaseSimpleCommand<SetDefaultSecurityRoleForm> { 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(Collections.unmodifiableList(Arrays.asList( 048 new PartyTypeDefinition(PartyTypes.EMPLOYEE.name(), Collections.unmodifiableList(Arrays.asList( 049 new SecurityRoleDefinition(SecurityRoleGroups.SecurityRole.name(), SecurityRoles.Edit.name()) 050 ))) 051 ))); 052 053 FORM_FIELD_DEFINITIONS = Collections.unmodifiableList(Arrays.asList( 054 new FieldDefinition("SecurityRoleGroupName", FieldType.ENTITY_NAME, true, null, null), 055 new FieldDefinition("SecurityRoleName", FieldType.ENTITY_NAME, true, null, null) 056 )); 057 } 058 059 /** Creates a new instance of SetDefaultSecurityRoleCommand */ 060 public SetDefaultSecurityRoleCommand(UserVisitPK userVisitPK, SetDefaultSecurityRoleForm form) { 061 super(userVisitPK, form, COMMAND_SECURITY_DEFINITION, FORM_FIELD_DEFINITIONS, false); 062 } 063 064 @Override 065 protected BaseResult execute() { 066 var securityControl = Session.getModelController(SecurityControl.class); 067 String securityRoleGroupName = form.getSecurityRoleGroupName(); 068 SecurityRoleGroup securityRoleGroup = securityControl.getSecurityRoleGroupByName(securityRoleGroupName); 069 070 if(securityRoleGroup != null) { 071 String securityRoleName = form.getSecurityRoleName(); 072 SecurityRoleDetailValue securityRoleDetailValue = securityControl.getSecurityRoleDetailValueByNameForUpdate(securityRoleGroup, 073 securityRoleName); 074 075 if(securityRoleDetailValue != null) { 076 securityRoleDetailValue.setIsDefault(Boolean.TRUE); 077 securityControl.updateSecurityRoleFromValue(securityRoleDetailValue, getPartyPK()); 078 } else { 079 addExecutionError(ExecutionErrors.UnknownSecurityRoleName.name(), securityRoleGroupName, securityRoleName); 080 } 081 } else { 082 addExecutionError(ExecutionErrors.DuplicateSecurityRoleGroupName.name(), securityRoleGroupName); 083 } 084 085 return null; 086 } 087 088}