/* @ITMillApache2LicenseForJavaFiles@ */ package com.vaadin.terminal; import java.io.Serializable; import java.net.URL; /** * A URIHandler is used for handling URI:s requested by the user and can * optionally provide a {@link DownloadStream}. If a {@link DownloadStream} is * returned by {@link #handleURI(URL, String)}, the stream is sent to the * client. * * @author IT Mill Ltd. * @version * @VERSION@ * @since 3.0 */ public interface URIHandler extends Serializable { /** * Handles a given URI. If the URI handler to emit a downloadable stream it * should return a {@code DownloadStream} object. * * @param context * the base URL * @param relativeUri * a URI relative to {@code context} * @return A downloadable stream or null if no stream is provided */ public DownloadStream handleURI(URL context, String relativeUri); /** * An {@code ErrorEvent} implementation for URIHandler. */ public interface ErrorEvent extends Terminal.ErrorEvent { /** * Gets the URIHandler that caused this error. * * @return the URIHandler that caused the error */ public URIHandler getURIHandler(); } }