void CalendarResource::itemRemoved(const Akonadi::Item &item) { if (!canPerformTask()) { return; } if (item.mimeType() == KCalCore::Event::eventMimeType()) { KGAPI2::Job *job = new EventDeleteJob(item.remoteId(), item.parentCollection().remoteId(), account(), this); job->setProperty(ITEM_PROPERTY, QVariant::fromValue(item)); connect(job, &EventCreateJob::finished, this, &CalendarResource::slotGenericJobFinished); } else if (item.mimeType() == KCalCore::Todo::todoMimeType()) { /* Google always automatically removes tasks with all their subtasks. In KOrganizer * by default we only remove the item we are given. For this reason we have to first * fetch all tasks, find all sub-tasks for the task being removed and detach them * from the task. Only then the task can be safely removed. */ ItemFetchJob *fetchJob = new ItemFetchJob(item.parentCollection()); fetchJob->setAutoDelete(true); fetchJob->fetchScope().fetchFullPayload(true); fetchJob->setProperty(ITEM_PROPERTY, qVariantFromValue(item)); connect(fetchJob, &ItemFetchJob::finished, this, &CalendarResource::slotRemoveTaskFetchJobFinished); fetchJob->start(); } else { cancelTask(i18n("Invalid payload type. Expected event or todo, got %1", item.mimeType())); } }
int ContactsHandler::setEntry(const Akonadi::Item &item, QString &newId, QString &errorMessage) { if (!item.hasPayload<KContacts::Addressee>()) { qCCritical(FATCRM_SUGARCRMRESOURCE_LOG) << "item (id=" << item.id() << ", remoteId=" << item.remoteId() << ", mime=" << item.mimeType() << ") is missing Addressee payload"; return SugarJob::InvalidContextError; } QList<KDSoapGenerated::TNS__Name_value> itemList; // if there is an id add it, otherwise skip this field // no id will result in the contact being added if (!item.remoteId().isEmpty()) { KDSoapGenerated::TNS__Name_value field; field.setName(QStringLiteral("id")); field.setValue(item.remoteId()); itemList << field; } // add regular sugar fields const KContacts::Addressee addressee = item.payload<KContacts::Addressee>(); KDSoapGenerated::TNS__Name_value_list valueList = addresseeToNameValueList(addressee, itemList); return mSession->protocol()->setEntry(module(), valueList, newId, errorMessage); }
int DocumentsHandler::setEntry(const Akonadi::Item &item, QString &newId, QString &errorMessage) { if (!item.hasPayload<SugarDocument>()) { qCCritical(FATCRM_SUGARCRMRESOURCE_LOG) << "item (id=" << item.id() << ", remoteId=" << item.remoteId() << ", mime=" << item.mimeType() << ") is missing Document payload"; return SugarJob::InvalidContextError; } QList<KDSoapGenerated::TNS__Name_value> itemList; // if there is an id add it, otherwise skip this field // no id will result in the email being added if (!item.remoteId().isEmpty()) { KDSoapGenerated::TNS__Name_value field; field.setName(QStringLiteral("id")); field.setValue(item.remoteId()); itemList << field; } const SugarDocument document = item.payload<SugarDocument>(); const SugarDocument::AccessorHash accessors = SugarDocument::accessorHash(); SugarDocument::AccessorHash::const_iterator it = accessors.constBegin(); SugarDocument::AccessorHash::const_iterator endIt = accessors.constEnd(); for (; it != endIt; ++it) { // check if this is a read-only field if (it.key() == QLatin1String("id")) { continue; } const SugarDocument::valueGetter getter = (*it).getter; KDSoapGenerated::TNS__Name_value field; field.setName(sugarFieldFromCrmField(it.key())); field.setValue(KDCRMUtils::encodeXML((document.*getter)())); itemList << field; } // plus custom fields QMap<QString, QString> customFields = document.customFields(); QMap<QString, QString>::const_iterator cit = customFields.constBegin(); const QMap<QString, QString>::const_iterator end = customFields.constEnd(); for ( ; cit != end ; ++cit ) { KDSoapGenerated::TNS__Name_value field; field.setName(customSugarFieldFromCrmField(cit.key())); field.setValue(KDCRMUtils::encodeXML(cit.value())); itemList << field; } KDSoapGenerated::TNS__Name_value_list valueList; valueList.setItems(itemList); return mSession->protocol()->setEntry(module(), valueList, newId, errorMessage); }
bool SalesforceContactsHandler::setEntry(const Akonadi::Item &item, SforceService *soap) { if (!item.hasPayload<KABC::Addressee>()) { kError() << "item (id=" << item.id() << ", remoteId=" << item.remoteId() << ", mime=" << item.mimeType() << ") is missing Addressee payload"; return false; } ENS__SObject object; object.setType(QLatin1String("Contact")); // if there is an id add it, otherwise skip this field // no id will result in the contact being added if (!item.remoteId().isEmpty()) { object.setId(item.remoteId()); } const KABC::Addressee addressee = item.payload<KABC::Addressee>(); QList<KDSoapValue> valueList; ContactAccessorHash::const_iterator it = mAccessors->constBegin(); ContactAccessorHash::const_iterator endIt = mAccessors->constEnd(); for (; it != endIt; ++it) { // Id is already part of the object, we have the accessor for the query if (it.key() == QLatin1String("Id")) { continue; } if (it->isAvailable) { const QString value = it->getter(addressee); valueList << KDSoapValue(it.key(), value); kDebug() << "Upsert: name=" << it.key() << "value=" << value; } } object.setAny(valueList); TNS__Upsert upsert; upsert.setExternalIDFieldName(QLatin1String("Id")); upsert.setSObjects(QList<ENS__SObject>() << object); soap->asyncUpsert(upsert); return true; }
bool ContactsHandler::setEntry(const Akonadi::Item &item) { if (!item.hasPayload<KABC::Addressee>()) { kError() << "item (id=" << item.id() << ", remoteId=" << item.remoteId() << ", mime=" << item.mimeType() << ") is missing Addressee payload"; return false; } QList<KDSoapGenerated::TNS__Name_value> itemList; // if there is an id add it, otherwise skip this field // no id will result in the contact being added if (!item.remoteId().isEmpty()) { KDSoapGenerated::TNS__Name_value field; field.setName(QLatin1String("id")); field.setValue(item.remoteId()); itemList << field; } const KABC::Addressee addressee = item.payload<KABC::Addressee>(); ContactAccessorHash::const_iterator it = mAccessors->constBegin(); ContactAccessorHash::const_iterator endIt = mAccessors->constEnd(); for (; it != endIt; ++it) { // check if this is a read-only field if ((*it)->getter == 0) { continue; } KDSoapGenerated::TNS__Name_value field; field.setName(it.key()); const QString value = KDCRMUtils::encodeXML((*it)->getter(addressee)); field.setValue(value); itemList << field; } KDSoapGenerated::TNS__Name_value_list valueList; valueList.setItems(itemList); soap()->asyncSet_entry(sessionId(), moduleName(), valueList); return true; }
bool TasksHandler::setEntry( const Akonadi::Item &item ) { if ( !item.hasPayload<KCalCore::Todo::Ptr>() ) { kError() << "item (id=" << item.id() << ", remoteId=" << item.remoteId() << ", mime=" << item.mimeType() << ") is missing Todo payload"; return false; } QList<TNS__Name_value> itemList; // if there is an id add it, otherwise skip this field // no id will result in the contact being added if ( !item.remoteId().isEmpty() ) { TNS__Name_value field; field.setName( QLatin1String( "id" ) ); field.setValue( item.remoteId() ); itemList << field; } const KCalCore::Todo::Ptr todo = item.payload<KCalCore::Todo::Ptr>(); AccessorHash::const_iterator it = mAccessors->constBegin(); AccessorHash::const_iterator endIt = mAccessors->constEnd(); for ( ; it != endIt; ++it ) { // check if this is a read-only field if ( (*it)->getter == 0 ) { continue; } TNS__Name_value field; field.setName(sugarFieldFromCrmField(it.key())); field.setValue(KDCRMUtils::encodeXML((*it)->getter(*todo))); itemList << field; } TNS__Name_value_list valueList; valueList.setItems( itemList ); soap()->asyncSet_entry( sessionId(), moduleName(), valueList ); return true; }