X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fngircd%2Firc-login.c;h=cd3fcc61784f1207010dc39d840e9286a80bdc4f;hb=3dc16212003f3339f4b5d362c093bd831241c951;hp=594ddcc303d9c76bdbda8b737fbce76d85acc401;hpb=5aa9c8f44cdee19b40440a61bc212ca6351117ca;p=ngircd-alex.git diff --git a/src/ngircd/irc-login.c b/src/ngircd/irc-login.c index 594ddcc3..cd3fcc61 100644 --- a/src/ngircd/irc-login.c +++ b/src/ngircd/irc-login.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-login.c,v 1.18 2002/09/03 18:55:03 alex Exp $ + * $Id: irc-login.c,v 1.20 2002/09/03 20:58:43 alex Exp $ * * irc-login.c: Anmeldung und Abmeldung im IRC */ @@ -65,7 +65,7 @@ IRC_PASS( CLIENT *Client, REQUEST *Req ) } else if((( Client_Type( Client ) == CLIENT_UNKNOWN ) || ( Client_Type( Client ) == CLIENT_UNKNOWNSERVER )) && (( Req->argc == 3 ) || ( Req->argc == 4 ))) { - CHAR *impl, *serverver, *flags, *ptr; + CHAR c2, c4, *type, *impl, *serverver, *flags, *ptr; INT protohigh, protolow; /* noch nicht registrierte Server-Verbindung */ @@ -74,24 +74,35 @@ IRC_PASS( CLIENT *Client, REQUEST *Req ) /* Passwort speichern */ Client_SetPassword( Client, Req->argv[0] ); - /* Protokollversion ueberpruefen */ - if( strlen( Req->argv[1] ) > 4 ) Req->argv[1][4] = '\0'; - if( strlen( Req->argv[1] ) != 4 ) protohigh = protolow = 0; - else + /* Protokollversion ermitteln */ + if( strlen( Req->argv[1] ) >= 4 ) { + c2 = Req->argv[1][2]; + c4 = Req->argv[1][4]; + + Req->argv[1][4] = '\0'; protolow = atoi( &Req->argv[1][2] ); Req->argv[1][2] = '\0'; protohigh = atoi( Req->argv[1] ); - } + + Req->argv[1][2] = c2; + Req->argv[1][4] = c4; + } + else protohigh = protolow = 0; + + /* Protokoll-Typ */ + if( strlen( Req->argv[1] ) > 4 ) type = &Req->argv[1][4]; + else type = NULL; /* Implementation, Version und ngIRCd-Flags */ impl = Req->argv[2]; ptr = strchr( impl, '|' ); if( ptr ) *ptr = '\0'; - if( strcmp( impl, PACKAGE ) == 0 ) + if( type && ( strcmp( type, PROTOIRCPLUS ) == 0 )) { - /* auf der anderen Seite laeuft auch ein ngIRCd */ + /* auf der anderen Seite laeuft ein Server, der + * ebenfalls das IRC+-Protokoll versteht */ serverver = ptr + 1; flags = strchr( serverver, ':' ); if( flags ) @@ -100,12 +111,12 @@ IRC_PASS( CLIENT *Client, REQUEST *Req ) flags++; } else flags = ""; - Log( LOG_INFO, "Connection %d: Peer announces itself as %s-%s (flags: \"%s\") using protocol version %d.%d.", Client_Conn( Client ), impl, serverver, flags, protohigh, protolow ); + Log( LOG_INFO, "Connection %d: Peer announces itself as %s-%s (flags: \"%s\") using protocol version %d.%d+.", Client_Conn( Client ), impl, serverver, flags, protohigh, protolow ); } else { serverver = flags = ""; - Log( LOG_INFO, "Connection %d: Peer announces itself as server of type \"%s\" usinf protocol version %d.%d.", Client_Conn( Client ), impl, protohigh, protolow ); + Log( LOG_INFO, "Connection %d: Peer announces itself as \"%s\" using protocol version %d.%d.", Client_Conn( Client ), impl, protohigh, protolow ); } Client_SetType( Client, CLIENT_GOTPASSSERVER );