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.model.control.security.server.transfer; 018 019import javax.inject.Inject; 020import com.echothree.model.control.security.common.SecurityOptions; 021import com.echothree.model.control.security.common.transfer.SecurityRoleGroupTransfer; 022import com.echothree.model.control.security.common.transfer.SecurityRoleTransfer; 023import com.echothree.model.control.security.server.control.SecurityControl; 024import com.echothree.model.data.security.server.entity.SecurityRoleGroup; 025import com.echothree.model.data.user.server.entity.UserVisit; 026import com.echothree.util.common.transfer.MapWrapper; 027import javax.enterprise.context.RequestScoped; 028 029@RequestScoped 030public class SecurityRoleGroupTransferCache 031 extends BaseSecurityTransferCache<SecurityRoleGroup, SecurityRoleGroupTransfer> { 032 033 @Inject 034 SecurityControl securityControl; 035 036 boolean includeSecurityRolesCount; 037 boolean includeSecurityRoles; 038 039 /** Creates a new instance of SecurityRoleGroupTransferCache */ 040 protected SecurityRoleGroupTransferCache() { 041 super(); 042 043 var options = session.getOptions(); 044 if(options != null) { 045 includeSecurityRolesCount = options.contains(SecurityOptions.SecurityRoleGroupIncludeSecurityRolesCount); 046 includeSecurityRoles = options.contains(SecurityOptions.SecurityRoleGroupIncludeSecurityRoles); 047 } 048 049 setIncludeEntityInstance(true); 050 } 051 052 public SecurityRoleGroupTransfer getSecurityRoleGroupTransfer(UserVisit userVisit, SecurityRoleGroup securityRoleGroup) { 053 var securityRoleGroupTransfer = get(securityRoleGroup); 054 055 if(securityRoleGroupTransfer == null) { 056 var securityRoleGroupDetail = securityRoleGroup.getLastDetail(); 057 var securityRoleGroupName = securityRoleGroupDetail.getSecurityRoleGroupName(); 058 var parentSecurityRoleGroup = securityRoleGroupDetail.getParentSecurityRoleGroup(); 059 var parentSecurityRoleGroupTransfer = parentSecurityRoleGroup == null ? null : getSecurityRoleGroupTransfer(userVisit, parentSecurityRoleGroup); 060 var isDefault = securityRoleGroupDetail.getIsDefault(); 061 var sortOrder = securityRoleGroupDetail.getSortOrder(); 062 var description = securityControl.getBestSecurityRoleGroupDescription(securityRoleGroup, getLanguage(userVisit)); 063 064 securityRoleGroupTransfer = new SecurityRoleGroupTransfer(securityRoleGroupName, parentSecurityRoleGroupTransfer, isDefault, sortOrder, description); 065 put(userVisit, securityRoleGroup, securityRoleGroupTransfer); 066 067 if(includeSecurityRolesCount) { 068 securityRoleGroupTransfer.setSecurityRoleCount(securityControl.countSecurityRolesBySecurityRoleGroup(securityRoleGroup)); 069 } 070 071 if(includeSecurityRoles) { 072 var securityRoleTransfers = securityControl.getSecurityRoleTransfersBySecurityRoleGroup(userVisit, securityRoleGroup); 073 var securityRoles = new MapWrapper<SecurityRoleTransfer>(securityRoleTransfers.size()); 074 075 securityRoleTransfers.forEach((securityRoleTransfer) -> { 076 securityRoles.put(securityRoleTransfer.getSecurityRoleName(), securityRoleTransfer); 077 }); 078 079 securityRoleGroupTransfer.setSecurityRoles(securityRoles); 080 } 081 } 082 083 return securityRoleGroupTransfer; 084 } 085 086}