001 // Copyright 2010 The Apache Software Foundation 002 // 003 // Licensed under the Apache License, Version 2.0 (the "License"); 004 // you may not use this file except in compliance with the License. 005 // You may obtain a copy of the License at 006 // 007 // http://www.apache.org/licenses/LICENSE-2.0 008 // 009 // Unless required by applicable law or agreed to in writing, software 010 // distributed under the License is distributed on an "AS IS" BASIS, 011 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 012 // See the License for the specific language governing permissions and 013 // limitations under the License. 014 015 package org.apache.tapestry5.services.assets; 016 017 import java.io.IOException; 018 019 import javax.servlet.http.HttpServletResponse; 020 021 import org.apache.tapestry5.Asset; 022 import org.apache.tapestry5.SymbolConstants; 023 import org.apache.tapestry5.internal.services.AssetDispatcher; 024 import org.apache.tapestry5.services.Request; 025 import org.apache.tapestry5.services.Response; 026 027 /** 028 * Handler for asset requests, which expose some kind of {@link Asset} to 029 * the user agent (i.e., the client web browser). Starting in Tapestry 5.2, 030 * asset paths are more structured, consisting of four parts: 031 * <ul> 032 * <li><code>/assets/</code> -- the root path for all assets 033 * <li> 034 * <em>application version</em> -- the application version, as defined by the 035 * {@link SymbolConstants#APPLICATION_VERSION} symbol 036 * <li><em>handler id</em> -- a handler for this part of the asset path (defined by contributions to the 037 * <code>AssetDispatcher</code> service) 038 * <li><em>extra path</em> -- additional path beyond the handler id, used to identify the specific resource 039 * </ul> 040 * <p> 041 * So, an example path might be <code>/assets/1.0.1/corelib/components/select.png</code>. The handler id would be 042 * <code>corelib</code>, and the extra path would be <code>components/select.png</code>. 043 * 044 * @since 5.2.0 045 * @see AssetDispatcher 046 */ 047 public interface AssetRequestHandler 048 { 049 /** 050 * Given a request targeted (via the handler id) to the specific handler, process the request. 051 * The handler is responsible for processing the request, sending back either a bytestream 052 * (via {@link Response#getOutputStream(String)}) or an error response 053 * (via {@link Response#sendError(int, String)}). It is the handler's responsibility to allow 054 * for client-side caching (possibly sending an {@link HttpServletResponse#SC_NOT_MODIFIED} response). 055 * <p> 056 * The handler should return true if it provided a response. If the handler returns false, this indicates that the 057 * extra path did not identify a known asset (virtual or otherwise) and the AssetDispatcher service should send a 058 * {@link HttpServletResponse#SC_NOT_FOUND} response. 059 * 060 * @param request 061 * incoming asset request 062 * @param response 063 * used to send a response to client 064 * @param extraPath 065 * additional path to identify the specific asset 066 * @return true if request handler, false if asset not found 067 */ 068 boolean handleAssetRequest(Request request, Response response, String extraPath) throws IOException; 069 }