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.core.server.command; 018 019import com.echothree.control.user.core.common.form.GetBaseEncryptionKeyForm; 020import com.echothree.control.user.core.common.result.CoreResultFactory; 021import com.echothree.model.control.core.server.control.EncryptionKeyControl; 022import com.echothree.model.control.party.common.PartyTypes; 023import com.echothree.model.control.security.common.SecurityRoleGroups; 024import com.echothree.model.control.security.common.SecurityRoles; 025import com.echothree.model.data.user.common.pk.UserVisitPK; 026import com.echothree.util.common.command.BaseResult; 027import com.echothree.util.common.message.ExecutionErrors; 028import com.echothree.util.common.validation.FieldDefinition; 029import com.echothree.util.common.validation.FieldType; 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 GetBaseEncryptionKeyCommand 040 extends BaseSimpleCommand<GetBaseEncryptionKeyForm> { 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.BaseEncryptionKey.name(), SecurityRoles.Review.name()) 050 )) 051 )); 052 053 FORM_FIELD_DEFINITIONS = List.of( 054 new FieldDefinition("BaseEncryptionKeyName", FieldType.ENTITY_NAME, false, null, null) 055 ); 056 } 057 058 /** Creates a new instance of GetBaseEncryptionKeyCommand */ 059 public GetBaseEncryptionKeyCommand() { 060 super(COMMAND_SECURITY_DEFINITION, FORM_FIELD_DEFINITIONS, false); 061 } 062 063 @Override 064 protected BaseResult execute() { 065 var encryptionKeyControl = Session.getModelController(EncryptionKeyControl.class); 066 var result = CoreResultFactory.getGetBaseEncryptionKeyResult(); 067 var baseEncryptionKeyName = form.getBaseEncryptionKeyName(); 068 var baseEncryptionKey = baseEncryptionKeyName == null? null: encryptionKeyControl.getBaseEncryptionKeyByName(baseEncryptionKeyName); 069 070 if(baseEncryptionKeyName == null || baseEncryptionKey != null) { 071 var userVisit = getUserVisit(); 072 073 if(baseEncryptionKey == null) { 074 result.setBaseEncryptionKey(encryptionKeyControl.getActiveBaseEncryptionKeyTransfer(userVisit)); 075 } else { 076 result.setBaseEncryptionKey(encryptionKeyControl.getBaseEncryptionKeyTransfer(userVisit, baseEncryptionKey)); 077 } 078 } else { 079 addExecutionError(ExecutionErrors.UnknownBaseEncryptionKeyName.name(), baseEncryptionKeyName); 080 } 081 082 return result; 083 } 084 085}