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