1
0
mirror of https://github.com/moparisthebest/davmail synced 2025-01-07 03:38:05 -05:00

EWS: workaround for Exchange bug, replace xml 1.0 header with xml 1.1 and log message download progress

git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@1709 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
mguessan 2011-06-20 10:24:16 +00:00
parent bfebee2b38
commit cfc13bfe88

View File

@ -20,6 +20,7 @@ package davmail.exchange.ews;
import davmail.exchange.XMLStreamUtil; import davmail.exchange.XMLStreamUtil;
import davmail.http.DavGatewayHttpClientFacade; import davmail.http.DavGatewayHttpClientFacade;
import davmail.ui.tray.DavGatewayTray;
import davmail.util.StringUtil; import davmail.util.StringUtil;
import org.apache.commons.codec.binary.Base64; import org.apache.commons.codec.binary.Base64;
import org.apache.commons.httpclient.Header; import org.apache.commons.httpclient.Header;
@ -1006,6 +1007,26 @@ public abstract class EWSMethod extends PostMethod {
responseItems = new ArrayList<Item>(); responseItems = new ArrayList<Item>();
XMLStreamReader reader; XMLStreamReader reader;
try { try {
inputStream = new FilterInputStream(inputStream) {
int totalCount;
int lastLogCount;
@Override
public int read(byte[] buffer, int offset, int length) throws IOException {
int count = super.read(buffer, offset, length);
// workaround for Exchange bug: replace xml 1.0 header with xml 1.1
if (totalCount == 0 && count > 18 && buffer[17] == '0') {
buffer[17] = '1';
}
totalCount += count;
if (totalCount - lastLogCount > 1024 * 1024) {
LOGGER.debug("Downloaded " + (totalCount / 1024) + " KBytes");
DavGatewayTray.switchIcon();
lastLogCount = totalCount;
}
return count;
}
};
reader = XMLStreamUtil.createXMLStreamReader(inputStream); reader = XMLStreamUtil.createXMLStreamReader(inputStream);
while (reader.hasNext()) { while (reader.hasNext()) {
reader.next(); reader.next();