X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?p=ngircd-alex.git;a=blobdiff_plain;f=src%2Fngircd%2Flists.c;h=4f3c59e0c559ab335f2e978206808e78f21cf6c5;hp=ec0ed701b426118eba48eab04d0f4dd6dd9a20b3;hb=f86bbd718d4a439509c290b62722f4aa96c00abb;hpb=592565aef58544813d9a8acda683398e1e566195 diff --git a/src/ngircd/lists.c b/src/ngircd/lists.c index ec0ed701..4f3c59e0 100644 --- a/src/ngircd/lists.c +++ b/src/ngircd/lists.c @@ -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: lists.c,v 1.7 2002/09/08 00:55:45 alex Exp $ + * $Id: lists.c,v 1.9 2002/10/03 21:49:59 alex Exp $ * * lists.c: Verwaltung der "IRC-Listen": Ban, Invite, ... */ @@ -54,6 +54,7 @@ LOCAL C2C *My_Invites, *My_Bans; LOCAL C2C *New_C2C PARAMS(( CHAR *Mask, CHANNEL *Chan, BOOLEAN OnlyOnce )); LOCAL BOOLEAN Check_List PARAMS(( C2C **Cl2Chan, CLIENT *Client, CHANNEL *Chan )); +LOCAL BOOLEAN Already_Registered PARAMS(( C2C *Cl2Chan, CHAR *Mask, CHANNEL *Chan )); @@ -101,13 +102,20 @@ Lists_CheckInvited( CLIENT *Client, CHANNEL *Chan ) GLOBAL BOOLEAN -Lists_AddInvited( CHAR *Mask, CHANNEL *Chan, BOOLEAN OnlyOnce ) +Lists_AddInvited( CLIENT *From, CHAR *Mask, CHANNEL *Chan, BOOLEAN OnlyOnce ) { C2C *c2c; assert( Mask != NULL ); assert( Chan != NULL ); + if( Already_Registered( My_Invites, Mask, Chan )) + { + /* Eintrag ist bereits vorhanden */ + IRC_WriteStrClient( From, RPL_INVITELIST_MSG, Client_ID( From ), Channel_Name( Chan ), Mask ); + return FALSE; + } + c2c = New_C2C( Mask, Chan, OnlyOnce ); if( ! c2c ) { @@ -181,13 +189,20 @@ Lists_CheckBanned( CLIENT *Client, CHANNEL *Chan ) GLOBAL BOOLEAN -Lists_AddBanned( CHAR *Mask, CHANNEL *Chan ) +Lists_AddBanned( CLIENT *From, CHAR *Mask, CHANNEL *Chan ) { C2C *c2c; assert( Mask != NULL ); assert( Chan != NULL ); + if( Already_Registered( My_Bans, Mask, Chan )) + { + /* Eintrag ist bereits vorhanden */ + IRC_WriteStrClient( From, RPL_BANLIST_MSG, Client_ID( From ), Channel_Name( Chan ), Mask ); + return FALSE; + } + c2c = New_C2C( Mask, Chan, FALSE ); if( ! c2c ) { @@ -302,13 +317,13 @@ GLOBAL CHAR * Lists_MakeMask( CHAR *Pattern ) { /* Hier wird aus einem "beliebigen" Pattern eine gueltige IRC-Mask erzeugt. - * Diese ist aber nur bis zum naechsten Aufruf von Lists_MakeMask() gueltig, - * da ein einziger globaler Puffer verwendet wird. ->Umkopieren!*/ + * Diese ist aber nur bis zum naechsten Aufruf von Lists_MakeMask() gueltig, + * da ein einziger globaler Puffer verwendet wird. ->Umkopieren!*/ STATIC CHAR TheMask[MASK_LEN]; CHAR *excl, *at; - assert( Pattern ); + assert( Pattern != NULL ); excl = strchr( Pattern, '!' ); at = strchr( Pattern, '@' ); @@ -415,4 +430,19 @@ Check_List( C2C **Cl2Chan, CLIENT *Client, CHANNEL *Chan ) } /* Check_List */ +LOCAL BOOLEAN +Already_Registered( C2C *List, CHAR *Mask, CHANNEL *Chan ) +{ + C2C *c2c; + + c2c = List; + while( c2c ) + { + if(( c2c->channel == Chan ) && ( strcasecmp( c2c->mask, Mask ) == 0 )) return TRUE; + c2c = c2c->next; + } + return FALSE; +} /* Already_Registered */ + + /* -eof- */