]> arthur.barton.de Git - ngircd-alex.git/blobdiff - src/ngircd/client.c
- IRC-Befehl KILL sowie Kills bei Nick Collsisions implementiert.
[ngircd-alex.git] / src / ngircd / client.c
index 7866742c79d8e97de9dcbad6ff216c541c638ad4..871aa1d49d98ff0426c24fb33c3323364f1115bd 100644 (file)
@@ -9,7 +9,7 @@
  * Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
  * der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
  *
- * $Id: client.c,v 1.35 2002/01/29 00:14:49 alex Exp $
+ * $Id: client.c,v 1.37 2002/02/17 19:02:49 alex Exp $
  *
  * client.c: Management aller Clients
  *
  * Server gewesen, so existiert eine entsprechende CONNECTION-Struktur.
  *
  * $Log: client.c,v $
+ * Revision 1.37  2002/02/17 19:02:49  alex
+ * - Client_CheckNick() und Client_CheckID() lieferten u.U. falsche Ergebnisse.
+ *
+ * Revision 1.36  2002/02/06 16:49:41  alex
+ * - neue Funktion Client_IsValidNick(), Nicknames werden besser validiert.
+ *
  * Revision 1.35  2002/01/29 00:14:49  alex
  * - neue Funktion Client_TopServer(), Client_NewXXX() angepasst.
  *
@@ -715,8 +721,12 @@ GLOBAL BOOLEAN Client_CheckNick( CLIENT *Client, CHAR *Nick )
        assert( Client != NULL );
        assert( Nick != NULL );
        
-       /* Nick zu lang? */
-       if( strlen( Nick ) > CLIENT_NICK_LEN ) return IRC_WriteStrClient( Client, ERR_ERRONEUSNICKNAME_MSG, Client_ID( Client ), Nick );
+       /* Nick ungueltig? */
+       if( ! Client_IsValidNick( Nick ))
+       {
+               IRC_WriteStrClient( Client, ERR_ERRONEUSNICKNAME_MSG, Client_ID( Client ), Nick );
+               return FALSE;
+       }
 
        /* Nick bereits vergeben? */
        c = My_Clients;
@@ -747,7 +757,11 @@ GLOBAL BOOLEAN Client_CheckID( CLIENT *Client, CHAR *ID )
        assert( ID != NULL );
 
        /* Nick zu lang? */
-       if( strlen( ID ) > CLIENT_ID_LEN ) return IRC_WriteStrClient( Client, ERR_ERRONEUSNICKNAME_MSG, Client_ID( Client ), ID );
+       if( strlen( ID ) > CLIENT_ID_LEN )
+       {
+               IRC_WriteStrClient( Client, ERR_ERRONEUSNICKNAME_MSG, Client_ID( Client ), ID );
+               return FALSE;
+       }
 
        /* ID bereits vergeben? */
        c = My_Clients;
@@ -873,6 +887,18 @@ GLOBAL INT Client_UnknownCount( VOID )
 } /* Client_UnknownCount */
 
 
+GLOBAL BOOLEAN Client_IsValidNick( CHAR *Nick )
+{
+       /* Ist der Nick gueltig? */
+       
+       assert( Nick != NULL );
+
+       if( Nick[0] == '#' ) return FALSE;
+       if( strlen( Nick ) > CLIENT_NICK_LEN ) return FALSE;
+       return TRUE;
+} /* Client_IsValidNick */
+
+
 LOCAL INT Count( CLIENT_TYPE Type )
 {
        CLIENT *c;