/* * Copyright (c) 2010-2011 Lockheed Martin Corporation * * 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 org.eurekastreams.server.persistence.mappers.cache; import java.util.List; import org.eurekastreams.server.persistence.mappers.chained.RefreshStrategy; import org.eurekastreams.server.persistence.mappers.stream.CachedDomainMapper; /** * Generic mapper to set multiple keyed single values in cache at one time. The keys come from the list of requests and * the values come from the list of responses. IMPORTANT: There MUST be a 1-to-1 correspondence between the requests and * the responses (rqst[i] must go with resp[i]) - both order and placeholders for missing values - else keys will be * associated with the wrong values in cache! * * @param <TRequestType> * Request type; toString must return the value used in the cache key. */ public class MultiSetKeyedSingleValueCacheMapper<TRequestType> extends CachedDomainMapper implements RefreshStrategy<List<TRequestType>, List<Long>> { /** Prefix on the cache key. */ private final String keyPrefix; /** * Constructor. * * @param inKeyPrefix * Prefix on the cache key. */ public MultiSetKeyedSingleValueCacheMapper(final String inKeyPrefix) { keyPrefix = inKeyPrefix; } /** * {@inheritDoc} */ public void refresh(final List<TRequestType> inRequest, final List<Long> inResponse) { for (int i = 0; i < inRequest.size() && i < inResponse.size(); i++) { getCache().set(keyPrefix + inRequest.get(i).toString(), inResponse.get(i)); } } }