All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.adobe.acs.commons.httpcache.engine.impl.delegate.HttpCacheEngineBindingsDelegate Maven / Gradle / Ivy

There is a newer version: 6.10.0
Show newest version
/*
 * ACS AEM Commons
 *
 * Copyright (C) 2013 - 2023 Adobe
 *
 * Licensed 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 com.adobe.acs.commons.httpcache.engine.impl.delegate;

import com.adobe.acs.commons.httpcache.config.HttpCacheConfig;
import com.adobe.acs.commons.httpcache.config.impl.HttpCacheConfigComparator;
import com.adobe.acs.commons.httpcache.engine.impl.HttpCacheEngineImpl;
import com.adobe.acs.commons.httpcache.rule.HttpCacheHandlingRule;
import com.adobe.acs.commons.httpcache.store.HttpCacheStore;
import org.apache.commons.lang.StringUtils;
import org.apache.sling.commons.osgi.PropertiesUtil;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.CopyOnWriteArrayList;

/**
 * HttpCacheEngineBindingsDelegate
 * 

* Handles the bulk of the bindings logic for the HttpCacheEngineImpl *

*/ public class HttpCacheEngineBindingsDelegate { private static final Logger log = LoggerFactory.getLogger(HttpCacheEngineImpl.class); /** Thread safe list to contain the registered HttpCacheConfig references. */ private CopyOnWriteArrayList cacheConfigs = new CopyOnWriteArrayList<>(); /** Thread safe hash map to contain the registered cache store references. */ private final ConcurrentHashMap cacheStoresMap = new ConcurrentHashMap<>(); /** Thread safe map to contain the registered HttpCacheHandlingRule references. */ private final ConcurrentHashMap cacheHandlingRules = new ConcurrentHashMap<>(); /** Thread safe list containing the OSGi configurations for the registered httpCacheConfigs. Used only for mbean.*/ private final ConcurrentHashMap> cacheConfigConfigs = new ConcurrentHashMap<>(); /** * Binds cache config. Cache config could come and go at run time. * * @param cacheConfig * @param configs */ public void bindHttpCacheConfig(final HttpCacheConfig cacheConfig, final Map configs) { // Validate cache config object if (!cacheConfig.isValid()) { log.info("Http cache config rejected as the request uri is absent."); return; } // Check if the same object is already there in the map. if (cacheConfigs.contains(cacheConfig)) { log.trace("Http cache config object already exists in the cacheConfigs map and hence ignored."); return; } // Sort cacheConfigs by order final CopyOnWriteArrayList tmp = new CopyOnWriteArrayList(this.cacheConfigs); tmp.add(cacheConfig); Collections.sort(tmp, new HttpCacheConfigComparator()); this.cacheConfigs = tmp; this.cacheConfigConfigs.put(cacheConfig, configs); log.debug("Total number of cache configs added: {}", cacheConfigs.size()); } /** * Unbinds cache config. * * @param cacheConfig */ public void unbindHttpCacheConfig(final HttpCacheConfig cacheConfig) { if (cacheConfigs.contains(cacheConfig)) { // Remove the associated cached items from the cache store. if (cacheStoresMap.containsKey(cacheConfig.getCacheStoreName())) { cacheStoresMap.get(cacheConfig.getCacheStoreName()).invalidate(cacheConfig); } else { log.debug("Configured cache store is unavailable and hence nothing to invalidate."); } // Remove the entry from the map. cacheConfigs.remove(cacheConfig); cacheConfigConfigs.remove(cacheConfig); log.debug("Total number of cache configs after removal: {}", cacheConfigs.size()); return; } log.debug("This cache config entry was not bound and hence nothing to unbind."); } /** * Binds cache store implementation * * @param cacheStore */ public void bindHttpCacheStore(final HttpCacheStore cacheStore) { final String cacheStoreType = cacheStore.getStoreType(); if (cacheStoreType != null && cacheStoresMap.putIfAbsent(cacheStoreType, cacheStore) == null) { log.debug("HTTP Cache Store [ {} -> ADDED ] for a total of [ {} ]", cacheStore.getStoreType(), cacheStoresMap.size()); } } /** * Unbinds cache store. * * @param cacheStore */ public void unbindHttpCacheStore(final HttpCacheStore cacheStore) { final String cacheStoreType = cacheStore.getStoreType(); if (cacheStoreType != null && cacheStoresMap.remove(cacheStoreType) != null) { log.debug("HTTP Cache Store [ {} -> REMOVED ] for a total of [ {} ]", cacheStore.getStoreType(), cacheStoresMap.size()); } } /** * Binds cache handling rule * * @param cacheHandlingRule * @param properties */ public void bindHttpCacheHandlingRule(final HttpCacheHandlingRule cacheHandlingRule, final Map properties) { // Get the service pid and make it as key. if (cacheHandlingRules.putIfAbsent(getServicePid(properties), cacheHandlingRule) == null) { log.debug("Cache handling rule implementation {} has been added", cacheHandlingRule.getClass().getName()); log.debug("Total number of cache handling rule available after addition: {}", cacheHandlingRules.size()); } } /** * Unbinds handling rule. * * @param cacheHandlingRule * @param configs */ public void unbindHttpCacheHandlingRule(final HttpCacheHandlingRule cacheHandlingRule, final Map configs) { if (cacheHandlingRules.remove(getServicePid(configs) ) != null) { log.debug("Cache handling rule removed - {}.", cacheHandlingRule.getClass().getName()); log.debug("Total number of cache handling rules available after removal: {}", cacheHandlingRules.size()); } } public List getCacheConfigs() { return Collections.unmodifiableList(cacheConfigs); } public Map getCacheStoresMap() { return cacheStoresMap; } public Map getCacheHandlingRules() { return cacheHandlingRules; } public Map> getCacheConfigConfigs() { return cacheConfigConfigs; } private String getServicePid(Map configs) { String servicePid = PropertiesUtil.toString(configs.get("service.pid"), StringUtils.EMPTY); if(StringUtils.isBlank(servicePid)){ servicePid =PropertiesUtil.toString(configs.get("component.name"), StringUtils.EMPTY); } return servicePid; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy