Fix ALFCOM-2994: Components added to Alfresco Dashboard are not working

git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@14912 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
This commit is contained in:
David Caruana
2009-06-25 09:44:53 +00:00
parent 4f5d805723
commit af5ff20ec6

View File

@@ -27,8 +27,6 @@ package org.alfresco.repo.web.scripts;
import java.io.ByteArrayOutputStream; import java.io.ByteArrayOutputStream;
import java.io.IOException; import java.io.IOException;
import java.io.OutputStream; import java.io.OutputStream;
import java.io.OutputStreamWriter;
import java.io.UnsupportedEncodingException;
import java.io.Writer; import java.io.Writer;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
@@ -52,6 +50,7 @@ import org.alfresco.service.cmr.repository.NodeRef;
import org.alfresco.service.cmr.repository.TemplateService; import org.alfresco.service.cmr.repository.TemplateService;
import org.alfresco.service.cmr.security.AuthorityService; import org.alfresco.service.cmr.security.AuthorityService;
import org.alfresco.service.descriptor.DescriptorService; import org.alfresco.service.descriptor.DescriptorService;
import org.alfresco.util.StringBuilderWriter;
import org.alfresco.web.scripts.AbstractRuntimeContainer; import org.alfresco.web.scripts.AbstractRuntimeContainer;
import org.alfresco.web.scripts.Authenticator; import org.alfresco.web.scripts.Authenticator;
import org.alfresco.web.scripts.Cache; import org.alfresco.web.scripts.Cache;
@@ -508,8 +507,9 @@ public class RepositoryContainer extends AbstractRuntimeContainer implements Ten
private static class BufferedResponse implements TransactionListener, WrappingWebScriptResponse private static class BufferedResponse implements TransactionListener, WrappingWebScriptResponse
{ {
private WebScriptResponse res; private WebScriptResponse res;
private ByteArrayOutputStream outputStream; private int bufferSize;
private OutputStreamWriter outputWriter; private ByteArrayOutputStream outputStream = null;
private StringBuilderWriter outputWriter = null;
/** /**
@@ -521,15 +521,7 @@ public class RepositoryContainer extends AbstractRuntimeContainer implements Ten
public BufferedResponse(WebScriptResponse res, int bufferSize) public BufferedResponse(WebScriptResponse res, int bufferSize)
{ {
this.res = res; this.res = res;
this.outputStream = new ByteArrayOutputStream(bufferSize); this.bufferSize = bufferSize;
try
{
this.outputWriter = new OutputStreamWriter(outputStream, "UTF-8");
}
catch (UnsupportedEncodingException e)
{
throw new AlfrescoRuntimeException("Failed to create buffered response", e);
};
} }
/* /*
@@ -574,6 +566,14 @@ public class RepositoryContainer extends AbstractRuntimeContainer implements Ten
*/ */
public OutputStream getOutputStream() throws IOException public OutputStream getOutputStream() throws IOException
{ {
if (outputStream == null)
{
if (outputWriter != null)
{
throw new AlfrescoRuntimeException("Already buffering output writer");
}
this.outputStream = new ByteArrayOutputStream(bufferSize);
}
return outputStream; return outputStream;
} }
@@ -592,6 +592,14 @@ public class RepositoryContainer extends AbstractRuntimeContainer implements Ten
*/ */
public Writer getWriter() throws IOException public Writer getWriter() throws IOException
{ {
if (outputWriter == null)
{
if (outputStream != null)
{
throw new AlfrescoRuntimeException("Already buffering output stream");
}
outputWriter = new StringBuilderWriter(bufferSize);
}
return outputWriter; return outputWriter;
} }
@@ -601,7 +609,14 @@ public class RepositoryContainer extends AbstractRuntimeContainer implements Ten
*/ */
public void reset() public void reset()
{ {
outputStream.reset(); if (outputStream != null)
{
outputStream.reset();
}
else if (outputWriter != null)
{
outputWriter = null;
}
res.reset(); res.reset();
} }
@@ -702,8 +717,16 @@ public class RepositoryContainer extends AbstractRuntimeContainer implements Ten
if (logger.isDebugEnabled()) if (logger.isDebugEnabled())
logger.debug("Writing Transactional response: size=" + outputStream.size()); logger.debug("Writing Transactional response: size=" + outputStream.size());
outputStream.flush(); if (outputWriter != null)
outputStream.writeTo(res.getOutputStream()); {
outputWriter.flush();
res.getWriter().write(outputWriter.toString());
}
else if (outputStream != null)
{
outputStream.flush();
outputStream.writeTo(res.getOutputStream());
}
} }
catch (IOException e) catch (IOException e)
{ {