mirror of
https://github.com/moparisthebest/davmail
synced 2025-01-07 11:48:02 -05:00
Carddav: handle picture delete
git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@1195 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
parent
9a701c6385
commit
144e86dc74
@ -2813,14 +2813,15 @@ public abstract class ExchangeSession {
|
|||||||
properties.put("spousecn", property.getValue());
|
properties.put("spousecn", property.getValue());
|
||||||
} else if ("PHOTO".equals(property.getKey())) {
|
} else if ("PHOTO".equals(property.getKey())) {
|
||||||
properties.put("photo", property.getValue());
|
properties.put("photo", property.getValue());
|
||||||
|
properties.put("haspicture", "true");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// reset missing properties to null
|
// reset missing properties to null
|
||||||
for (String key : CONTACT_ATTRIBUTES) {
|
for (String key : CONTACT_ATTRIBUTES) {
|
||||||
if (!"imapUid".equals(key) && !"etag".equals(key) && !"urlcompname".equals(key) &&
|
if (!"imapUid".equals(key) && !"etag".equals(key) && !"urlcompname".equals(key)
|
||||||
|
&& !"lastmodified".equals(key) &&
|
||||||
!properties.containsKey(key)) {
|
!properties.containsKey(key)) {
|
||||||
// TODO: enable
|
properties.put(key, null);
|
||||||
//properties.put(key, null);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -591,7 +591,7 @@ public class DavExchangeSession extends ExchangeSession {
|
|||||||
ArrayList<DavConstants> list = new ArrayList<DavConstants>();
|
ArrayList<DavConstants> list = new ArrayList<DavConstants>();
|
||||||
for (Map.Entry<String, String> entry : entrySet()) {
|
for (Map.Entry<String, String> entry : entrySet()) {
|
||||||
String key = entry.getKey();
|
String key = entry.getKey();
|
||||||
if (key.startsWith("email") || "private".equals(key)) {
|
if (key.startsWith("email")) {
|
||||||
list.add(Field.createDavProperty("write" + key, entry.getValue()));
|
list.add(Field.createDavProperty("write" + key, entry.getValue()));
|
||||||
} else if (!"photo".equals(key)) {
|
} else if (!"photo".equals(key)) {
|
||||||
list.add(Field.createDavProperty(key, entry.getValue()));
|
list.add(Field.createDavProperty(key, entry.getValue()));
|
||||||
@ -646,11 +646,10 @@ public class DavExchangeSession extends ExchangeSession {
|
|||||||
}
|
}
|
||||||
itemResult.status = status;
|
itemResult.status = status;
|
||||||
|
|
||||||
|
String contactPictureUrl = getHref() + "/ContactPicture.jpg";
|
||||||
String photo = get("photo");
|
String photo = get("photo");
|
||||||
if (photo != null) {
|
if (photo != null) {
|
||||||
// photo url
|
// photo url
|
||||||
String contactPictureUrl = getHref() + "/ContactPicture.jpg";
|
|
||||||
// need to update photo
|
// need to update photo
|
||||||
BufferedImage image = ImageIO.read(new ByteArrayInputStream(Base64.decodeBase64(photo.getBytes())));
|
BufferedImage image = ImageIO.read(new ByteArrayInputStream(Base64.decodeBase64(photo.getBytes())));
|
||||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
@ -689,6 +688,20 @@ public class DavExchangeSession extends ExchangeSession {
|
|||||||
attachmentPropPatchMethod.releaseConnection();
|
attachmentPropPatchMethod.releaseConnection();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
// try to delete picture
|
||||||
|
DeleteMethod deleteMethod = new DeleteMethod(contactPictureUrl);
|
||||||
|
try {
|
||||||
|
status = httpClient.executeMethod(deleteMethod);
|
||||||
|
if (status != HttpStatus.SC_OK && status != HttpStatus.SC_NOT_FOUND) {
|
||||||
|
throw new IOException("Unable to delete contact picture");
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOGGER.error("Error in contact photo delete", e);
|
||||||
|
throw e;
|
||||||
|
} finally {
|
||||||
|
deleteMethod.releaseConnection();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// need to retrieve new etag
|
// need to retrieve new etag
|
||||||
HeadMethod headMethod = new HeadMethod(URIUtil.encodePath(getHref()));
|
HeadMethod headMethod = new HeadMethod(URIUtil.encodePath(getHref()));
|
||||||
@ -1209,35 +1222,36 @@ public class DavExchangeSession extends ExchangeSession {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ExchangeSession.ContactPhoto getContactPhoto(ExchangeSession.Contact contact) throws IOException {
|
public ExchangeSession.ContactPhoto getContactPhoto(ExchangeSession.Contact contact) throws IOException {
|
||||||
ContactPhoto contactPhoto;
|
ContactPhoto contactPhoto = null;
|
||||||
final GetMethod method = new GetMethod(contact.getHref() + "/ContactPicture.jpg");
|
if ("1".equals(contact.get("haspicture"))) {
|
||||||
method.setRequestHeader("Translate", "f");
|
final GetMethod method = new GetMethod(contact.getHref() + "/ContactPicture.jpg");
|
||||||
method.setRequestHeader("Accept-Encoding", "gzip");
|
method.setRequestHeader("Translate", "f");
|
||||||
|
method.setRequestHeader("Accept-Encoding", "gzip");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
DavGatewayHttpClientFacade.executeGetMethod(httpClient, method, true);
|
DavGatewayHttpClientFacade.executeGetMethod(httpClient, method, true);
|
||||||
InputStream inputStream;
|
InputStream inputStream;
|
||||||
if (isGzipEncoded(method)) {
|
if (isGzipEncoded(method)) {
|
||||||
inputStream = (new GZIPInputStream(method.getResponseBodyAsStream()));
|
inputStream = (new GZIPInputStream(method.getResponseBodyAsStream()));
|
||||||
} else {
|
} else {
|
||||||
inputStream = method.getResponseBodyAsStream();
|
inputStream = method.getResponseBodyAsStream();
|
||||||
|
}
|
||||||
|
|
||||||
|
contactPhoto = new ContactPhoto();
|
||||||
|
contactPhoto.contentType = "image/jpeg";
|
||||||
|
|
||||||
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
|
InputStream partInputStream = inputStream;
|
||||||
|
byte[] bytes = new byte[8192];
|
||||||
|
int length;
|
||||||
|
while ((length = partInputStream.read(bytes)) > 0) {
|
||||||
|
baos.write(bytes, 0, length);
|
||||||
|
}
|
||||||
|
contactPhoto.content = new String(Base64.encodeBase64(baos.toByteArray()));
|
||||||
|
} finally {
|
||||||
|
method.releaseConnection();
|
||||||
}
|
}
|
||||||
|
|
||||||
contactPhoto = new ContactPhoto();
|
|
||||||
contactPhoto.contentType = "image/jpeg";
|
|
||||||
|
|
||||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
|
||||||
InputStream partInputStream = inputStream;
|
|
||||||
byte[] bytes = new byte[8192];
|
|
||||||
int length;
|
|
||||||
while ((length = partInputStream.read(bytes)) > 0) {
|
|
||||||
baos.write(bytes, 0, length);
|
|
||||||
}
|
|
||||||
contactPhoto.content = new String(Base64.encodeBase64(baos.toByteArray()));
|
|
||||||
} finally {
|
|
||||||
method.releaseConnection();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return contactPhoto;
|
return contactPhoto;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -132,8 +132,7 @@ public class Field {
|
|||||||
createField("iconIndex", 0x1080, PropertyType.Long);//PR_ICON_INDEX
|
createField("iconIndex", 0x1080, PropertyType.Long);//PR_ICON_INDEX
|
||||||
createField(URN_SCHEMAS_HTTPMAIL, "read");
|
createField(URN_SCHEMAS_HTTPMAIL, "read");
|
||||||
//createField("read", 0x0e69, PropertyType.Boolean);//PR_READ
|
//createField("read", 0x0e69, PropertyType.Boolean);//PR_READ
|
||||||
createField("deleted", DistinguishedPropertySetType.Common, 0x8570, "deleted");
|
createField("deleted", DistinguishedPropertySetType.Common, 0x8570, "deleted", PropertyType.Boolean);
|
||||||
createField("writedeleted", DistinguishedPropertySetType.Common, 0x8570, PropertyType.String10);
|
|
||||||
|
|
||||||
createField(URN_SCHEMAS_HTTPMAIL, "date");//PR_CLIENT_SUBMIT_TIME, 0x0039
|
createField(URN_SCHEMAS_HTTPMAIL, "date");//PR_CLIENT_SUBMIT_TIME, 0x0039
|
||||||
//createField("date", 0x0e06, PropertyType.SystemTime);//PR_MESSAGE_DELIVERY_TIME
|
//createField("date", 0x0e06, PropertyType.SystemTime);//PR_MESSAGE_DELIVERY_TIME
|
||||||
@ -251,10 +250,9 @@ public class Field {
|
|||||||
|
|
||||||
// contact private flags
|
// contact private flags
|
||||||
createField("private", DistinguishedPropertySetType.Common, 0x8506, "private", PropertyType.Boolean); // True/False
|
createField("private", DistinguishedPropertySetType.Common, 0x8506, "private", PropertyType.Boolean); // True/False
|
||||||
createField("writeprivate", DistinguishedPropertySetType.Common, 0x8506, PropertyType.Boolean);
|
|
||||||
createField("sensitivity", 0x0036, PropertyType.Long); // PR_SENSITIVITY SENSITIVITY_PRIVATE = 2, SENSITIVITY_PERSONAL = 1, SENSITIVITY_NONE = 0
|
createField("sensitivity", 0x0036, PropertyType.Long); // PR_SENSITIVITY SENSITIVITY_PRIVATE = 2, SENSITIVITY_PERSONAL = 1, SENSITIVITY_NONE = 0
|
||||||
|
|
||||||
createField("haspicture", DistinguishedPropertySetType.Address, 0x8015, "haspicture"); // True/False
|
createField("haspicture", DistinguishedPropertySetType.Address, 0x8015, "haspicture", PropertyType.Boolean); // True/False
|
||||||
|
|
||||||
// OWA settings
|
// OWA settings
|
||||||
createField("messageclass", 0x001a, PropertyType.String);
|
createField("messageclass", 0x001a, PropertyType.String);
|
||||||
@ -279,7 +277,7 @@ public class Field {
|
|||||||
String name = 'x' + toHexString(propertyTag) + propertyTypeMap.get(propertyType);
|
String name = 'x' + toHexString(propertyTag) + propertyTypeMap.get(propertyType);
|
||||||
Field field;
|
Field field;
|
||||||
if (propertyType == PropertyType.Binary) {
|
if (propertyType == PropertyType.Binary) {
|
||||||
field = new Field(alias, SCHEMAS_MAPI_PROPTAG, name, null, "bin.base64", propertyType);
|
field = new Field(alias, SCHEMAS_MAPI_PROPTAG, name, null, "bin.base64", name, propertyType);
|
||||||
} else {
|
} else {
|
||||||
field = new Field(alias, SCHEMAS_MAPI_PROPTAG, name, propertyType);
|
field = new Field(alias, SCHEMAS_MAPI_PROPTAG, name, propertyType);
|
||||||
}
|
}
|
||||||
@ -292,6 +290,7 @@ public class Field {
|
|||||||
|
|
||||||
protected static void createField(String alias, DistinguishedPropertySetType propertySetType, int propertyTag, String responseAlias, PropertyType propertyType) {
|
protected static void createField(String alias, DistinguishedPropertySetType propertySetType, int propertyTag, String responseAlias, PropertyType propertyType) {
|
||||||
String name;
|
String name;
|
||||||
|
String updateAlias;
|
||||||
if (propertySetType == DistinguishedPropertySetType.Address) {
|
if (propertySetType == DistinguishedPropertySetType.Address) {
|
||||||
// Address namespace expects integer names
|
// Address namespace expects integer names
|
||||||
name = String.valueOf(propertyTag);
|
name = String.valueOf(propertyTag);
|
||||||
@ -299,16 +298,9 @@ public class Field {
|
|||||||
// Common namespace expects hex names
|
// Common namespace expects hex names
|
||||||
name = "0x" + toHexString(propertyTag);
|
name = "0x" + toHexString(propertyTag);
|
||||||
}
|
}
|
||||||
|
updateAlias = "_x0030_x" + toHexString(propertyTag);
|
||||||
Field field = new Field(alias, Namespace.getNamespace(SCHEMAS_MAPI_ID.getURI() +
|
Field field = new Field(alias, Namespace.getNamespace(SCHEMAS_MAPI_ID.getURI() +
|
||||||
'{' + distinguishedPropertySetMap.get(propertySetType) + "}/"), name, responseAlias, null, propertyType);
|
'{' + distinguishedPropertySetMap.get(propertySetType) + "}/"), name, responseAlias, null, updateAlias, propertyType);
|
||||||
fieldMap.put(field.alias, field);
|
|
||||||
}
|
|
||||||
|
|
||||||
protected static void createField(String alias, DistinguishedPropertySetType propertySetType, int propertyTag, PropertyType propertyType) {
|
|
||||||
String name = "_x0030_x" + toHexString(propertyTag);
|
|
||||||
|
|
||||||
Field field = new Field(alias, Namespace.getNamespace(SCHEMAS_MAPI_ID.getURI() +
|
|
||||||
'{' + distinguishedPropertySetMap.get(propertySetType) + "}/"), name, propertyType);
|
|
||||||
fieldMap.put(field.alias, field);
|
fieldMap.put(field.alias, field);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -333,6 +325,7 @@ public class Field {
|
|||||||
protected final String uri;
|
protected final String uri;
|
||||||
protected final String requestPropertyString;
|
protected final String requestPropertyString;
|
||||||
protected final DavPropertyName responsePropertyName;
|
protected final DavPropertyName responsePropertyName;
|
||||||
|
protected final DavPropertyName updatePropertyName;
|
||||||
protected final String cast;
|
protected final String cast;
|
||||||
protected final boolean isIntValue;
|
protected final boolean isIntValue;
|
||||||
protected final boolean isMultivalued;
|
protected final boolean isMultivalued;
|
||||||
@ -344,11 +337,12 @@ public class Field {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public Field(String alias, Namespace namespace, String name, PropertyType propertyType) {
|
public Field(String alias, Namespace namespace, String name, PropertyType propertyType) {
|
||||||
this(alias, namespace, name, null, null, propertyType);
|
this(alias, namespace, name, null, null, name, propertyType);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Field(String alias, Namespace namespace, String name, String responseAlias, String cast, PropertyType propertyType) {
|
public Field(String alias, Namespace namespace, String name, String responseAlias, String cast, String updateAlias, PropertyType propertyType) {
|
||||||
davPropertyName = DavPropertyName.create(name, namespace);
|
davPropertyName = DavPropertyName.create(name, namespace);
|
||||||
|
updatePropertyName = DavPropertyName.create(updateAlias, namespace);
|
||||||
this.propertyType = propertyType;
|
this.propertyType = propertyType;
|
||||||
isMultivalued = propertyType == PropertyType.StringArray;
|
isMultivalued = propertyType == PropertyType.StringArray;
|
||||||
isIntValue = propertyType == PropertyType.Integer || propertyType == PropertyType.Long;
|
isIntValue = propertyType == PropertyType.Integer || propertyType == PropertyType.Long;
|
||||||
@ -405,7 +399,7 @@ public class Field {
|
|||||||
Field field = Field.get(alias);
|
Field field = Field.get(alias);
|
||||||
if (value == null) {
|
if (value == null) {
|
||||||
// return DavPropertyName to remove property
|
// return DavPropertyName to remove property
|
||||||
return field.davPropertyName;
|
return field.updatePropertyName;
|
||||||
} else if (field.isMultivalued) {
|
} else if (field.isMultivalued) {
|
||||||
List<XmlSerializable> valueList = new ArrayList<XmlSerializable>();
|
List<XmlSerializable> valueList = new ArrayList<XmlSerializable>();
|
||||||
String[] values = value.split("\n");
|
String[] values = value.split("\n");
|
||||||
@ -417,15 +411,17 @@ public class Field {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
return new DefaultDavProperty(field.davPropertyName, valueList);
|
return new DefaultDavProperty(field.updatePropertyName, valueList);
|
||||||
} else if (field.isBooleanValue) {
|
} else if (field.isBooleanValue) {
|
||||||
if ("true".equals(value)) {
|
if ("true".equals(value)) {
|
||||||
return new DefaultDavProperty(field.davPropertyName, "1");
|
return new DefaultDavProperty(field.updatePropertyName, "1");
|
||||||
|
} else if ("false".equals(value)){
|
||||||
|
return new DefaultDavProperty(field.updatePropertyName, "0");
|
||||||
} else {
|
} else {
|
||||||
return new DefaultDavProperty(field.davPropertyName, "0");
|
throw new RuntimeException("Invalid value for "+field.alias+": "+value);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return new DefaultDavProperty(field.davPropertyName, value);
|
return new DefaultDavProperty(field.updatePropertyName, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -193,4 +193,85 @@ public class TestExchangeSessionContact extends AbstractExchangeSessionTestCase
|
|||||||
|
|
||||||
assertNotNull(session.getContactPhoto(contact));
|
assertNotNull(session.getContactPhoto(contact));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testUpdateContact() throws IOException {
|
||||||
|
ExchangeSession.Contact contact = (ExchangeSession.Contact) session.getItem("testcontactfolder", itemName);
|
||||||
|
|
||||||
|
VCardWriter vCardWriter = new VCardWriter();
|
||||||
|
vCardWriter.startCard();
|
||||||
|
|
||||||
|
vCardWriter.endCard();
|
||||||
|
|
||||||
|
ExchangeSession.ItemResult result = session.createOrUpdateContact("testcontactfolder", itemName, vCardWriter.toString(), contact.etag, null);
|
||||||
|
assertEquals(200, result.status);
|
||||||
|
|
||||||
|
contact = (ExchangeSession.Contact) session.getItem("testcontactfolder", itemName);
|
||||||
|
assertNull(contact.get("cn"));
|
||||||
|
assertNull(contact.get("sn"));
|
||||||
|
assertNull(contact.get("givenName"));
|
||||||
|
assertNull(contact.get("middlename"));
|
||||||
|
assertNull(contact.get("personaltitle"));
|
||||||
|
assertNull(contact.get("namesuffix"));
|
||||||
|
assertNotNull("lastmodified");
|
||||||
|
assertNull(contact.get("nickname"));
|
||||||
|
|
||||||
|
assertNull(contact.get("mobile"));
|
||||||
|
assertNull(contact.get("telephoneNumber"));
|
||||||
|
assertNull(contact.get("homePhone"));
|
||||||
|
assertNull(contact.get("facsimiletelephonenumber"));
|
||||||
|
assertNull(contact.get("pager"));
|
||||||
|
|
||||||
|
assertNull(contact.get("homepostofficebox"));
|
||||||
|
assertNull(contact.get("homeStreet"));
|
||||||
|
assertNull(contact.get("homeCity"));
|
||||||
|
assertNull(contact.get("homeState"));
|
||||||
|
assertNull(contact.get("homePostalCode"));
|
||||||
|
assertNull(contact.get("homeCountry"));
|
||||||
|
|
||||||
|
assertNull(contact.get("postofficebox"));
|
||||||
|
assertNull(contact.get("roomnumber"));
|
||||||
|
assertNull(contact.get("street"));
|
||||||
|
assertNull(contact.get("l"));
|
||||||
|
assertNull(contact.get("st"));
|
||||||
|
assertNull(contact.get("postalcode"));
|
||||||
|
assertNull(contact.get("co"));
|
||||||
|
|
||||||
|
assertNull(contact.get("email1"));
|
||||||
|
assertNull(contact.get("email2"));
|
||||||
|
assertNull(contact.get("email3"));
|
||||||
|
|
||||||
|
assertNull(contact.get("o"));
|
||||||
|
assertNull(contact.get("department"));
|
||||||
|
|
||||||
|
assertNull(contact.get("businesshomepage"));
|
||||||
|
assertNull(contact.get("title"));
|
||||||
|
assertNull(contact.get("description"));
|
||||||
|
|
||||||
|
assertNull(contact.get("extensionattribute1"));
|
||||||
|
assertNull(contact.get("extensionattribute2"));
|
||||||
|
assertNull(contact.get("extensionattribute3"));
|
||||||
|
assertNull(contact.get("extensionattribute4"));
|
||||||
|
|
||||||
|
assertNull(contact.get("profession"));
|
||||||
|
assertNull(contact.get("im"));
|
||||||
|
assertNull(contact.get("bday"));
|
||||||
|
|
||||||
|
assertNull(contact.get("otherpostofficebox"));
|
||||||
|
assertNull(contact.get("otherstreet"));
|
||||||
|
assertNull(contact.get("othercity"));
|
||||||
|
assertNull(contact.get("otherstate"));
|
||||||
|
assertNull(contact.get("otherpostalcode"));
|
||||||
|
assertNull(contact.get("othercountry"));
|
||||||
|
|
||||||
|
assertNull(contact.get("secretarycn"));
|
||||||
|
assertNull(contact.get("manager"));
|
||||||
|
assertNull(contact.get("spousecn"));
|
||||||
|
assertNull(contact.get("keywords"));
|
||||||
|
|
||||||
|
assertNull(contact.get("private"));
|
||||||
|
|
||||||
|
assertNull(session.getContactPhoto(contact));
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user