mirror of
https://github.com/moparisthebest/davmail
synced 2025-01-13 06:28:19 -05:00
EWS: implement folder handling, including the new MoveFolderMethod
git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@1111 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
parent
d961b647fa
commit
342b5d4e12
@ -24,7 +24,7 @@ package davmail.exchange.ews;
|
|||||||
public class DistinguishedFolderId extends FolderId {
|
public class DistinguishedFolderId extends FolderId {
|
||||||
|
|
||||||
private DistinguishedFolderId(String value) {
|
private DistinguishedFolderId(String value) {
|
||||||
super("t:DistinguishedFolderId", value);
|
super("t:DistinguishedFolderId", value, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final DistinguishedFolderId CALENDAR = new DistinguishedFolderId("calendar");
|
public static final DistinguishedFolderId CALENDAR = new DistinguishedFolderId("calendar");
|
||||||
|
35
src/java/davmail/exchange/ews/EWSException.java
Normal file
35
src/java/davmail/exchange/ews/EWSException.java
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
* DavMail POP/IMAP/SMTP/CalDav/LDAP Exchange Gateway
|
||||||
|
* Copyright (C) 2010 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;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* EWS Exception
|
||||||
|
*/
|
||||||
|
public class EWSException extends IOException {
|
||||||
|
/**
|
||||||
|
* Create EWS Exception with detailed error message
|
||||||
|
*
|
||||||
|
* @param message error message
|
||||||
|
*/
|
||||||
|
public EWSException(String message) {
|
||||||
|
super(message);
|
||||||
|
}
|
||||||
|
}
|
@ -18,10 +18,10 @@
|
|||||||
*/
|
*/
|
||||||
package davmail.exchange.ews;
|
package davmail.exchange.ews;
|
||||||
|
|
||||||
import com.wutka.dtd.DTDOutput;
|
|
||||||
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;
|
||||||
import org.apache.commons.httpclient.HttpConnection;
|
import org.apache.commons.httpclient.HttpConnection;
|
||||||
|
import org.apache.commons.httpclient.HttpException;
|
||||||
import org.apache.commons.httpclient.HttpState;
|
import org.apache.commons.httpclient.HttpState;
|
||||||
import org.apache.commons.httpclient.methods.PostMethod;
|
import org.apache.commons.httpclient.methods.PostMethod;
|
||||||
import org.apache.commons.httpclient.methods.RequestEntity;
|
import org.apache.commons.httpclient.methods.RequestEntity;
|
||||||
@ -44,11 +44,14 @@ public abstract class EWSMethod extends PostMethod {
|
|||||||
protected BaseShape baseShape;
|
protected BaseShape baseShape;
|
||||||
protected boolean includeMimeContent;
|
protected boolean includeMimeContent;
|
||||||
protected FolderId folderId;
|
protected FolderId folderId;
|
||||||
|
protected FolderId toFolderId;
|
||||||
protected FolderId parentFolderId;
|
protected FolderId parentFolderId;
|
||||||
protected ItemId itemId;
|
protected ItemId itemId;
|
||||||
protected Set<FieldURI> additionalProperties;
|
protected Set<FieldURI> additionalProperties;
|
||||||
protected Disposal deleteType;
|
protected Disposal deleteType;
|
||||||
|
|
||||||
|
protected Set<FieldUpdate> updates;
|
||||||
|
|
||||||
protected final String itemType;
|
protected final String itemType;
|
||||||
protected final String methodName;
|
protected final String methodName;
|
||||||
protected final String responseCollectionName;
|
protected final String responseCollectionName;
|
||||||
@ -163,9 +166,21 @@ public abstract class EWSMethod extends PostMethod {
|
|||||||
|
|
||||||
protected void writeFolderId(Writer writer) throws IOException {
|
protected void writeFolderId(Writer writer) throws IOException {
|
||||||
if (folderId != null) {
|
if (folderId != null) {
|
||||||
writer.write("<m:FolderIds>");
|
if (updates == null) {
|
||||||
|
writer.write("<m:FolderIds>");
|
||||||
|
}
|
||||||
folderId.write(writer);
|
folderId.write(writer);
|
||||||
writer.write("</m:FolderIds>");
|
if (updates == null) {
|
||||||
|
writer.write("</m:FolderIds>");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void writeToFolderId(Writer writer) throws IOException {
|
||||||
|
if (toFolderId != null) {
|
||||||
|
writer.write("<m:ToFolderId>");
|
||||||
|
toFolderId.write(writer);
|
||||||
|
writer.write("</m:ToFolderId>");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -207,6 +222,47 @@ public abstract class EWSMethod extends PostMethod {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void startChanges(Writer writer) throws IOException {
|
||||||
|
if (updates != null) {
|
||||||
|
writer.write("<m:");
|
||||||
|
writer.write(itemType);
|
||||||
|
writer.write("Changes>");
|
||||||
|
writer.write("<t:");
|
||||||
|
writer.write(itemType);
|
||||||
|
writer.write("Change>");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void writeUpdates(Writer writer) throws IOException {
|
||||||
|
if (updates != null) {
|
||||||
|
writer.write("<t:Updates>");
|
||||||
|
for (FieldUpdate fieldUpdate : updates) {
|
||||||
|
writer.write("<t:Set");
|
||||||
|
writer.write(itemType);
|
||||||
|
writer.write("Field>");
|
||||||
|
|
||||||
|
fieldUpdate.write(itemType, writer);
|
||||||
|
|
||||||
|
writer.write("</t:Set");
|
||||||
|
writer.write(itemType);
|
||||||
|
writer.write("Field>");
|
||||||
|
}
|
||||||
|
writer.write("</t:Updates>");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected void endChanges(Writer writer) throws IOException {
|
||||||
|
if (updates != null) {
|
||||||
|
writer.write("</t:");
|
||||||
|
writer.write(itemType);
|
||||||
|
writer.write("Change>");
|
||||||
|
writer.write("</m:");
|
||||||
|
writer.write(itemType);
|
||||||
|
writer.write("Changes>");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
protected byte[] generateSoapEnvelope() {
|
protected byte[] generateSoapEnvelope() {
|
||||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
try {
|
try {
|
||||||
@ -216,7 +272,7 @@ public abstract class EWSMethod extends PostMethod {
|
|||||||
"xmlns:m=\"http://schemas.microsoft.com/exchange/services/2006/messages\">" +
|
"xmlns:m=\"http://schemas.microsoft.com/exchange/services/2006/messages\">" +
|
||||||
"<soap:Header>" +
|
"<soap:Header>" +
|
||||||
"<t:RequestServerVersion Version=\"Exchange2007_SP1\"/>" +
|
"<t:RequestServerVersion Version=\"Exchange2007_SP1\"/>" +
|
||||||
"</soap:Header>"+
|
"</soap:Header>" +
|
||||||
"<soap:Body>");
|
"<soap:Body>");
|
||||||
writer.write("<m:");
|
writer.write("<m:");
|
||||||
writer.write(methodName);
|
writer.write(methodName);
|
||||||
@ -241,12 +297,16 @@ public abstract class EWSMethod extends PostMethod {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected void writeSoapBody(Writer writer) throws IOException {
|
protected void writeSoapBody(Writer writer) throws IOException {
|
||||||
|
startChanges(writer);
|
||||||
writeShape(writer);
|
writeShape(writer);
|
||||||
writeRestriction(writer);
|
writeRestriction(writer);
|
||||||
writeItemId(writer);
|
writeItemId(writer);
|
||||||
writeParentFolderId(writer);
|
writeParentFolderId(writer);
|
||||||
|
writeToFolderId(writer);
|
||||||
writeFolderId(writer);
|
writeFolderId(writer);
|
||||||
writeItem(writer);
|
writeItem(writer);
|
||||||
|
writeUpdates(writer);
|
||||||
|
endChanges(writer);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -313,11 +373,19 @@ public abstract class EWSMethod extends PostMethod {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Item> getResponseItems() {
|
public void checkSuccess() throws EWSException {
|
||||||
|
if (errorDetail != null) {
|
||||||
|
throw new EWSException(errorDetail);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<Item> getResponseItems() throws EWSException {
|
||||||
|
checkSuccess();
|
||||||
return responseItems;
|
return responseItems;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Item getResponseItem() {
|
public Item getResponseItem() throws EWSException {
|
||||||
|
checkSuccess();
|
||||||
if (responseItems != null && responseItems.size() == 1) {
|
if (responseItems != null && responseItems.size() == 1) {
|
||||||
return responseItems.get(0);
|
return responseItems.get(0);
|
||||||
} else {
|
} else {
|
||||||
@ -325,7 +393,8 @@ public abstract class EWSMethod extends PostMethod {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public byte[] getMimeContent() {
|
public byte[] getMimeContent() throws EWSException {
|
||||||
|
checkSuccess();
|
||||||
return mimeContent;
|
return mimeContent;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -381,6 +450,8 @@ public abstract class EWSMethod extends PostMethod {
|
|||||||
} else {
|
} else {
|
||||||
if (tagLocalName.endsWith("Id")) {
|
if (tagLocalName.endsWith("Id")) {
|
||||||
value = getAttributeValue(reader, "Id");
|
value = getAttributeValue(reader, "Id");
|
||||||
|
// get change key
|
||||||
|
item.put("ChangeKey", getAttributeValue(reader, "ChangeKey"));
|
||||||
}
|
}
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
value = getTagContent(reader);
|
value = getTagContent(reader);
|
||||||
|
@ -45,6 +45,22 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
public FolderId folderId;
|
public FolderId folderId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected class FolderPath {
|
||||||
|
protected String parentPath;
|
||||||
|
protected String folderName;
|
||||||
|
|
||||||
|
protected FolderPath(String folderPath) {
|
||||||
|
int slashIndex = folderPath.lastIndexOf('/');
|
||||||
|
if (slashIndex < 0) {
|
||||||
|
parentPath = "";
|
||||||
|
folderName = folderPath;
|
||||||
|
} else {
|
||||||
|
parentPath = folderPath.substring(0, slashIndex);
|
||||||
|
folderName = folderPath.substring(slashIndex + 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @inheritDoc
|
* @inheritDoc
|
||||||
*/
|
*/
|
||||||
@ -317,7 +333,8 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
|
|
||||||
protected Folder buildFolder(EWSMethod.Item item) {
|
protected Folder buildFolder(EWSMethod.Item item) {
|
||||||
Folder folder = new Folder();
|
Folder folder = new Folder();
|
||||||
folder.folderId = new FolderId(item.get("FolderId"));
|
folder.folderId = new FolderId(item.get("FolderId"), item.get("ChangeKey"));
|
||||||
|
folder.displayName = item.get(ExtendedFieldURI.PR_URL_COMP_NAME.getPropertyTag());
|
||||||
folder.folderClass = item.get(ExtendedFieldURI.PR_CONTAINER_CLASS.getPropertyTag());
|
folder.folderClass = item.get(ExtendedFieldURI.PR_CONTAINER_CLASS.getPropertyTag());
|
||||||
folder.etag = item.get(ExtendedFieldURI.PR_LAST_MODIFICATION_TIME.getPropertyTag());
|
folder.etag = item.get(ExtendedFieldURI.PR_LAST_MODIFICATION_TIME.getPropertyTag());
|
||||||
folder.ctag = item.get(ExtendedFieldURI.PR_LOCAL_COMMIT_TIME_MAX.getPropertyTag());
|
folder.ctag = item.get(ExtendedFieldURI.PR_LOCAL_COMMIT_TIME_MAX.getPropertyTag());
|
||||||
@ -342,11 +359,7 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
Condition condition, boolean recursive) throws IOException {
|
Condition condition, boolean recursive) throws IOException {
|
||||||
FindFolderMethod findFolderMethod = new FindFolderMethod(FolderQueryTraversal.SHALLOW,
|
FindFolderMethod findFolderMethod = new FindFolderMethod(FolderQueryTraversal.SHALLOW,
|
||||||
BaseShape.ID_ONLY, parentFolderId, FOLDER_PROPERTIES, (SearchExpression) condition);
|
BaseShape.ID_ONLY, parentFolderId, FOLDER_PROPERTIES, (SearchExpression) condition);
|
||||||
try {
|
executeMethod(findFolderMethod);
|
||||||
httpClient.executeMethod(findFolderMethod);
|
|
||||||
} finally {
|
|
||||||
findFolderMethod.releaseConnection();
|
|
||||||
}
|
|
||||||
for (EWSMethod.Item item : findFolderMethod.getResponseItems()) {
|
for (EWSMethod.Item item : findFolderMethod.getResponseItems()) {
|
||||||
Folder folder = buildFolder(item);
|
Folder folder = buildFolder(item);
|
||||||
if (parentFolderPath.length() > 0) {
|
if (parentFolderPath.length() > 0) {
|
||||||
@ -369,11 +382,7 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
@Override
|
@Override
|
||||||
public EwsExchangeSession.Folder getFolder(String folderPath) throws IOException {
|
public EwsExchangeSession.Folder getFolder(String folderPath) throws IOException {
|
||||||
GetFolderMethod getFolderMethod = new GetFolderMethod(BaseShape.ID_ONLY, getFolderId(folderPath), FOLDER_PROPERTIES);
|
GetFolderMethod getFolderMethod = new GetFolderMethod(BaseShape.ID_ONLY, getFolderId(folderPath), FOLDER_PROPERTIES);
|
||||||
try {
|
executeMethod(getFolderMethod);
|
||||||
httpClient.executeMethod(getFolderMethod);
|
|
||||||
} finally {
|
|
||||||
getFolderMethod.releaseConnection();
|
|
||||||
}
|
|
||||||
EWSMethod.Item item = getFolderMethod.getResponseItem();
|
EWSMethod.Item item = getFolderMethod.getResponseItem();
|
||||||
Folder folder = null;
|
Folder folder = null;
|
||||||
if (item != null) {
|
if (item != null) {
|
||||||
@ -387,16 +396,28 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
* @inheritDoc
|
* @inheritDoc
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void createFolder(String folderName, String folderClass) throws IOException {
|
public void createFolder(String folderPath, String folderClass) throws IOException {
|
||||||
throw new UnsupportedOperationException();
|
FolderPath path = new FolderPath(folderPath);
|
||||||
|
EWSMethod.Item folder = new EWSMethod.Item();
|
||||||
|
folder.type = "Folder";
|
||||||
|
folder.put("DisplayName", path.folderName);
|
||||||
|
folder.put("FolderClass", folderClass);
|
||||||
|
CreateFolderMethod createFolderMethod = new CreateFolderMethod(getFolderId(path.parentPath), folder);
|
||||||
|
executeMethod(createFolderMethod);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @inheritDoc
|
* @inheritDoc
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void deleteFolder(String folderName) throws IOException {
|
public void deleteFolder(String folderPath) throws IOException {
|
||||||
throw new UnsupportedOperationException();
|
FolderId folderId = getFolderIdIfExists(folderPath);
|
||||||
|
if (folderId != null) {
|
||||||
|
DeleteFolderMethod deleteFolderMethod = new DeleteFolderMethod(folderId);
|
||||||
|
executeMethod(deleteFolderMethod);
|
||||||
|
} else {
|
||||||
|
LOGGER.debug("Folder "+folderPath+" not found");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -411,8 +432,24 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
* @inheritDoc
|
* @inheritDoc
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void moveFolder(String folderName, String targetName) throws IOException {
|
public void moveFolder(String folderPath, String targetFolderPath) throws IOException {
|
||||||
throw new UnsupportedOperationException();
|
FolderPath path = new FolderPath(folderPath);
|
||||||
|
FolderPath targetPath = new FolderPath(targetFolderPath);
|
||||||
|
FolderId folderId = getFolderId(folderPath);
|
||||||
|
FolderId toFolderId = getFolderId(targetPath.parentPath);
|
||||||
|
toFolderId.changeKey = null;
|
||||||
|
// move folder
|
||||||
|
if (!path.parentPath.equals(targetPath.parentPath)) {
|
||||||
|
MoveFolderMethod moveFolderMethod = new MoveFolderMethod(folderId, toFolderId);
|
||||||
|
executeMethod(moveFolderMethod);
|
||||||
|
}
|
||||||
|
// rename folder
|
||||||
|
if (!path.folderName.equals(targetPath.folderName)) {
|
||||||
|
Set<FieldUpdate> updates = new HashSet<FieldUpdate>();
|
||||||
|
updates.add(new FieldUpdate(UnindexedFieldURI.FOLDER_DISPLAYNAME, targetPath.folderName));
|
||||||
|
UpdateFolderMethod updateFolderMethod = new UpdateFolderMethod(folderId, updates);
|
||||||
|
executeMethod(updateFolderMethod);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -470,6 +507,14 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
|
|
||||||
|
|
||||||
private FolderId getFolderId(String folderPath) throws IOException {
|
private FolderId getFolderId(String folderPath) throws IOException {
|
||||||
|
FolderId folderId = getFolderIdIfExists(folderPath);
|
||||||
|
if (folderId == null) {
|
||||||
|
throw new DavMailException("EXCEPTION_FOLDER_NOT_FOUND", folderPath);
|
||||||
|
}
|
||||||
|
return folderId;
|
||||||
|
}
|
||||||
|
|
||||||
|
private FolderId getFolderIdIfExists(String folderPath) throws IOException {
|
||||||
String[] folderNames;
|
String[] folderNames;
|
||||||
FolderId currentFolderId;
|
FolderId currentFolderId;
|
||||||
if (folderPath.startsWith(PUBLIC_ROOT)) {
|
if (folderPath.startsWith(PUBLIC_ROOT)) {
|
||||||
@ -506,12 +551,16 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
for (String folderName : folderNames) {
|
for (String folderName : folderNames) {
|
||||||
if (folderName.length() > 0) {
|
if (folderName.length() > 0) {
|
||||||
currentFolderId = getSubFolderByName(currentFolderId, folderName);
|
currentFolderId = getSubFolderByName(currentFolderId, folderName);
|
||||||
|
if (currentFolderId == null) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return currentFolderId;
|
return currentFolderId;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected FolderId getSubFolderByName(FolderId parentFolderId, String folderName) throws IOException {
|
protected FolderId getSubFolderByName(FolderId parentFolderId, String folderName) throws IOException {
|
||||||
|
FolderId folderId = null;
|
||||||
FindFolderMethod findFolderMethod = new FindFolderMethod(
|
FindFolderMethod findFolderMethod = new FindFolderMethod(
|
||||||
FolderQueryTraversal.SHALLOW,
|
FolderQueryTraversal.SHALLOW,
|
||||||
BaseShape.ID_ONLY,
|
BaseShape.ID_ONLY,
|
||||||
@ -520,16 +569,23 @@ public class EwsExchangeSession extends ExchangeSession {
|
|||||||
new TwoOperandExpression(TwoOperandExpression.Operator.IsEqualTo,
|
new TwoOperandExpression(TwoOperandExpression.Operator.IsEqualTo,
|
||||||
ExtendedFieldURI.PR_URL_COMP_NAME, folderName)
|
ExtendedFieldURI.PR_URL_COMP_NAME, folderName)
|
||||||
);
|
);
|
||||||
try {
|
executeMethod(findFolderMethod);
|
||||||
httpClient.executeMethod(findFolderMethod);
|
|
||||||
} finally {
|
|
||||||
findFolderMethod.releaseConnection();
|
|
||||||
}
|
|
||||||
EWSMethod.Item item = findFolderMethod.getResponseItem();
|
EWSMethod.Item item = findFolderMethod.getResponseItem();
|
||||||
if (item == null) {
|
if (item != null) {
|
||||||
throw new DavMailException("EXCEPTION_FOLDER_NOT_FOUND", folderName);
|
folderId = new FolderId(item.get("FolderId"), item.get("ChangeKey"));
|
||||||
}
|
}
|
||||||
return new FolderId(item.get("FolderId"));
|
return folderId;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected int executeMethod(EWSMethod ewsMethod) throws IOException {
|
||||||
|
int status;
|
||||||
|
try {
|
||||||
|
status = httpClient.executeMethod(ewsMethod);
|
||||||
|
ewsMethod.checkSuccess();
|
||||||
|
} finally {
|
||||||
|
ewsMethod.releaseConnection();
|
||||||
|
}
|
||||||
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -85,6 +85,22 @@ public class ExtendedFieldURI implements FieldURI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void appendValue(StringBuilder buffer, String itemType, String value) {
|
||||||
|
appendTo(buffer);
|
||||||
|
buffer.append("<t:");
|
||||||
|
buffer.append(itemType);
|
||||||
|
buffer.append('>');
|
||||||
|
buffer.append("<t:ExtendedProperty>");
|
||||||
|
appendTo(buffer);
|
||||||
|
buffer.append("<t:Value>");
|
||||||
|
buffer.append(value);
|
||||||
|
buffer.append("</t:Value>");
|
||||||
|
buffer.append("</t:ExtendedProperty>");
|
||||||
|
buffer.append("</t:");
|
||||||
|
buffer.append(itemType);
|
||||||
|
buffer.append('>');
|
||||||
|
}
|
||||||
|
|
||||||
public static final ExtendedFieldURI PR_INSTANCE_KEY = new ExtendedFieldURI(0xff6, PropertyType.Binary);
|
public static final ExtendedFieldURI PR_INSTANCE_KEY = new ExtendedFieldURI(0xff6, PropertyType.Binary);
|
||||||
public static final ExtendedFieldURI PR_MESSAGE_SIZE = new ExtendedFieldURI(0xe08, PropertyType.Integer);
|
public static final ExtendedFieldURI PR_MESSAGE_SIZE = new ExtendedFieldURI(0xe08, PropertyType.Integer);
|
||||||
public static final ExtendedFieldURI PR_INTERNET_ARTICLE_NUMBER = new ExtendedFieldURI(0xe23, PropertyType.Integer);
|
public static final ExtendedFieldURI PR_INTERNET_ARTICLE_NUMBER = new ExtendedFieldURI(0xe23, PropertyType.Integer);
|
||||||
|
@ -26,6 +26,16 @@ import java.io.Writer;
|
|||||||
*/
|
*/
|
||||||
public interface FieldURI {
|
public interface FieldURI {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Append field to buffer
|
||||||
|
* @param buffer current buffer
|
||||||
|
*/
|
||||||
public void appendTo(StringBuilder buffer);
|
public void appendTo(StringBuilder buffer);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Append updated field value to buffer
|
||||||
|
* @param buffer current buffer
|
||||||
|
*/
|
||||||
|
public void appendValue(StringBuilder buffer, String itemType, String value);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
41
src/java/davmail/exchange/ews/FieldUpdate.java
Normal file
41
src/java/davmail/exchange/ews/FieldUpdate.java
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
* DavMail POP/IMAP/SMTP/CalDav/LDAP Exchange Gateway
|
||||||
|
* Copyright (C) 2010 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;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.Writer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Field update
|
||||||
|
*/
|
||||||
|
public class FieldUpdate {
|
||||||
|
FieldURI fieldURI;
|
||||||
|
String value;
|
||||||
|
|
||||||
|
public FieldUpdate(FieldURI fieldURI, String value) {
|
||||||
|
this.fieldURI = fieldURI;
|
||||||
|
this.value = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void write(String itemType, Writer writer) throws IOException {
|
||||||
|
StringBuilder buffer = new StringBuilder();
|
||||||
|
fieldURI.appendValue(buffer, itemType, value);
|
||||||
|
writer.write(buffer.toString());
|
||||||
|
}
|
||||||
|
}
|
@ -25,9 +25,11 @@ import java.io.Writer;
|
|||||||
* Folder Id.
|
* Folder Id.
|
||||||
*/
|
*/
|
||||||
public class FolderId extends Option {
|
public class FolderId extends Option {
|
||||||
|
protected String changeKey;
|
||||||
|
|
||||||
protected FolderId(String name, String value) {
|
protected FolderId(String name, String value, String changeKey) {
|
||||||
super(name, value);
|
super(name, value);
|
||||||
|
this.changeKey = changeKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -35,8 +37,9 @@ public class FolderId extends Option {
|
|||||||
*
|
*
|
||||||
* @param value id value
|
* @param value id value
|
||||||
*/
|
*/
|
||||||
public FolderId(String value) {
|
public FolderId(String value, String changeKey) {
|
||||||
super("t:FolderId", value);
|
super("t:FolderId", value);
|
||||||
|
this.changeKey = changeKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -48,6 +51,10 @@ public class FolderId extends Option {
|
|||||||
writer.write(name);
|
writer.write(name);
|
||||||
writer.write(" Id=\"");
|
writer.write(" Id=\"");
|
||||||
writer.write(value);
|
writer.write(value);
|
||||||
|
if (changeKey != null) {
|
||||||
|
writer.write("\" ChangeKey=\"");
|
||||||
|
writer.write(changeKey);
|
||||||
|
}
|
||||||
writer.write("\"/>");
|
writer.write("\"/>");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -35,4 +35,21 @@ public class IndexedFieldURI implements FieldURI {
|
|||||||
buffer.append("\" FieldIndex=\"").append(fieldIndex);
|
buffer.append("\" FieldIndex=\"").append(fieldIndex);
|
||||||
buffer.append("\"/>");
|
buffer.append("\"/>");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void appendValue(StringBuilder buffer, String itemType, String value) {
|
||||||
|
appendTo(buffer);
|
||||||
|
buffer.append("<t:");
|
||||||
|
buffer.append(itemType);
|
||||||
|
buffer.append('>');
|
||||||
|
buffer.append("<t:");
|
||||||
|
buffer.append(fieldIndex);
|
||||||
|
buffer.append('>');
|
||||||
|
buffer.append(value);
|
||||||
|
buffer.append("</t:");
|
||||||
|
buffer.append(fieldIndex);
|
||||||
|
buffer.append('>');
|
||||||
|
buffer.append("</t:");
|
||||||
|
buffer.append(itemType);
|
||||||
|
buffer.append('>');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
30
src/java/davmail/exchange/ews/MoveFolderMethod.java
Normal file
30
src/java/davmail/exchange/ews/MoveFolderMethod.java
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
/*
|
||||||
|
* DavMail POP/IMAP/SMTP/CalDav/LDAP Exchange Gateway
|
||||||
|
* Copyright (C) 2010 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;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create Folder method.
|
||||||
|
*/
|
||||||
|
public class MoveFolderMethod extends EWSMethod {
|
||||||
|
public MoveFolderMethod(FolderId folderId, FolderId toFolderId) {
|
||||||
|
super("Folder", "MoveFolder");
|
||||||
|
this.folderId = folderId;
|
||||||
|
this.toFolderId = toFolderId;
|
||||||
|
}
|
||||||
|
}
|
@ -25,16 +25,41 @@ import java.io.Writer;
|
|||||||
* Unindexed Field URI
|
* Unindexed Field URI
|
||||||
*/
|
*/
|
||||||
public class UnindexedFieldURI implements FieldURI {
|
public class UnindexedFieldURI implements FieldURI {
|
||||||
protected String fieldURI;
|
protected final String fieldURI;
|
||||||
|
protected final String fieldName;
|
||||||
|
|
||||||
public UnindexedFieldURI(String fieldURI) {
|
public UnindexedFieldURI(String fieldURI) {
|
||||||
this.fieldURI = fieldURI;
|
this.fieldURI = fieldURI;
|
||||||
|
int colonIndex = fieldURI.indexOf(':');
|
||||||
|
if (colonIndex < 0) {
|
||||||
|
fieldName = fieldURI;
|
||||||
|
} else {
|
||||||
|
fieldName = fieldURI.substring(colonIndex+1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void appendTo(StringBuilder buffer) {
|
public void appendTo(StringBuilder buffer) {
|
||||||
buffer.append("<t:FieldURI FieldURI=\"").append(fieldURI).append("\"/>");
|
buffer.append("<t:FieldURI FieldURI=\"").append(fieldURI).append("\"/>");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void appendValue(StringBuilder buffer, String itemType, String value) {
|
||||||
|
appendTo(buffer);
|
||||||
|
buffer.append("<t:");
|
||||||
|
buffer.append(itemType);
|
||||||
|
buffer.append('>');
|
||||||
|
buffer.append("<t:");
|
||||||
|
buffer.append(fieldName);
|
||||||
|
buffer.append('>');
|
||||||
|
buffer.append(value);
|
||||||
|
buffer.append("</t:");
|
||||||
|
buffer.append(fieldName);
|
||||||
|
buffer.append('>');
|
||||||
|
buffer.append("</t:");
|
||||||
|
buffer.append(itemType);
|
||||||
|
buffer.append('>');
|
||||||
|
}
|
||||||
|
|
||||||
public static final UnindexedFieldURI DATE_TIME_SENT = new UnindexedFieldURI("item:DateTimeSent");
|
public static final UnindexedFieldURI DATE_TIME_SENT = new UnindexedFieldURI("item:DateTimeSent");
|
||||||
|
public static final UnindexedFieldURI FOLDER_DISPLAYNAME = new UnindexedFieldURI("folder:DisplayName");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
32
src/java/davmail/exchange/ews/UpdateFolderMethod.java
Normal file
32
src/java/davmail/exchange/ews/UpdateFolderMethod.java
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
/*
|
||||||
|
* DavMail POP/IMAP/SMTP/CalDav/LDAP Exchange Gateway
|
||||||
|
* Copyright (C) 2010 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;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create Folder method.
|
||||||
|
*/
|
||||||
|
public class UpdateFolderMethod extends EWSMethod {
|
||||||
|
public UpdateFolderMethod(FolderId folderId, Set<FieldUpdate> updates) {
|
||||||
|
super("Folder", "UpdateFolder");
|
||||||
|
this.folderId = folderId;
|
||||||
|
this.updates = updates;
|
||||||
|
}
|
||||||
|
}
|
@ -27,6 +27,7 @@ import java.io.IOException;
|
|||||||
|
|
||||||
import davmail.Settings;
|
import davmail.Settings;
|
||||||
import davmail.http.DavGatewaySSLProtocolSocketFactory;
|
import davmail.http.DavGatewaySSLProtocolSocketFactory;
|
||||||
|
import org.apache.log4j.Level;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Exchange session test case.
|
* Exchange session test case.
|
||||||
@ -59,13 +60,15 @@ public class AbstractExchangeSessionTestCase extends TestCase {
|
|||||||
Settings.setProperty("davmail.password", password);
|
Settings.setProperty("davmail.password", password);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Settings.setProperty("davmail.enableEws", "true");
|
|
||||||
|
|
||||||
DavGatewaySSLProtocolSocketFactory.register();
|
DavGatewaySSLProtocolSocketFactory.register();
|
||||||
// force server mode
|
// force server mode
|
||||||
Settings.setProperty("davmail.server", "true");
|
Settings.setProperty("davmail.server", "true");
|
||||||
|
|
||||||
// enable WIRE debug log
|
// enable WIRE debug log
|
||||||
//Settings.setLoggingLevel("httpclient.wire", Level.DEBUG);
|
//Settings.setLoggingLevel("httpclient.wire", Level.DEBUG);
|
||||||
|
// enable EWS support
|
||||||
|
//Settings.setProperty("davmail.enableEws", "true");
|
||||||
|
|
||||||
// open session, get username and password from davmail.properties
|
// open session, get username and password from davmail.properties
|
||||||
// Note: those properties should *not* exist in normal production mode,
|
// Note: those properties should *not* exist in normal production mode,
|
||||||
|
@ -55,9 +55,12 @@ public class TestExchangeSessionFolder extends AbstractExchangeSessionTestCase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void testMoveFolder() throws IOException {
|
public void testMoveFolder() throws IOException {
|
||||||
|
session.deleteFolder("target");
|
||||||
|
session.deleteFolder("tomove");
|
||||||
session.createMessageFolder("tomove");
|
session.createMessageFolder("tomove");
|
||||||
session.moveFolder("tomove", "test/moved");
|
session.createMessageFolder("target");
|
||||||
session.deleteFolder("test/moved");
|
session.moveFolder("tomove", "target/moved");
|
||||||
|
session.deleteFolder("target");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDeleteFolder() throws IOException {
|
public void testDeleteFolder() throws IOException {
|
||||||
|
Loading…
Reference in New Issue
Block a user