/* * Copyright (c) 2013, 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.oauth.cache; import org.wso2.carbon.identity.application.common.cache.BaseCache; import org.wso2.carbon.identity.oauth.listener.OAuthCacheRemoveListener; import org.wso2.carbon.identity.oauth2.model.AccessTokenDO; import org.wso2.carbon.utils.CarbonUtils; public class OAuthCache extends BaseCache<OAuthCacheKey, CacheEntry> { private static final String OAUTH_CACHE_NAME = "OAuthCache"; private static volatile OAuthCache instance; private OAuthCache() { super(OAUTH_CACHE_NAME); super.addListener(new OAuthCacheRemoveListener()); } public static OAuthCache getInstance() { CarbonUtils.checkSecurity(); if (instance == null) { synchronized (OAuthCache.class) { if (instance == null) { instance = new OAuthCache(); } } } return instance; } }