summaryrefslogtreecommitdiffstats
path: root/kresources/exchange/resourceexchange.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'kresources/exchange/resourceexchange.cpp')
-rw-r--r--kresources/exchange/resourceexchange.cpp627
1 files changed, 0 insertions, 627 deletions
diff --git a/kresources/exchange/resourceexchange.cpp b/kresources/exchange/resourceexchange.cpp
deleted file mode 100644
index 1f6779a81..000000000
--- a/kresources/exchange/resourceexchange.cpp
+++ /dev/null
@@ -1,627 +0,0 @@
-/*
- This file is part of libkpimexchange.
- Copyright (c) 2002 Jan-Pascal van Best <[email protected]>
-
- 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 <stdlib.h>
-
-#include <tqdatetime.h>
-#include <tqstring.h>
-#include <tqptrlist.h>
-#include <tqwidgetlist.h>
-#include <tqwidget.h>
-
-#include <kdebug.h>
-#include <kapplication.h>
-#include <kstringhandler.h>
-#include <kglobal.h>
-#include <klocale.h>
-
-#include <libkcal/calendarlocal.h>
-#include <libkcal/calendar.h>
-#include <libkcal/journal.h>
-
-#include <kresources/configwidget.h>
-
-#include <kabc/locknull.h>
-
-#include "dateset.h"
-#include "exchangeaccount.h"
-#include "exchangeclient.h"
-#include "exchangemonitor.h"
-
-#include "resourceexchange.h"
-#include "resourceexchangeconfig.h"
-
-
-using namespace KCal;
-using namespace KPIM;
-
-typedef KRES::PluginFactory<ResourceExchange,ResourceExchangeConfig> ExchangeFactory;
-
-// FIXME: Use K_EXPORT_COMPONENT_FACTORY( resourcecalendarexchange, ExchangeFactory ); here
-// Problem: How to insert the catalogue!
-extern "C"
-{
- void* init_resourcecalendarexchange()
- {
- TDEGlobal::locale()->insertCatalogue( "kres_exchange" );
- return new ExchangeFactory;
- }
-}
-
-class ResourceExchange::EventInfo {
-public:
- KCal::Event* event;
- KURL url;
- long updateWatch;
-};
-
-ResourceExchange::ResourceExchange( const TDEConfig *config )
- : ResourceCalendar( config ), mClient(0), mMonitor(0), mCache(0), mDates(0),
- mEventDates(0), mCacheDates(0)
-{
- mLock = new KABC::LockNull( true );
-
- mTimeZoneId = TQString::fromLatin1( "UTC" );
-
- kdDebug() << "Creating ResourceExchange" << endl;
- if (config ) {
- mAccount = new ExchangeAccount(
- config->readEntry( "ExchangeHost" ),
- config->readEntry( "ExchangePort" ),
- config->readEntry( "ExchangeAccount" ),
- KStringHandler::obscure( config->readEntry( "ExchangePassword" ) ),
- config->readEntry( "ExchangeMailbox" ) );
- mCachedSeconds = config->readNumEntry( "ExchangeCacheTimeout", 600 );
- mAutoMailbox = config->readBoolEntry( "ExchangeAutoMailbox", true );
- } else {
- setResourceName( i18n( "Exchange Server" ) );
- mAccount = new ExchangeAccount( "", "", "", "" );
- mCachedSeconds = 600;
- }
-}
-
-ResourceExchange::~ResourceExchange()
-{
- kdDebug() << "Destructing ResourceExchange" << endl;
-
- close();
-
- delete mAccount; mAccount = 0;
-}
-
-void ResourceExchange::writeConfig( TDEConfig* config )
-{
- ResourceCalendar::writeConfig( config );
- config->writeEntry( "ExchangeHost", mAccount->host() );
- config->writeEntry( "ExchangePort", mAccount->port() );
- config->writeEntry( "ExchangeAccount", mAccount->account() );
- config->writeEntry( "ExchangeMailbox", mAccount->mailbox() );
- config->writeEntry( "ExchangePassword", KStringHandler::obscure( mAccount->password() ) );
- config->writeEntry( "ExchangeCacheTimeout", mCachedSeconds );
- config->writeEntry( "ExchangeAutoMailbox", mAutoMailbox );
-}
-
-bool ResourceExchange::doOpen()
-{
- kdDebug() << "ResourceExchange::doOpen()" << endl;
-
- mClient = new ExchangeClient( mAccount, mTimeZoneId );
- connect( mClient, TQT_SIGNAL( downloadFinished( int, const TQString & ) ),
- TQT_SLOT( slotDownloadFinished( int, const TQString & ) ) );
- connect( mClient, TQT_SIGNAL( event( KCal::Event *, const KURL & ) ),
- TQT_SLOT( downloadedEvent( KCal::Event *, const KURL & ) ) );
-
-#if 0
- kdDebug() << "Creating monitor" << endl;
- TQHostAddress ip;
- ip.setAddress( mAccount->host() );
- mMonitor = new ExchangeMonitor( mAccount, ExchangeMonitor::CallBack, ip );
- connect( mMonitor, TQT_SIGNAL(notify( const TQValueList<long>& , const TQValueList<KURL>& )), this, TQT_SLOT(slotMonitorNotify( const TQValueList<long>& , const TQValueList<KURL>& )) );
- connect( mMonitor, TQT_SIGNAL(error(int , const TQString&)), this, TQT_SLOT(slotMonitorError(int , const TQString&)) );
-
- mMonitor->addWatch( mAccount->calendarURL(), ExchangeMonitor::UpdateNewMember, 1 );
-#endif
-
- TQWidgetList* widgets = TQApplication::topLevelWidgets();
- if ( !widgets->isEmpty() )
- mClient->setWindow( widgets->first() );
- delete widgets;
-
- mDates = new DateSet();
-
- mEventDates = new TQMap<Event,TQDateTime>();
- mCacheDates = new TQMap<TQDate, TQDateTime>();
-
- mCache = new CalendarLocal( mTimeZoneId );
- // mOldestDate = 0L;
- // mNewestDate = 0L;
-
- // FIXME: check if server exists, account is OK, etc.
- return true;
-}
-
-void ResourceExchange::doClose()
-{
- kdDebug() << "ResourceExchange::doClose()" << endl;
-
- // delete mNewestDate;
- // delete mOldestDate;
- delete mDates; mDates = 0;
-// delete mMonitor; mMonitor = 0;
- delete mClient; mClient = 0;
- delete mEventDates; mEventDates = 0;
- delete mCacheDates; mCacheDates = 0;
- if (mCache) {
- mCache->close();
- delete mCache; mCache = 0;
- }
-// setModified( false );
-}
-
-bool ResourceExchange::doLoad()
-{
- return true;
-}
-
-bool ResourceExchange::doSave()
-{
- kdDebug() << "ResourceExchange::save() " << mChangedIncidences.count()
- << endl;
-
- Incidence::List::Iterator it = mChangedIncidences.begin();
- while( it != mChangedIncidences.end() ) {
- if ( (*it)->type() == "Event" ) {
- if ( uploadEvent( static_cast<Event *>( *it ) ) ) {
- it = mChangedIncidences.remove( it );
- } else {
- kdError() << "ResourceExchange::save(): upload failed." << endl;
- ++it;
- }
- } else {
- kdError() << "ResourceExchange::save() type not handled: "
- << (*it)->type() << endl;
- ++it;
- }
- }
- return true;
-}
-
-KABC::Lock *ResourceExchange::lock()
-{
- return mLock;
-}
-
-void ResourceExchange::slotMonitorNotify( const TQValueList<long>& IDs, const TQValueList<KURL>& urls )
-{
- kdDebug() << "ResourceExchange::slotMonitorNotify()" << endl;
-
- TQString result;
- KPIM::ExchangeMonitor::IDList::ConstIterator it;
- for ( it = IDs.begin(); it != IDs.end(); ++it ) {
- if ( it == IDs.begin() )
- result += TQString::number( (*it) );
- else
- result += "," + TQString::number( (*it) );
- }
- kdDebug() << "Got signals for " << result << endl;
- TQValueList<KURL>::ConstIterator it2;
- for ( it2 = urls.begin(); it2 != urls.end(); ++it2 ) {
- kdDebug() << "URL: " << (*it2).prettyURL() << endl;
- }
-
- /* Now find out what happened:
- * One or more of the following:
- * 1. Event added in period that we think we have cached
- * 2. Event deleted that we have in cache
- * 3. Event modified that we have in cache
- * 4. Something else happened that isn't relevant to us
- * Update cache, then notify whoever's watching us
- * We may be able to find (1) and (3) by looking at the
- * DAV:getlastmodified property
- * (2) is trickier: we might have to resort to checking
- * all uids in the cache
- * Or: put monitors on every event in the cache, so that
- * we know when one gets deleted or modified
- * Only look for new events using the global monitor
- */
-}
-
-void ResourceExchange::slotMonitorError( int errorCode, const TQString& moreInfo )
-{
- kdError() << "Ignoring error from Exchange monitor, code=" << errorCode << "; more info: " << moreInfo << endl;
-}
-
-
-bool ResourceExchange::addEvent( Event *event )
-{
- return addEvent( event, TQString() );
-}
-
-bool ResourceExchange::addEvent( Event *event, const TQString &subresource )
-{
- Q_UNUSED( subresource ); //subresources are not supported
-
- if( !mCache ) return false;
- kdDebug() << "ResourceExchange::addEvent" << endl;
-
- // FIXME: first check of upload finished successfully, only then
- // add to cache
- mCache->addEvent( event );
-
- uploadEvent( event );
-// insertEvent( event );
-
- event->registerObserver( this );
-// setModified( true );
-
- return true;
-}
-
-bool ResourceExchange::uploadEvent( Event *event )
-{
- mClient->uploadSynchronous( event );
- return true;
-}
-
-bool ResourceExchange::deleteEvent(Event *event)
-{
- if ( !mCache ) return false;
- kdDebug(5800) << "ResourceExchange::deleteEvent" << endl;
-
- mClient->removeSynchronous( event );
-
- // This also frees the event
- return mCache->deleteEvent( event );
-
-// setModified( true );
-}
-
-void ResourceExchange::changeIncidence( Incidence *incidence )
-{
- kdDebug() << "ResourceExchange::changeIncidence(): "
- << incidence->summary() << endl;
-
- if ( mChangedIncidences.find( incidence ) == mChangedIncidences.end() ) {
- mChangedIncidences.append( incidence );
- }
-}
-
-Event *ResourceExchange::event( const TQString &uid )
-{
- kdDebug(5800) << "ResourceExchange::event(): " << uid << endl;
-
- // FIXME: Look in exchange server for uid!
- Event *event = 0;
- if ( mCache )
- event = mCache->event( uid );
- return event;
-}
-
-void ResourceExchange::subscribeEvents( const TQDate &start, const TQDate &end )
-{
- kdDebug(5800) << "ResourceExchange::subscribeEvents()" << endl;
- // FIXME: possible race condition if several subscribe events are run close
- // to each other
- mClient->download( start, end, false );
-}
-
-void ResourceExchange::downloadedEvent( KCal::Event *event, const KURL &url )
-{
- kdDebug() << "Downloaded event: " << event->summary() << " from url "
- << url.prettyURL() << endl;
- // FIXME: add watches to the monitor for these events
- // KURL url =
- // mMonitor->addWatch( url, KPIM::ExchangeMonitor::Update, 0 );
-// emit eventsAdded( events );
-}
-
-void ResourceExchange::slotDownloadFinished( int result,
- const TQString &moreinfo )
-{
- kdDebug() << "ResourceExchange::downloadFinished" << endl;
-
- if ( result != KPIM::ExchangeClient::ResultOK ) {
- // Do something useful with the error report
- kdError() << "ResourceExchange::slotDownloadFinished(): error " << result
- << ": " << moreinfo << endl;
- }
-}
-
-void ResourceExchange::unsubscribeEvents( const TQDate &/*start*/, const TQDate &/*end*/ )
-{
- kdDebug() << "ResourceExchange::unsubscribeEvents()" << endl;
-}
-
-bool ResourceExchange::addTodo( Todo *todo )
-{
- return addTodo( todo, TQString() );
-}
-
-bool ResourceExchange::addTodo( Todo */*todo*/, const TQString &subresource )
-{
- Q_UNUSED( subresource ); //subresources are not supported
- // This resource doesn't handle todos yet!
- return false;
-/* if( !mCache)
- return false;
- mCache->addTodo( todo );
-
- todo->registerObserver( this );
-
-// setModified( true );
-
- return true;*/
-}
-
-
-bool ResourceExchange::deleteTodo(Todo */*todo*/)
-{
- // We don't handle todos yet
-// if( !mCache )
- return false;
-// mCache->deleteTodo( todo );
-
-// setModified( true );
-}
-
-Todo::List ResourceExchange::rawTodos( TodoSortField /*sortField*/, SortDirection /*sortDirection*/ )
-{
- // We don't handle todos yet
- return Todo::List();
-/* Todo::List list;
- if ( mCache )
- list = mCache->rawTodos( sortField, sortDirection );
- return list;*/
-}
-
-Todo *ResourceExchange::todo( const TQString &/*uid*/ )
-{
- // We don't handle todos yet
- return 0;
-/* if ( !mCache )
- return 0;
- else
- return mCache->todo( uid );*/
-}
-
-Todo::List ResourceExchange::rawTodosForDate( const TQDate &/*date*/ )
-{
- Todo::List list;
- // We don't handle todos yet
-/* if ( mCache )
- list = mCache->rawTodosForDate( date );*/
- return list;
-}
-
-Alarm::List ResourceExchange::alarmsTo( const TQDateTime &to )
-{
- Alarm::List list;
- if ( mCache )
- list = mCache->alarmsTo( to );
- return list;
-}
-
-/* Invoked by korgac when checking alarms. Always updates the cache. */
-Alarm::List ResourceExchange::alarms( const TQDateTime &from, const TQDateTime &to )
-{
- kdDebug(5800) << "ResourceExchange::alarms(" << from.toString() << " - " << to.toString() << ")\n";
- Alarm::List list;
-
- TQDate start = from.date();
- TQDate end = to.date();
-
- if ( mCache ) {
-
- /* Clear the cache */
- Event::List oldEvents = mCache->rawEvents( start, end, false );
-
- Event::List::ConstIterator it;
- for( it = oldEvents.begin(); it != oldEvents.end(); ++it ) {
- mCache->deleteEvent( *it );
- }
-
- /* Fetch events */
- mClient->downloadSynchronous( mCache, start, end, false );
-
- list = mCache->alarms( from, to );
- }
- return list;
-}
-
-/****************************** PROTECTED METHODS ****************************/
-
-// after changes are made to an event, this should be called.
-void ResourceExchange::incidenceUpdated( IncidenceBase *incidence )
-{
- Event* event = dynamic_cast<Event *>( incidence );
- if ( event ) {
- kdDebug() << "Event updated, resubmit to server..." << endl;
- uploadEvent( event );
- }
-// setModified( true );
-}
-
-// this function will take a VEvent and insert it into the event
-// dictionary for the ResourceExchange. If there is no list of events for that
-// particular location in the dictionary, a new one will be created.
-/*
-void ResourceExchange::insertEvent(const Event *anEvent)
-{
- kdDebug() << "ResourceExchange::insertEvent" << endl;
-
-}
-*/
-// taking a TQDate, this function will look for an eventlist in the dict
-// with that date attached -
-Event::List ResourceExchange::rawEventsForDate( const TQDate &qd,
- EventSortField sortField,
- SortDirection sortDirection )
-{
- if (!mCache) return Event::List();
- // If the events for this date are not in the cache, or if they are old,
- // get them again
- TQDateTime now = TQDateTime::currentDateTime();
- // kdDebug() << "Now is " << now.toString() << endl;
- // kdDebug() << "mDates: " << mDates << endl;
- TQDate start = TQDate( qd.year(), qd.month(), 1 ); // First day of month
- if ( mDates && ( !mDates->contains( start ) ||
- (*mCacheDates)[start].secsTo( now ) > mCachedSeconds ) ) {
- TQDate end = start.addMonths( 1 ).addDays( -1 ); // Last day of month
- // Get events that occur in this period from the cache
- Event::List oldEvents = mCache->rawEvents( start, end, false );
- // And remove them all
- Event::List::ConstIterator it;
- for( it = oldEvents.begin(); it != oldEvents.end(); ++it ) {
- mCache->deleteEvent( *it );
- }
-
- // FIXME: This is needed for the hack below:
- Event::List eventsBefore = mCache->rawEvents();
-
- kdDebug() << "Reading events for month of " << TQString(start.toString()) << endl;
- mClient->downloadSynchronous( mCache, start, end, true ); // Show progress dialog
-
- // FIXME: This is a terrible hack! We need to install the observer for
- // newly downloaded events.However, downloading is done by
- // mClient->downloadSynchronous, where we don't have the pointer to this
- // available... On the other hand, here we don't really know which events
- // are really new.
- Event::List eventsAfter = mCache->rawEvents();
- for ( it = eventsAfter.begin(); it != eventsAfter.end(); ++it ) {
- if ( eventsBefore.find( *it ) == eventsBefore.end() ) {
- // it's a new event downloaded by downloadSynchronous -> install observer
- (*it)->registerObserver( this );
- }
- }
-
- mDates->add( start );
- mCacheDates->insert( start, now );
- }
-
- // Events are safely in the cache now, return them from cache
- Event::List events;
- if ( mCache )
- events = mCache->rawEventsForDate( qd, sortField, sortDirection );
- // kdDebug() << "Found " << events.count() << " events." << endl;
- return events;
-}
-
-
-Event::List ResourceExchange::rawEvents( const TQDate &start, const TQDate &end,
- bool inclusive )
-{
- kdDebug() << "ResourceExchange::rawEvents(start,end,inclusive)" << endl;
- if (!mCache) return Event::List();
- return mCache->rawEvents( start, end, inclusive );
-}
-
-Event::List ResourceExchange::rawEventsForDate(const TQDateTime &qdt)
-{
- kdDebug() << "ResourceExchange::rawEventsForDate(qdt)" << endl;
- return rawEventsForDate( qdt.date() );
-}
-
-Event::List ResourceExchange::rawEvents( EventSortField sortField, SortDirection sortDirection )
-{
- kdDebug() << "ResourceExchange::rawEvents()" << endl;
- if (!mCache) return Event::List();
- return mCache->rawEvents( sortField, sortDirection );
-}
-
-bool ResourceExchange::addJournal( Journal *journal )
-{
- return addJournal( journal, TQString() );
-}
-
-bool ResourceExchange::addJournal( Journal */*journal*/, const TQString &subresource )
-{
- Q_UNUSED( subresource ); //subresources are not supported
-
- // This resource doesn't handle journals yet
- return false;
-/* kdDebug(5800) << "Adding Journal on " << journal->dtStart().toString() << endl;
- if (mCache) {
- mCache->addJournal( journal );
-
- journal->registerObserver( this );
-
-// setModified( true );
- }
-
- return true;*/
-}
-
-bool ResourceExchange::deleteJournal(Journal */*journal*/)
-{
- // Wedon't handle journals yet
-// if( !mCache )
- return false;
-// mCache->deleteJournal( journal );
-
-// setModified( true );
-}
-
-Journal::List ResourceExchange::journals(const TQDate &/*date*/)
-{
- // We don't handle journals yet
- return Journal::List();
-/* Journal::List list;
- if ( mCache )
- list = mCache->journals( date );
- return list;*/
-}
-
-Journal *ResourceExchange::journal(const TQString &/*uid*/)
-{
- // We don't handle journals yet
- return 0;
-/* if( !mCache )
- return 0;
- return mCache->journal( uid );*/
-}
-
-Journal::List ResourceExchange::rawJournals( JournalSortField /*sortField*/, SortDirection /*sortDirection*/ )
-{
- // We don't handle journals yet
- return Journal::List();
-/* Journal::List list;
- if ( mCache )
- list = mCache->rawJournals( sortField, sortDirection );
- return list;*/
-}
-
-Journal::List ResourceExchange::rawJournalsForDate( const TQDate &/*date*/ )
-{
- // We don't handle journals yet
- return Journal::List();
-/* Journal::List list;
- if ( mCache )
- list = mCache->rawJournalsForDate( date );
- return list;*/
-}
-
-void ResourceExchange::setTimeZoneId( const TQString &tzid )
-{
- mTimeZoneId = tzid;
- if ( mCache ) mCache->setTimeZoneId( tzid );
- if ( mClient ) mClient->setTimeZoneId( tzid );
-}
-
-#include "resourceexchange.moc"