mirror of
https://github.com/moparisthebest/davmail
synced 2025-01-07 11:48:02 -05:00
Carddav: implement categories
git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@1184 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
parent
be64383007
commit
63324f9a78
@ -1751,6 +1751,9 @@ public abstract class ExchangeSession {
|
|||||||
|
|
||||||
writer.appendProperty("BDAY", get("bday"));
|
writer.appendProperty("BDAY", get("bday"));
|
||||||
|
|
||||||
|
// categories
|
||||||
|
writer.appendProperty("CATEGORIES", get("keywords"));
|
||||||
|
|
||||||
writer.appendProperty("X-ASSISTANT", get("secretarycn"));
|
writer.appendProperty("X-ASSISTANT", get("secretarycn"));
|
||||||
writer.appendProperty("X-MANAGER", get("manager"));
|
writer.appendProperty("X-MANAGER", get("manager"));
|
||||||
writer.appendProperty("X-SPOUSE", get("spousecn"));
|
writer.appendProperty("X-SPOUSE", get("spousecn"));
|
||||||
@ -2672,6 +2675,8 @@ public abstract class ExchangeSession {
|
|||||||
protected static final String[] VCARD_ADR_OTHER_PROPERTIES = {"otherpostofficebox", null, "otherstreet", "othercity", "otherstate", "otherpostalcode", "othercountry"};
|
protected static final String[] VCARD_ADR_OTHER_PROPERTIES = {"otherpostofficebox", null, "otherstreet", "othercity", "otherstate", "otherpostalcode", "othercountry"};
|
||||||
protected static final String[] VCARD_ORG_PROPERTIES = {"o", "department"};
|
protected static final String[] VCARD_ORG_PROPERTIES = {"o", "department"};
|
||||||
|
|
||||||
|
protected static final String[] EMPTY_PROPERTIES = {"description", "keywords"};
|
||||||
|
|
||||||
protected void convertContactProperties(Map<String, String> properties, String[] contactProperties, List<String> values) {
|
protected void convertContactProperties(Map<String, String> properties, String[] contactProperties, List<String> values) {
|
||||||
for (int i = 0; i < values.size() && i < contactProperties.length; i++) {
|
for (int i = 0; i < values.size() && i < contactProperties.length; i++) {
|
||||||
if (contactProperties[i] != null) {
|
if (contactProperties[i] != null) {
|
||||||
@ -2763,6 +2768,8 @@ public abstract class ExchangeSession {
|
|||||||
LOGGER.warn("Invalid date: " + value);
|
LOGGER.warn("Invalid date: " + value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if ("CATEGORIES".equals(property.getKey())) {
|
||||||
|
properties.put("keywords", property.getValue());
|
||||||
} else if ("X-ASSISTANT".equals(property.getKey())) {
|
} else if ("X-ASSISTANT".equals(property.getKey())) {
|
||||||
properties.put("secretarycn", property.getValue());
|
properties.put("secretarycn", property.getValue());
|
||||||
} else if ("X-MANAGER".equals(property.getKey())) {
|
} else if ("X-MANAGER".equals(property.getKey())) {
|
||||||
@ -2771,6 +2778,13 @@ public abstract class ExchangeSession {
|
|||||||
properties.put("spousecn", property.getValue());
|
properties.put("spousecn", property.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// detect empty values
|
||||||
|
for (String key : EMPTY_PROPERTIES) {
|
||||||
|
if (!properties.containsKey(key)) {
|
||||||
|
properties.put(key, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return internalCreateOrUpdateContact(folderPath, itemName, properties, etag, noneMatch);
|
return internalCreateOrUpdateContact(folderPath, itemName, properties, etag, noneMatch);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3116,6 +3130,7 @@ public abstract class ExchangeSession {
|
|||||||
CONTACT_ATTRIBUTES.add("othercountry");
|
CONTACT_ATTRIBUTES.add("othercountry");
|
||||||
CONTACT_ATTRIBUTES.add("othercity");
|
CONTACT_ATTRIBUTES.add("othercity");
|
||||||
CONTACT_ATTRIBUTES.add("haspicture");
|
CONTACT_ATTRIBUTES.add("haspicture");
|
||||||
|
CONTACT_ATTRIBUTES.add("keywords");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -42,6 +42,7 @@ import org.apache.jackrabbit.webdav.client.methods.PropPatchMethod;
|
|||||||
import org.apache.jackrabbit.webdav.property.DavProperty;
|
import org.apache.jackrabbit.webdav.property.DavProperty;
|
||||||
import org.apache.jackrabbit.webdav.property.DavPropertyNameSet;
|
import org.apache.jackrabbit.webdav.property.DavPropertyNameSet;
|
||||||
import org.apache.jackrabbit.webdav.property.DavPropertySet;
|
import org.apache.jackrabbit.webdav.property.DavPropertySet;
|
||||||
|
import org.w3c.dom.Node;
|
||||||
|
|
||||||
import javax.mail.MessagingException;
|
import javax.mail.MessagingException;
|
||||||
import javax.mail.internet.MimeMessage;
|
import javax.mail.internet.MimeMessage;
|
||||||
@ -967,7 +968,21 @@ public class DavExchangeSession extends ExchangeSession {
|
|||||||
if (property == null) {
|
if (property == null) {
|
||||||
return null;
|
return null;
|
||||||
} else {
|
} else {
|
||||||
return (String) property.getValue();
|
Object value = property.getValue();
|
||||||
|
if (value instanceof Node) {
|
||||||
|
return ((Node) value).getTextContent();
|
||||||
|
} else if (value instanceof List) {
|
||||||
|
StringBuilder buffer = new StringBuilder();
|
||||||
|
for (Object node : (List) value) {
|
||||||
|
if (buffer.length() > 0) {
|
||||||
|
buffer.append(',');
|
||||||
|
}
|
||||||
|
buffer.append(((Node) node).getTextContent());
|
||||||
|
}
|
||||||
|
return buffer.toString();
|
||||||
|
} else {
|
||||||
|
return (String) value;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1166,7 +1181,7 @@ public class DavExchangeSession extends ExchangeSession {
|
|||||||
if (mimeMessage.getContent() instanceof MimeMultipart) {
|
if (mimeMessage.getContent() instanceof MimeMultipart) {
|
||||||
photoBodyPart = (MimePart) ((MimeMultipart) mimeMessage.getContent()).getBodyPart(1);
|
photoBodyPart = (MimePart) ((MimeMultipart) mimeMessage.getContent()).getBodyPart(1);
|
||||||
} else {
|
} else {
|
||||||
photoBodyPart = (MimePart) mimeMessage;
|
photoBodyPart = mimeMessage;
|
||||||
}
|
}
|
||||||
contactPhoto = new ContactPhoto();
|
contactPhoto = new ContactPhoto();
|
||||||
String contentType = photoBodyPart.getContentType();
|
String contentType = photoBodyPart.getContentType();
|
||||||
|
@ -21,9 +21,15 @@ package davmail.exchange.dav;
|
|||||||
import org.apache.jackrabbit.webdav.DavConstants;
|
import org.apache.jackrabbit.webdav.DavConstants;
|
||||||
import org.apache.jackrabbit.webdav.property.DavPropertyName;
|
import org.apache.jackrabbit.webdav.property.DavPropertyName;
|
||||||
import org.apache.jackrabbit.webdav.property.DefaultDavProperty;
|
import org.apache.jackrabbit.webdav.property.DefaultDavProperty;
|
||||||
|
import org.apache.jackrabbit.webdav.xml.DomUtil;
|
||||||
import org.apache.jackrabbit.webdav.xml.Namespace;
|
import org.apache.jackrabbit.webdav.xml.Namespace;
|
||||||
|
import org.apache.jackrabbit.webdav.xml.XmlSerializable;
|
||||||
|
import org.w3c.dom.Document;
|
||||||
|
import org.w3c.dom.Element;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -45,12 +51,13 @@ public class Field {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected static final Namespace EMPTY = Namespace.getNamespace("");
|
protected static final Namespace EMPTY = Namespace.getNamespace("");
|
||||||
|
protected static final Namespace XML = Namespace.getNamespace("xml:");
|
||||||
protected static final Namespace DAV = Namespace.getNamespace("DAV:");
|
protected static final Namespace DAV = Namespace.getNamespace("DAV:");
|
||||||
protected static final Namespace URN_SCHEMAS_HTTPMAIL = Namespace.getNamespace("urn:schemas:httpmail:");
|
protected static final Namespace URN_SCHEMAS_HTTPMAIL = Namespace.getNamespace("urn:schemas:httpmail:");
|
||||||
protected static final Namespace URN_SCHEMAS_MAILHEADER = Namespace.getNamespace("urn:schemas:mailheader:");
|
protected static final Namespace URN_SCHEMAS_MAILHEADER = Namespace.getNamespace("urn:schemas:mailheader:");
|
||||||
|
|
||||||
protected static final Namespace SCHEMAS_EXCHANGE = Namespace.getNamespace("http://schemas.microsoft.com/exchange/");
|
protected static final Namespace SCHEMAS_EXCHANGE = Namespace.getNamespace("http://schemas.microsoft.com/exchange/");
|
||||||
protected static final Namespace SCHEMAS_MAPI = Namespace.getNamespace("http://schemas.microsoft.com/mapi/");
|
protected static final Namespace SCHEMAS_MAPI = Namespace.getNamespace("http://schemas.microsoft.com/mapi/");
|
||||||
protected static final Namespace SCHEMAS_MAPI_PROPTAG = Namespace.getNamespace("http://schemas.microsoft.com/mapi/proptag/");
|
protected static final Namespace SCHEMAS_MAPI_PROPTAG = Namespace.getNamespace("http://schemas.microsoft.com/mapi/proptag/");
|
||||||
protected static final Namespace SCHEMAS_MAPI_ID = Namespace.getNamespace("http://schemas.microsoft.com/mapi/id/");
|
protected static final Namespace SCHEMAS_MAPI_ID = Namespace.getNamespace("http://schemas.microsoft.com/mapi/id/");
|
||||||
protected static final Namespace SCHEMAS_MAPI_STRING = Namespace.getNamespace("http://schemas.microsoft.com/mapi/string/");
|
protected static final Namespace SCHEMAS_MAPI_STRING = Namespace.getNamespace("http://schemas.microsoft.com/mapi/string/");
|
||||||
@ -239,6 +246,9 @@ public class Field {
|
|||||||
createField(URN_SCHEMAS_CONTACTS, "othercountry"); // PR_OTHER_ADDRESS_COUNTRY 0x3A60 String
|
createField(URN_SCHEMAS_CONTACTS, "othercountry"); // PR_OTHER_ADDRESS_COUNTRY 0x3A60 String
|
||||||
createField(URN_SCHEMAS_CONTACTS, "othercity"); // PR_OTHER_ADDRESS_CITY 0x3A5F String
|
createField(URN_SCHEMAS_CONTACTS, "othercity"); // PR_OTHER_ADDRESS_CITY 0x3A5F String
|
||||||
|
|
||||||
|
createField("keywords", SCHEMAS_EXCHANGE, "keywords-utf8", PropertyType.StringArray); // PS_PUBLIC_STRINGS Keywords String
|
||||||
|
//createField("keywords", DistinguishedPropertySetType.PublicStrings, "Keywords", ); // PS_PUBLIC_STRINGS Keywords String
|
||||||
|
|
||||||
// contact private flags
|
// contact private flags
|
||||||
createField("private", DistinguishedPropertySetType.Common, 0x8506, "private"); // True/False
|
createField("private", DistinguishedPropertySetType.Common, 0x8506, "private"); // True/False
|
||||||
createField("sensitivity", 0x0036, PropertyType.Long); // PR_SENSITIVITY SENSITIVITY_PRIVATE=2, SENSITIVITY_NONE = 0
|
createField("sensitivity", 0x0036, PropertyType.Long); // PR_SENSITIVITY SENSITIVITY_PRIVATE=2, SENSITIVITY_NONE = 0
|
||||||
@ -307,6 +317,14 @@ public class Field {
|
|||||||
fieldMap.put(field.alias, field);
|
fieldMap.put(field.alias, field);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected static void createField(String alias, Namespace namespace, String name, PropertyType propertyType) {
|
||||||
|
Field field = new Field(alias, namespace, name);
|
||||||
|
if (propertyType == PropertyType.StringArray) {
|
||||||
|
field.isMultivalued = true;
|
||||||
|
}
|
||||||
|
fieldMap.put(field.alias, field);
|
||||||
|
}
|
||||||
|
|
||||||
protected final DavPropertyName davPropertyName;
|
protected final DavPropertyName davPropertyName;
|
||||||
protected final String alias;
|
protected final String alias;
|
||||||
protected final String uri;
|
protected final String uri;
|
||||||
@ -314,6 +332,7 @@ public class Field {
|
|||||||
protected final DavPropertyName responsePropertyName;
|
protected final DavPropertyName responsePropertyName;
|
||||||
protected final String cast;
|
protected final String cast;
|
||||||
protected boolean isIntValue;
|
protected boolean isIntValue;
|
||||||
|
protected boolean isMultivalued;
|
||||||
|
|
||||||
|
|
||||||
public Field(Namespace namespace, String name) {
|
public Field(Namespace namespace, String name) {
|
||||||
@ -375,11 +394,24 @@ public class Field {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static DavConstants createDavProperty(String alias, String value) {
|
public static DavConstants createDavProperty(String alias, String value) {
|
||||||
|
Field field = Field.get(alias);
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
// return DavPropertyName to remove property
|
// return DavPropertyName to remove property
|
||||||
return Field.get(alias).davPropertyName;
|
return field.davPropertyName;
|
||||||
|
} else if (field.isMultivalued) {
|
||||||
|
List<XmlSerializable> valueList = new ArrayList<XmlSerializable>();
|
||||||
|
String[] values = value.split("\n");
|
||||||
|
for (final String singleValue : values) {
|
||||||
|
valueList.add(new XmlSerializable() {
|
||||||
|
public Element toXml(Document document) {
|
||||||
|
return DomUtil.createElement(document, "v", XML, singleValue);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return new DefaultDavProperty(field.davPropertyName, valueList);
|
||||||
} else {
|
} else {
|
||||||
return new DefaultDavProperty(Field.get(alias).davPropertyName, value);
|
return new DefaultDavProperty(field.davPropertyName, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -132,6 +132,8 @@ public class Field {
|
|||||||
FIELD_MAP.put("othercountry", new ExtendedFieldURI(0x3A60, ExtendedFieldURI.PropertyType.String));
|
FIELD_MAP.put("othercountry", new ExtendedFieldURI(0x3A60, ExtendedFieldURI.PropertyType.String));
|
||||||
FIELD_MAP.put("othercity", new ExtendedFieldURI(0x3A5F, ExtendedFieldURI.PropertyType.String));
|
FIELD_MAP.put("othercity", new ExtendedFieldURI(0x3A5F, ExtendedFieldURI.PropertyType.String));
|
||||||
|
|
||||||
|
FIELD_MAP.put("keywords", new ExtendedFieldURI(ExtendedFieldURI.DistinguishedPropertySetType.PublicStrings, "Keywords"));
|
||||||
|
|
||||||
FIELD_MAP.put("private", new ExtendedFieldURI(ExtendedFieldURI.DistinguishedPropertySetType.Common, 0x8506, ExtendedFieldURI.PropertyType.Boolean));
|
FIELD_MAP.put("private", new ExtendedFieldURI(ExtendedFieldURI.DistinguishedPropertySetType.Common, 0x8506, ExtendedFieldURI.PropertyType.Boolean));
|
||||||
FIELD_MAP.put("sensitivity", new ExtendedFieldURI(0x0036, ExtendedFieldURI.PropertyType.Long));
|
FIELD_MAP.put("sensitivity", new ExtendedFieldURI(0x0036, ExtendedFieldURI.PropertyType.Long));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user