summaryrefslogtreecommitdiffstats
path: root/kresources/lib/groupwaredataadaptor.cpp
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commit460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 (patch)
tree67208f7c145782a7e90b123b982ca78d88cc2c87 /kresources/lib/groupwaredataadaptor.cpp
downloadtdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.tar.gz
tdepim-460c52653ab0dcca6f19a4f492ed2c5e4e963ab0.zip
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdepim@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kresources/lib/groupwaredataadaptor.cpp')
-rw-r--r--kresources/lib/groupwaredataadaptor.cpp283
1 files changed, 283 insertions, 0 deletions
diff --git a/kresources/lib/groupwaredataadaptor.cpp b/kresources/lib/groupwaredataadaptor.cpp
new file mode 100644
index 000000000..aa83f4674
--- /dev/null
+++ b/kresources/lib/groupwaredataadaptor.cpp
@@ -0,0 +1,283 @@
+/*
+ This file is part of kdepim.
+
+ Copyright (c) 2004 Cornelius Schumacher <schumacher@kde.org>
+ Copyright (c) 2004 Till Adam <adam@kde.org>
+ Copyright (c) 2005 Reinhold Kainhofer <reinhold@kainhofer.com>
+
+ This library is free software; you can redistribute it and/or
+ modify it under the terms of the GNU Library General Public
+ License as published by the Free Software Foundation; either
+ version 2 of the License, or (at your option) any later version.
+
+ This library is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ Library General Public License for more details.
+
+ You should have received a copy of the GNU Library General Public License
+ along with this library; see the file COPYING.LIB. If not, write to
+ the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ Boston, MA 02110-1301, USA.
+*/
+
+#include "groupwaredataadaptor.h"
+#include <kdebug.h>
+#include <kio/job.h>
+#include <libemailfunctions/idmapper.h>
+
+using namespace KPIM;
+
+GroupwareUploadItem::GroupwareUploadItem( UploadType type ) : mItemType( KPIM::FolderLister::Unknown ), mType( type )
+{
+}
+
+KURL GroupwareUploadItem::adaptNewItemUrl( GroupwareDataAdaptor *adaptor,
+ const KURL &baseurl )
+{
+kdDebug()<<"GroupwareUploadItem::adaptNewItemUrl, baseurl=" << baseurl.url() << endl;
+ if ( adaptor ) {
+ QString path( adaptor->defaultNewItemName( this ) );
+kdDebug() << "path=" << path << endl;
+ KURL u( baseurl );
+ if ( path.isEmpty() ) return u;
+ else {
+ u.addPath( path );
+kdDebug() << "Final Path for new item: " << u.url() << endl;
+ return u;
+ }
+ } else return baseurl;
+}
+
+KIO::TransferJob *GroupwareUploadItem::createRawUploadJob(
+ GroupwareDataAdaptor *adaptor, const KURL &/*baseurl*/ )
+{
+ Q_ASSERT( adaptor );
+ if ( !adaptor ) return 0;
+ const QString dta = data();
+ //kdDebug(7000) << "Uploading: " << data << endl;
+ KURL upUrl( url() );
+ if ( adaptor )
+ adaptor->adaptUploadUrl( upUrl );
+ kdDebug(7000) << "Uploading to: " << upUrl.prettyURL() << endl;
+ KIO::TransferJob *job = KIO::storedPut( dta.utf8(), upUrl, -1, true,
+ false, false );
+ job->addMetaData( "PropagateHttpHeader", "true" );
+ if ( adaptor ) {
+ job->addMetaData( "customHTTPHeader", "Content-Type: " + adaptor->mimeType() );
+ }
+ return job;
+}
+
+KIO::TransferJob *GroupwareUploadItem::createUploadNewJob(
+ GroupwareDataAdaptor *adaptor, const KURL &baseurl )
+{
+kdDebug()<<"GroupwareUploadItem::createUploadNewJob, baseurl=" << baseurl.url() << endl;
+ setUrl( adaptNewItemUrl( adaptor, baseurl ) );
+ KIO::TransferJob *job = createRawUploadJob( adaptor, baseurl );
+ if ( job ) {
+ kdDebug() << "Adding If-None-Match " << endl;
+ QString header;
+ if ( job->outgoingMetaData().contains("customHTTPHeader") ) {
+ header = job->outgoingMetaData()["customHTTPHeader"];
+ header += "\r\n";
+ }
+ header += "If-None-Match: *";
+ job->addMetaData( "customHTTPHeader", header );
+ }
+ return job;
+}
+
+KIO::TransferJob *GroupwareUploadItem::createUploadJob(
+ GroupwareDataAdaptor *adaptor, const KURL &baseurl )
+{
+kdDebug()<<"GroupwareUploadItem::createUploadJob" << endl;
+ KIO::TransferJob *job = createRawUploadJob( adaptor, baseurl );
+ if ( job && adaptor ) {
+ kdDebug()<<"Adding If-Match header: " << adaptor->idMapper()->fingerprint( uid() ) << endl;
+ QString header;
+ if ( job->outgoingMetaData().contains("customHTTPHeader") ) {
+ header = job->outgoingMetaData()["customHTTPHeader"];
+ header += "\r\n";
+ }
+kdDebug()<<"old HEADER: " << header << endl;
+ header += "If-Match: " + adaptor->idMapper()->fingerprint( uid() );
+kdDebug()<<"new HEADER: " << header << endl;
+ job->addMetaData( "customHTTPHeader", header );
+ }
+ return job;
+}
+
+
+GroupwareDataAdaptor::GroupwareDataAdaptor()
+ : QObject(), mFolderLister( 0 ), mIdMapper( 0 )
+{
+}
+
+GroupwareDataAdaptor::~GroupwareDataAdaptor()
+{
+}
+
+void GroupwareDataAdaptor::setUserPassword( KURL &url )
+{
+ kdDebug(5800) << "GroupwareDataAdaptor::setUserPassword, mUser="
+ << mUser << endl;
+ url.setUser( mUser );
+ url.setPass( mPassword );
+}
+
+FolderLister::Entry::List GroupwareDataAdaptor::defaultFolders()
+{
+ return FolderLister::Entry::List();
+}
+
+KIO::TransferJob *GroupwareDataAdaptor::createUploadJob( const KURL &url,
+ GroupwareUploadItem *item )
+{
+ if ( item ) {
+ KIO::TransferJob *job = item->createUploadJob( this, url );
+ setUidForJob( job, item->uid() );
+ return job;
+ } else return 0;
+}
+
+KIO::TransferJob *GroupwareDataAdaptor::createUploadNewJob( const KURL &url,
+ GroupwareUploadItem *item )
+{
+kdDebug()<<"GroupwareDataAdaptor::createUploadNewJob, url=" << url.url() << endl;
+ if ( item ) {
+ KIO::TransferJob *job = item->createUploadNewJob( this, url );
+ setUidForJob( job, item->uid() );
+ return job;
+ } else return 0;
+}
+
+void GroupwareDataAdaptor::processDownloadListItem( const KURL &entry,
+ const QString &newFingerprint, KPIM::FolderLister::ContentType type )
+{
+ bool download = false;
+ const QString &location = entry.path();
+
+ emit itemOnServer( entry );
+ // if not locally present, download
+ const QString &localId = idMapper()->localId( location );
+ kdDebug(5800) << "Looking up remote: " << location
+ << " found: " << localId << endl;
+ if ( localId.isEmpty() || !localItemExists( localId ) ) {
+ //kdDebug(7000) << "Not locally present, download: " << location << endl;
+ download = true;
+ } else {
+ kdDebug(5800) << "Locally present " << endl;
+ // locally present, let's check if it's newer than what we have
+ const QString &oldFingerprint = idMapper()->fingerprint( localId );
+ if ( oldFingerprint != newFingerprint ) {
+ kdDebug(5800) << "Fingerprint changed old: " << oldFingerprint <<
+ " new: " << newFingerprint << endl;
+ // something changed on the server, check if we also changed it locally
+ if ( localItemHasChanged( localId ) ) {
+ // TODO conflict resolution
+ kdDebug(5800) << "TODO conflict resolution" << endl;
+ download = true;
+ } else {
+ download = true;
+ }
+ } else {
+ kdDebug(5800) << "Fingerprint not changed, don't download this " << endl;
+ }
+ }
+ if ( download ) {
+ emit itemToDownload( entry, type );
+ }
+}
+
+bool GroupwareDataAdaptor::interpretRemoveJob( KIO::Job *job, const QString &/*jobData*/ )
+{
+ if ( !job ) return false;
+ KIO::DeleteJob *deljob = dynamic_cast<KIO::DeleteJob*>(job);
+ bool error = job->error();
+ const QString err = job->errorString();
+
+ if ( deljob ) {
+ KURL::List urls( deljob->urls() );
+ for ( KURL::List::Iterator it = urls.begin(); it != urls.end(); ++it ) {
+ if ( error ) {
+ emit itemDeletionError( *it, err );
+ } else {
+ // FIXME: Don't use QString::null here
+ emit itemDeleted( QString::null, *it );
+ }
+ }
+ return true;
+ } else {
+ return false;
+ }
+}
+
+
+bool GroupwareDataAdaptor::interpretUploadJob( KIO::Job *job, const QString &/*jobData*/ )
+{
+ kdDebug(7000) << "GroupwareDataAdaptor::interpretUploadJob " << endl;
+ KIO::TransferJob *trfjob = dynamic_cast<KIO::TransferJob*>(job);
+ bool error = job->error();
+ const QString err = job->errorString();
+
+ if ( trfjob ) {
+ KURL url( trfjob->url() );
+ if ( error ) {
+ emit itemUploadError( url, err );
+ } else {
+ // We don't know the local id here (and we don't want to extract it from
+ // the idMapper, that's the task of the receiver
+ emit itemUploaded( uidFromJob( job ), url );
+ }
+ return true;
+ } else {
+ return false;
+ }
+}
+
+bool GroupwareDataAdaptor::interpretUploadNewJob( KIO::Job *job, const QString &/*jobData*/ )
+{
+// TODO: How does the incidence mapper know the old/new ids???
+ kdDebug(7000) << "GroupwareDataAdaptor::interpretUploadNewJob " << endl;
+ KIO::TransferJob *trfjob = dynamic_cast<KIO::TransferJob*>(job);
+ bool error = job->error();
+ const QString err = job->errorString();
+
+ if ( trfjob ) {
+ KURL url( trfjob->url() );
+ if ( error ) {
+ emit itemUploadNewError( idMapper()->localId( url.path() ), err );
+ } else {
+ // We don't know the local id here (and we don't want to extract it from
+ // the idMapper, that's the task of the receiver
+ emit itemUploadedNew( uidFromJob( job ), url );
+ }
+ return true;
+ } else {
+ return false;
+ }
+}
+
+QString GroupwareDataAdaptor::uidFromJob( KIO::Job *job ) const
+{
+kdDebug()<<"GroupwareDataAdaptor::uidFromJob( "<<job<<")"<<endl;
+ if ( mJobUIDMap.contains( job ) ) {
+ kdDebug()<<" Contained: "<< mJobUIDMap[job] << endl;
+ return mJobUIDMap[ job ];
+ } else {
+ return QString::null;
+ }
+}
+
+void GroupwareDataAdaptor::setUidForJob( KIO::Job *job, const QString &uid )
+{
+ if ( uid.isEmpty() ) {
+ mJobUIDMap.remove( job );
+ } else {
+ mJobUIDMap[ job ] = uid;
+ }
+}
+
+
+#include "groupwaredataadaptor.moc"