X-Git-Url: https://arthur.barton.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fngircd%2Firc-login.c;h=95ec959cc0cf9bbf9d588e2776c4a51bbe59a442;hb=4e125fb67cf9d00a9da0bf4602a4e5c0745bf282;hp=5a68d5e823f1438928712796884b7b8436251145;hpb=14048c471757ad63c9ca6aab38877bf4579a5062;p=ngircd-alex.git diff --git a/src/ngircd/irc-login.c b/src/ngircd/irc-login.c index 5a68d5e8..95ec959c 100644 --- a/src/ngircd/irc-login.c +++ b/src/ngircd/irc-login.c @@ -38,23 +38,9 @@ #include "irc-login.h" -typedef struct _INTRO_INFO { - char *nick; /* Nick name */ - int hopcount; /* Hop count */ - char *user; /* User name */ - char *host; /* Host name */ - CLIENT *server; /* Server the client is connected to */ - char *mode; /* User modes */ - char *name; /* Real name */ -} INTRO_INFO; - - static bool Hello_User PARAMS(( CLIENT *Client )); static void Kill_Nick PARAMS(( char *Nick, char *Reason )); -static void Introduce_Client PARAMS((CLIENT *From, char *Nick, - const int HopCount, char *User, - char *Host, CLIENT *Server, - char *Mode, char *Name )); +static void Introduce_Client PARAMS((CLIENT *To, CLIENT *Client)); static void cb_introduceClient PARAMS((CLIENT *Client, CLIENT *Prefix, void *i)); @@ -81,7 +67,7 @@ IRC_PASS( CLIENT *Client, REQUEST *Req ) /* Not yet registered "unknown" connection, PASS with one * argument: either a regular client, service, or server * using the old RFC 1459 section 4.1.1 syntax. */ - LogDebug("Connection %d: got PASS command ...", + LogDebug("Connection %d: got PASS command (RFC 1459) ...", Client_Conn(Client)); } else if ((Client_Type(Client) == CLIENT_UNKNOWN || Client_Type(Client) == CLIENT_UNKNOWNSERVER) && @@ -89,7 +75,7 @@ IRC_PASS( CLIENT *Client, REQUEST *Req ) /* Not yet registered "unknown" connection or outgoing server * link, PASS with three or four argument: server using the * RFC 2813 section 4.1.1 syntax. */ - LogDebug("Connection %d: got PASS command (new server link) ...", + LogDebug("Connection %d: got PASS command (RFC 2813, new server link) ...", Client_Conn(Client)); } else if (Client_Type(Client) == CLIENT_UNKNOWN || Client_Type(Client) == CLIENT_UNKNOWNSERVER) { @@ -103,7 +89,6 @@ IRC_PASS( CLIENT *Client, REQUEST *Req ) } Client_SetPassword(Client, Req->argv[0]); - Client_SetType(Client, CLIENT_GOTPASS); /* Protocol version */ if (Req->argc >= 2 && strlen(Req->argv[1]) >= 4) { @@ -119,8 +104,12 @@ IRC_PASS( CLIENT *Client, REQUEST *Req ) Req->argv[1][2] = c2; Req->argv[1][4] = c4; - } else + + Client_SetType(Client, CLIENT_GOTPASS_2813); + } else { protohigh = protolow = 0; + Client_SetType(Client, CLIENT_GOTPASS); + } /* Protocol type, see doc/Protocol.txt */ if (Req->argc >= 2 && strlen(Req->argv[1]) > 4) @@ -185,29 +174,23 @@ GLOBAL bool IRC_NICK( CLIENT *Client, REQUEST *Req ) { CLIENT *intr_c, *target, *c; - CONN_ID conn; char *nick, *user, *hostname, *modes, *info; int token, hops; assert( Client != NULL ); assert( Req != NULL ); -#ifndef STRICT_RFC /* Some IRC clients, for example BitchX, send the NICK and USER * commands in the wrong order ... */ - if( Client_Type( Client ) == CLIENT_UNKNOWN - || Client_Type( Client ) == CLIENT_GOTPASS - || Client_Type( Client ) == CLIENT_GOTNICK - || Client_Type( Client ) == CLIENT_GOTUSER - || Client_Type( Client ) == CLIENT_USER - || ( Client_Type( Client ) == CLIENT_SERVER && Req->argc == 1 )) -#else - if( Client_Type( Client ) == CLIENT_UNKNOWN - || Client_Type( Client ) == CLIENT_GOTPASS - || Client_Type( Client ) == CLIENT_GOTNICK - || Client_Type( Client ) == CLIENT_USER - || ( Client_Type( Client ) == CLIENT_SERVER && Req->argc == 1 )) + if(Client_Type(Client) == CLIENT_UNKNOWN + || Client_Type(Client) == CLIENT_GOTPASS + || Client_Type(Client) == CLIENT_GOTNICK +#ifndef STRICT_RFC + || Client_Type(Client) == CLIENT_GOTUSER #endif + || Client_Type(Client) == CLIENT_USER + || Client_Type(Client) == CLIENT_SERVICE + || (Client_Type(Client) == CLIENT_SERVER && Req->argc == 1)) { /* User registration or change of nickname */ @@ -255,9 +238,9 @@ IRC_NICK( CLIENT *Client, REQUEST *Req ) return CONNECTED; } - if(( Client_Type( target ) != CLIENT_USER ) - && ( Client_Type( target ) != CLIENT_SERVER )) - { + if (Client_Type(target) != CLIENT_USER && + Client_Type(target) != CLIENT_SERVICE && + Client_Type(target) != CLIENT_SERVER) { /* New client */ Log( LOG_DEBUG, "Connection %d: got valid NICK command ...", Client_Conn( Client )); @@ -271,25 +254,22 @@ IRC_NICK( CLIENT *Client, REQUEST *Req ) return Hello_User( Client ); else Client_SetType( Client, CLIENT_GOTNICK ); - } - else - { + } else { /* Nickname change */ if (Client_Conn(target) > NONE) { /* Local client */ Log(LOG_INFO, - "User \"%s\" changed nick (connection %d): \"%s\" -> \"%s\".", - Client_Mask(target), Client_Conn(target), - Client_ID(target), Req->argv[0]); + "%s \"%s\" changed nick (connection %d): \"%s\" -> \"%s\".", + Client_TypeText(target), Client_Mask(target), + Client_Conn(target), Client_ID(target), + Req->argv[0]); Conn_UpdateIdle(Client_Conn(target)); - } - else - { + } else { /* Remote client */ - Log( LOG_DEBUG, - "User \"%s\" changed nick: \"%s\" -> \"%s\".", - Client_Mask( target ), Client_ID( target ), - Req->argv[0] ); + LogDebug("%s \"%s\" changed nick: \"%s\" -> \"%s\".", + Client_TypeText(target), + Client_Mask(target), Client_ID(target), + Req->argv[0]); } /* Inform all users and servers (which have to know) @@ -340,15 +320,6 @@ IRC_NICK( CLIENT *Client, REQUEST *Req ) token = atoi(Req->argv[1]); modes = ""; info = Req->argv[0]; - - conn = Client_Conn(Client); - if (conn != NONE && - !(Conn_Options(conn) & CONN_RFC1459)) { - Log(LOG_INFO, - "Switching connection %d (\"%s\") to RFC 1459 compatibility mode.", - conn, Client_ID(Client)); - Conn_SetOption(conn, CONN_RFC1459); - } } /* Nick ueberpruefen */ @@ -388,21 +359,12 @@ IRC_NICK( CLIENT *Client, REQUEST *Req ) * other servers about the new user. * RFC 1459: announce the new client only after receiving the * USER command, first we need more information! */ - if (Req->argc >= 7) { - modes = Client_Modes(c); - LogDebug("User \"%s\" (+%s) registered (via %s, on %s, %d hop%s).", - Client_Mask(c), modes, Client_ID(Client), - Client_ID(intr_c), Client_Hops(c), - Client_Hops(c) > 1 ? "s": ""); - - Introduce_Client(Client, Req->argv[0], - atoi(Req->argv[1]) + 1, Req->argv[2], - Req->argv[3], intr_c, Req->argv[5], Req->argv[6]); - } else { - LogDebug("User \"%s\" is beeing registered (RFC 1459) ...", + if (Req->argc < 7) { + LogDebug("Client \"%s\" is beeing registered (RFC 1459) ...", Client_Mask(c)); Client_SetType(c, CLIENT_GOTNICK); - } + } else + Introduce_Client(Client, c); return CONNECTED; } @@ -417,7 +379,6 @@ GLOBAL bool IRC_USER(CLIENT * Client, REQUEST * Req) { CLIENT *c; - char modes[CLIENT_MODE_LEN + 1] = "+"; #ifdef IDENTAUTH char *ptr; #endif @@ -484,19 +445,10 @@ IRC_USER(CLIENT * Client, REQUEST * Req) LogDebug("Connection %d: got valid USER command for \"%s\".", Client_Conn(Client), Client_Mask(c)); - /* RFC 1459 style user registration? Inform other servers! */ - if (Client_Type(c) == CLIENT_GOTNICK) { - strlcat(modes, Client_Modes(c), sizeof(modes)); - Introduce_Client(Client, Client_ID(c), Client_Hops(c), - Client_User(c), Client_Hostname(c), - Client_Introducer(c), modes, - Client_Info(c)); - LogDebug("User \"%s\" (%s) registered (via %s, on %s, %d hop%s).", - Client_Mask(c), modes, Client_ID(Client), - Client_ID(Client_Introducer(c)), Client_Hops(c), - Client_Hops(c) > 1 ? "s": ""); - Client_SetType(c, CLIENT_USER); - } + /* RFC 1459 style user registration? + * Introduce client to network: */ + if (Client_Type(c) == CLIENT_GOTNICK) + Introduce_Client(Client, c); return CONNECTED; } else if (Client_Type(Client) == CLIENT_USER) { @@ -714,8 +666,6 @@ IRC_PONG(CLIENT *Client, REQUEST *Req) static bool Hello_User(CLIENT * Client) { - char modes[CLIENT_MODE_LEN + 1] = "+"; - assert(Client != NULL); /* Check password ... */ @@ -728,14 +678,7 @@ Hello_User(CLIENT * Client) return DISCONNECTED; } - Log(LOG_NOTICE, "User \"%s\" registered (connection %d).", - Client_Mask(Client), Client_Conn(Client)); - - /* Inform other servers */ - strlcat(modes, Client_Modes(Client), sizeof(modes)); - Introduce_Client(NULL, Client_ID(Client), 1, Client_User(Client), - Client_Hostname(Client), NULL, modes, - Client_Info(Client)); + Introduce_Client(NULL, Client); if (!IRC_WriteStrClient (Client, RPL_WELCOME_MSG, Client_ID(Client), Client_Mask(Client))) @@ -759,8 +702,6 @@ Hello_User(CLIENT * Client) if (!IRC_Send_ISUPPORT(Client)) return DISCONNECTED; - Client_SetType(Client, CLIENT_USER); - if (!IRC_Send_LUSERS(Client)) return DISCONNECTED; if (!IRC_Show_MOTD(Client)) @@ -792,45 +733,62 @@ Kill_Nick( char *Nick, char *Reason ) static void -Introduce_Client(CLIENT *From, char *Nick, const int HopCount, char *User, - char *Host, CLIENT *Server, char *Mode, char *Name) +Introduce_Client(CLIENT *From, CLIENT *Client) { - INTRO_INFO i; + char *type; + + Client_SetType(Client, CLIENT_USER); - i.nick = Nick; - i.hopcount = HopCount; - i.user = User ? User : "-"; - i.host = Host ? Host : "-"; - i.server = Server ? Server : Client_ThisServer(); - i.mode = Mode ? Mode : "+"; - i.name = Name ? Name : ""; + if (From) { + if (Conf_IsService(Conf_GetServer(Client_Conn(From)), Client_ID(Client))) { + type = "Service"; + } else + type = "User"; + LogDebug("%s \"%s\" (+%s) registered (via %s, on %s, %d hop%s).", + type, Client_Mask(Client), Client_Modes(Client), + Client_ID(From), Client_ID(Client_Introducer(Client)), + Client_Hops(Client), Client_Hops(Client) > 1 ? "s": ""); + } else + Log(LOG_NOTICE, "User \"%s\" registered (connection %d).", + Client_Mask(Client), Client_Conn(Client)); + /* Inform other servers */ IRC_WriteStrServersPrefixFlag_CB(From, From != NULL ? From : Client_ThisServer(), - '\0', cb_introduceClient, (void *)(&i)); + '\0', cb_introduceClient, (void *)Client); } /* Introduce_Client */ static void -cb_introduceClient(CLIENT *Client, CLIENT *Prefix, void *data) +cb_introduceClient(CLIENT *To, CLIENT *Prefix, void *data) { - INTRO_INFO *i = (INTRO_INFO *)data; + CLIENT *c = (CLIENT *)data; CONN_ID conn; + char *modes, *user, *host; + + modes = Client_Modes(c); + user = Client_User(c) ? Client_User(c) : "-"; + host = Client_Hostname(c) ? Client_Hostname(c) : "-"; - conn = Client_Conn(Client); + conn = Client_Conn(To); if (Conn_Options(conn) & CONN_RFC1459) { /* RFC 1459 mode: separate NICK and USER commands */ - Conn_WriteStr(conn, "NICK %s :%d", i->nick, i->hopcount); + Conn_WriteStr(conn, "NICK %s :%d", Client_ID(c), + Client_Hops(c) + 1); Conn_WriteStr(conn, ":%s USER %s %s %s :%s", - i->nick, i->user, i->host, - Client_ID(i->server), i->name); + Client_ID(c), user, host, + Client_ID(Client_Introducer(c)), Client_Info(c)); + if (modes[0]) + Conn_WriteStr(conn, ":%s MODE %s +%s", + Client_ID(c), Client_ID(c), modes); } else { /* RFC 2813 mode: one combined NICK command */ - IRC_WriteStrClientPrefix(Client, Prefix, - "NICK %s %d %s %s %d %s :%s", - i->nick, i->hopcount, i->user, i->host, - Client_MyToken(i->server), i->mode, - i->name); + IRC_WriteStrClientPrefix(To, Prefix, + "NICK %s %d %s %s %d +%s :%s", + Client_ID(c), Client_Hops(c) + 1, + user, host, + Client_MyToken(Client_Introducer(c)), + modes, Client_Info(c)); } } /* cb_introduceClient */