mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-10-08 14:51:49 +00:00
125484 slanglois: MNT-16155 Update source headers - remove old Copyrights from Java and JSP dource files git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.1.N/root@125603 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
200 lines
4.4 KiB
Java
200 lines
4.4 KiB
Java
package org.alfresco.repo.content;
|
|
|
|
import java.io.Closeable;
|
|
import java.io.File;
|
|
import java.io.InputStream;
|
|
import java.io.OutputStream;
|
|
import java.nio.channels.FileChannel;
|
|
import java.nio.channels.WritableByteChannel;
|
|
import java.util.Locale;
|
|
|
|
import org.alfresco.service.cmr.repository.ContentData;
|
|
import org.alfresco.service.cmr.repository.ContentIOException;
|
|
import org.alfresco.service.cmr.repository.ContentReader;
|
|
import org.alfresco.service.cmr.repository.ContentStreamListener;
|
|
import org.alfresco.service.cmr.repository.ContentWriter;
|
|
|
|
/**
|
|
* Proxy for {@link ContentWriter} which captures {@link OutputStream} or {@link WritableByteChannel} to introduce a possibility of releasing captured resource
|
|
*
|
|
* @author Dmitry Velichkevich
|
|
* @see ContentWriter
|
|
* @see AbstractStreamAwareProxy
|
|
*/
|
|
public class StreamAwareContentWriterProxy extends AbstractStreamAwareProxy implements ContentWriter
|
|
{
|
|
private ContentWriter delegatee;
|
|
|
|
private Closeable releaseableResource;
|
|
|
|
public StreamAwareContentWriterProxy(ContentWriter delegator)
|
|
{
|
|
this.delegatee = delegator;
|
|
}
|
|
|
|
@Override
|
|
public OutputStream getContentOutputStream() throws ContentIOException
|
|
{
|
|
OutputStream result = delegatee.getContentOutputStream();
|
|
|
|
if (null == releaseableResource)
|
|
{
|
|
releaseableResource = result;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
@Override
|
|
public FileChannel getFileChannel(boolean truncate) throws ContentIOException
|
|
{
|
|
FileChannel result = delegatee.getFileChannel(truncate);
|
|
|
|
if (null == releaseableResource)
|
|
{
|
|
releaseableResource = result;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
@Override
|
|
public ContentReader getReader() throws ContentIOException
|
|
{
|
|
return delegatee.getReader();
|
|
}
|
|
|
|
@Override
|
|
public WritableByteChannel getWritableChannel() throws ContentIOException
|
|
{
|
|
WritableByteChannel result = delegatee.getWritableChannel();
|
|
|
|
if (null == releaseableResource)
|
|
{
|
|
releaseableResource = result;
|
|
}
|
|
|
|
return result;
|
|
}
|
|
|
|
@Override
|
|
public void guessEncoding()
|
|
{
|
|
delegatee.guessEncoding();
|
|
}
|
|
|
|
@Override
|
|
public void guessMimetype(String filename)
|
|
{
|
|
delegatee.guessMimetype(filename);
|
|
}
|
|
|
|
@Override
|
|
public boolean isClosed()
|
|
{
|
|
return delegatee.isClosed();
|
|
}
|
|
|
|
@Override
|
|
public void putContent(ContentReader reader) throws ContentIOException
|
|
{
|
|
delegatee.putContent(reader);
|
|
}
|
|
|
|
@Override
|
|
public void putContent(InputStream is) throws ContentIOException
|
|
{
|
|
delegatee.putContent(is);
|
|
}
|
|
|
|
@Override
|
|
public void putContent(File file) throws ContentIOException
|
|
{
|
|
delegatee.putContent(file);
|
|
}
|
|
|
|
@Override
|
|
public void putContent(String content) throws ContentIOException
|
|
{
|
|
delegatee.putContent(content);
|
|
}
|
|
|
|
@Override
|
|
public void addListener(ContentStreamListener listener)
|
|
{
|
|
delegatee.addListener(listener);
|
|
}
|
|
|
|
@Override
|
|
public ContentData getContentData()
|
|
{
|
|
return delegatee.getContentData();
|
|
}
|
|
|
|
@Override
|
|
public String getContentUrl()
|
|
{
|
|
return delegatee.getContentUrl();
|
|
}
|
|
|
|
@Override
|
|
public String getEncoding()
|
|
{
|
|
return delegatee.getEncoding();
|
|
}
|
|
|
|
@Override
|
|
public Locale getLocale()
|
|
{
|
|
return delegatee.getLocale();
|
|
}
|
|
|
|
@Override
|
|
public String getMimetype()
|
|
{
|
|
return delegatee.getMimetype();
|
|
}
|
|
|
|
@Override
|
|
public long getSize()
|
|
{
|
|
return delegatee.getSize();
|
|
}
|
|
|
|
@Override
|
|
public boolean isChannelOpen()
|
|
{
|
|
return delegatee.isChannelOpen();
|
|
}
|
|
|
|
@Override
|
|
public void setEncoding(String encoding)
|
|
{
|
|
delegatee.setEncoding(encoding);
|
|
}
|
|
|
|
@Override
|
|
public void setLocale(Locale locale)
|
|
{
|
|
delegatee.setLocale(locale);
|
|
}
|
|
|
|
@Override
|
|
public void setMimetype(String mimetype)
|
|
{
|
|
delegatee.setMimetype(mimetype);
|
|
}
|
|
|
|
@Override
|
|
public boolean canBeClosed()
|
|
{
|
|
return delegatee.isChannelOpen();
|
|
}
|
|
|
|
@Override
|
|
public Closeable getStream()
|
|
{
|
|
return releaseableResource;
|
|
}
|
|
}
|