X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?p=ngircd-alex.git;a=blobdiff_plain;f=src%2Fngircd%2Fclient.c;h=cdb4f185a9744458a7c428bcdb4a66d2f706e49d;hp=871aa1d49d98ff0426c24fb33c3323364f1115bd;hb=ff54198f43eda3251eb117982728dd0cb145a921;hpb=9f3a9df24a90300e4a323a27a8cd75d9ed33f8c0 diff --git a/src/ngircd/client.c b/src/ngircd/client.c index 871aa1d4..cdb4f185 100644 --- a/src/ngircd/client.c +++ b/src/ngircd/client.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: client.c,v 1.37 2002/02/17 19:02:49 alex Exp $ + * $Id: client.c,v 1.40 2002/02/27 23:23:53 alex Exp $ * * client.c: Management aller Clients * @@ -21,6 +21,15 @@ * Server gewesen, so existiert eine entsprechende CONNECTION-Struktur. * * $Log: client.c,v $ + * Revision 1.40 2002/02/27 23:23:53 alex + * - Includes fuer einige Header bereinigt. + * + * Revision 1.39 2002/02/27 18:22:09 alex + * - neue Funktion Client_SetAway() und Client_Away() implementiert. + * + * Revision 1.38 2002/02/27 14:47:53 alex + * - Logging beim Abmelden von Clients (erneut) geaendert: nun ist's aber gut ;-) + * * Revision 1.37 2002/02/17 19:02:49 alex * - Client_CheckNick() und Client_CheckID() lieferten u.U. falsche Ergebnisse. * @@ -163,7 +172,7 @@ #include "channel.h" #include "conf.h" #include "conn.h" -#include "irc.h" +#include "irc-write.h" #include "log.h" #include "messages.h" @@ -345,7 +354,11 @@ GLOBAL VOID Client_Destroy( CLIENT *Client, CHAR *LogMsg, CHAR *FwdMsg ) } else if( c->type == CLIENT_SERVER ) { - if( c != This_Server ) Log( LOG_NOTICE, "Server \"%s\" unregistered: %s", c->id, txt ); + if( c != This_Server ) + { + if( c->conn_id != NONE ) Log( LOG_NOTICE, "Server \"%s\" unregistered (connection %d): %s", c->id, c->conn_id, txt ); + else Log( LOG_NOTICE, "Server \"%s\" unregistered: %s", c->id, txt ); + } /* andere Server informieren */ if( ! NGIRCd_Quit ) @@ -354,7 +367,19 @@ GLOBAL VOID Client_Destroy( CLIENT *Client, CHAR *LogMsg, CHAR *FwdMsg ) else IRC_WriteStrServersPrefix( Client_NextHop( c ), c, "SQUIT %s :", c->id ); } } - else Log( LOG_NOTICE, "Unknown client \"%s\" unregistered: %s", c->id, txt ); + else + { + if( c->conn_id != NONE ) + { + if( c->id[0] ) Log( LOG_NOTICE, "Client \"%s\" unregistered (connection %d): %s", c->id, c->conn_id, txt ); + else Log( LOG_NOTICE, "Client unregistered (connection %d): %s", c->conn_id, txt ); + } + else + { + if( c->id[0] ) Log( LOG_WARNING, "Unregistered unknown client \"%s\": %s", c->id, txt ); + else Log( LOG_WARNING, "Unregistered unknown client: %s", c->id, txt ); + } + } free( c ); break; @@ -430,6 +455,29 @@ GLOBAL VOID Client_SetPassword( CLIENT *Client, CHAR *Pwd ) } /* Client_SetPassword */ +GLOBAL VOID Client_SetAway( CLIENT *Client, CHAR *Txt ) +{ + /* Von einem Client gelieferte AWAY-Nachricht */ + + assert( Client != NULL ); + + if( Txt ) + { + /* Client AWAY setzen */ + strncpy( Client->away, Txt, CLIENT_AWAY_LEN ); + Client->away[CLIENT_AWAY_LEN - 1] = '\0'; + Client_ModeAdd( Client, 'a' ); + Log( LOG_DEBUG, "User \"%s\" is away: %s", Client_Mask( Client ), Txt ); + } + else + { + /* AWAY loeschen */ + Client_ModeDel( Client, 'a' ); + Log( LOG_DEBUG, "User \"%s\" is no longer away.", Client_Mask( Client )); + } +} /* Client_SetAway */ + + GLOBAL VOID Client_SetType( CLIENT *Client, INT Type ) { assert( Client != NULL ); @@ -712,6 +760,15 @@ GLOBAL BOOLEAN Client_HasMode( CLIENT *Client, CHAR Mode ) } /* Client_HasMode */ +GLOBAL CHAR *Client_Away( CLIENT *Client ) +{ + /* AWAY-Text liefern */ + + assert( Client != NULL ); + return Client->away; +} /* Client_Away */ + + GLOBAL BOOLEAN Client_CheckNick( CLIENT *Client, CHAR *Nick ) { /* Nick ueberpruefen */ @@ -959,6 +1016,7 @@ LOCAL CLIENT *New_Client_Struct( VOID ) c->hops = -1; c->token = -1; c->mytoken = -1; + strcpy( c->away, "" ); return c; } /* New_Client */