/*
*
* Copyright (C) 2007-2015 Licensed to the Comunes Association (CA) under
* one or more contributor license agreements (see COPYRIGHT for details).
* The CA licenses this file to you under the GNU Affero General Public
* License version 3, (the "License"); you may not use this file except in
* compliance with the License. This file is part of kune.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package cc.kune.events.server.utils;
import java.util.List;
import java.util.Map;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import cc.kune.core.server.LogThis;
import cc.kune.core.server.persist.CachedCollection;
import cc.kune.domain.Container;
import com.google.inject.Singleton;
// TODO: Auto-generated Javadoc
/**
* The Class EventsCache is used to cache events of a group. Right now is only
* used in the export functionality because we don't have a way to detect gadget
* changes (of dates, etc) to expire this elements.
*
* @author vjrj@ourproject.org (Vicente J. Ruiz Jurado)
*/
@LogThis
@Singleton
public class EventsCache extends CachedCollection<Container, List<Map<String, String>>> {
/** The Constant LOG. */
public static final Log LOG = LogFactory.getLog(EventsCache.class);
/**
* Instantiates a new events cache.
*/
public EventsCache() {
super(100);
}
/*
* (non-Javadoc)
*
* @see cc.kune.core.server.persist.CachedCollection#get(java.lang.Object)
*/
@Override
public List<Map<String, String>> get(final Object key) {
final List<Map<String, String>> list = super.get(key);
if (list != null) {
LOG.debug("Using events cache for " + ((Container) key).getStateToken());
} else {
LOG.debug("Events cache empty for " + ((Container) key).getStateToken());
}
return list;
}
/*
* (non-Javadoc)
*
* @see java.util.Map#put(java.lang.Object, java.lang.Object)
*/
@SuppressWarnings("unchecked")
@Override
public List<Map<String, String>> put(final Container container, final List<Map<String, String>> value) {
final Object put = super.put(container, value);
LOG.debug("Event list added for container " + container.getStateToken() + ", size " + this.size());
return (List<Map<String, String>>) put;
}
}