]> arthur.barton.de Git - ngircd-alex.git/blobdiff - src/ngircd/client.c
- neue Funktion Client_GetID(), liefert die "Client ID".
[ngircd-alex.git] / src / ngircd / client.c
index 950e977c57e2085e6af7d60fee1ac7743cde2ca5..8767c55f43f8811a0c2644dee7529e3b172e1826 100644 (file)
@@ -9,7 +9,7 @@
  * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
  * der an comBase beteiligten Autoren finden Sie in der Datei AUTHORS.
  *
- * $Id: client.c,v 1.2 2001/12/23 22:04:37 alex Exp $
+ * $Id: client.c,v 1.8 2001/12/27 16:54:51 alex Exp $
  *
  * client.c: Management aller Clients
  *
  * Server gewesen, so existiert eine entsprechende CONNECTION-Struktur.
  *
  * $Log: client.c,v $
+ * Revision 1.8  2001/12/27 16:54:51  alex
+ * - neue Funktion Client_GetID(), liefert die "Client ID".
+ *
+ * Revision 1.7  2001/12/26 14:45:37  alex
+ * - "Code Cleanups".
+ *
+ * Revision 1.6  2001/12/26 03:19:16  alex
+ * - neue Funktion Client_Name().
+ *
+ * Revision 1.5  2001/12/25 22:04:26  alex
+ * - Aenderungen an den Debug- und Logging-Funktionen.
+ *
+ * Revision 1.4  2001/12/25 19:21:26  alex
+ * - Client-Typ ("Status") besser unterteilt, My_Clients ist zudem nun global.
+ *
+ * Revision 1.3  2001/12/24 01:31:14  alex
+ * - einige assert()'s eingestraeut.
+ *
  * Revision 1.2  2001/12/23 22:04:37  alex
  * - einige neue Funktionen,
  * - CLIENT-Struktur erweitert.
  *
  * Revision 1.1  2001/12/14 08:13:43  alex
  * - neues Modul begonnen :-)
- *
  */
 
 
 #include <imp.h>
 #include <assert.h>
 #include <unistd.h>
+#include <stdio.h>
 #include <string.h>
 
+#include <exp.h>
+#include "client.h"
+
+#include <imp.h>
 #include "channel.h"
 #include "conn.h"
+#include "irc.h"
 #include "log.h"
+#include "messages.h"
 
 #include <exp.h>
-#include "client.h"
 
 
 LOCAL CLIENT *My_Clients;
+LOCAL CHAR GetID_Buffer[CLIENT_ID_LEN];
 
 
 LOCAL CLIENT *New_Client_Struct( VOID );
@@ -90,16 +114,19 @@ GLOBAL VOID Client_Exit( VOID )
                free( c );
                c = next;
        }
-       if( cnt ) Log( LOG_DEBUG, "Freed %d client structure%s.", cnt, cnt == 1 ? "" : "s" );
+       if( cnt ) Log( LOG_INFO, "Freed %d client structure%s.", cnt, cnt == 1 ? "" : "s" );
 } /* Client Exit */
 
 
-GLOBAL CLIENT *Client_New_Local( CONN_ID Idx, CHAR *Hostname )
+GLOBAL CLIENT *Client_NewLocal( CONN_ID Idx, CHAR *Hostname )
 {
        /* Neuen lokalen Client erzeugen. */
        
        CLIENT *client;
 
+       assert( Idx >= 0 );
+       assert( Hostname != NULL );
+       
        client = New_Client_Struct( );
        if( ! client ) return NULL;
 
@@ -114,7 +141,7 @@ GLOBAL CLIENT *Client_New_Local( CONN_ID Idx, CHAR *Hostname )
        My_Clients = client;
        
        return client;
-} /* Client_New_Local */
+} /* Client_NewLocal */
 
 
 GLOBAL VOID Client_Destroy( CLIENT *Client )
@@ -123,6 +150,8 @@ GLOBAL VOID Client_Destroy( CLIENT *Client )
        
        CLIENT *last, *c;
 
+       assert( Client != NULL );
+       
        last = NULL;
        c = My_Clients;
        while( c )
@@ -147,6 +176,8 @@ GLOBAL CLIENT *Client_GetFromConn( CONN_ID Idx )
 
        CLIENT *c;
 
+       assert( Idx >= 0 );
+       
        c = My_Clients;
        while( c )
        {
@@ -157,6 +188,58 @@ GLOBAL CLIENT *Client_GetFromConn( CONN_ID Idx )
 } /* Client_GetFromConn */
 
 
+GLOBAL CHAR *Client_Name( CLIENT *Client )
+{
+       assert( Client != NULL );
+
+       if( Client->nick[0] ) return Client->nick;
+       else return "*";
+} /* Client_Name */
+
+
+GLOBAL BOOLEAN Client_CheckNick( CLIENT *Client, CHAR *Nick )
+{
+       /* Nick ueberpruefen */
+
+       CLIENT *c;
+       
+       assert( Client != NULL );
+       assert( Nick != NULL );
+       
+       /* Nick zu lang? */
+       if( strlen( Nick ) > CLIENT_NICK_LEN ) return IRC_WriteStrClient( Client, This_Server, ERR_ERRONEUSNICKNAME_MSG, Client_Name( Client ), Nick );
+
+       /* Nick bereits vergeben? */
+       c = My_Clients;
+       while( c )
+       {
+               if( strcasecmp( c->nick, Nick ) == 0 )
+               {
+                       /* den Nick gibt es bereits */
+                       IRC_WriteStrClient( Client, This_Server, ERR_NICKNAMEINUSE_MSG, Client_Name( Client ), Nick );
+                       return FALSE;
+               }
+               c = c->next;
+       }
+
+       return TRUE;
+} /* Client_CheckNick */
+
+
+GLOBAL CHAR *Client_GetID( CLIENT *Client )
+{
+       /* Client-"ID" liefern, wie sie z.B. fuer
+        * Prefixe benoetigt wird. */
+
+       assert( Client != NULL );
+       
+       if( Client->type == CLIENT_SERVER ) return Client->host;
+
+       sprintf( GetID_Buffer, "%s!%s@%s", Client->nick, Client->user, Client->host );
+       return GetID_Buffer;
+} /* Client_GetID */
+
+
 LOCAL CLIENT *New_Client_Struct( VOID )
 {
        /* Neue CLIENT-Struktur pre-initialisieren */