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.CreatePartySecurityRoleTemplateRoleForm;
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.control.security.server.logic.PartySecurityRoleTemplateLogic;
025import com.echothree.model.data.user.common.pk.UserVisitPK;
026import com.echothree.util.common.message.ExecutionErrors;
027import com.echothree.util.common.validation.FieldDefinition;
028import com.echothree.util.common.validation.FieldType;
029import com.echothree.util.common.command.BaseResult;
030import com.echothree.util.server.control.BaseSimpleCommand;
031import com.echothree.util.server.control.CommandSecurityDefinition;
032import com.echothree.util.server.control.PartyTypeDefinition;
033import com.echothree.util.server.control.SecurityRoleDefinition;
034import com.echothree.util.server.persistence.Session;
035import java.util.List;
036import javax.enterprise.context.Dependent;
037
038@Dependent
039public class CreatePartySecurityRoleTemplateRoleCommand
040        extends BaseSimpleCommand<CreatePartySecurityRoleTemplateRoleForm> {
041    
042    private final static CommandSecurityDefinition COMMAND_SECURITY_DEFINITION;
043    private final static List<FieldDefinition> FORM_FIELD_DEFINITIONS;
044    
045    static {
046        COMMAND_SECURITY_DEFINITION = new CommandSecurityDefinition(List.of(
047                new PartyTypeDefinition(PartyTypes.UTILITY.name(), null),
048                new PartyTypeDefinition(PartyTypes.EMPLOYEE.name(), List.of(
049                        new SecurityRoleDefinition(SecurityRoleGroups.PartySecurityRoleTemplateRole.name(), SecurityRoles.Create.name())
050                        ))
051                ));
052        
053        FORM_FIELD_DEFINITIONS = List.of(
054                new FieldDefinition("PartySecurityRoleTemplateName", FieldType.ENTITY_NAME, true, null, null),
055                new FieldDefinition("SecurityRoleGroupName", FieldType.ENTITY_NAME, true, null, null),
056                new FieldDefinition("SecurityRoleName", FieldType.ENTITY_NAME, false, null, null)
057                );
058    }
059    
060    /** Creates a new instance of CreatePartySecurityRoleTemplateRoleCommand */
061    public CreatePartySecurityRoleTemplateRoleCommand() {
062        super(COMMAND_SECURITY_DEFINITION, FORM_FIELD_DEFINITIONS, false);
063    }
064    
065    @Override
066    protected BaseResult execute() {
067        var securityControl = Session.getModelController(SecurityControl.class);
068        var partySecurityRoleTemplateName = form.getPartySecurityRoleTemplateName();
069        var partySecurityRoleTemplate = securityControl.getPartySecurityRoleTemplateByName(partySecurityRoleTemplateName);
070        
071        if(partySecurityRoleTemplate != null) {
072            var securityRoleGroupName = form.getSecurityRoleGroupName();
073            var securityRoleGroup = securityControl.getSecurityRoleGroupByName(securityRoleGroupName);
074            
075            if(securityRoleGroup != null) {
076                var securityRoleName = form.getSecurityRoleName();
077
078                if(securityRoleName == null) {
079                    var securityRoles = securityControl.getSecurityRoles(securityRoleGroup);
080
081                    // Pass 1: Check for duplicates.
082                    for(var securityRole : securityRoles) {
083                        var partySecurityRoleTemplateRole = securityControl.getPartySecurityRoleTemplateRole(partySecurityRoleTemplate,
084                                securityRole);
085
086                        if(partySecurityRoleTemplateRole != null) {
087                            addExecutionError(ExecutionErrors.DuplicatePartySecurityRoleTemplateRole.name(), partySecurityRoleTemplateName, securityRoleGroupName,
088                                    securityRole.getLastDetail().getSecurityRoleName());
089                            break;
090                        }
091                    }
092
093                    // Pass 2: Add Security Roles if there were no errors.
094                    if(!hasExecutionErrors()) {
095                        securityRoles.forEach((securityRole) -> {
096                            PartySecurityRoleTemplateLogic.getInstance().createPartySecurityRoleTemplateRole(partySecurityRoleTemplate, securityRole, getPartyPK());
097                        });
098                    }
099                } else {
100                    var securityRole = securityControl.getSecurityRoleByName(securityRoleGroup, securityRoleName);
101
102                    if(securityRole != null) {
103                        var partySecurityRoleTemplateRole = securityControl.getPartySecurityRoleTemplateRole(partySecurityRoleTemplate,
104                                securityRole);
105
106                        if(partySecurityRoleTemplateRole == null) {
107                            PartySecurityRoleTemplateLogic.getInstance().createPartySecurityRoleTemplateRole(partySecurityRoleTemplate, securityRole, getPartyPK());
108                        } else {
109                            addExecutionError(ExecutionErrors.DuplicatePartySecurityRoleTemplateRole.name(), partySecurityRoleTemplateName, securityRoleGroupName,
110                                    securityRoleName);
111                        }
112                    } else {
113                        addExecutionError(ExecutionErrors.UnknownSecurityRoleName.name(), securityRoleGroupName, securityRoleName);
114                    }
115                }
116            } else {
117                addExecutionError(ExecutionErrors.UnknownSecurityRoleGroupName.name(), securityRoleGroupName);
118            }
119        } else {
120            addExecutionError(ExecutionErrors.UnknownPartySecurityRoleTemplateName.name(), partySecurityRoleTemplateName);
121        }
122        
123        return null;
124    }
125    
126}