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.edit.SecurityEditFactory;
020import com.echothree.control.user.security.common.edit.SecurityRoleGroupDescriptionEdit;
021import com.echothree.control.user.security.common.form.EditSecurityRoleGroupDescriptionForm;
022import com.echothree.control.user.security.common.result.EditSecurityRoleGroupDescriptionResult;
023import com.echothree.control.user.security.common.result.SecurityResultFactory;
024import com.echothree.control.user.security.common.spec.SecurityRoleGroupDescriptionSpec;
025import com.echothree.model.control.party.common.PartyTypes;
026import com.echothree.model.control.party.server.control.PartyControl;
027import com.echothree.model.control.security.common.SecurityRoleGroups;
028import com.echothree.model.control.security.common.SecurityRoles;
029import com.echothree.model.control.security.server.control.SecurityControl;
030import com.echothree.model.data.security.server.entity.SecurityRoleGroup;
031import com.echothree.model.data.security.server.entity.SecurityRoleGroupDescription;
032import com.echothree.model.data.user.common.pk.UserVisitPK;
033import com.echothree.util.common.message.ExecutionErrors;
034import com.echothree.util.common.validation.FieldDefinition;
035import com.echothree.util.common.validation.FieldType;
036import com.echothree.util.common.command.EditMode;
037import com.echothree.util.server.control.BaseAbstractEditCommand;
038import com.echothree.util.server.control.CommandSecurityDefinition;
039import com.echothree.util.server.control.PartyTypeDefinition;
040import com.echothree.util.server.control.SecurityRoleDefinition;
041import com.echothree.util.server.persistence.Session;
042import java.util.List;
043import javax.enterprise.context.Dependent;
044
045@Dependent
046public class EditSecurityRoleGroupDescriptionCommand
047        extends BaseAbstractEditCommand<SecurityRoleGroupDescriptionSpec, SecurityRoleGroupDescriptionEdit, EditSecurityRoleGroupDescriptionResult, SecurityRoleGroupDescription, SecurityRoleGroup> {
048    
049    private final static CommandSecurityDefinition COMMAND_SECURITY_DEFINITION;
050    private final static List<FieldDefinition> SPEC_FIELD_DEFINITIONS;
051    private final static List<FieldDefinition> EDIT_FIELD_DEFINITIONS;
052    
053    static {
054        COMMAND_SECURITY_DEFINITION = new CommandSecurityDefinition(List.of(
055                new PartyTypeDefinition(PartyTypes.UTILITY.name(), null),
056                new PartyTypeDefinition(PartyTypes.EMPLOYEE.name(), List.of(
057                        new SecurityRoleDefinition(SecurityRoleGroups.SecurityRoleGroup.name(), SecurityRoles.Description.name())
058                        ))
059                ));
060        
061        SPEC_FIELD_DEFINITIONS = List.of(
062                new FieldDefinition("SecurityRoleGroupName", FieldType.ENTITY_NAME, true, null, null),
063                new FieldDefinition("LanguageIsoName", FieldType.ENTITY_NAME, true, null, null)
064                );
065        
066        EDIT_FIELD_DEFINITIONS = List.of(
067                new FieldDefinition("Description", FieldType.STRING, true, 1L, 132L)
068                );
069    }
070    
071    /** Creates a new instance of EditSecurityRoleGroupDescriptionCommand */
072    public EditSecurityRoleGroupDescriptionCommand() {
073        super(COMMAND_SECURITY_DEFINITION, SPEC_FIELD_DEFINITIONS, EDIT_FIELD_DEFINITIONS);
074    }
075
076    @Override
077    public EditSecurityRoleGroupDescriptionResult getResult() {
078        return SecurityResultFactory.getEditSecurityRoleGroupDescriptionResult();
079    }
080
081    @Override
082    public SecurityRoleGroupDescriptionEdit getEdit() {
083        return SecurityEditFactory.getSecurityRoleGroupDescriptionEdit();
084    }
085
086    @Override
087    public SecurityRoleGroupDescription getEntity(EditSecurityRoleGroupDescriptionResult result) {
088        var securityControl = Session.getModelController(SecurityControl.class);
089        SecurityRoleGroupDescription securityRoleGroupDescription = null;
090        var securityRoleGroupName = spec.getSecurityRoleGroupName();
091        var securityRoleGroup = securityControl.getSecurityRoleGroupByName(securityRoleGroupName);
092
093        if(securityRoleGroup != null) {
094            var partyControl = Session.getModelController(PartyControl.class);
095            var languageIsoName = spec.getLanguageIsoName();
096            var language = partyControl.getLanguageByIsoName(languageIsoName);
097
098            if(language != null) {
099                if(editMode.equals(EditMode.LOCK) || editMode.equals(EditMode.ABANDON)) {
100                    securityRoleGroupDescription = securityControl.getSecurityRoleGroupDescription(securityRoleGroup, language);
101                } else { // EditMode.UPDATE
102                    securityRoleGroupDescription = securityControl.getSecurityRoleGroupDescriptionForUpdate(securityRoleGroup, language);
103                }
104
105                if(securityRoleGroupDescription == null) {
106                    addExecutionError(ExecutionErrors.UnknownSecurityRoleGroupDescription.name(), securityRoleGroupName, languageIsoName);
107                }
108            } else {
109                addExecutionError(ExecutionErrors.UnknownLanguageIsoName.name(), languageIsoName);
110            }
111        } else {
112            addExecutionError(ExecutionErrors.UnknownSecurityRoleGroupName.name(), securityRoleGroupName);
113        }
114
115        return securityRoleGroupDescription;
116    }
117
118    @Override
119    public SecurityRoleGroup getLockEntity(SecurityRoleGroupDescription securityRoleGroupDescription) {
120        return securityRoleGroupDescription.getSecurityRoleGroup();
121    }
122
123    @Override
124    public void fillInResult(EditSecurityRoleGroupDescriptionResult result, SecurityRoleGroupDescription securityRoleGroupDescription) {
125        var securityControl = Session.getModelController(SecurityControl.class);
126
127        result.setSecurityRoleGroupDescription(securityControl.getSecurityRoleGroupDescriptionTransfer(getUserVisit(), securityRoleGroupDescription));
128    }
129
130    @Override
131    public void doLock(SecurityRoleGroupDescriptionEdit edit, SecurityRoleGroupDescription securityRoleGroupDescription) {
132        edit.setDescription(securityRoleGroupDescription.getDescription());
133    }
134
135    @Override
136    public void doUpdate(SecurityRoleGroupDescription securityRoleGroupDescription) {
137        var securityControl = Session.getModelController(SecurityControl.class);
138        var securityRoleGroupDescriptionValue = securityControl.getSecurityRoleGroupDescriptionValue(securityRoleGroupDescription);
139        
140        securityRoleGroupDescriptionValue.setDescription(edit.getDescription());
141        
142        securityControl.updateSecurityRoleGroupDescriptionFromValue(securityRoleGroupDescriptionValue, getPartyPK());
143    }
144
145    
146}