commit - 0370c4843f3a837460b1c2f2db520f9f57b5ce3e
commit + 7157d9365157d969c1f7db14e6bc67825d9fc14d
blob - 23d807d92da62f508d42ae4aa78f711da208540b
blob + 5b125b0e75b5a3da8fd11dc177198f8c778bd203
--- src/ngircd/channel.c
+++ src/ngircd/channel.c
* Naehere Informationen entnehmen Sie bitter der Datei COPYING. Eine Liste
* der an ngIRCd beteiligten Autoren finden Sie in der Datei AUTHORS.
*
- * $Id: channel.c,v 1.16 2002/02/27 23:23:53 alex Exp $
+ * $Id: channel.c,v 1.17 2002/03/02 01:35:50 alex Exp $
*
* channel.c: Management der Channels
*
* $Log: channel.c,v $
+ * Revision 1.17 2002/03/02 01:35:50 alex
+ * - Channel- und Nicknames werden nun ordentlich validiert.
+ *
* Revision 1.16 2002/02/27 23:23:53 alex
* - Includes fuer einige Header bereinigt.
*
GLOBAL BOOLEAN Channel_IsValidName( CHAR *Name )
{
/* PrŸfen, ob Name als Channelname gueltig */
+
+ CHAR *ptr, badchars[] = " ,:\x07";
assert( Name != NULL );
if(( Name[0] != '#' ) || ( strlen( Name ) >= CHANNEL_NAME_LEN )) return FALSE;
+
+ ptr = Name;
+ while( *ptr )
+ {
+ if( strchr( badchars, *ptr )) return FALSE;
+ ptr++;
+ }
+
return TRUE;
} /* Channel_IsValidName */
blob - cdb4f185a9744458a7c428bcdb4a66d2f706e49d
blob + 6b574763744a321b3ad55941af45e807efd323c5
--- src/ngircd/client.c
+++ src/ngircd/client.c
* 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.40 2002/02/27 23:23:53 alex Exp $
+ * $Id: client.c,v 1.41 2002/03/02 01:35:50 alex Exp $
*
* client.c: Management aller Clients
*
* Server gewesen, so existiert eine entsprechende CONNECTION-Struktur.
*
* $Log: client.c,v $
+ * Revision 1.41 2002/03/02 01:35:50 alex
+ * - Channel- und Nicknames werden nun ordentlich validiert.
+ *
* Revision 1.40 2002/02/27 23:23:53 alex
* - Includes fuer einige Header bereinigt.
*
GLOBAL BOOLEAN Client_IsValidNick( CHAR *Nick )
{
/* Ist der Nick gueltig? */
+
+ CHAR *ptr, goodchars[] = ";0123456789";
assert( Nick != NULL );
if( Nick[0] == '#' ) return FALSE;
- if( strlen( Nick ) > CLIENT_NICK_LEN ) return FALSE;
+ if( strchr( goodchars, Nick[0] )) return FALSE;
+ if( strlen( Nick ) >= CLIENT_NICK_LEN ) return FALSE;
+
+ ptr = Nick;
+ while( *ptr )
+ {
+ if(( *ptr < 'A' ) && ( ! strchr( goodchars, *ptr ))) return FALSE;
+ if(( *ptr > '}' ) && ( ! strchr( goodchars, *ptr ))) return FALSE;
+ ptr++;
+ }
+
return TRUE;
} /* Client_IsValidNick */