/* * Copyright (c) 2015, WSO2 Inc. (http://www.wso2.org) All Rights Reserved. * * WSO2 Inc. licenses this file to you under the Apache License, * Version 2.0 (the "License"); you may not use this file except * in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ package org.wso2.carbon.identity.application.authentication.framework.inbound; import org.wso2.carbon.base.MultitenantConstants; import org.wso2.carbon.identity.application.authentication.framework.store.SessionDataStore; import org.wso2.carbon.identity.application.common.cache.BaseCache; import org.wso2.carbon.identity.core.util.IdentityTenantUtil; import org.wso2.carbon.identity.core.util.IdentityUtil; public class InboundAuthenticationContextCache extends BaseCache<InboundAuthenticationContextCacheKey, InboundAuthenticationContextCacheEntry> { private static final String INBOUND_AUTHENTICATION_CONTEXT_CACHE_NAME = "InboundAuthenticationContextCache"; private static volatile InboundAuthenticationContextCache instance; private boolean enableRequestScopeCache = false; private InboundAuthenticationContextCache(String cacheName) { super(cacheName); if (IdentityUtil.getProperty("JDBCPersistenceManager.SessionDataPersist.Temporary") != null) { enableRequestScopeCache = Boolean .parseBoolean(IdentityUtil.getProperty("JDBCPersistenceManager.SessionDataPersist.Temporary")); } } public static InboundAuthenticationContextCache getInstance() { if (instance == null) { synchronized (InboundAuthenticationContextCache.class) { if (instance == null) { instance = new InboundAuthenticationContextCache(INBOUND_AUTHENTICATION_CONTEXT_CACHE_NAME); } } } return instance; } public void addToCache(InboundAuthenticationContextCacheKey key, InboundAuthenticationContextCacheEntry entry) { super.addToCache(key, entry); if (enableRequestScopeCache) { int tenantId = MultitenantConstants.INVALID_TENANT_ID; String tenantDomain = entry.getInboundAuthenticationContext().getTenantDomain(); if (tenantDomain != null) { tenantId = IdentityTenantUtil.getTenantId(tenantDomain); } SessionDataStore.getInstance().storeSessionData(key.getResultId(), INBOUND_AUTHENTICATION_CONTEXT_CACHE_NAME, entry, tenantId); } } public InboundAuthenticationContextCacheEntry getValueFromCache(InboundAuthenticationContextCacheKey key) { InboundAuthenticationContextCacheEntry entry = super.getValueFromCache(key); if (entry == null && enableRequestScopeCache) { entry = (InboundAuthenticationContextCacheEntry) SessionDataStore.getInstance() .getSessionData(key.getResultId(), INBOUND_AUTHENTICATION_CONTEXT_CACHE_NAME); } return entry; } public void clearCacheEntry(InboundAuthenticationContextCacheKey key) { super.clearCacheEntry(key); if (enableRequestScopeCache) { SessionDataStore.getInstance().clearSessionData(key.getResultId(), INBOUND_AUTHENTICATION_CONTEXT_CACHE_NAME); } } }