2
This file is part of kdepim.
4
Copyright (c) 2004 Cornelius Schumacher <schumacher@kde.org>
5
Copyright (c) 2004 Till Adam <adam@kde.org>
6
Copyright (c) 2005 Reinhold Kainhofer <reinhold@kainhofer.com>
8
This library is free software; you can redistribute it and/or
9
modify it under the terms of the GNU Library General Public
10
License as published by the Free Software Foundation; either
11
version 2 of the License, or (at your option) any later version.
13
This library is distributed in the hope that it will be useful,
14
but WITHOUT ANY WARRANTY; without even the implied warranty of
15
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16
Library General Public License for more details.
18
You should have received a copy of the GNU Library General Public License
19
along with this library; see the file COPYING.LIB. If not, write to
20
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
21
Boston, MA 02110-1301, USA.
24
#include "groupwaredataadaptor.h"
27
#include <kio/deletejob.h>
28
#include <kresources/idmapper.h>
32
GroupwareUploadItem::GroupwareUploadItem( UploadType type ) : mItemType( KPIM::FolderLister::Unknown ), mType( type )
36
KUrl GroupwareUploadItem::adaptNewItemUrl( GroupwareDataAdaptor *adaptor,
39
kDebug()<<"GroupwareUploadItem::adaptNewItemUrl, baseurl=" << baseurl.url();
41
QString path( adaptor->defaultNewItemName( this ) );
42
kDebug() <<"path=" << path;
44
if ( path.isEmpty() ) return u;
47
kDebug() <<"Final Path for new item:" << u.url();
50
} else return baseurl;
53
KIO::TransferJob *GroupwareUploadItem::createRawUploadJob(
54
GroupwareDataAdaptor *adaptor, const KUrl &/*baseurl*/ )
57
if ( !adaptor ) return 0;
58
const QString dta = data();
59
//kDebug(7000) <<"Uploading:" << data;
62
adaptor->adaptUploadUrl( upUrl );
63
kDebug(7000) <<"Uploading to:" << upUrl.prettyUrl();
64
KIO::TransferJob *job = KIO::storedPut( dta.toUtf8(), upUrl, -1, KIO::Overwrite |
65
KIO::HideProgressInfo );
66
job->addMetaData( "PropagateHttpHeader", "true" );
68
job->addMetaData( "customHTTPHeader", "Content-Type: " + adaptor->mimeType() );
73
KIO::TransferJob *GroupwareUploadItem::createUploadNewJob(
74
GroupwareDataAdaptor *adaptor, const KUrl &baseurl )
76
kDebug()<<"GroupwareUploadItem::createUploadNewJob, baseurl=" << baseurl.url();
77
setUrl( adaptNewItemUrl( adaptor, baseurl ) );
78
KIO::TransferJob *job = createRawUploadJob( adaptor, baseurl );
80
kDebug() <<"Adding If-None-Match";
82
if ( job->outgoingMetaData().contains("customHTTPHeader") ) {
83
header = job->outgoingMetaData()["customHTTPHeader"];
86
header += "If-None-Match: *";
87
job->addMetaData( "customHTTPHeader", header );
92
KIO::TransferJob *GroupwareUploadItem::createUploadJob(
93
GroupwareDataAdaptor *adaptor, const KUrl &baseurl )
95
kDebug()<<"GroupwareUploadItem::createUploadJob";
96
KIO::TransferJob *job = createRawUploadJob( adaptor, baseurl );
97
if ( job && adaptor ) {
98
kDebug()<<"Adding If-Match header:" << adaptor->idMapper()->fingerprint( uid() );
100
if ( job->outgoingMetaData().contains("customHTTPHeader") ) {
101
header = job->outgoingMetaData()["customHTTPHeader"];
104
kDebug()<<"old HEADER:" << header;
105
header += "If-Match: " + adaptor->idMapper()->fingerprint( uid() );
106
kDebug()<<"new HEADER:" << header;
107
job->addMetaData( "customHTTPHeader", header );
113
GroupwareDataAdaptor::GroupwareDataAdaptor()
114
: QObject(), mFolderLister( 0 ), mIdMapper( 0 )
118
GroupwareDataAdaptor::~GroupwareDataAdaptor()
122
void GroupwareDataAdaptor::setUserPassword( KUrl &url )
124
kDebug(5800) <<"GroupwareDataAdaptor::setUserPassword, mUser="
126
url.setUser( mUser );
127
url.setPass( mPassword );
130
FolderLister::Entry::List GroupwareDataAdaptor::defaultFolders()
132
return FolderLister::Entry::List();
135
KIO::TransferJob *GroupwareDataAdaptor::createUploadJob( const KUrl &url,
136
GroupwareUploadItem *item )
139
KIO::TransferJob *job = item->createUploadJob( this, url );
140
setUidForJob( job, item->uid() );
145
KIO::TransferJob *GroupwareDataAdaptor::createUploadNewJob( const KUrl &url,
146
GroupwareUploadItem *item )
148
kDebug()<<"GroupwareDataAdaptor::createUploadNewJob, url=" << url.url();
150
KIO::TransferJob *job = item->createUploadNewJob( this, url );
151
setUidForJob( job, item->uid() );
156
void GroupwareDataAdaptor::processDownloadListItem( const KUrl &entry,
157
const QString &newFingerprint, KPIM::FolderLister::ContentType type )
159
bool download = false;
160
const QString &location = entry.path();
162
emit itemOnServer( entry );
163
// if not locally present, download
164
const QString &localId = idMapper()->localId( location );
165
kDebug(5800) <<"Looking up remote:" << location
166
<< "found:" << localId;
167
if ( localId.isEmpty() || !localItemExists( localId ) ) {
168
//kDebug(7000) <<"Not locally present, download:" << location;
171
kDebug(5800) <<"Locally present";
172
// locally present, let's check if it's newer than what we have
173
const QString &oldFingerprint = idMapper()->fingerprint( localId );
174
if ( oldFingerprint != newFingerprint ) {
175
kDebug(5800) <<"Fingerprint changed old:" << oldFingerprint <<
176
"new:" << newFingerprint;
177
// something changed on the server, check if we also changed it locally
178
if ( localItemHasChanged( localId ) ) {
179
// TODO conflict resolution
180
kDebug(5800) <<"TODO conflict resolution";
186
kDebug(5800) <<"Fingerprint not changed, don't download this";
190
emit itemToDownload( entry, type );
194
bool GroupwareDataAdaptor::interpretRemoveJob( KIO::Job *job, const QString &/*jobData*/ )
196
if ( !job ) return false;
197
KIO::DeleteJob *deljob = dynamic_cast<KIO::DeleteJob*>(job);
198
bool error = job->error();
199
const QString err = job->errorString();
202
KUrl::List urls( deljob->urls() );
203
for ( KUrl::List::Iterator it = urls.begin(); it != urls.end(); ++it ) {
205
emit itemDeletionError( *it, err );
207
// FIXME: Don't use QString() here
208
emit itemDeleted( QString(), *it );
218
bool GroupwareDataAdaptor::interpretUploadJob( KIO::Job *job, const QString &/*jobData*/ )
220
kDebug(7000) <<"GroupwareDataAdaptor::interpretUploadJob";
221
KIO::TransferJob *trfjob = dynamic_cast<KIO::TransferJob*>(job);
222
bool error = job->error();
223
const QString err = job->errorString();
226
KUrl url( trfjob->url() );
228
emit itemUploadError( url, err );
230
// We don't know the local id here (and we don't want to extract it from
231
// the idMapper, that's the task of the receiver
232
emit itemUploaded( uidFromJob( job ), url );
240
bool GroupwareDataAdaptor::interpretUploadNewJob( KIO::Job *job, const QString &/*jobData*/ )
242
// TODO: How does the incidence mapper know the old/new ids???
243
kDebug(7000) <<"GroupwareDataAdaptor::interpretUploadNewJob";
244
KIO::TransferJob *trfjob = dynamic_cast<KIO::TransferJob*>(job);
245
bool error = job->error();
246
const QString err = job->errorString();
249
KUrl url( trfjob->url() );
251
emit itemUploadNewError( idMapper()->localId( url.path() ), err );
253
// We don't know the local id here (and we don't want to extract it from
254
// the idMapper, that's the task of the receiver
255
emit itemUploadedNew( uidFromJob( job ), url );
263
QString GroupwareDataAdaptor::uidFromJob( KIO::Job *job ) const
265
kDebug()<<"GroupwareDataAdaptor::uidFromJob("<<job<<")";
266
if ( mJobUIDMap.contains( job ) ) {
267
kDebug()<<" Contained:"<< mJobUIDMap[job];
268
return mJobUIDMap[ job ];
274
void GroupwareDataAdaptor::setUidForJob( KIO::Job *job, const QString &uid )
276
if ( uid.isEmpty() ) {
277
mJobUIDMap.remove( job );
279
mJobUIDMap[ job ] = uid;
284
#include "groupwaredataadaptor.moc"