1
0
mirror of https://github.com/moparisthebest/davmail synced 2025-01-09 20:58:05 -05:00

Additional code fixes from audit, do not try to get time zone from options page in direct EWS mode

git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@2255 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
mguessan 2014-03-17 09:28:43 +00:00
parent bd69676be5
commit 0da754e615

View File

@ -30,10 +30,7 @@ import davmail.http.DavGatewayHttpClientFacade;
import davmail.util.IOUtil; import davmail.util.IOUtil;
import davmail.util.StringUtil; import davmail.util.StringUtil;
import org.apache.commons.httpclient.*; import org.apache.commons.httpclient.*;
import org.apache.commons.httpclient.methods.ByteArrayRequestEntity; import org.apache.commons.httpclient.methods.*;
import org.apache.commons.httpclient.methods.GetMethod;
import org.apache.commons.httpclient.methods.HeadMethod;
import org.apache.commons.httpclient.methods.PostMethod;
import org.apache.commons.httpclient.params.HttpClientParams; import org.apache.commons.httpclient.params.HttpClientParams;
import javax.mail.MessagingException; import javax.mail.MessagingException;
@ -111,6 +108,7 @@ public class EwsExchangeSession extends ExchangeSession {
} }
protected Map<String, String> folderIdMap; protected Map<String, String> folderIdMap;
protected boolean directEws;
protected class Folder extends ExchangeSession.Folder { protected class Folder extends ExchangeSession.Folder {
public FolderId folderId; public FolderId folderId;
@ -204,7 +202,7 @@ public class EwsExchangeSession extends ExchangeSession {
if (method != null) { if (method != null) {
method.releaseConnection(); method.releaseConnection();
} }
boolean directEws = method == null || "/ews/services.wsdl".equalsIgnoreCase(method.getPath()); directEws = method == null || "/ews/services.wsdl".equalsIgnoreCase(method.getPath());
// options page is not available in direct EWS mode // options page is not available in direct EWS mode
if (!directEws) { if (!directEws) {
@ -325,24 +323,24 @@ public class EwsExchangeSession extends ExchangeSession {
} }
protected static class AutoDiscoverMethod extends PostMethod { protected static class AutoDiscoverMethod extends PostMethod {
AutoDiscoverMethod(String autodiscoverHost, String userEmail) { AutoDiscoverMethod(String autodiscoverHost, String userEmail) throws IOException {
super("https://" + autodiscoverHost + "/autodiscover/autodiscover.xml"); super("https://" + autodiscoverHost + "/autodiscover/autodiscover.xml");
setAutoDiscoverRequestEntity(userEmail); setAutoDiscoverRequestEntity(userEmail);
} }
AutoDiscoverMethod(String userEmail) { AutoDiscoverMethod(String userEmail) throws IOException {
super("/autodiscover/autodiscover.xml"); super("/autodiscover/autodiscover.xml");
setAutoDiscoverRequestEntity(userEmail); setAutoDiscoverRequestEntity(userEmail);
} }
void setAutoDiscoverRequestEntity(String userEmail) { void setAutoDiscoverRequestEntity(String userEmail) throws IOException {
String body = "<Autodiscover xmlns=\"http://schemas.microsoft.com/exchange/autodiscover/outlook/requestschema/2006\">" + String body = "<Autodiscover xmlns=\"http://schemas.microsoft.com/exchange/autodiscover/outlook/requestschema/2006\">" +
"<Request>" + "<Request>" +
"<EMailAddress>" + userEmail + "</EMailAddress>" + "<EMailAddress>" + userEmail + "</EMailAddress>" +
"<AcceptableResponseSchema>http://schemas.microsoft.com/exchange/autodiscover/outlook/responseschema/2006a</AcceptableResponseSchema>" + "<AcceptableResponseSchema>http://schemas.microsoft.com/exchange/autodiscover/outlook/responseschema/2006a</AcceptableResponseSchema>" +
"</Request>" + "</Request>" +
"</Autodiscover>"; "</Autodiscover>";
setRequestEntity(new ByteArrayRequestEntity(body.getBytes(), "text/xml")); setRequestEntity(new StringRequestEntity(body, "text/xml", "UTF-8"));
} }
String ewsUrl; String ewsUrl;
@ -359,6 +357,7 @@ public class EwsExchangeSession extends ExchangeSession {
autodiscoverReader = new BufferedReader(new InputStreamReader(getResponseBodyAsStream())); autodiscoverReader = new BufferedReader(new InputStreamReader(getResponseBodyAsStream()));
String line; String line;
// find ews url // find ews url
//noinspection StatementWithEmptyBody
while ((line = autodiscoverReader.readLine()) != null while ((line = autodiscoverReader.readLine()) != null
&& (!line.contains("<EwsUrl>")) && (!line.contains("<EwsUrl>"))
&& (!line.contains("</EwsUrl>"))) { && (!line.contains("</EwsUrl>"))) {
@ -447,9 +446,9 @@ public class EwsExchangeSession extends ExchangeSession {
// workaround for broken message headers on Exchange 2010 // workaround for broken message headers on Exchange 2010
&& messageHeaders.toLowerCase().contains("message-id:")) { && messageHeaders.toLowerCase().contains("message-id:")) {
// workaround for messages in Sent folder // workaround for messages in Sent folder
if (messageHeaders.indexOf("From:") < 0) { if (!messageHeaders.contains("From:")) {
String from = item.get(Field.get("from").getResponseName()); String from = item.get(Field.get("from").getResponseName());
messageHeaders = "From: " + from + "\n" + messageHeaders; messageHeaders = "From: " + from + '\n' + messageHeaders;
} }
result = new ByteArrayInputStream(messageHeaders.getBytes("UTF-8")); result = new ByteArrayInputStream(messageHeaders.getBytes("UTF-8"));
@ -1335,6 +1334,7 @@ public class EwsExchangeSession extends ExchangeSession {
} }
if ("*".equals(noneMatch)) { if ("*".equals(noneMatch)) {
// create requested // create requested
//noinspection VariableNotUsedInsideIf
if (currentItemId != null) { if (currentItemId != null) {
itemResult.status = HttpStatus.SC_PRECONDITION_FAILED; itemResult.status = HttpStatus.SC_PRECONDITION_FAILED;
return itemResult; return itemResult;
@ -1433,8 +1433,6 @@ public class EwsExchangeSession extends ExchangeSession {
itemName = StringUtil.base64ToUrl(itemId.id) + ".EML"; itemName = StringUtil.base64ToUrl(itemId.id) + ".EML";
} }
String instancetype = response.get(Field.get("instancetype").getResponseName()); String instancetype = response.get(Field.get("instancetype").getResponseName());
boolean isrecurring = "true".equals(response.get(Field.get("isrecurring").getResponseName()));
String calendaritemtype = response.get(Field.get("calendaritemtype").getResponseName());
isException = "3".equals(instancetype); isException = "3".equals(instancetype);
} }
@ -1468,6 +1466,7 @@ public class EwsExchangeSession extends ExchangeSession {
} }
if ("*".equals(noneMatch)) { if ("*".equals(noneMatch)) {
// create requested // create requested
//noinspection VariableNotUsedInsideIf
if (currentItemId != null) { if (currentItemId != null) {
itemResult.status = HttpStatus.SC_PRECONDITION_FAILED; itemResult.status = HttpStatus.SC_PRECONDITION_FAILED;
return itemResult; return itemResult;
@ -1911,9 +1910,6 @@ public class EwsExchangeSession extends ExchangeSession {
ITEM_PROPERTIES.add("instancetype"); ITEM_PROPERTIES.add("instancetype");
ITEM_PROPERTIES.add("urlcompname"); ITEM_PROPERTIES.add("urlcompname");
ITEM_PROPERTIES.add("subject"); ITEM_PROPERTIES.add("subject");
ITEM_PROPERTIES.add("calendaritemtype");
ITEM_PROPERTIES.add("isrecurring");
} }
protected static final HashSet<String> EVENT_REQUEST_PROPERTIES = new HashSet<String>(); protected static final HashSet<String> EVENT_REQUEST_PROPERTIES = new HashSet<String>();
@ -2100,13 +2096,14 @@ public class EwsExchangeSession extends ExchangeSession {
try { try {
String timezoneId = null; String timezoneId = null;
if (!"Exchange2007_SP1".equals(serverVersion)) { if (!"Exchange2007_SP1".equals(serverVersion)) {
// On Exchange 2010, get user timezone from server
GetUserConfigurationMethod getUserConfigurationMethod = new GetUserConfigurationMethod(); GetUserConfigurationMethod getUserConfigurationMethod = new GetUserConfigurationMethod();
executeMethod(getUserConfigurationMethod); executeMethod(getUserConfigurationMethod);
EWSMethod.Item item = getUserConfigurationMethod.getResponseItem(); EWSMethod.Item item = getUserConfigurationMethod.getResponseItem();
if (item != null) { if (item != null) {
timezoneId = item.get("timezone"); timezoneId = item.get("timezone");
} }
} else { } else if (!directEws) {
timezoneId = getTimezoneidFromOptions(); timezoneId = getTimezoneidFromOptions();
} }
// failover: use timezone id from settings file // failover: use timezone id from settings file
@ -2147,14 +2144,14 @@ public class EwsExchangeSession extends ExchangeSession {
protected String getTimezoneidFromOptions() { protected String getTimezoneidFromOptions() {
String result = null; String result = null;
// get user mail URL from html body // get time zone setting from html body
BufferedReader optionsPageReader = null; BufferedReader optionsPageReader = null;
GetMethod optionsMethod = new GetMethod("/owa/?ae=Options&t=Regional"); GetMethod optionsMethod = new GetMethod("/owa/?ae=Options&t=Regional");
try { try {
DavGatewayHttpClientFacade.executeGetMethod(httpClient, optionsMethod, false); DavGatewayHttpClientFacade.executeGetMethod(httpClient, optionsMethod, false);
optionsPageReader = new BufferedReader(new InputStreamReader(optionsMethod.getResponseBodyAsStream())); optionsPageReader = new BufferedReader(new InputStreamReader(optionsMethod.getResponseBodyAsStream()));
String line; String line;
// find email // find timezone
//noinspection StatementWithEmptyBody //noinspection StatementWithEmptyBody
while ((line = optionsPageReader.readLine()) != null while ((line = optionsPageReader.readLine()) != null
&& (!line.contains("tblTmZn")) && (!line.contains("tblTmZn"))