]> arthur.barton.de Git - ngircd-alex.git/blobdiff - src/ngircd/conn.h
Implement IRC commands SERVICE, SERVLIST, and SQUERY as dummy functions
[ngircd-alex.git] / src / ngircd / conn.h
index e1f34f9fafd371933858241a50fdcd3a7678b499..3bb76ab39d13379f24ee469a2a97a91deb500ca7 100644 (file)
@@ -8,7 +8,7 @@
  * (at your option) any later version.
  * Please read the file COPYING, README and AUTHORS for more information.
  *
- * $Id: conn.h,v 1.35 2005/06/12 16:28:55 alex Exp $
+ * $Id: conn.h,v 1.46 2008/02/26 22:04:17 fw Exp $
  *
  * Connection management (header)
  */
 #include <time.h>                      /* for time_t, see below */
 
 
-#define CONN_ISCLOSING         1U      /* Conn_Close() already called */
-#define CONN_ISCONNECTING      2U      /* connect() in progress */
+#define CONN_ISCLOSING         1       /* Conn_Close() already called */
+#define CONN_ISCONNECTING      2       /* connect() in progress */
 
 #ifdef ZLIB
-#define CONN_ZIP               4U      /* zlib compressed link */
+#define CONN_ZIP               4       /* zlib compressed link */
 #endif
 
 
 typedef int CONN_ID;
 
+#include "client.h"
 
 #ifdef CONN_MODULE
 
 #include "defines.h"
 #include "resolve.h"
+#include "array.h"
+#include "tool.h"
+#include "ng_ipaddr.h"
 
 #ifdef ZLIB
 #include <zlib.h>
@@ -43,10 +47,8 @@ typedef struct _ZipData
 {
        z_stream in;                    /* "Handle" for input stream */
        z_stream out;                   /* "Handle" for output stream */
-       char rbuf[READBUFFER_LEN];      /* Read buffer */
-       int rdatalen;                   /* Length of data in read buffer (compressed) */
-       char wbuf[WRITEBUFFER_LEN];     /* Write buffer */
-       int wdatalen;                   /* Length of data in write buffer (uncompressed) */
+       array rbuf;                     /* Read buffer (compressed) */
+       array wbuf;                     /* Write buffer (uncompressed) */
        long bytes_in, bytes_out;       /* Counter for statistics (uncompressed!) */
 } ZIPDATA;
 #endif /* ZLIB */
@@ -54,13 +56,12 @@ typedef struct _ZipData
 typedef struct _Connection
 {
        int sock;                       /* Socket handle */
-       struct sockaddr_in addr;        /* Client address */
-       RES_STAT *res_stat;             /* Status of resolver process, if any */
+       ng_ipaddr_t addr;               /* Client address */
+       RES_STAT res_stat;              /* Status of resolver process */
        char host[HOST_LEN];            /* Hostname */
-       char rbuf[READBUFFER_LEN];      /* Read buffer */
-       int rdatalen;                   /* Length of data in read buffer */
-       char wbuf[WRITEBUFFER_LEN];     /* Write buffer */
-       int wdatalen;                   /* Length of data in write buffer */
+       array rbuf;                     /* Read buffer */
+       array wbuf;                     /* Write buffer */
+       time_t signon;                  /* Signon ("connect") time */
        time_t lastdata;                /* Last activity */
        time_t lastping;                /* Last PING */
        time_t lastprivmsg;             /* Last PRIVMSG */
@@ -69,6 +70,7 @@ typedef struct _Connection
        long msg_in, msg_out;           /* Received and sent IRC messages */
        int flag;                       /* Flag (see "irc-write" module) */
        UINT16 options;                 /* Link options / connection state */
+       CLIENT *client;                 /* pointer to client structure */
 #ifdef ZLIB
        ZIPDATA zip;                    /* Compression information */
 #endif  /* ZLIB */
@@ -84,24 +86,18 @@ GLOBAL long WCounter;
 GLOBAL void Conn_Init PARAMS((void ));
 GLOBAL void Conn_Exit PARAMS(( void ));
 
-GLOBAL int Conn_InitListeners PARAMS(( void ));
+GLOBAL unsigned int Conn_InitListeners PARAMS(( void ));
 GLOBAL void Conn_ExitListeners PARAMS(( void ));
 
-GLOBAL bool Conn_NewListener PARAMS(( const UINT16 Port ));
-
 GLOBAL void Conn_Handler PARAMS(( void ));
 
-GLOBAL bool Conn_Write PARAMS(( CONN_ID Idx, char *Data, int Len ));
 GLOBAL bool Conn_WriteStr PARAMS(( CONN_ID Idx, char *Format, ... ));
 
 GLOBAL void Conn_Close PARAMS(( CONN_ID Idx, char *LogMsg, char *FwdMsg, bool InformClient ));
 
 GLOBAL void Conn_SyncServerStruct PARAMS(( void ));
 
-GLOBAL int Conn_MaxFD;
-
-
+GLOBAL CLIENT* Conn_GetClient PARAMS((CONN_ID i));
 #endif
 
-
 /* -eof- */