summaryrefslogtreecommitdiff
path: root/include/users.h
diff options
context:
space:
mode:
authorw00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7>2008-09-07 22:23:03 +0000
committerw00t <w00t@e03df62e-2008-0410-955e-edbf42e46eb7>2008-09-07 22:23:03 +0000
commit631029ff1f75b3b9bef2d769259334355fbd8266 (patch)
tree205e45bef7285efb0f50a653da2e63ca2ee06dd8 /include/users.h
parent78c14ffcc5429f4855e2f3a6c822a1d37f9f591a (diff)
Merge class connection in with class user (nothing else inherits it anyway, and all the fields in here were only really useful to users anyway)
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@10460 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'include/users.h')
-rw-r--r--include/users.h52
1 files changed, 50 insertions, 2 deletions
diff --git a/include/users.h b/include/users.h
index 508681ddd..c4c85fb0f 100644
--- a/include/users.h
+++ b/include/users.h
@@ -15,7 +15,6 @@
#define __USERS_H__
#include "socket.h"
-#include "connection.h"
#include "dns.h"
#include "mode.h"
@@ -413,7 +412,7 @@ class CoreExport VisData
* by nickname, or the FindDescriptor method of the InspIRCd class to find a specific user by their
* file descriptor value.
*/
-class CoreExport User : public connection
+class CoreExport User : public EventHandler
{
private:
/** Pointer to creator.
@@ -472,6 +471,55 @@ class CoreExport User : public connection
*/
VisData* Visibility;
+ /** Hostname of connection.
+ * This should be valid as per RFC1035.
+ */
+ std::string host;
+
+ /** Stats counter for bytes inbound
+ */
+ int bytes_in;
+
+ /** Stats counter for bytes outbound
+ */
+ int bytes_out;
+
+ /** Stats counter for commands inbound
+ */
+ int cmds_in;
+
+ /** Stats counter for commands outbound
+ */
+ int cmds_out;
+
+ /** True if user has authenticated, false if otherwise
+ */
+ bool haspassed;
+
+ /** Used by User to indicate the registration status of the connection
+ * It is a bitfield of the REG_NICK, REG_USER and REG_ALL bits to indicate
+ * the connection state.
+ */
+ char registered;
+
+ /** Time the connection was last pinged
+ */
+ time_t lastping;
+
+ /** Time the connection was created, set in the constructor. This
+ * may be different from the time the user's classbase object was
+ * created.
+ */
+ time_t signon;
+
+ /** Time that the connection last sent a message, used to calculate idle time
+ */
+ time_t idle_lastmsg;
+
+ /** Used by PING checking code
+ */
+ time_t nping;
+
/** Stored reverse lookup from res_forward
*/
std::string stored_host;