/* @ITMillApache2LicenseForJavaFiles@ */ package com.itmill.toolkit.terminal; import java.io.InputStream; import com.itmill.toolkit.Application; import com.itmill.toolkit.service.FileTypeResolver; /** * StreamResource is a resource provided to the client directly by * the application. The strean resource is fetched from URI that is most often * in the context of the application or window. The resource is automatically * registered to window in creation. * * @author IT Mill Ltd. * @version * @VERSION@ * @since 3.0 */ @SuppressWarnings("serial") public class StreamResource implements ApplicationResource { /** * Source stream the downloaded content is fetched from. */ private StreamSource streamSource = null; /** * Explicit mime-type. */ private String MIMEType = null; /** * Filename. */ private String filename; /** * Application. */ private final Application application; /** * Default buffer size for this stream resource. */ private int bufferSize = 0; /** * Default cache time for this stream resource. */ private long cacheTime = DEFAULT_CACHETIME; /** * Creates a new stream resource for downloading from stream. * * @param streamSource * the source Stream. * @param filename * the name of the file. * @param application * the Application object. */ public StreamResource(StreamSource streamSource, String filename, Application application) { this.application = application; setFilename(filename); setStreamSource(streamSource); // Register to application application.addResource(this); } /** * @see com.itmill.toolkit.terminal.Resource#getMIMEType() */ public String getMIMEType() { if (MIMEType != null) { return MIMEType; } return FileTypeResolver.getMIMEType(filename); } /** * Sets the mime type of the resource. * * @param MIMEType * the MIME type to be set. */ public void setMIMEType(String MIMEType) { this.MIMEType = MIMEType; } /** * Returns the source for this StreamResource. StreamSource is * queried when the resource is about to be streamed to the client. * * @return Source of the StreamResource. */ public StreamSource getStreamSource() { return streamSource; } /** * Sets the source for this StreamResource. * StreamSource is queried when the resource is about to be * streamed to the client. * * @param streamSource * the source to set. */ public void setStreamSource(StreamSource streamSource) { this.streamSource = streamSource; } /** * Gets the filename. * * @return the filename. */ public String getFilename() { return filename; } /** * Sets the filename. * * @param filename * the filename to set. */ public void setFilename(String filename) { this.filename = filename; } /** * @see com.itmill.toolkit.terminal.ApplicationResource#getApplication() */ public Application getApplication() { return application; } /** * @see com.itmill.toolkit.terminal.ApplicationResource#getStream() */ public DownloadStream getStream() { final StreamSource ss = getStreamSource(); if (ss == null) { return null; } final DownloadStream ds = new DownloadStream(ss.getStream(), getMIMEType(), getFilename()); ds.setBufferSize(getBufferSize()); ds.setCacheTime(cacheTime); return ds; } /** * Interface implemented by the source of a StreamResource. * * @author IT Mill Ltd. * @version * @VERSION@ * @since 3.0 */ public interface StreamSource { /** * Returns new input stream that is used for reading the resource. */ public InputStream getStream(); } /* documented in superclass */ public int getBufferSize() { return bufferSize; } /** * Sets the size of the download buffer used for this resource. * * @param bufferSize * the size of the buffer in bytes. */ public void setBufferSize(int bufferSize) { this.bufferSize = bufferSize; } /* documented in superclass */ public long getCacheTime() { return cacheTime; } /** * Sets the length of cache expiration time. * *

* This gives the adapter the possibility cache streams sent to the client. * The caching may be made in adapter or at the client if the client * supports caching. Zero or negavive value disbales the caching of this * stream. *

* * @param cacheTime * the cache time in milliseconds. * */ public void setCacheTime(long cacheTime) { this.cacheTime = cacheTime; } }