X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?p=ngircd-alex.git;a=blobdiff_plain;f=src%2Fngircd%2Firc.c;h=3c878148df4fd657b24a5055c9318ec89bd5eea7;hp=4ec0427f2ff3cb197d3effffdf751d9aace0763f;hb=39d7b014cfc775690d386334cbab9387e68ea25c;hpb=3da161131a1fd94b572dd23963a612e16366a1e4 diff --git a/src/ngircd/irc.c b/src/ngircd/irc.c index 4ec0427f..3c878148 100644 --- a/src/ngircd/irc.c +++ b/src/ngircd/irc.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.c,v 1.94 2002/07/25 11:37:01 alex Exp $ + * $Id: irc.c,v 1.97 2002/10/09 13:33:19 alex Exp $ * * irc.c: IRC-Befehle */ @@ -109,7 +109,7 @@ IRC_NOTICE( CLIENT *Client, REQUEST *Req ) assert( Client != NULL ); assert( Req != NULL ); - if(( Client_Type( Client ) != CLIENT_USER ) && ( Client_Type( Client ) != CLIENT_SERVER )) return IRC_WriteStrClient( Client, ERR_NOTREGISTERED_MSG, Client_ID( Client )); + if(( Client_Type( Client ) != CLIENT_USER ) && ( Client_Type( Client ) != CLIENT_SERVER )) return; /* Falsche Anzahl Parameter? */ if( Req->argc != 2 ) return CONNECTED; @@ -206,7 +206,7 @@ IRC_NAMES( CLIENT *Client, REQUEST *Req ) if( strlen( rpl ) > ( LINE_LEN - CLIENT_NICK_LEN - 4 )) { /* Zeile wird zu lang: senden! */ - if( ! IRC_WriteStrClient( from, rpl )) return DISCONNECTED; + if( ! IRC_WriteStrClient( from, "%s", rpl )) return DISCONNECTED; sprintf( rpl, RPL_NAMREPLY_MSG, Client_ID( from ), "*", "*" ); } } @@ -217,7 +217,7 @@ IRC_NAMES( CLIENT *Client, REQUEST *Req ) if( rpl[strlen( rpl ) - 1] != ':') { /* es wurden User gefunden */ - if( ! IRC_WriteStrClient( from, rpl )) return DISCONNECTED; + if( ! IRC_WriteStrClient( from, "%s", rpl )) return DISCONNECTED; } return IRC_WriteStrClient( from, RPL_ENDOFNAMES_MSG, Client_ID( from ), "*" ); @@ -259,7 +259,7 @@ IRC_ISON( CLIENT *Client, REQUEST *Req ) } if( rpl[strlen( rpl ) - 1] == ' ' ) rpl[strlen( rpl ) - 1] = '\0'; - return IRC_WriteStrClient( Client, rpl, Client_ID( Client ) ); + return IRC_WriteStrClient( Client, "%s", rpl, Client_ID( Client ) ); } /* IRC_ISON */ @@ -325,7 +325,7 @@ IRC_WHOIS( CLIENT *Client, REQUEST *Req ) if( strlen( str ) > ( LINE_LEN - CHANNEL_NAME_LEN - 4 )) { /* Zeile wird zu lang: senden! */ - if( ! IRC_WriteStrClient( Client, str )) return DISCONNECTED; + if( ! IRC_WriteStrClient( Client, "%s", str )) return DISCONNECTED; sprintf( str, RPL_WHOISCHANNELS_MSG, Client_ID( from ), Client_ID( c )); } @@ -335,7 +335,7 @@ IRC_WHOIS( CLIENT *Client, REQUEST *Req ) if( str[strlen( str ) - 1] != ':') { /* Es sind noch Daten da, die gesendet werden muessen */ - if( ! IRC_WriteStrClient( Client, str )) return DISCONNECTED; + if( ! IRC_WriteStrClient( Client, "%s", str )) return DISCONNECTED; } /* IRC-Operator? */ @@ -477,7 +477,7 @@ IRC_USERHOST( CLIENT *Client, REQUEST *Req ) } if( rpl[strlen( rpl ) - 1] == ' ' ) rpl[strlen( rpl ) - 1] = '\0'; - return IRC_WriteStrClient( Client, rpl, Client_ID( Client ) ); + return IRC_WriteStrClient( Client, "%s", rpl, Client_ID( Client ) ); } /* IRC_USERHOST */ @@ -655,6 +655,49 @@ IRC_KILL( CLIENT *Client, REQUEST *Req ) } /* IRC_KILL */ +GLOBAL BOOLEAN +IRC_ADMIN(CLIENT *Client, REQUEST *Req ) +{ + CLIENT *target, *prefix; + + assert( Client != NULL ); + assert( Req != NULL ); + + if(( Client_Type( Client ) != CLIENT_USER ) && ( Client_Type( Client ) != CLIENT_SERVER )) return IRC_WriteStrClient( Client, ERR_NOTREGISTERED_MSG, Client_ID( Client )); + + /* Falsche Anzahl Parameter? */ + if(( Req->argc > 1 )) return IRC_WriteStrClient( Client, ERR_NEEDMOREPARAMS_MSG, Client_ID( Client ), Req->command ); + + /* Ziel suchen */ + if( Req->argc == 1 ) target = Client_Search( Req->argv[0] ); + else target = Client_ThisServer( ); + + /* Prefix ermitteln */ + if( Client_Type( Client ) == CLIENT_SERVER ) prefix = Client_Search( Req->prefix ); + else prefix = Client; + if( ! prefix ) return IRC_WriteStrClient( Client, ERR_NOSUCHSERVER_MSG, Client_ID( Client ), Req->prefix ); + + /* An anderen Server weiterleiten? */ + if( target != Client_ThisServer( )) + { + if( ! target ) return IRC_WriteStrClient( Client, ERR_NOSUCHSERVER_MSG, Client_ID( Client ), Req->argv[0] ); + + /* forwarden */ + IRC_WriteStrClientPrefix( target, prefix, "ADMIN %s", Req->argv[0] ); + return CONNECTED; + } + + /* mit Versionsinfo antworten */ + if( ! IRC_WriteStrClient( Client, RPL_ADMINME_MSG, Client_ID( prefix ), Conf_ServerName )) return DISCONNECTED; + if( ! IRC_WriteStrClient( Client, RPL_ADMINLOC1_MSG, Client_ID( prefix ), Conf_ServerAdmin1 )) return DISCONNECTED; + if( ! IRC_WriteStrClient( Client, RPL_ADMINLOC2_MSG, Client_ID( prefix ), Conf_ServerAdmin2 )) return DISCONNECTED; + if( ! IRC_WriteStrClient( Client, RPL_ADMINEMAIL_MSG, Client_ID( prefix ), Conf_ServerAdminMail )) return DISCONNECTED; + + return CONNECTED; +} /* IRC_ADMIN */ + + + GLOBAL BOOLEAN IRC_Show_MOTD( CLIENT *Client ) { @@ -725,7 +768,7 @@ IRC_Send_NAMES( CLIENT *Client, CHANNEL *Chan ) if( strlen( str ) > ( LINE_LEN - CLIENT_NICK_LEN - 4 )) { /* Zeile wird zu lang: senden! */ - if( ! IRC_WriteStrClient( Client, str )) return DISCONNECTED; + if( ! IRC_WriteStrClient( Client, "%s", str )) return DISCONNECTED; sprintf( str, RPL_NAMREPLY_MSG, Client_ID( Client ), "=", Channel_Name( Chan )); } } @@ -736,7 +779,7 @@ IRC_Send_NAMES( CLIENT *Client, CHANNEL *Chan ) if( str[strlen( str ) - 1] != ':') { /* Es sind noch Daten da, die gesendet werden muessen */ - if( ! IRC_WriteStrClient( Client, str )) return DISCONNECTED; + if( ! IRC_WriteStrClient( Client, "%s", str )) return DISCONNECTED; } return CONNECTED;