/* * ==================================================================== * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF 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. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation. For more * information on the Apache Software Foundation, please see * <http://www.apache.org/>. * */ package org.apach3.http.impl.client.cache; import java.io.IOException; import org.apach3.commons.logging.Log; import org.apach3.commons.logging.LogFactory; import org.apach3.http.HttpHost; import org.apach3.http.HttpRequest; import org.apach3.http.ProtocolException; import org.apach3.http.client.cache.HttpCacheEntry; import org.apach3.http.protocol.HttpContext; /** * Class used to represent an asynchronous revalidation event, such as with * "stale-while-revalidate" */ class AsynchronousValidationRequest implements Runnable { private final AsynchronousValidator parent; private final CachingHttpClient cachingClient; private final HttpHost target; private final HttpRequest request; private final HttpContext context; private final HttpCacheEntry cacheEntry; private final String identifier; private final Log log = LogFactory.getLog(getClass()); /** * Used internally by {@link AsynchronousValidator} to schedule a * revalidation. * @param cachingClient * @param target * @param request * @param context * @param cacheEntry * @param bookKeeping * @param identifier */ AsynchronousValidationRequest(AsynchronousValidator parent, CachingHttpClient cachingClient, HttpHost target, HttpRequest request, HttpContext context, HttpCacheEntry cacheEntry, String identifier) { this.parent = parent; this.cachingClient = cachingClient; this.target = target; this.request = request; this.context = context; this.cacheEntry = cacheEntry; this.identifier = identifier; } public void run() { try { cachingClient.revalidateCacheEntry(target, request, context, cacheEntry); } catch (IOException ioe) { log.debug("Asynchronous revalidation failed due to exception: " + ioe); } catch (ProtocolException pe) { log.error("ProtocolException thrown during asynchronous revalidation: " + pe); } finally { parent.markComplete(identifier); } } String getIdentifier() { return identifier; } }