mirror of
https://github.com/moparisthebest/davmail
synced 2024-12-13 03:02:22 -05:00
Caldav: first duedate implementation on tasks, fix delete task and concat ctag to detect changes on both calendar and tasks folders
git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@1738 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
parent
42623b3994
commit
9c7aab25ad
@ -52,8 +52,7 @@ public class VCalendar extends VObject {
|
|||||||
this.email = email;
|
this.email = email;
|
||||||
// set OWA timezone information
|
// set OWA timezone information
|
||||||
if (this.vTimezone == null && vTimezone != null) {
|
if (this.vTimezone == null && vTimezone != null) {
|
||||||
this.vObjects.add(0, vTimezone);
|
setTimezone(vTimezone);
|
||||||
this.vTimezone = vTimezone;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -88,10 +87,24 @@ public class VCalendar extends VObject {
|
|||||||
type = "VCALENDAR";
|
type = "VCALENDAR";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set timezone on vObject
|
||||||
|
*
|
||||||
|
* @param vTimezone timezone object
|
||||||
|
*/
|
||||||
|
public void setTimezone(VObject vTimezone) {
|
||||||
|
if (vObjects == null) {
|
||||||
|
addVObject(vTimezone);
|
||||||
|
} else {
|
||||||
|
vObjects.add(0, vTimezone);
|
||||||
|
}
|
||||||
|
this.vTimezone = vTimezone;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void addVObject(VObject vObject) {
|
public void addVObject(VObject vObject) {
|
||||||
super.addVObject(vObject);
|
super.addVObject(vObject);
|
||||||
if (firstVevent == null && ("VEVENT".equals(vObject.type)|| "VTODO".equals(vObject.type))) {
|
if (firstVevent == null && ("VEVENT".equals(vObject.type) || "VTODO".equals(vObject.type))) {
|
||||||
firstVevent = vObject;
|
firstVevent = vObject;
|
||||||
}
|
}
|
||||||
if ("VTIMEZONE".equals(vObject.type)) {
|
if ("VTIMEZONE".equals(vObject.type)) {
|
||||||
|
32
src/java/davmail/exchange/ews/AffectedTaskOccurrences.java
Normal file
32
src/java/davmail/exchange/ews/AffectedTaskOccurrences.java
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
/*
|
||||||
|
* DavMail POP/IMAP/SMTP/CalDav/LDAP Exchange Gateway
|
||||||
|
* Copyright (C) 2011 Mickael Guessant
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or
|
||||||
|
* modify it under the terms of the GNU General Public License
|
||||||
|
* as published by the Free Software Foundation; either version 2
|
||||||
|
* of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
package davmail.exchange.ews;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Item delete option.
|
||||||
|
*/
|
||||||
|
@SuppressWarnings({"JavaDoc", "UnusedDeclaration"})
|
||||||
|
public final class AffectedTaskOccurrences extends AttributeOption {
|
||||||
|
private AffectedTaskOccurrences(String value) {
|
||||||
|
super("AffectedTaskOccurrences", value);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static final AffectedTaskOccurrences AllOccurrences = new AffectedTaskOccurrences("AllOccurrences");
|
||||||
|
public static final AffectedTaskOccurrences SpecifiedOccurrenceOnly = new AffectedTaskOccurrences("SpecifiedOccurrenceOnly");
|
||||||
|
}
|
@ -33,6 +33,7 @@ public class DeleteItemMethod extends EWSMethod {
|
|||||||
super("Item", "DeleteItem");
|
super("Item", "DeleteItem");
|
||||||
addMethodOption(deleteType);
|
addMethodOption(deleteType);
|
||||||
addMethodOption(sendMeetingCancellations);
|
addMethodOption(sendMeetingCancellations);
|
||||||
|
addMethodOption(AffectedTaskOccurrences.AllOccurrences);
|
||||||
this.itemId = itemId;
|
this.itemId = itemId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -882,7 +882,12 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public ExchangeSession.Folder getFolder(String folderPath) throws IOException {
|
public ExchangeSession.Folder getFolder(String folderPath) throws IOException {
|
||||||
return internalGetFolder(folderPath);
|
Folder folder = internalGetFolder(folderPath);
|
||||||
|
if (isMainCalendar(folderPath)) {
|
||||||
|
Folder taskFolder = internalGetFolder(TASKS);
|
||||||
|
folder.ctag += taskFolder.ctag;
|
||||||
|
}
|
||||||
|
return folder;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -1199,7 +1204,7 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
public ItemResult createOrUpdate() throws IOException {
|
public ItemResult createOrUpdate() throws IOException {
|
||||||
if (vCalendar.isTodo() && isMainCalendar(folderPath)) {
|
if (vCalendar.isTodo() && isMainCalendar(folderPath)) {
|
||||||
// task item, move to tasks folder
|
// task item, move to tasks folder
|
||||||
folderPath = "tasks";
|
folderPath = TASKS;
|
||||||
}
|
}
|
||||||
|
|
||||||
ItemResult itemResult = new ItemResult();
|
ItemResult itemResult = new ItemResult();
|
||||||
@ -1248,6 +1253,7 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
} else {
|
} else {
|
||||||
updates.add(Field.createFieldUpdate("status", vTodoToTaskStatusMap.get(vTodoStatus)));
|
updates.add(Field.createFieldUpdate("status", vTodoToTaskStatusMap.get(vTodoStatus)));
|
||||||
}
|
}
|
||||||
|
updates.add(Field.createFieldUpdate("duedate", convertCalendarDateToExchange(vCalendar.getFirstVeventPropertyValue("DUE"))));
|
||||||
if (currentItemId != null) {
|
if (currentItemId != null) {
|
||||||
// update
|
// update
|
||||||
createOrUpdateItemMethod = new UpdateItemMethod(MessageDisposition.SaveOnly,
|
createOrUpdateItemMethod = new UpdateItemMethod(MessageDisposition.SaveOnly,
|
||||||
@ -1377,6 +1383,7 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
getItemMethod.addAdditionalProperty(Field.get("description"));
|
getItemMethod.addAdditionalProperty(Field.get("description"));
|
||||||
getItemMethod.addAdditionalProperty(Field.get("percentcomplete"));
|
getItemMethod.addAdditionalProperty(Field.get("percentcomplete"));
|
||||||
getItemMethod.addAdditionalProperty(Field.get("status"));
|
getItemMethod.addAdditionalProperty(Field.get("status"));
|
||||||
|
getItemMethod.addAdditionalProperty(Field.get("duedate"));
|
||||||
} else if (!"Message".equals(type)) {
|
} else if (!"Message".equals(type)) {
|
||||||
getItemMethod = new GetItemMethod(BaseShape.ID_ONLY, itemId, true);
|
getItemMethod = new GetItemMethod(BaseShape.ID_ONLY, itemId, true);
|
||||||
getItemMethod.addAdditionalProperty(Field.get("reminderset"));
|
getItemMethod.addAdditionalProperty(Field.get("reminderset"));
|
||||||
@ -1393,9 +1400,11 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
|
|
||||||
executeMethod(getItemMethod);
|
executeMethod(getItemMethod);
|
||||||
if ("Task".equals(type)) {
|
if ("Task".equals(type)) {
|
||||||
|
VObject vTimezone = getVTimezone();
|
||||||
VCalendar localVCalendar = new VCalendar();
|
VCalendar localVCalendar = new VCalendar();
|
||||||
VObject vTodo = new VObject();
|
VObject vTodo = new VObject();
|
||||||
vTodo.type = "VTODO";
|
vTodo.type = "VTODO";
|
||||||
|
localVCalendar.setTimezone(vTimezone);
|
||||||
vTodo.setPropertyValue("LAST-MODIFIED", convertDateFromExchange(getItemMethod.getResponseItem().get(Field.get("lastmodified").getResponseName())));
|
vTodo.setPropertyValue("LAST-MODIFIED", convertDateFromExchange(getItemMethod.getResponseItem().get(Field.get("lastmodified").getResponseName())));
|
||||||
vTodo.setPropertyValue("CREATED", convertDateFromExchange(getItemMethod.getResponseItem().get(Field.get("created").getResponseName())));
|
vTodo.setPropertyValue("CREATED", convertDateFromExchange(getItemMethod.getResponseItem().get(Field.get("created").getResponseName())));
|
||||||
String calendarUid = getItemMethod.getResponseItem().get(Field.get("calendaruid").getResponseName());
|
String calendarUid = getItemMethod.getResponseItem().get(Field.get("calendaruid").getResponseName());
|
||||||
@ -1408,6 +1417,9 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
vTodo.setPropertyValue("DESCRIPTION", getItemMethod.getResponseItem().get(Field.get("description").getResponseName()));
|
vTodo.setPropertyValue("DESCRIPTION", getItemMethod.getResponseItem().get(Field.get("description").getResponseName()));
|
||||||
vTodo.setPropertyValue("PERCENT-COMPLETE", getItemMethod.getResponseItem().get(Field.get("percentcomplete").getResponseName()));
|
vTodo.setPropertyValue("PERCENT-COMPLETE", getItemMethod.getResponseItem().get(Field.get("percentcomplete").getResponseName()));
|
||||||
vTodo.setPropertyValue("STATUS", taskTovTodoStatusMap.get(getItemMethod.getResponseItem().get(Field.get("status").getResponseName())));
|
vTodo.setPropertyValue("STATUS", taskTovTodoStatusMap.get(getItemMethod.getResponseItem().get(Field.get("status").getResponseName())));
|
||||||
|
VProperty vProperty = new VProperty("DUE", convertDateFromExchange(getItemMethod.getResponseItem().get(Field.get("duedate").getResponseName())));
|
||||||
|
vProperty.setParam("TZID", vTimezone.getPropertyValue("TZID"));
|
||||||
|
vTodo.addProperty(vProperty);
|
||||||
localVCalendar.addVObject(vTodo);
|
localVCalendar.addVObject(vTodo);
|
||||||
content = localVCalendar.toString().getBytes("UTF-8");
|
content = localVCalendar.toString().getBytes("UTF-8");
|
||||||
} else {
|
} else {
|
||||||
@ -1577,7 +1589,7 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
EWSMethod.Item item = getEwsItem(folderPath, itemName);
|
EWSMethod.Item item = getEwsItem(folderPath, itemName);
|
||||||
if (item == null && isMainCalendar(folderPath)) {
|
if (item == null && isMainCalendar(folderPath)) {
|
||||||
// look for item in task folder
|
// look for item in task folder
|
||||||
item = getEwsItem("tasks", itemName);
|
item = getEwsItem(TASKS, itemName);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (item == null) {
|
if (item == null) {
|
||||||
@ -1643,6 +1655,10 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
@Override
|
@Override
|
||||||
public void deleteItem(String folderPath, String itemName) throws IOException {
|
public void deleteItem(String folderPath, String itemName) throws IOException {
|
||||||
EWSMethod.Item item = getEwsItem(folderPath, itemName);
|
EWSMethod.Item item = getEwsItem(folderPath, itemName);
|
||||||
|
if (item == null && isMainCalendar(folderPath)) {
|
||||||
|
// look for item in task folder
|
||||||
|
item = getEwsItem(TASKS, itemName);
|
||||||
|
}
|
||||||
if (item != null) {
|
if (item != null) {
|
||||||
DeleteItemMethod deleteItemMethod = new DeleteItemMethod(new ItemId(item), DeleteType.HardDelete, SendMeetingCancellations.SendToNone);
|
DeleteItemMethod deleteItemMethod = new DeleteItemMethod(new ItemId(item), DeleteType.HardDelete, SendMeetingCancellations.SendToNone);
|
||||||
executeMethod(deleteItemMethod);
|
executeMethod(deleteItemMethod);
|
||||||
|
@ -209,7 +209,8 @@ public final class Field {
|
|||||||
|
|
||||||
// task
|
// task
|
||||||
FIELD_MAP.put("percentcomplete", new UnindexedFieldURI("task:PercentComplete"));
|
FIELD_MAP.put("percentcomplete", new UnindexedFieldURI("task:PercentComplete"));
|
||||||
FIELD_MAP.put("status", new UnindexedFieldURI("task:Status"));
|
FIELD_MAP.put("status", new UnindexedFieldURI("task:Status"));
|
||||||
|
FIELD_MAP.put("duedate", new UnindexedFieldURI("task:DueDate"));
|
||||||
|
|
||||||
// attachments
|
// attachments
|
||||||
FIELD_MAP.put("attachments", new UnindexedFieldURI("item:Attachments"));
|
FIELD_MAP.put("attachments", new UnindexedFieldURI("item:Attachments"));
|
||||||
|
Loading…
Reference in New Issue
Block a user