001// -------------------------------------------------------------------------------- 002// Copyright 2002-2026 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.user.common.pk.UserVisitPK; 025import com.echothree.util.common.message.ExecutionErrors; 026import com.echothree.util.common.validation.FieldDefinition; 027import com.echothree.util.common.validation.FieldType; 028import com.echothree.util.common.command.BaseResult; 029import com.echothree.util.server.control.BaseSimpleCommand; 030import com.echothree.util.server.control.CommandSecurityDefinition; 031import com.echothree.util.server.control.PartyTypeDefinition; 032import com.echothree.util.server.control.SecurityRoleDefinition; 033import com.echothree.util.server.persistence.Session; 034import java.util.List; 035import javax.enterprise.context.Dependent; 036 037@Dependent 038public class SetDefaultSecurityRoleCommand 039 extends BaseSimpleCommand<SetDefaultSecurityRoleForm> { 040 041 private final static CommandSecurityDefinition COMMAND_SECURITY_DEFINITION; 042 private final static List<FieldDefinition> FORM_FIELD_DEFINITIONS; 043 044 static { 045 COMMAND_SECURITY_DEFINITION = new CommandSecurityDefinition(List.of( 046 new PartyTypeDefinition(PartyTypes.EMPLOYEE.name(), List.of( 047 new SecurityRoleDefinition(SecurityRoleGroups.SecurityRole.name(), SecurityRoles.Edit.name()) 048 )) 049 )); 050 051 FORM_FIELD_DEFINITIONS = List.of( 052 new FieldDefinition("SecurityRoleGroupName", FieldType.ENTITY_NAME, true, null, null), 053 new FieldDefinition("SecurityRoleName", FieldType.ENTITY_NAME, true, null, null) 054 ); 055 } 056 057 /** Creates a new instance of SetDefaultSecurityRoleCommand */ 058 public SetDefaultSecurityRoleCommand() { 059 super(COMMAND_SECURITY_DEFINITION, FORM_FIELD_DEFINITIONS, false); 060 } 061 062 @Override 063 protected BaseResult execute() { 064 var securityControl = Session.getModelController(SecurityControl.class); 065 var securityRoleGroupName = form.getSecurityRoleGroupName(); 066 var securityRoleGroup = securityControl.getSecurityRoleGroupByName(securityRoleGroupName); 067 068 if(securityRoleGroup != null) { 069 var securityRoleName = form.getSecurityRoleName(); 070 var securityRoleDetailValue = securityControl.getSecurityRoleDetailValueByNameForUpdate(securityRoleGroup, 071 securityRoleName); 072 073 if(securityRoleDetailValue != null) { 074 securityRoleDetailValue.setIsDefault(true); 075 securityControl.updateSecurityRoleFromValue(securityRoleDetailValue, getPartyPK()); 076 } else { 077 addExecutionError(ExecutionErrors.UnknownSecurityRoleName.name(), securityRoleGroupName, securityRoleName); 078 } 079 } else { 080 addExecutionError(ExecutionErrors.DuplicateSecurityRoleGroupName.name(), securityRoleGroupName); 081 } 082 083 return null; 084 } 085 086}