mirror of
https://github.com/moparisthebest/davmail
synced 2024-12-14 03:32:22 -05:00
iCal fix : Also send events on propfind if depth is 1
git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@251 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
parent
ceaf0438e8
commit
9f0981b294
@ -234,6 +234,10 @@ public class CaldavConnection extends AbstractConnection {
|
|||||||
buffer.append(" <D:status>HTTP/1.1 200 OK</D:status>\n");
|
buffer.append(" <D:status>HTTP/1.1 200 OK</D:status>\n");
|
||||||
buffer.append(" </D:propstat>\n");
|
buffer.append(" </D:propstat>\n");
|
||||||
buffer.append(" </D:response>\n");
|
buffer.append(" </D:response>\n");
|
||||||
|
// if depth is 1, also send events
|
||||||
|
if (depth > 0) {
|
||||||
|
appendEventsResponses(buffer, request, session.getAllEvents());
|
||||||
|
}
|
||||||
buffer.append("</D:multistatus>\n");
|
buffer.append("</D:multistatus>\n");
|
||||||
|
|
||||||
HashMap<String, String> responseHeaders = new HashMap<String, String>();
|
HashMap<String, String> responseHeaders = new HashMap<String, String>();
|
||||||
@ -293,35 +297,11 @@ public class CaldavConnection extends AbstractConnection {
|
|||||||
StringBuilder buffer = new StringBuilder();
|
StringBuilder buffer = new StringBuilder();
|
||||||
buffer.append("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" +
|
buffer.append("<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n" +
|
||||||
"<D:multistatus xmlns:D=\"DAV:\">\n");
|
"<D:multistatus xmlns:D=\"DAV:\">\n");
|
||||||
for (ExchangeSession.Event event : events) {
|
appendEventsResponses(buffer, request, events);
|
||||||
|
|
||||||
String eventPath = event.getPath().replaceAll("&", "&").replaceAll("<", "<").replaceAll(">", ">");
|
|
||||||
buffer.append("<D:response>\n");
|
|
||||||
buffer.append(" <D:href>/calendar").append(eventPath).append("</D:href>\n");
|
|
||||||
buffer.append(" <D:propstat>\n");
|
|
||||||
buffer.append(" <D:prop>\n");
|
|
||||||
if (request.hasProperty("calendar-data")) {
|
|
||||||
String ics = event.getICS();
|
|
||||||
if (ics != null && ics.length() > 0) {
|
|
||||||
ics = ics.replaceAll("&", "&").replaceAll("<", "<").replaceAll(">", ">");
|
|
||||||
buffer.append(" <C:calendar-data xmlns:C=\"urn:ietf:params:xml:ns:caldav\"\n");
|
|
||||||
buffer.append(" C:content-type=\"text/calendar\" C:version=\"2.0\">");
|
|
||||||
buffer.append(ics);
|
|
||||||
buffer.append("</C:calendar-data>\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (request.hasProperty("getetag")) {
|
|
||||||
buffer.append(" <D:getetag>").append(event.getEtag()).append("</D:getetag>\n");
|
|
||||||
}
|
|
||||||
buffer.append(" </D:prop>\n");
|
|
||||||
buffer.append(" <D:status>HTTP/1.1 200 OK</D:status>\n");
|
|
||||||
buffer.append(" </D:propstat>\n");
|
|
||||||
buffer.append(" </D:response>\n");
|
|
||||||
|
|
||||||
}
|
|
||||||
// send not found events errors
|
// send not found events errors
|
||||||
for (String href : notFound) {
|
for (String href : notFound) {
|
||||||
buffer.append("<D:response>\n");
|
buffer.append(" <D:response>\n");
|
||||||
buffer.append(" <D:href>").append(href).append("</D:href>\n");
|
buffer.append(" <D:href>").append(href).append("</D:href>\n");
|
||||||
buffer.append(" <D:propstat>\n");
|
buffer.append(" <D:propstat>\n");
|
||||||
buffer.append(" <D:status>HTTP/1.1 404 Not Found</D:status>\n");
|
buffer.append(" <D:status>HTTP/1.1 404 Not Found</D:status>\n");
|
||||||
@ -410,6 +390,36 @@ public class CaldavConnection extends AbstractConnection {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void appendEventsResponses(StringBuilder buffer, CaldavRequest request, List<ExchangeSession.Event> events) throws IOException {
|
||||||
|
int size = events.size();
|
||||||
|
int count = 0;
|
||||||
|
for (ExchangeSession.Event event : events) {
|
||||||
|
DavGatewayTray.debug("Retrieving event "+(++count)+"/"+size);
|
||||||
|
String eventPath = event.getPath().replaceAll("&", "&").replaceAll("<", "<").replaceAll(">", ">");
|
||||||
|
buffer.append("<D:response>\n");
|
||||||
|
buffer.append(" <D:href>/calendar").append(eventPath).append("</D:href>\n");
|
||||||
|
buffer.append(" <D:propstat>\n");
|
||||||
|
buffer.append(" <D:prop>\n");
|
||||||
|
if (request.hasProperty("calendar-data")) {
|
||||||
|
String ics = event.getICS();
|
||||||
|
if (ics != null && ics.length() > 0) {
|
||||||
|
ics = ics.replaceAll("&", "&").replaceAll("<", "<").replaceAll(">", ">");
|
||||||
|
buffer.append(" <C:calendar-data xmlns:C=\"urn:ietf:params:xml:ns:caldav\"\n");
|
||||||
|
buffer.append(" C:content-type=\"text/calendar\" C:version=\"2.0\">");
|
||||||
|
buffer.append(ics);
|
||||||
|
buffer.append("</C:calendar-data>\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (request.hasProperty("getetag")) {
|
||||||
|
buffer.append(" <D:getetag>").append(event.getEtag()).append("</D:getetag>\n");
|
||||||
|
}
|
||||||
|
buffer.append(" </D:prop>\n");
|
||||||
|
buffer.append(" <D:status>HTTP/1.1 200 OK</D:status>\n");
|
||||||
|
buffer.append(" </D:propstat>\n");
|
||||||
|
buffer.append(" </D:response>\n");
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void sendErr(int status, Exception e) throws IOException {
|
public void sendErr(int status, Exception e) throws IOException {
|
||||||
String message = e.getMessage();
|
String message = e.getMessage();
|
||||||
|
Loading…
Reference in New Issue
Block a user