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.form.GetSecurityRoleForm;
020import com.echothree.control.user.security.common.result.SecurityResultFactory;
021import com.echothree.model.control.core.common.EventTypes;
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.control.security.server.control.SecurityControl;
026import com.echothree.model.control.security.server.logic.SecurityRoleLogic;
027import com.echothree.model.data.security.server.entity.SecurityRole;
028import com.echothree.model.data.user.common.pk.UserVisitPK;
029import com.echothree.util.common.command.BaseResult;
030import com.echothree.util.common.validation.FieldDefinition;
031import com.echothree.util.common.validation.FieldType;
032import com.echothree.util.server.control.BaseSingleEntityCommand;
033import com.echothree.util.server.control.CommandSecurityDefinition;
034import com.echothree.util.server.control.PartyTypeDefinition;
035import com.echothree.util.server.control.SecurityRoleDefinition;
036import com.echothree.util.server.persistence.Session;
037import java.util.List;
038
039public class GetSecurityRoleCommand
040        extends BaseSingleEntityCommand<SecurityRole, GetSecurityRoleForm> {
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.SecurityRole.name(), SecurityRoles.Review.name())
050                ))
051        ));
052
053        FORM_FIELD_DEFINITIONS = List.of(
054                new FieldDefinition("SecurityRoleGroupName", FieldType.ENTITY_NAME, false, null, null),
055                new FieldDefinition("SecurityRoleName", FieldType.ENTITY_NAME, false, null, null),
056                new FieldDefinition("EntityRef", FieldType.ENTITY_REF, false, null, null),
057                new FieldDefinition("Key", FieldType.KEY, false, null, null),
058                new FieldDefinition("Guid", FieldType.GUID, false, null, null),
059                new FieldDefinition("Ulid", FieldType.ULID, false, null, null)
060        );
061    }
062    
063    /** Creates a new instance of GetSecurityRoleCommand */
064    public GetSecurityRoleCommand(UserVisitPK userVisitPK, GetSecurityRoleForm form) {
065        super(userVisitPK, form, COMMAND_SECURITY_DEFINITION, FORM_FIELD_DEFINITIONS, true);
066    }
067
068    @Override
069    protected SecurityRole getEntity() {
070        var securityRole = SecurityRoleLogic.getInstance().getSecurityRoleByUniversalSpec(this, form, true);
071
072        if(securityRole != null) {
073            sendEvent(securityRole.getPrimaryKey(), EventTypes.READ, null, null, getPartyPK());
074        }
075
076        return securityRole;
077    }
078
079    @Override
080    protected BaseResult getResult(SecurityRole securityRole) {
081        var result = SecurityResultFactory.getGetSecurityRoleResult();
082
083        if(securityRole != null) {
084            var securityControl = Session.getModelController(SecurityControl.class);
085
086            result.setSecurityRole(securityControl.getSecurityRoleTransfer(getUserVisit(), securityRole));
087        }
088
089        return result;
090    }
091
092}