Example #1
0
 private void processCategories(List<Category> categories) throws ServiceException {
   Stats stats = new Stats();
   // Get all existing contact groups
   Map<Integer, ContactGroup> groups = new HashMap<Integer, ContactGroup>();
   for (Category cat : categories) {
     groups.put(cat.getId(), new ContactGroup(cat.getName()));
   }
   // Get all contact mappings and update contact group dlist information
   Collection<DataSourceItem> mappings = localData.getAllContactMappings();
   for (DataSourceItem dsi : mappings) {
     if (dsi.remoteId != null) {
       RemoteId rid = RemoteId.parse(dsi.remoteId);
       if (rid.isContact()) {
         Contact contact = getContact(dsi);
         if (contact != null) {
           List<Category> cats = contact.getCategories();
           if (!cats.isEmpty()) {
             List<String> emails = getEmailAddresses(contact);
             if (!emails.isEmpty()) {
               for (Category cat : cats) {
                 ContactGroup group = groups.get(cat.getId());
                 if (group != null) {
                   group.addEmail(emails.get(0));
                 }
               }
             }
           }
         }
       }
     }
   }
   // Remove contact groups deleted remotely
   for (DataSourceItem dsi : mappings) {
     if (dsi.remoteId != null) {
       RemoteId rid = RemoteId.parse(dsi.remoteId);
       if (rid.isCategory() && !groups.containsKey(rid.getId())) {
         localData.deleteContactGroup(dsi.itemId);
         groups.remove(rid.getId());
         stats.deleted++;
       }
     }
   }
   // Create new or update existring contact groups
   for (Map.Entry<Integer, ContactGroup> me : groups.entrySet()) {
     RemoteId rid = RemoteId.categoryId(me.getKey());
     updateGroup(rid.toString(), me.getValue(), stats);
   }
   LOG.debug("Processed remote category changes: %s", stats);
 }
Example #2
0
 private SyncRequestEvent getContactEvent(Change change) throws ServiceException {
   int itemId = change.getItemId();
   if (change.isAdd() || change.isUpdate()) {
     com.zimbra.cs.mailbox.Contact zcontact = localData.getContact(itemId);
     if (ContactGroup.isContactGroup(zcontact)) {
       // Delete mapping so contact group will no longer be sync'd
       localData.deleteMapping(itemId);
     } else {
       ContactData cd = new ContactData(zcontact);
       if (change.isAdd()) {
         Contact contact = cd.getContact();
         pushedContacts.put(itemId, contact);
         return SyncRequestEvent.addContact(contact);
       } else {
         // LOG.debug("count = " + cd.getCategories().size());
         Contact newContact = cd.getContact();
         Contact oldContact = getContact(localData.getMapping(itemId));
         // LOG.debug("oldContact: " + oldContact);
         // LOG.debug("newContact: " + newContact);
         newContact.setId(oldContact.getId());
         // Add categories so we can track updates
         for (Category category : oldContact.getCategories()) {
           newContact.addCategory(category);
         }
         pushedContacts.put(itemId, newContact);
         ContactChange cc = cd.getContactChange(oldContact);
         return cc.isEmpty() ? null : SyncRequestEvent.updateContact(cc);
       }
     }
   } else if (change.isDelete()) {
     DataSourceItem dsi = localData.getMapping(itemId);
     RemoteId rid = RemoteId.parse(dsi.remoteId);
     if (rid.isContact()) {
       pushedContacts.put(itemId, new Contact(rid.getId()));
       return SyncRequestEvent.removeContact(rid.getId());
     } else {
       // Remove mapping for deleted contact group
       localData.deleteMapping(rid.getId());
     }
   }
   return null;
 }