summaryrefslogtreecommitdiffstats
path: root/kpf/src/Server.h
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
commitbcb704366cb5e333a626c18c308c7e0448a8e69f (patch)
treef0d6ab7d78ecdd9207cf46536376b44b91a1ca71 /kpf/src/Server.h
downloadtdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.tar.gz
tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.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/kdenetwork@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kpf/src/Server.h')
-rw-r--r--kpf/src/Server.h186
1 files changed, 186 insertions, 0 deletions
diff --git a/kpf/src/Server.h b/kpf/src/Server.h
new file mode 100644
index 00000000..8d26a167
--- /dev/null
+++ b/kpf/src/Server.h
@@ -0,0 +1,186 @@
+/*
+ KPF - Public fileserver for KDE
+
+ Copyright 2001 Rik Hemsley (rikkus) <[email protected]>
+
+ Permission is hereby granted, free of charge, to any person obtaining a copy
+ of this software and associated documentation files (the "Software"), to
+ deal in the Software without restriction, including without limitation the
+ rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
+ sell copies of the Software, and to permit persons to whom the Software is
+ furnished to do so, subject to the following conditions:
+
+ The above copyright notice and this permission notice shall be included in
+ all copies or substantial portions of the Software.
+
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
+ ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+*/
+
+#ifndef KPF_SERVER_H
+#define KPF_SERVER_H
+
+#include <qdatetime.h>
+#include <qstring.h>
+#include <qhostaddress.h>
+
+#include "Request.h"
+#include "Response.h"
+
+namespace KPF
+{
+ class WebServer;
+
+ /**
+ * Converses with a remote client. Handles requests and generates responses.
+ * Bandwidth is controlled by parent (WebServer).
+ */
+ class Server : public QObject
+ {
+ Q_OBJECT
+
+ public:
+
+ /**
+ * A Server can be in one of four states, enumerated here.
+ */
+ enum State { WaitingForRequest, WaitingForHeaders, Responding, Finished };
+
+ /**
+ * @param dir Root directory. Files not contained in this directory
+ * and subdirectories thereof will not be server.
+ *
+ * @param followSymlinks If false, an expensive algorithm will ensure
+ * that no symbolic links are present anywhere in the path from /
+ * to the requested resource.
+ *
+ * @param socket The system's socket device, used for communication.
+ *
+ * @param parent A WebServer, which will manage this Server.
+ */
+ Server
+ (
+ const QString & dir,
+ bool followSymlinks,
+ int socket,
+ WebServer * parent
+ );
+
+ /**
+ * Free internal data and close connection if still open.
+ */
+ virtual ~Server();
+
+ /**
+ * @return address of client that has connected to us.
+ */
+ QHostAddress peerAddress() const;
+
+ /**
+ * @return Request object associated with this connection.
+ * When persistent connections are used, the object may
+ * differ depending on the current state.
+ */
+ Request request() const;
+
+ /**
+ * @return Response object associated with this connection.
+ * When persistent connections are used, the object may
+ * differ depending on the current state.
+ */
+ Response response() const;
+
+ /**
+ * @return number of bytes sent out over the socket since this object
+ * was created.
+ */
+ ulong output() const;
+
+ /**
+ * @return current state.
+ * @see State.
+ */
+ State state() const;
+
+ /**
+ * @return date and time this object was created.
+ */
+ QDateTime birth() const;
+
+ /**
+ * @return date and time all activity was completed.
+ */
+ QDateTime death() const;
+
+ /**
+ * @return number of bytes remaining to send to client.
+ */
+ ulong bytesLeft() const;
+
+ /**
+ * Send no more than maxBytes to the client.
+ *
+ * @return number of bytes sent.
+ */
+ ulong write(ulong maxBytes);
+
+ /**
+ * Stop negotiating with client and sending data. Emit @ref finished.
+ * Do not flush output.
+ */
+ void cancel();
+
+ protected slots:
+
+ void slotReadyRead ();
+ void slotRead ();
+ void slotBytesWritten (int);
+ void slotConnectionClosed ();
+ void slotTimeout ();
+
+ signals:
+
+ void readyToWrite (Server *);
+ void output (Server *, ulong);
+ void finished (Server *);
+ void response (Server *);
+ void request (Server *);
+
+ private:
+
+ // Disable copying.
+
+ Server(const Server &);
+ Server & operator = (const Server &);
+
+ enum FlushSelect
+ {
+ Flush,
+ NoFlush
+ };
+
+ void setFinished (FlushSelect);
+ void writeLine (const QString &);
+ void prepareResponse ();
+ void respond (uint code, ulong size = 0);
+ bool readRequest (const QString &);
+ bool checkRequest ();
+ void handleRequest ();
+ void readHeaders ();
+ bool handleRange (const ByteRange &);
+ bool writeHeaderData (ulong, ulong &);
+ bool writeFileData (ulong, ulong &);
+ void reset ();
+
+ class Private;
+ Private * d;
+ };
+
+} // End namespace KPF
+
+#endif // KPF_SERVER_H
+// vim:ts=2:sw=2:tw=78:et