]> arthur.barton.de Git - ngircd-alex.git/blobdiff - src/ngircd/client.h
add support for the poll() interface
[ngircd-alex.git] / src / ngircd / client.h
index 370c5157e8a4313b1928e4ce950b922ab227b3c8..73de52b5cd7e49dd89b6b0725d2600368b4c79a3 100644 (file)
@@ -8,7 +8,7 @@
  * (at your option) any later version.
  * Please read the file COPYING, README and AUTHORS for more information.
  *
- * $Id: client.h,v 1.35 2005/03/19 18:43:48 fw Exp $
+ * $Id: client.h,v 1.42 2006/04/23 10:37:27 fw Exp $
  *
  * Client management (header)
  */
 
 #define CLIENT_TYPE int
 
+#include "defines.h"
 
 #if defined(__client_c__) | defined(S_SPLINT_S)
 
-#include "defines.h"
-
 typedef struct _CLIENT
 {
+       time_t starttime;               /* Start time of link */
        char id[CLIENT_ID_LEN];         /* nick (user) / ID (server) */
        UINT32 hash;                    /* hash of lower-case ID */
        POINTER *next;                  /* pointer to next client structure */
@@ -62,13 +62,23 @@ typedef POINTER CLIENT;
 #endif
 
 
+typedef struct _WHOWAS
+{
+       time_t time;                    /* time stamp of entry or 0 if unused */
+       char id[CLIENT_NICK_LEN];       /* client nick name */
+       char host[CLIENT_HOST_LEN];     /* hostname of the client */
+       char user[CLIENT_USER_LEN];     /* user name ("login") */
+       char info[CLIENT_INFO_LEN];     /* long user name */
+       char server[CLIENT_HOST_LEN];   /* server name */
+} WHOWAS;
+
+
 GLOBAL void Client_Init PARAMS(( void ));
 GLOBAL void Client_Exit PARAMS(( void ));
 
 GLOBAL CLIENT *Client_NewLocal PARAMS(( CONN_ID Idx, char *Hostname, int Type, bool Idented ));
 GLOBAL CLIENT *Client_NewRemoteServer PARAMS(( CLIENT *Introducer, char *Hostname, CLIENT *TopServer, int Hops, int Token, char *Info, bool Idented ));
 GLOBAL CLIENT *Client_NewRemoteUser PARAMS(( CLIENT *Introducer, char *Nick, int Hops, char *User, char *Hostname, int Token, char *Modes, char *Info, bool Idented ));
-GLOBAL CLIENT *Client_New PARAMS(( CONN_ID Idx, CLIENT *Introducer, CLIENT *TopServer, int Type, char *ID, char *User, char *Hostname, char *Info, int Hops, int Token, char *Modes, bool Idented ));
 
 GLOBAL void Client_Destroy PARAMS(( CLIENT *Client, char *LogMsg, char *FwdMsg, bool SendQuit ));
 #ifdef CONN_MODULE
@@ -77,7 +87,6 @@ GLOBAL void Client_DestroyNow PARAMS(( CLIENT *Client ));
 
 GLOBAL CLIENT *Client_ThisServer PARAMS(( void ));
 
-GLOBAL CLIENT *Client_GetFromConn PARAMS(( CONN_ID Idx ));
 GLOBAL CLIENT *Client_GetFromToken PARAMS(( CLIENT *Client, int Token ));
 
 GLOBAL CLIENT *Client_Search PARAMS(( char *ID ));
@@ -102,6 +111,7 @@ GLOBAL int Client_MyToken PARAMS(( CLIENT *Client ));
 GLOBAL CLIENT *Client_TopServer PARAMS(( CLIENT *Client ));
 GLOBAL CLIENT *Client_NextHop PARAMS(( CLIENT *Client ));
 GLOBAL char *Client_Away PARAMS(( CLIENT *Client ));
+GLOBAL time_t Client_StartTime PARAMS(( CLIENT *Client ));
 
 GLOBAL bool Client_HasMode PARAMS(( CLIENT *Client, char Mode ));
 
@@ -138,6 +148,11 @@ GLOBAL long Client_MyMaxUserCount PARAMS((  void ));
 
 GLOBAL bool Client_IsValidNick PARAMS(( char *Nick ));
 
+GLOBAL WHOWAS *Client_GetWhowas PARAMS(( void ));
+GLOBAL int Client_GetLastWhowasIndex PARAMS(( void ));
+
+GLOBAL void Client_RegisterWhowas PARAMS(( CLIENT *Client ));
+
 
 #endif