X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?p=ngircd-alex.git;a=blobdiff_plain;f=src%2Fngircd%2Firc-op.c;h=cd2b823574df79d73bdf3fc226919017016687d7;hp=8bc38307e5dcb3b71b03383e8a8b13d4f8670216;hb=071686ac6e7562189143ace52fd96d982d7a5726;hpb=151babd1689a0758b927ef0d6c7a215249a57983 diff --git a/src/ngircd/irc-op.c b/src/ngircd/irc-op.c index 8bc38307..cd2b8235 100644 --- a/src/ngircd/irc-op.c +++ b/src/ngircd/irc-op.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: irc-op.c,v 1.5 2002/06/11 13:59:07 alex Exp $ + * $Id: irc-op.c,v 1.9 2002/09/08 17:06:54 alex Exp $ * * irc-op.c: Befehle zur Channel-Verwaltung */ @@ -63,22 +63,6 @@ IRC_KICK( CLIENT *Client, REQUEST *Req ) } /* IRC_KICK */ -GLOBAL BOOLEAN -IRC_BAN( CLIENT *Client, REQUEST *Req ) -{ - assert( Client != NULL ); - assert( Req != NULL ); - - /* Valider Client? */ - if(( Client_Type( Client ) != CLIENT_USER ) && ( Client_Type( Client ) != CLIENT_SERVER )) return IRC_WriteStrClient( Client, ERR_NOTREGISTERED_MSG, Client_ID( Client )); - - /* Keine Parameter? */ - if( Req->argc < 1 ) return IRC_WriteStrClient( Client, ERR_NEEDMOREPARAMS_MSG, Client_ID( Client ), Req->command ); - - return CONNECTED; -} /* IRC_BAN */ - - GLOBAL BOOLEAN IRC_INVITE( CLIENT *Client, REQUEST *Req ) { @@ -120,17 +104,24 @@ IRC_INVITE( CLIENT *Client, REQUEST *Req ) /* Ist der Ziel-User bereits Mitglied? */ if( Channel_IsMemberOf( chan, target )) return IRC_WriteStrClient( from, ERR_USERONCHANNEL_MSG, Client_ID( from ), Req->argv[0], Req->argv[1] ); - } + /* Wenn der User gebanned ist, so muss das Invite auch gespeichert werden */ + if( Lists_CheckBanned( target, chan )) remember = TRUE; + Log( LOG_DEBUG, "User \"%s\" invites \"%s\" to \"%s\" ...", Client_Mask( from ), Req->argv[0], Req->argv[1] ); + if( remember ) + { + if( ! Lists_AddInvited( from, Client_Mask( target ), chan, TRUE )) return CONNECTED; + } + + /* an Ziel-Client forwarden ... */ IRC_WriteStrClientPrefix( target, from, "INVITE %s %s", Req->argv[0], Req->argv[1] ); - if( remember ) Lists_AddInvited( Client_Mask( target ), chan, TRUE ); if( Client_Conn( target ) > NONE ) { - /* lokaler Zeil-Client, Status-Code melden */ - if( ! IRC_WriteStrClientPrefix( from, from, RPL_INVITING_MSG, Client_ID( from ), Req->argv[0], Req->argv[1] )) return DISCONNECTED; + /* lokaler Ziel-Client, Status-Code melden */ + if( ! IRC_WriteStrClientPrefix( from, target, RPL_INVITING_MSG, Client_ID( from ), Req->argv[0], Req->argv[1] )) return DISCONNECTED; } return CONNECTED;