commit 71d8c371711f70e2d4b7ef9c908443a018cd6701 from: Gabor Adam Toth via: Alexander Barton date: Wed Mar 16 22:15:50 2011 UTC ClientUserNick setting commit - 52f59149adf4dbbb7c917225a7c66ac4aa053700 commit + 71d8c371711f70e2d4b7ef9c908443a018cd6701 blob - bb9350160c337ea27aac70cba2852bd5c6d663f2 blob + 7cfe08f7cc8000df1d3f5ec26c8e498833cd5c48 --- doc/sample-ngircd.conf.tmpl +++ doc/sample-ngircd.conf.tmpl @@ -27,6 +27,9 @@ # Set this hostname for every client instead of the real one ;ClientHost = irc.the.net + # Set every clients' user name to their nick name + ;ClientUserNick = yes + # Info text of the server. This will be shown by WHOIS and # LINKS requests for example. Info = Server Info Text blob - 11decc8689584e116b6505a3369f20cbcd59f073 blob + 1a6ad931f8b128604296c17c2b3ebbac64bb7bc3 --- src/ngircd/client.c +++ src/ngircd/client.c @@ -335,6 +335,9 @@ Client_SetID( CLIENT *Client, const char *ID ) strlcpy( Client->id, ID, sizeof( Client->id )); + if (Conf_ClientUserNick) + strlcpy( Client->user, ID, sizeof( Client->user )); + /* Hash */ Client->hash = Hash( Client->id ); } /* Client_SetID */ @@ -348,6 +351,8 @@ Client_SetUser( CLIENT *Client, const char *User, bool assert( Client != NULL ); assert( User != NULL ); + if (Conf_ClientUserNick) return; + if (Idented) { strlcpy(Client->user, User, sizeof(Client->user)); } else { blob - 622cb9f8f3667a0c7b983a7f982e28312b37c162 blob + 487c1eb50bc1397bc8482abbc69275df676610f0 --- src/ngircd/conf.c +++ src/ngircd/conf.c @@ -296,6 +296,7 @@ Conf_Test( void ) puts( "[GLOBAL]" ); printf(" Name = %s\n", Conf_ServerName); printf(" ClientHost = %s\n", Conf_ClientHost); + printf(" ClientUserNick = %s\n", yesno_to_str(Conf_ClientUserNick)); printf(" Info = %s\n", Conf_ServerInfo); #ifndef PAM printf(" Password = %s\n", Conf_ServerPwd); @@ -592,6 +593,7 @@ Set_Defaults(bool InitServers) strcpy(Conf_ServerName, ""); strcpy(Conf_ClientHost, ""); + Conf_ClientUserNick = false; snprintf(Conf_ServerInfo, sizeof Conf_ServerInfo, "%s %s", PACKAGE_NAME, PACKAGE_VERSION); strcpy(Conf_ServerPwd, ""); @@ -979,6 +981,11 @@ Handle_GLOBAL( int Line, char *Var, char *Arg ) Config_Error_TooLong( Line, Var ); return; } + if( strcasecmp( Var, "ClientUserNick" ) == 0 ) { + /* Use client nick name as user name */ + Conf_ClientUserNick = Check_ArgIsTrue( Arg ); + return; + } if( strcasecmp( Var, "Info" ) == 0 ) { /* Info text of server */ len = strlcpy( Conf_ServerInfo, Arg, sizeof( Conf_ServerInfo )); blob - 1747139df06055f53a4f5e89407b1adab11a1f6e blob + 10b64076f638b7760056b661f1ba792d826521c3 --- src/ngircd/conf.h +++ src/ngircd/conf.h @@ -99,6 +99,7 @@ GLOBAL char Conf_ServerName[CLIENT_ID_LEN]; /** Hostname of the clients */ GLOBAL char Conf_ClientHost[CLIENT_ID_LEN]; +GLOBAL bool Conf_ClientUserNick; /** Server info text */ GLOBAL char Conf_ServerInfo[CLIENT_INFO_LEN];