summaryrefslogtreecommitdiffstats
path: root/kio/kio/davjob.h
diff options
context:
space:
mode:
Diffstat (limited to 'kio/kio/davjob.h')
-rw-r--r--kio/kio/davjob.h127
1 files changed, 127 insertions, 0 deletions
diff --git a/kio/kio/davjob.h b/kio/kio/davjob.h
new file mode 100644
index 000000000..400ca9f8e
--- /dev/null
+++ b/kio/kio/davjob.h
@@ -0,0 +1,127 @@
+// -*- c++ -*-
+/* This file is part of the KDE libraries
+ Copyright (C) 2002 Jan-Pascal van Best <janpascal@vanbest.org>
+
+ 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.
+*/
+
+#ifndef __kio_davjob_h__
+#define __kio_davjob_h__
+
+#include <kurl.h>
+
+#include <qobject.h>
+#include <qptrlist.h>
+#include <qstring.h>
+#include <qstringlist.h>
+#include <qguardedptr.h>
+#include <qdom.h>
+
+#include <sys/types.h>
+#include <sys/stat.h>
+
+#include <kio/jobclasses.h>
+#include <kio/global.h>
+
+class Observer;
+class QTimer;
+
+namespace KIO {
+
+ class Slave;
+ class SlaveInterface;
+
+ /**
+ * The transfer job pumps data into and/or out of a Slave.
+ * Data is sent to the slave on request of the slave ( dataReq).
+ * If data coming from the slave can not be handled, the
+ * reading of data from the slave should be suspended.
+ * @see KIO::davPropFind()
+ * @see KIO::davPropPatch()
+ * @see KIO::davSearch()
+ * @since 3.1
+ */
+ class KIO_EXPORT DavJob : public TransferJob {
+ Q_OBJECT
+
+ public:
+ /**
+ * Use KIO::davPropFind(), KIO::davPropPatch() and
+ * KIO::davSearch() to create a new DavJob.
+ */
+ DavJob(const KURL& url, int method,
+ const QString& request, bool showProgressInfo);
+ /**
+ * Returns the response as a QDomDocument.
+ * @return the response document
+ */
+ QDomDocument& response() { return m_response; }
+
+ protected slots:
+ virtual void slotFinished();
+ virtual void slotData( const QByteArray &data);
+
+ protected:
+ bool m_suspended;
+ TransferJob *m_subJob;
+ private:
+ class DavJobPrivate;
+ DavJobPrivate *d;
+ QString dummy; // kept around for BC reasons
+ QDomDocument m_response;
+ };
+
+ /**
+ * Creates a new DavJob that issues a PROPFIND command. PROPFIND retrieves
+ * the properties of the resource identified by the given @p url.
+ *
+ * @param url the URL of the resource
+ * @param properties a propfind document that describes the properties that
+ * should be retrieved
+ * @param depth the depth of the request. Can be "0", "1" or "infinity"
+ * @param showProgressInfo true to show progress information
+ * @return the new DavJob
+ */
+ KIO_EXPORT DavJob* davPropFind( const KURL& url, const QDomDocument& properties, QString depth, bool showProgressInfo=true );
+
+ /**
+ * Creates a new DavJob that issues a PROPPATCH command. PROPPATCH sets
+ * the properties of the resource identified by the given @p url.
+ *
+ * @param url the URL of the resource
+ * @param properties a PROPPACTCH document that describes the properties that
+ * should be modified and its new values
+ * @param showProgressInfo true to show progress information
+ * @return the new DavJob
+ */
+ KIO_EXPORT DavJob* davPropPatch( const KURL& url, const QDomDocument& properties, bool showProgressInfo=true );
+
+ /**
+ * Creates a new DavJob that issues a SEARCH command.
+ *
+ * @param url the URL of the resource
+ * @param nsURI the URI of the search method's qualified name
+ * @param qName the local part of the search method's qualified name
+ * @param query the search string
+ * @param showProgressInfo true to show progress information
+ * @return the new DavJob
+ */
+ KIO_EXPORT DavJob* davSearch( const KURL &url, const QString& nsURI, const QString& qName, const QString& query, bool showProgressInfo=true );
+
+}
+
+#endif
+