mirror of
https://github.com/etesync/android
synced 2025-01-12 16:50:57 +00:00
Use RawContactsEntity to query raw contact data
This commit is contained in:
parent
c707b1eb9d
commit
365e04154b
@ -83,14 +83,14 @@ public class Contact extends Resource {
|
|||||||
PROPERTY_PHONETIC_LAST_NAME = "X-PHONETIC-LAST-NAME",
|
PROPERTY_PHONETIC_LAST_NAME = "X-PHONETIC-LAST-NAME",
|
||||||
PROPERTY_SIP = "X-SIP";
|
PROPERTY_SIP = "X-SIP";
|
||||||
|
|
||||||
public final static EmailType EMAIL_TYPE_MOBILE = EmailType.get("X-MOBILE");
|
public final static EmailType EMAIL_TYPE_MOBILE = EmailType.get("x-mobile");
|
||||||
|
|
||||||
public final static TelephoneType
|
public final static TelephoneType
|
||||||
PHONE_TYPE_CALLBACK = TelephoneType.get("X-CALLBACK"),
|
PHONE_TYPE_CALLBACK = TelephoneType.get("x-callback"),
|
||||||
PHONE_TYPE_COMPANY_MAIN = TelephoneType.get("X-COMPANY_MAIN"),
|
PHONE_TYPE_COMPANY_MAIN = TelephoneType.get("x-company_main"),
|
||||||
PHONE_TYPE_RADIO = TelephoneType.get("X-RADIO"),
|
PHONE_TYPE_RADIO = TelephoneType.get("x-radio"),
|
||||||
PHONE_TYPE_ASSISTANT = TelephoneType.get("X-ASSISTANT"),
|
PHONE_TYPE_ASSISTANT = TelephoneType.get("X-assistant"),
|
||||||
PHONE_TYPE_MMS = TelephoneType.get("X-MMS");
|
PHONE_TYPE_MMS = TelephoneType.get("x-mms");
|
||||||
public final static RelatedType
|
public final static RelatedType
|
||||||
RELATED_TYPE_BROTHER = RelatedType.get("brother"),
|
RELATED_TYPE_BROTHER = RelatedType.get("brother"),
|
||||||
RELATED_TYPE_FATHER = RelatedType.get("father"),
|
RELATED_TYPE_FATHER = RelatedType.get("father"),
|
||||||
@ -437,6 +437,7 @@ public class Contact extends Resource {
|
|||||||
if (photo != null)
|
if (photo != null)
|
||||||
vcard.addPhoto(new Photo(photo, ImageType.JPEG));
|
vcard.addPhoto(new Photo(photo, ImageType.JPEG));
|
||||||
|
|
||||||
|
// REL
|
||||||
for (Related related : relations)
|
for (Related related : relations)
|
||||||
vcard.addRelated(related);
|
vcard.addRelated(related);
|
||||||
|
|
||||||
|
@ -13,11 +13,14 @@ import android.content.ContentProviderOperation;
|
|||||||
import android.content.ContentProviderOperation.Builder;
|
import android.content.ContentProviderOperation.Builder;
|
||||||
import android.content.ContentUris;
|
import android.content.ContentUris;
|
||||||
import android.content.ContentValues;
|
import android.content.ContentValues;
|
||||||
|
import android.content.Entity;
|
||||||
|
import android.content.EntityIterator;
|
||||||
import android.content.res.AssetFileDescriptor;
|
import android.content.res.AssetFileDescriptor;
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
import android.database.DatabaseUtils;
|
import android.database.DatabaseUtils;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.RemoteException;
|
import android.os.RemoteException;
|
||||||
|
import android.provider.ContactsContract;
|
||||||
import android.provider.ContactsContract.CommonDataKinds;
|
import android.provider.ContactsContract.CommonDataKinds;
|
||||||
import android.provider.ContactsContract.CommonDataKinds.Email;
|
import android.provider.ContactsContract.CommonDataKinds.Email;
|
||||||
import android.provider.ContactsContract.CommonDataKinds.GroupMembership;
|
import android.provider.ContactsContract.CommonDataKinds.GroupMembership;
|
||||||
@ -61,6 +64,7 @@ import ezvcard.parameter.EmailType;
|
|||||||
import ezvcard.parameter.ImppType;
|
import ezvcard.parameter.ImppType;
|
||||||
import ezvcard.parameter.RelatedType;
|
import ezvcard.parameter.RelatedType;
|
||||||
import ezvcard.parameter.TelephoneType;
|
import ezvcard.parameter.TelephoneType;
|
||||||
|
import ezvcard.parameter.VCardParameter;
|
||||||
import ezvcard.property.Address;
|
import ezvcard.property.Address;
|
||||||
import ezvcard.property.Anniversary;
|
import ezvcard.property.Anniversary;
|
||||||
import ezvcard.property.Birthday;
|
import ezvcard.property.Birthday;
|
||||||
@ -72,7 +76,7 @@ import lombok.Cleanup;
|
|||||||
|
|
||||||
|
|
||||||
public class LocalAddressBook extends LocalCollection<Contact> {
|
public class LocalAddressBook extends LocalCollection<Contact> {
|
||||||
private final static String TAG = "davdroid.LocalAddressBook";
|
private final static String TAG = "davdroid.resource";
|
||||||
|
|
||||||
protected final static String COLUMN_UNKNOWN_PROPERTIES = RawContacts.SYNC3;
|
protected final static String COLUMN_UNKNOWN_PROPERTIES = RawContacts.SYNC3;
|
||||||
|
|
||||||
@ -186,64 +190,94 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
Contact c = (Contact)res;
|
Contact c = (Contact)res;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
@Cleanup Cursor cursor = providerClient.query(ContentUris.withAppendedId(entriesURI(), c.getLocalID()),
|
@Cleanup EntityIterator iter = ContactsContract.RawContacts.newEntityIterator(providerClient.query(
|
||||||
new String[] { entryColumnUID(), COLUMN_UNKNOWN_PROPERTIES, RawContacts.STARRED }, null, null, null);
|
ContactsContract.RawContactsEntity.CONTENT_URI,
|
||||||
if (cursor != null && cursor.moveToNext()) {
|
null, RawContacts._ID + "=" + c.getLocalID(),
|
||||||
c.setUid(cursor.getString(0));
|
null, null));
|
||||||
c.setUnknownProperties(cursor.getString(1));
|
|
||||||
c.setStarred(cursor.getInt(2) != 0);
|
if (iter.hasNext()) {
|
||||||
|
Entity e = iter.next();
|
||||||
|
|
||||||
|
ContentValues values = e.getEntityValues();
|
||||||
|
c.setUid(values.getAsString(entryColumnUID()));
|
||||||
|
c.setUnknownProperties(values.getAsString(COLUMN_UNKNOWN_PROPERTIES));
|
||||||
|
c.setStarred(values.getAsBoolean(RawContacts.STARRED));
|
||||||
|
|
||||||
|
List<Entity.NamedContentValues> subValues = e.getSubValues();
|
||||||
|
for (Entity.NamedContentValues subValue : subValues) {
|
||||||
|
values = subValue.values;
|
||||||
|
String mimeType = values.getAsString(ContactsContract.RawContactsEntity.MIMETYPE);
|
||||||
|
switch (mimeType) {
|
||||||
|
case StructuredName.CONTENT_ITEM_TYPE:
|
||||||
|
populateStructuredName(c, values);
|
||||||
|
break;
|
||||||
|
case Phone.CONTENT_ITEM_TYPE:
|
||||||
|
populatePhoneNumber(c, values);
|
||||||
|
break;
|
||||||
|
case Email.CONTENT_ITEM_TYPE:
|
||||||
|
populateEmailAddress(c, values);
|
||||||
|
break;
|
||||||
|
case Photo.CONTENT_ITEM_TYPE:
|
||||||
|
populatePhoto(c, values);
|
||||||
|
break;
|
||||||
|
case Organization.CONTENT_ITEM_TYPE:
|
||||||
|
populateOrganization(c, values);
|
||||||
|
break;
|
||||||
|
case Im.CONTENT_ITEM_TYPE:
|
||||||
|
populateIMPP(c, values);
|
||||||
|
break;
|
||||||
|
case Nickname.CONTENT_ITEM_TYPE:
|
||||||
|
populateNickname(c, values);
|
||||||
|
break;
|
||||||
|
case Note.CONTENT_ITEM_TYPE:
|
||||||
|
populateNote(c, values);
|
||||||
|
break;
|
||||||
|
case StructuredPostal.CONTENT_ITEM_TYPE:
|
||||||
|
populatePostalAddress(c, values);
|
||||||
|
break;
|
||||||
|
case GroupMembership.CONTENT_ITEM_TYPE:
|
||||||
|
populateGroupMembership(c, values);
|
||||||
|
break;
|
||||||
|
case Website.CONTENT_ITEM_TYPE:
|
||||||
|
populateURL(c, values);
|
||||||
|
break;
|
||||||
|
case CommonDataKinds.Event.CONTENT_ITEM_TYPE:
|
||||||
|
populateEvent(c, values);
|
||||||
|
break;
|
||||||
|
case Relation.CONTENT_ITEM_TYPE:
|
||||||
|
populateRelation(c, values);
|
||||||
|
break;
|
||||||
|
case SipAddress.CONTENT_ITEM_TYPE:
|
||||||
|
populateSipAddress(c, values);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Log.i(TAG, "Populated contact: " + c);
|
||||||
} else
|
} else
|
||||||
throw new RecordNotFoundException();
|
throw new RecordNotFoundException();
|
||||||
|
|
||||||
populateStructuredName(c);
|
|
||||||
populatePhoneNumbers(c);
|
|
||||||
populateEmailAddresses(c);
|
|
||||||
populatePhoto(c);
|
|
||||||
populateOrganization(c);
|
|
||||||
populateIMPPs(c);
|
|
||||||
populateNickname(c);
|
|
||||||
populateNote(c);
|
|
||||||
populatePostalAddresses(c);
|
|
||||||
populateCategories(c);
|
|
||||||
populateURLs(c);
|
|
||||||
populateEvents(c);
|
|
||||||
populateRelations(c);
|
|
||||||
populateSipAddress(c);
|
|
||||||
} catch(RemoteException ex) {
|
} catch(RemoteException ex) {
|
||||||
throw new LocalStorageException(ex);
|
throw new LocalStorageException(ex);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void populateStructuredName(Contact c) throws RemoteException {
|
private void populateStructuredName(Contact c, ContentValues row) {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] {
|
c.setDisplayName(row.getAsString(StructuredName.DISPLAY_NAME));
|
||||||
/* 0 */ StructuredName.DISPLAY_NAME, StructuredName.PREFIX, StructuredName.GIVEN_NAME,
|
|
||||||
/* 3 */ StructuredName.MIDDLE_NAME, StructuredName.FAMILY_NAME, StructuredName.SUFFIX,
|
|
||||||
/* 6 */ StructuredName.PHONETIC_GIVEN_NAME, StructuredName.PHONETIC_MIDDLE_NAME, StructuredName.PHONETIC_FAMILY_NAME
|
|
||||||
}, StructuredName.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), StructuredName.CONTENT_ITEM_TYPE }, null);
|
|
||||||
|
|
||||||
if (cursor != null && cursor.moveToNext()) {
|
c.setPrefix(row.getAsString(StructuredName.PREFIX));
|
||||||
c.setDisplayName(cursor.getString(0));
|
c.setGivenName(row.getAsString(StructuredName.GIVEN_NAME));
|
||||||
|
c.setMiddleName(row.getAsString(StructuredName.MIDDLE_NAME));
|
||||||
|
c.setFamilyName(row.getAsString(StructuredName.FAMILY_NAME));
|
||||||
|
c.setSuffix(row.getAsString(StructuredName.SUFFIX));
|
||||||
|
|
||||||
c.setPrefix(cursor.getString(1));
|
c.setPhoneticGivenName(row.getAsString(StructuredName.PHONETIC_GIVEN_NAME));
|
||||||
c.setGivenName(cursor.getString(2));
|
c.setPhoneticMiddleName(row.getAsString(StructuredName.PHONETIC_MIDDLE_NAME));
|
||||||
c.setMiddleName(cursor.getString(3));
|
c.setPhoneticFamilyName(row.getAsString(StructuredName.PHONETIC_FAMILY_NAME));
|
||||||
c.setFamilyName(cursor.getString(4));
|
|
||||||
c.setSuffix(cursor.getString(5));
|
|
||||||
|
|
||||||
c.setPhoneticGivenName(cursor.getString(6));
|
|
||||||
c.setPhoneticMiddleName(cursor.getString(7));
|
|
||||||
c.setPhoneticFamilyName(cursor.getString(8));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void populatePhoneNumbers(Contact c) throws RemoteException {
|
protected void populatePhoneNumber(Contact c, ContentValues row) {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] { Phone.TYPE, Phone.LABEL, Phone.NUMBER, Phone.IS_SUPER_PRIMARY },
|
ezvcard.property.Telephone number = new ezvcard.property.Telephone(row.getAsString(Phone.NUMBER));
|
||||||
Phone.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
switch (row.getAsInteger(Phone.TYPE)) {
|
||||||
new String[] { String.valueOf(c.getLocalID()), Phone.CONTENT_ITEM_TYPE }, null);
|
|
||||||
while (cursor != null && cursor.moveToNext()) {
|
|
||||||
ezvcard.property.Telephone number = new ezvcard.property.Telephone(cursor.getString(2));
|
|
||||||
switch (cursor.getInt(0)) {
|
|
||||||
case Phone.TYPE_HOME:
|
case Phone.TYPE_HOME:
|
||||||
number.addType(TelephoneType.HOME);
|
number.addType(TelephoneType.HOME);
|
||||||
break;
|
break;
|
||||||
@ -306,23 +340,18 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
number.addType(Contact.PHONE_TYPE_MMS);
|
number.addType(Contact.PHONE_TYPE_MMS);
|
||||||
break;
|
break;
|
||||||
case Phone.TYPE_CUSTOM:
|
case Phone.TYPE_CUSTOM:
|
||||||
String customType = cursor.getString(1);
|
String customType = row.getAsString(Phone.LABEL);
|
||||||
if (!StringUtils.isEmpty(customType))
|
if (!StringUtils.isEmpty(customType))
|
||||||
number.addType(TelephoneType.get(labelToXName(customType)));
|
number.addType(TelephoneType.get(labelToXName(customType)));
|
||||||
}
|
}
|
||||||
if (cursor.getInt(3) != 0) // IS_PRIMARY
|
if (row.getAsBoolean(Phone.IS_PRIMARY))
|
||||||
number.addType(TelephoneType.PREF);
|
number.addType(TelephoneType.PREF);
|
||||||
c.getPhoneNumbers().add(number);
|
c.getPhoneNumbers().add(number);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
protected void populateEmailAddresses(Contact c) throws RemoteException {
|
protected void populateEmailAddress(Contact c, ContentValues row) {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] { Email.TYPE, Email.ADDRESS, Email.LABEL, Email.IS_SUPER_PRIMARY },
|
ezvcard.property.Email email = new ezvcard.property.Email(row.getAsString(Email.ADDRESS));
|
||||||
Email.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
switch (row.getAsInteger(Email.TYPE)) {
|
||||||
new String[] { String.valueOf(c.getLocalID()), Email.CONTENT_ITEM_TYPE }, null);
|
|
||||||
while (cursor != null && cursor.moveToNext()) {
|
|
||||||
ezvcard.property.Email email = new ezvcard.property.Email(cursor.getString(1));
|
|
||||||
switch (cursor.getInt(0)) {
|
|
||||||
case Email.TYPE_HOME:
|
case Email.TYPE_HOME:
|
||||||
email.addType(EmailType.HOME);
|
email.addType(EmailType.HOME);
|
||||||
break;
|
break;
|
||||||
@ -333,23 +362,17 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
email.addType(Contact.EMAIL_TYPE_MOBILE);
|
email.addType(Contact.EMAIL_TYPE_MOBILE);
|
||||||
break;
|
break;
|
||||||
case Email.TYPE_CUSTOM:
|
case Email.TYPE_CUSTOM:
|
||||||
String customType = cursor.getString(2);
|
String customType = row.getAsString(Email.LABEL);
|
||||||
if (!StringUtils.isEmpty(customType))
|
if (!StringUtils.isEmpty(customType))
|
||||||
email.addType(EmailType.get(labelToXName(customType)));
|
email.addType(EmailType.get(labelToXName(customType)));
|
||||||
}
|
}
|
||||||
if (cursor.getInt(3) != 0) // IS_PRIMARY
|
if (row.getAsBoolean(Email.IS_PRIMARY))
|
||||||
email.addType(EmailType.PREF);
|
email.addType(EmailType.PREF);
|
||||||
c.getEmails().add(email);
|
c.getEmails().add(email);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
protected void populatePhoto(Contact c) throws RemoteException {
|
protected void populatePhoto(Contact c, ContentValues row) throws RemoteException {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(),
|
if (row.containsKey(Photo.PHOTO_FILE_ID)) {
|
||||||
new String[] { Photo.PHOTO_FILE_ID, Photo.PHOTO },
|
|
||||||
Photo.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), Photo.CONTENT_ITEM_TYPE }, null);
|
|
||||||
if (cursor != null && cursor.moveToNext()) {
|
|
||||||
if (!cursor.isNull(0)) {
|
|
||||||
Uri photoUri = Uri.withAppendedPath(
|
Uri photoUri = Uri.withAppendedPath(
|
||||||
ContentUris.withAppendedId(RawContacts.CONTENT_URI, c.getLocalID()),
|
ContentUris.withAppendedId(RawContacts.CONTENT_URI, c.getLocalID()),
|
||||||
RawContacts.DisplayPhoto.CONTENT_DIRECTORY);
|
RawContacts.DisplayPhoto.CONTENT_DIRECTORY);
|
||||||
@ -361,20 +384,15 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
Log.w(TAG, "Couldn't read high-res contact photo", ex);
|
Log.w(TAG, "Couldn't read high-res contact photo", ex);
|
||||||
}
|
}
|
||||||
} else
|
} else
|
||||||
c.setPhoto(cursor.getBlob(1));
|
c.setPhoto(row.getAsByteArray(Photo.PHOTO));
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void populateOrganization(Contact c) throws RemoteException {
|
protected void populateOrganization(Contact c, ContentValues row) {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(),
|
String company = row.getAsString(Organization.COMPANY),
|
||||||
new String[] { Organization.COMPANY, Organization.DEPARTMENT, Organization.TITLE, Organization.JOB_DESCRIPTION },
|
department = row.getAsString(Organization.DEPARTMENT),
|
||||||
Organization.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
title = row.getAsString(Organization.TITLE),
|
||||||
new String[] { String.valueOf(c.getLocalID()), Organization.CONTENT_ITEM_TYPE }, null);
|
role = row.getAsString(Organization.JOB_DESCRIPTION);
|
||||||
if (cursor != null && cursor.moveToNext()) {
|
|
||||||
String company = cursor.getString(0),
|
|
||||||
department = cursor.getString(1),
|
|
||||||
title = cursor.getString(2),
|
|
||||||
role = cursor.getString(3);
|
|
||||||
if (!StringUtils.isEmpty(company) || !StringUtils.isEmpty(department)) {
|
if (!StringUtils.isEmpty(company) || !StringUtils.isEmpty(department)) {
|
||||||
ezvcard.property.Organization org = new ezvcard.property.Organization();
|
ezvcard.property.Organization org = new ezvcard.property.Organization();
|
||||||
if (!StringUtils.isEmpty(company))
|
if (!StringUtils.isEmpty(company))
|
||||||
@ -383,22 +401,18 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
org.addValue(department);
|
org.addValue(department);
|
||||||
c.setOrganization(org);
|
c.setOrganization(org);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!StringUtils.isEmpty(title))
|
if (!StringUtils.isEmpty(title))
|
||||||
c.setJobTitle(title);
|
c.setJobTitle(title);
|
||||||
if (!StringUtils.isEmpty(role))
|
if (!StringUtils.isEmpty(role))
|
||||||
c.setJobDescription(role);
|
c.setJobDescription(role);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
protected void populateIMPPs(Contact c) throws RemoteException {
|
protected void populateIMPP(Contact c, ContentValues row) {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] { Im.DATA, Im.TYPE, Im.LABEL, Im.PROTOCOL, Im.CUSTOM_PROTOCOL },
|
String handle = row.getAsString(Im.DATA);
|
||||||
Im.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), Im.CONTENT_ITEM_TYPE }, null);
|
|
||||||
while (cursor != null && cursor.moveToNext()) {
|
|
||||||
String handle = cursor.getString(0);
|
|
||||||
|
|
||||||
Impp impp = null;
|
Impp impp = null;
|
||||||
switch (cursor.getInt(3)) {
|
switch (row.getAsInteger(Im.PROTOCOL)) {
|
||||||
case Im.PROTOCOL_AIM:
|
case Im.PROTOCOL_AIM:
|
||||||
impp = Impp.aim(handle);
|
impp = Impp.aim(handle);
|
||||||
break;
|
break;
|
||||||
@ -427,11 +441,11 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
impp = new Impp("netmeeting", handle);
|
impp = new Impp("netmeeting", handle);
|
||||||
break;
|
break;
|
||||||
case Im.PROTOCOL_CUSTOM:
|
case Im.PROTOCOL_CUSTOM:
|
||||||
impp = new Impp(cursor.getString(4), handle);
|
impp = new Impp(row.getAsString(Im.CUSTOM_PROTOCOL), handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (impp != null) {
|
if (impp != null) {
|
||||||
switch (cursor.getInt(1)) {
|
switch (row.getAsInteger(Im.TYPE)) {
|
||||||
case Im.TYPE_HOME:
|
case Im.TYPE_HOME:
|
||||||
impp.addType(ImppType.HOME);
|
impp.addType(ImppType.HOME);
|
||||||
break;
|
break;
|
||||||
@ -439,44 +453,28 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
impp.addType(ImppType.WORK);
|
impp.addType(ImppType.WORK);
|
||||||
break;
|
break;
|
||||||
case Im.TYPE_CUSTOM:
|
case Im.TYPE_CUSTOM:
|
||||||
String customType = cursor.getString(2);
|
String customType = row.getAsString(Im.LABEL);
|
||||||
if (!StringUtils.isEmpty(customType))
|
if (!StringUtils.isEmpty(customType))
|
||||||
impp.addType(ImppType.get(labelToXName(customType)));
|
impp.addType(ImppType.get(labelToXName(customType)));
|
||||||
}
|
}
|
||||||
|
|
||||||
c.getImpps().add(impp);
|
c.getImpps().add(impp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void populateNickname(Contact c, ContentValues row) {
|
||||||
|
// TYPE (maiden name, short name, …) and LABEL are not processed here because Contacts app doesn't support it
|
||||||
|
c.setNickName(row.getAsString(Nickname.NAME));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void populateNickname(Contact c) throws RemoteException {
|
protected void populateNote(Contact c, ContentValues row) {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] { Nickname.NAME },
|
c.setNote(row.getAsString(Note.NOTE));
|
||||||
Nickname.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), Nickname.CONTENT_ITEM_TYPE }, null);
|
|
||||||
if (cursor != null && cursor.moveToNext())
|
|
||||||
c.setNickName(cursor.getString(0));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void populateNote(Contact c) throws RemoteException {
|
protected void populatePostalAddress(Contact c, ContentValues row) {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] { Note.NOTE },
|
|
||||||
Note.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), Note.CONTENT_ITEM_TYPE }, null);
|
|
||||||
if (cursor != null && cursor.moveToNext())
|
|
||||||
c.setNote(cursor.getString(0));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void populatePostalAddresses(Contact c) throws RemoteException {
|
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] {
|
|
||||||
/* 0 */ StructuredPostal.FORMATTED_ADDRESS, StructuredPostal.TYPE, StructuredPostal.LABEL,
|
|
||||||
/* 3 */ StructuredPostal.STREET, StructuredPostal.POBOX, StructuredPostal.NEIGHBORHOOD,
|
|
||||||
/* 6 */ StructuredPostal.CITY, StructuredPostal.REGION, StructuredPostal.POSTCODE,
|
|
||||||
/* 9 */ StructuredPostal.COUNTRY
|
|
||||||
}, StructuredPostal.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), StructuredPostal.CONTENT_ITEM_TYPE }, null);
|
|
||||||
while (cursor != null && cursor.moveToNext()) {
|
|
||||||
Address address = new Address();
|
Address address = new Address();
|
||||||
|
address.setLabel(row.getAsString(StructuredPostal.FORMATTED_ADDRESS));
|
||||||
address.setLabel(cursor.getString(0));
|
switch (row.getAsInteger(StructuredPostal.TYPE)) {
|
||||||
switch (cursor.getInt(1)) {
|
|
||||||
case StructuredPostal.TYPE_HOME:
|
case StructuredPostal.TYPE_HOME:
|
||||||
address.addType(AddressType.HOME);
|
address.addType(AddressType.HOME);
|
||||||
break;
|
break;
|
||||||
@ -484,31 +482,26 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
address.addType(AddressType.WORK);
|
address.addType(AddressType.WORK);
|
||||||
break;
|
break;
|
||||||
case StructuredPostal.TYPE_CUSTOM:
|
case StructuredPostal.TYPE_CUSTOM:
|
||||||
String customType = cursor.getString(2);
|
String customType = row.getAsString(StructuredPostal.LABEL);
|
||||||
if (!StringUtils.isEmpty(customType))
|
if (!StringUtils.isEmpty(customType))
|
||||||
address.addType(AddressType.get(labelToXName(customType)));
|
address.addType(AddressType.get(labelToXName(customType)));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
address.setStreetAddress(cursor.getString(3));
|
address.setStreetAddress(row.getAsString(StructuredPostal.STREET));
|
||||||
address.setPoBox(cursor.getString(4));
|
address.setPoBox(row.getAsString(StructuredPostal.POBOX));
|
||||||
address.setExtendedAddress(cursor.getString(5));
|
address.setExtendedAddress(row.getAsString(StructuredPostal.NEIGHBORHOOD));
|
||||||
address.setLocality(cursor.getString(6));
|
address.setLocality(row.getAsString(StructuredPostal.CITY));
|
||||||
address.setRegion(cursor.getString(7));
|
address.setRegion(row.getAsString(StructuredPostal.REGION));
|
||||||
address.setPostalCode(cursor.getString(8));
|
address.setPostalCode(row.getAsString(StructuredPostal.POSTCODE));
|
||||||
address.setCountry(cursor.getString(9));
|
address.setCountry(row.getAsString(StructuredPostal.COUNTRY));
|
||||||
c.getAddresses().add(address);
|
c.getAddresses().add(address);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
protected void populateCategories(Contact c) throws RemoteException {
|
protected void populateGroupMembership(Contact c, ContentValues row) throws RemoteException {
|
||||||
@Cleanup Cursor cursorMemberships = providerClient.query(dataURI(),
|
|
||||||
new String[] { GroupMembership.GROUP_ROW_ID, GroupMembership.GROUP_SOURCE_ID },
|
|
||||||
GroupMembership.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), GroupMembership.CONTENT_ITEM_TYPE }, null);
|
|
||||||
List<String> categories = c.getCategories();
|
List<String> categories = c.getCategories();
|
||||||
while (cursorMemberships != null && cursorMemberships.moveToNext()) {
|
|
||||||
long rowID = cursorMemberships.getLong(0);
|
long rowID = row.getAsLong(GroupMembership.GROUP_ROW_ID);
|
||||||
String sourceID = cursorMemberships.getString(1);
|
String sourceID = row.getAsString(GroupMembership.GROUP_SOURCE_ID);
|
||||||
|
|
||||||
// either a row ID or a source ID must be available
|
// either a row ID or a source ID must be available
|
||||||
String where, whereArg;
|
String where, whereArg;
|
||||||
@ -549,25 +542,16 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
} else
|
} else
|
||||||
Log.d(TAG, "Group not found (maybe deleted)");
|
Log.d(TAG, "Group not found (maybe deleted)");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void populateURL(Contact c, ContentValues row) throws RemoteException {
|
||||||
|
c.getURLs().add(row.getAsString(Website.URL));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void populateURLs(Contact c) throws RemoteException {
|
protected void populateEvent(Contact c, ContentValues row) throws RemoteException {
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] { Website.URL },
|
|
||||||
Website.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), Website.CONTENT_ITEM_TYPE }, null);
|
|
||||||
while (cursor != null && cursor.moveToNext())
|
|
||||||
c.getURLs().add(cursor.getString(0));
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void populateEvents(Contact c) throws RemoteException {
|
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(), new String[] { CommonDataKinds.Event.TYPE, CommonDataKinds.Event.START_DATE },
|
|
||||||
Photo.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), CommonDataKinds.Event.CONTENT_ITEM_TYPE }, null);
|
|
||||||
while (cursor != null && cursor.moveToNext()) {
|
|
||||||
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd", Locale.US);
|
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd", Locale.US);
|
||||||
try {
|
try {
|
||||||
Date date = formatter.parse(cursor.getString(1));
|
Date date = formatter.parse(row.getAsString(CommonDataKinds.Event.START_DATE));
|
||||||
switch (cursor.getInt(0)) {
|
switch (row.getAsInteger(CommonDataKinds.Event.TYPE)) {
|
||||||
case CommonDataKinds.Event.TYPE_ANNIVERSARY:
|
case CommonDataKinds.Event.TYPE_ANNIVERSARY:
|
||||||
c.setAnniversary(new Anniversary(date));
|
c.setAnniversary(new Anniversary(date));
|
||||||
break;
|
break;
|
||||||
@ -579,24 +563,25 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
Log.w(TAG, "Couldn't parse local birthday/anniversary date", e);
|
Log.w(TAG, "Couldn't parse local birthday/anniversary date", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void populateRelation(Contact c, ContentValues row) throws RemoteException {
|
||||||
|
String name = row.getAsString(Relation.NAME);
|
||||||
|
|
||||||
|
// find relation by name or create new one
|
||||||
|
Related related = null;
|
||||||
|
for (Related rel : c.getRelations()) {
|
||||||
|
if (rel.getText().equals(name)) {
|
||||||
|
related = rel;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (related == null) {
|
||||||
|
related = new Related();
|
||||||
|
c.getRelations().add(related);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void populateRelations(Contact c) throws RemoteException {
|
Set<RelatedType> types = related.getTypes();
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(),
|
switch (row.getAsInteger(Relation.TYPE)) {
|
||||||
new String[] { Relation.NAME, Relation.TYPE, Relation.LABEL },
|
|
||||||
Relation.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), Relation.CONTENT_ITEM_TYPE }, null);
|
|
||||||
|
|
||||||
Map<String, List<RelatedType>> relations = new HashMap<>();
|
|
||||||
while (cursor != null && cursor.moveToNext()) {
|
|
||||||
String name = cursor.getString(0);
|
|
||||||
List<RelatedType> types = relations.get(name);
|
|
||||||
if (types == null) {
|
|
||||||
types = new LinkedList<>();
|
|
||||||
relations.put(name, types);
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (cursor.getInt(1)) {
|
|
||||||
case Relation.TYPE_ASSISTANT:
|
case Relation.TYPE_ASSISTANT:
|
||||||
types.add(RelatedType.AGENT);
|
types.add(RelatedType.AGENT);
|
||||||
break;
|
break;
|
||||||
@ -640,30 +625,16 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
case Relation.TYPE_SPOUSE:
|
case Relation.TYPE_SPOUSE:
|
||||||
types.add(RelatedType.SPOUSE);
|
types.add(RelatedType.SPOUSE);
|
||||||
case Relation.TYPE_CUSTOM:
|
case Relation.TYPE_CUSTOM:
|
||||||
String customType = cursor.getString(2);
|
String customType = row.getAsString(Relation.LABEL);
|
||||||
if (!StringUtils.isEmpty(customType))
|
if (!StringUtils.isEmpty(customType))
|
||||||
types.add(RelatedType.get(customType));
|
types.add(RelatedType.get(customType));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (String name : relations.keySet()) {
|
protected void populateSipAddress(Contact c, ContentValues row) throws RemoteException {
|
||||||
Related related = new Related();
|
|
||||||
related.setText(name);
|
|
||||||
for (RelatedType type : relations.get(name))
|
|
||||||
related.addType(type);
|
|
||||||
c.getRelations().add(related);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void populateSipAddress(Contact c) throws RemoteException {
|
|
||||||
@Cleanup Cursor cursor = providerClient.query(dataURI(),
|
|
||||||
new String[] { SipAddress.SIP_ADDRESS, SipAddress.TYPE, SipAddress.LABEL },
|
|
||||||
SipAddress.RAW_CONTACT_ID + "=? AND " + Data.MIMETYPE + "=?",
|
|
||||||
new String[] { String.valueOf(c.getLocalID()), SipAddress.CONTENT_ITEM_TYPE }, null);
|
|
||||||
if (cursor != null && cursor.moveToNext()) {
|
|
||||||
try {
|
try {
|
||||||
Impp impp = new Impp("sip:" + cursor.getString(0));
|
Impp impp = new Impp("sip:" + row.getAsString(SipAddress.SIP_ADDRESS));
|
||||||
switch (cursor.getInt(1)) {
|
switch (row.getAsInteger(SipAddress.TYPE)) {
|
||||||
case SipAddress.TYPE_HOME:
|
case SipAddress.TYPE_HOME:
|
||||||
impp.addType(ImppType.HOME);
|
impp.addType(ImppType.HOME);
|
||||||
break;
|
break;
|
||||||
@ -671,7 +642,7 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
impp.addType(ImppType.WORK);
|
impp.addType(ImppType.WORK);
|
||||||
break;
|
break;
|
||||||
case SipAddress.TYPE_CUSTOM:
|
case SipAddress.TYPE_CUSTOM:
|
||||||
String customType = cursor.getString(2);
|
String customType = row.getAsString(SipAddress.LABEL);
|
||||||
if (!StringUtils.isEmpty(customType))
|
if (!StringUtils.isEmpty(customType))
|
||||||
impp.addType(ImppType.get(labelToXName(customType)));
|
impp.addType(ImppType.get(labelToXName(customType)));
|
||||||
}
|
}
|
||||||
@ -680,7 +651,6 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
Log.e(TAG, "Illegal SIP URI", e);
|
Log.e(TAG, "Illegal SIP URI", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* content builder methods */
|
/* content builder methods */
|
||||||
@ -735,7 +705,6 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
for (String url : contact.getURLs())
|
for (String url : contact.getURLs())
|
||||||
queueOperation(buildURL(newDataInsertBuilder(localID, backrefIdx), url));
|
queueOperation(buildURL(newDataInsertBuilder(localID, backrefIdx), url));
|
||||||
|
|
||||||
// events
|
|
||||||
if (contact.getAnniversary() != null)
|
if (contact.getAnniversary() != null)
|
||||||
queueOperation(buildEvent(newDataInsertBuilder(localID, backrefIdx), contact.getAnniversary(), CommonDataKinds.Event.TYPE_ANNIVERSARY));
|
queueOperation(buildEvent(newDataInsertBuilder(localID, backrefIdx), contact.getAnniversary(), CommonDataKinds.Event.TYPE_ANNIVERSARY));
|
||||||
if (contact.getBirthDay() != null)
|
if (contact.getBirthDay() != null)
|
||||||
@ -773,12 +742,15 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
protected Builder buildPhoneNumber(Builder builder, Telephone number) {
|
protected Builder buildPhoneNumber(Builder builder, Telephone number) {
|
||||||
int typeCode = Phone.TYPE_OTHER;
|
int typeCode = Phone.TYPE_OTHER;
|
||||||
String typeLabel = null;
|
String typeLabel = null;
|
||||||
boolean is_primary = false;
|
|
||||||
|
|
||||||
Set<TelephoneType> types = number.getTypes();
|
Set<TelephoneType> types = number.getTypes();
|
||||||
|
|
||||||
// preferred number?
|
// preferred number?
|
||||||
if (types.contains(TelephoneType.PREF))
|
boolean is_primary = false;
|
||||||
|
if (types.contains(TelephoneType.PREF)) {
|
||||||
is_primary = true;
|
is_primary = true;
|
||||||
|
types.remove(TelephoneType.PREF);
|
||||||
|
}
|
||||||
|
|
||||||
// 1 Android type <-> 2 VCard types: fax, cell, pager
|
// 1 Android type <-> 2 VCard types: fax, cell, pager
|
||||||
if (types.contains(TelephoneType.FAX)) {
|
if (types.contains(TelephoneType.FAX)) {
|
||||||
@ -811,8 +783,6 @@ public class LocalAddressBook extends LocalCollection<Contact> {
|
|||||||
typeCode = Phone.TYPE_COMPANY_MAIN;
|
typeCode = Phone.TYPE_COMPANY_MAIN;
|
||||||
} else if (types.contains(TelephoneType.ISDN)) {
|
} else if (types.contains(TelephoneType.ISDN)) {
|
||||||
typeCode = Phone.TYPE_ISDN;
|
typeCode = Phone.TYPE_ISDN;
|
||||||
} else if (types.contains(TelephoneType.PREF)) {
|
|
||||||
typeCode = Phone.TYPE_MAIN;
|
|
||||||
} else if (types.contains(Contact.PHONE_TYPE_RADIO)) {
|
} else if (types.contains(Contact.PHONE_TYPE_RADIO)) {
|
||||||
typeCode = Phone.TYPE_RADIO;
|
typeCode = Phone.TYPE_RADIO;
|
||||||
} else if (types.contains(TelephoneType.TEXTPHONE)) {
|
} else if (types.contains(TelephoneType.TEXTPHONE)) {
|
||||||
|
@ -581,7 +581,6 @@ public class LocalCalendar extends LocalCollection<Event> {
|
|||||||
String rDateStr = event.getRdate().getValue();
|
String rDateStr = event.getRdate().getValue();
|
||||||
if (rDate.getTimeZone() != null)
|
if (rDate.getTimeZone() != null)
|
||||||
rDateStr = DateUtils.findAndroidTimezoneID(rDate.getTimeZone().getID()) + ";" + rDateStr;
|
rDateStr = DateUtils.findAndroidTimezoneID(rDate.getTimeZone().getID()) + ";" + rDateStr;
|
||||||
Log.i(TAG, "Setting RDate in DB: " + rDateStr);
|
|
||||||
builder = builder.withValue(Events.RDATE, rDateStr);
|
builder = builder.withValue(Events.RDATE, rDateStr);
|
||||||
}
|
}
|
||||||
if (event.getExrule() != null)
|
if (event.getExrule() != null)
|
||||||
|
Loading…
Reference in New Issue
Block a user