You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
291 lines
7.1 KiB
291 lines
7.1 KiB
/*=========================================================================
|
|
| KCalDAV
|
|
|--------------------------------------------------------------------------
|
|
| (c) 2010 Timothy Pearson
|
|
| (c) 2009 Kumaran Santhanam (initial KDE4 version)
|
|
|
|
|
| This project is released under the GNU General Public License.
|
|
| Please see the file COPYING for more details.
|
|
|--------------------------------------------------------------------------
|
|
| Job class for accessing remote calendars.
|
|
========================================================================*/
|
|
|
|
/*=========================================================================
|
|
| INCLUDES
|
|
========================================================================*/
|
|
|
|
#ifndef KCALDAV_JOB_H
|
|
#define KCALDAV_JOB_H
|
|
|
|
#include <tqthread.h>
|
|
#include <tqstring.h>
|
|
#include <tqdatetime.h>
|
|
#include <tqapplication.h>
|
|
|
|
extern "C" {
|
|
#include <caldav.h>
|
|
}
|
|
|
|
namespace KCal {
|
|
|
|
/*=========================================================================
|
|
| CLASS
|
|
========================================================================*/
|
|
|
|
/**
|
|
* Calendar job.
|
|
*/
|
|
class CalDavJob : public TQThread {
|
|
|
|
public:
|
|
|
|
/**
|
|
* @param url URL to load.
|
|
*/
|
|
CalDavJob(const TQString& url = TQString());
|
|
|
|
virtual ~CalDavJob();
|
|
|
|
/**
|
|
* Sets a new URL to load.
|
|
*/
|
|
virtual void setUrl(const TQString& s) {
|
|
mUrl = s;
|
|
}
|
|
|
|
/**
|
|
* Sets a new Tasks URL to load.
|
|
*/
|
|
virtual void setTasksUrl(const TQString& s) {
|
|
mTasksUrl = s;
|
|
}
|
|
|
|
/**
|
|
* Sets a new Journals URL to load.
|
|
*/
|
|
virtual void setJournalsUrl(const TQString& s) {
|
|
mJournalsUrl = s;
|
|
}
|
|
|
|
/**
|
|
* Sets the parent qobject.
|
|
*/
|
|
virtual void setParent(TQObject *s) {
|
|
mParent = s;
|
|
}
|
|
|
|
/**
|
|
* Sets the type (0==read, 1==write)
|
|
*/
|
|
virtual void setType(int s) {
|
|
mType = s;
|
|
}
|
|
|
|
/**
|
|
* @return URL to load.
|
|
*/
|
|
virtual TQString url() const {
|
|
return mUrl;
|
|
}
|
|
|
|
/**
|
|
* @return Tasks URL to load.
|
|
*/
|
|
virtual TQString tasksUrl() const {
|
|
return mTasksUrl;
|
|
}
|
|
|
|
/**
|
|
* @return Journals URL to load.
|
|
*/
|
|
virtual TQString journalsUrl() const {
|
|
return mJournalsUrl;
|
|
}
|
|
|
|
/**
|
|
* @return parent object
|
|
*/
|
|
virtual TQObject *parent() {
|
|
return mParent;
|
|
}
|
|
|
|
/**
|
|
* @return type
|
|
*/
|
|
virtual int type() {
|
|
return mType;
|
|
}
|
|
|
|
/**
|
|
* @return true if events downloading process failed.
|
|
*/
|
|
virtual bool error() const {
|
|
return mError;
|
|
}
|
|
|
|
/**
|
|
* @return true if tasks downloading process failed.
|
|
*/
|
|
virtual bool tasksError() const {
|
|
return mTasksError;
|
|
}
|
|
|
|
/**
|
|
* @return true if journals downloading process failed.
|
|
*/
|
|
virtual bool journalsError() const {
|
|
return mJournalsError;
|
|
}
|
|
|
|
/**
|
|
* @return an event error string.
|
|
*/
|
|
virtual TQString errorString() const {
|
|
return mErrorString;
|
|
}
|
|
|
|
/**
|
|
* @return a task error string.
|
|
*/
|
|
virtual TQString tasksErrorString() const {
|
|
return mTasksErrorString;
|
|
}
|
|
|
|
/**
|
|
* @return a journal error string.
|
|
*/
|
|
virtual TQString journalsErrorString() const {
|
|
return mJournalsErrorString;
|
|
}
|
|
|
|
/**
|
|
* @return an event error number.
|
|
*/
|
|
virtual long errorNumber() const {
|
|
return mErrorNumber;
|
|
}
|
|
|
|
/**
|
|
* @return a task error number.
|
|
*/
|
|
virtual long tasksErrorNumber() const {
|
|
return mTasksErrorNumber;
|
|
}
|
|
|
|
/**
|
|
* @return a journal error number.
|
|
*/
|
|
virtual long journalsErrorNumber() const {
|
|
return mJournalsErrorNumber;
|
|
}
|
|
|
|
protected:
|
|
|
|
virtual void run();
|
|
|
|
/**
|
|
* Main run method for event jobs. Jobs should not override run() method.
|
|
* Instead of this they should override this one.
|
|
* @param caldavRuntime specific libcaldav runtime information. This pointer should not be saved for the usage
|
|
* outside of runJob.
|
|
* @return libcaldav response code (see CALDAV_RESPONSE)
|
|
*/
|
|
virtual int runJob(runtime_info* caldavRuntime) = 0;
|
|
|
|
/**
|
|
* Main run method for task jobs. Jobs should not override run() method.
|
|
* Instead of this they should override this one.
|
|
* @param caldavRuntime specific libcaldav runtime information. This pointer should not be saved for the usage
|
|
* outside of runJob.
|
|
* @return libcaldav response code (see CALDAV_RESPONSE)
|
|
*/
|
|
virtual int runTasksJob(runtime_info* caldavRuntime) = 0;
|
|
|
|
/**
|
|
* Main run method for journal jobs. Jobs should not override run() method.
|
|
* Instead of this they should override this one.
|
|
* @param caldavRuntime specific libcaldav runtime information. This pointer should not be saved for the usage
|
|
* outside of runJob.
|
|
* @return libcaldav response code (see CALDAV_RESPONSE)
|
|
*/
|
|
virtual int runJournalsJob(runtime_info* caldavRuntime) = 0;
|
|
|
|
/**
|
|
* Some cleaning. Jobs may (and usually should) override this method.
|
|
*/
|
|
virtual void cleanJob() {
|
|
mError = false;
|
|
mErrorString = "";
|
|
mErrorNumber = 0;
|
|
mTasksError = false;
|
|
mTasksErrorString = "";
|
|
mTasksErrorNumber = 0;
|
|
mJournalsError = false;
|
|
mJournalsErrorString = "";
|
|
mJournalsErrorNumber = 0;
|
|
}
|
|
|
|
/**
|
|
* Sets an event error string to @p err. Also sets an error flag.
|
|
*/
|
|
void setErrorString(const TQString& str, const long number);
|
|
|
|
/**
|
|
* Sets a task error string to @p err. Also sets an error flag.
|
|
*/
|
|
void setTasksErrorString(const TQString& str, const long number);
|
|
|
|
/**
|
|
* Sets a journal error string to @p err. Also sets an error flag.
|
|
*/
|
|
void setJournalsErrorString(const TQString& str, const long number);
|
|
|
|
/**
|
|
* Process an event error.
|
|
* Subclasses can overwrite this method, if some special error message handling
|
|
* should be done. Call setErrorString() to set the error after processing is done.
|
|
* @param err error structure.
|
|
*/
|
|
virtual void processError(const caldav_error* err);
|
|
|
|
/**
|
|
* Process a task error.
|
|
* Subclasses can overwrite this method, if some special error message handling
|
|
* should be done. Call setErrorString() to set the error after processing is done.
|
|
* @param err error structure.
|
|
*/
|
|
virtual void processTasksError(const caldav_error* err);
|
|
|
|
/**
|
|
* Process a journal error.
|
|
* Subclasses can overwrite this method, if some special error message handling
|
|
* should be done. Call setErrorString() to set the error after processing is done.
|
|
* @param err error structure.
|
|
*/
|
|
virtual void processJournalsError(const caldav_error* err);
|
|
|
|
private:
|
|
|
|
TQString mUrl;
|
|
TQString mTasksUrl;
|
|
TQString mJournalsUrl;
|
|
bool mError;
|
|
bool mTasksError;
|
|
bool mJournalsError;
|
|
TQString mErrorString;
|
|
TQString mTasksErrorString;
|
|
TQString mJournalsErrorString;
|
|
long mErrorNumber;
|
|
long mTasksErrorNumber;
|
|
long mJournalsErrorNumber;
|
|
TQObject *mParent;
|
|
int mType;
|
|
|
|
void enableCaldavDebug(runtime_info*);
|
|
};
|
|
|
|
} // namespace KCal
|
|
|
|
#endif // KCALDAV_JOB_H
|
|
|