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}