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

Caldav: fix OSX Mountain Lion (iCal 6) support

git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@1983 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
mguessan 2012-07-30 20:48:45 +00:00
parent 939115a471
commit 0f47689ecd

View File

@ -96,7 +96,7 @@ public class CaldavConnection extends AbstractConnection {
while ((line = readClient()) != null && line.length() > 0) { while ((line = readClient()) != null && line.length() > 0) {
int index = line.indexOf(':'); int index = line.indexOf(':');
if (index <= 0) { if (index <= 0) {
wireLogger.warn("Invalid header: "+line); wireLogger.warn("Invalid header: " + line);
throw new DavMailException("EXCEPTION_INVALID_HEADER"); throw new DavMailException("EXCEPTION_INVALID_HEADER");
} }
headers.put(line.substring(0, index).toLowerCase(), line.substring(index + 1).trim()); headers.put(line.substring(0, index).toLowerCase(), line.substring(index + 1).trim());
@ -969,7 +969,7 @@ public class CaldavConnection extends AbstractConnection {
if (request.hasProperty("principal-URL") && request.isIcal5()) { if (request.hasProperty("principal-URL") && request.isIcal5()) {
response.appendHrefProperty("D:principal-URL", encodePath(request, "/principals/" + prefix + '/' + actualPrincipal)); response.appendHrefProperty("D:principal-URL", encodePath(request, "/principals/" + prefix + '/' + actualPrincipal));
} }
if (request.hasProperty("calendar-home-set")) { if (request.hasProperty("calendar-home-set")) {
if ("users".equals(prefix)) { if ("users".equals(prefix)) {
@ -1440,7 +1440,9 @@ public class CaldavConnection extends AbstractConnection {
} }
protected boolean isIcal5() { protected boolean isIcal5() {
return isUserAgent("CoreDAV/") || isUserAgent("iOS/5"); return isUserAgent("CoreDAV/") || isUserAgent("iOS/5")
// iCal 6
|| isUserAgent("Mac OS X/10.8");
} }
protected boolean isUserAgent(String key) { protected boolean isUserAgent(String key) {
@ -1629,12 +1631,12 @@ public class CaldavConnection extends AbstractConnection {
*/ */
String result = calendarPath.toString(); String result = calendarPath.toString();
// replace unsupported spaces // replace unsupported spaces
if (result.indexOf(' ') >=0 ) { if (result.indexOf(' ') >= 0) {
result = result.replaceAll("___", " "); result = result.replaceAll("___", " ");
} }
// replace /addressbook suffix on public folders // replace /addressbook suffix on public folders
if (result.startsWith("/public")) { if (result.startsWith("/public")) {
result = result.replaceAll("/addressbook", ""); result = result.replaceAll("/addressbook", "");
} }
return result; return result;