1
0
mirror of https://github.com/osmarks/ngircd.git synced 2024-12-12 09:50:29 +00:00

Cleaned up PRIVMSG and NOTICE patches.

This commit is contained in:
Brandon Beresini 2008-06-12 21:54:05 -07:00 committed by Alexander Barton
parent 2546a13ad2
commit d4eb55c79f
5 changed files with 92 additions and 77 deletions

View File

@ -766,20 +766,6 @@ IRC_Send_WHO(CLIENT *Client, CHANNEL *Chan, bool OnlyOps)
} /* IRC_Send_WHO */ } /* IRC_Send_WHO */
static bool
MatchCaseInsensitive(const char *pattern, const char *searchme)
{
char haystack[COMMAND_LEN];
strlcpy(haystack, searchme, sizeof(haystack));
ngt_LowerStr(haystack);
return Match(pattern, haystack);
}
GLOBAL bool GLOBAL bool
IRC_WHO( CLIENT *Client, REQUEST *Req ) IRC_WHO( CLIENT *Client, REQUEST *Req )
{ {

View File

@ -41,7 +41,6 @@ static char UNUSED id[] = "$Id: irc.c,v 1.132 2008/01/15 22:28:14 fw Exp $";
static char *Option_String PARAMS((CONN_ID Idx)); static char *Option_String PARAMS((CONN_ID Idx));
static bool Send_Message PARAMS((CLIENT *Client, REQUEST *Req, int ForceType, bool SendErrors)); static bool Send_Message PARAMS((CLIENT *Client, REQUEST *Req, int ForceType, bool SendErrors));
static bool Send_Message_Mask PARAMS((CLIENT *from, char *targetMask, char *message, bool SendErrors)); static bool Send_Message_Mask PARAMS((CLIENT *from, char *targetMask, char *message, bool SendErrors));
static bool MatchCaseInsensitive PARAMS((const char *pattern, const char *searchme));
GLOBAL bool GLOBAL bool
@ -309,12 +308,11 @@ Send_Message(CLIENT * Client, REQUEST * Req, int ForceType, bool SendErrors)
{ {
CLIENT *cl, *from; CLIENT *cl, *from;
CHANNEL *chan; CHANNEL *chan;
char *targetList = Req->argv[0];
char *currentTarget = Req->argv[0]; char *currentTarget = Req->argv[0];
unsigned int targetCount = 1; char *lastCurrentTarget;
assert( Client != NULL ); assert(Client != NULL);
assert( Req != NULL ); assert(Req != NULL);
if (Req->argc == 0) { if (Req->argc == 0) {
if (!SendErrors) if (!SendErrors)
@ -344,28 +342,35 @@ Send_Message(CLIENT * Client, REQUEST * Req, int ForceType, bool SendErrors)
Client_ID(Client), Req->prefix); Client_ID(Client), Req->prefix);
} }
while (*targetList) { /* handle msgtarget = msgto *("," msgto) */
if (*targetList == ',') { currentTarget = strtok_r(currentTarget, ",", &lastCurrentTarget);
*targetList = '\0';
targetCount++;
}
targetList++;
}
while (targetCount > 0) { while (currentTarget) {
/* Check for and handle valid <msgto> of form:
* RFC 2812 2.3.1:
* msgto = channel / ( user [ "%" host ] "@" servername )
* msgto =/ ( user "%" host ) / targetmask
* msgto =/ nickname / ( nickname "!" user "@" host )
*/
if (strchr(currentTarget, '!') == NULL) if (strchr(currentTarget, '!') == NULL)
/* nickname */
cl = Client_Search(currentTarget); cl = Client_Search(currentTarget);
else else
cl = NULL; cl = NULL;
if (cl == NULL) { if (cl == NULL) {
char target[513]; // max mesage length plus null terminator /* If currentTarget isn't a nickname check for:
* user ["%" host] "@" servername
* user "%" host
* nickname "!" user "@" host
*/
char target[COMMAND_LEN];
char * nick = NULL; char * nick = NULL;
char * user = NULL; char * user = NULL;
char * host = NULL; char * host = NULL;
char * server = NULL; char * server = NULL;
strncpy(target, currentTarget, 512); strlcpy(target, currentTarget, COMMAND_LEN);
target[512] = '\0';
server = strchr(target, '@'); server = strchr(target, '@');
if (server) { if (server) {
*server = '\0'; *server = '\0';
@ -378,32 +383,34 @@ Send_Message(CLIENT * Client, REQUEST * Req, int ForceType, bool SendErrors)
} }
user = strchr(target, '!'); user = strchr(target, '!');
if (user) { if (user) {
/* msgto form: nick!user@host */
*user = '\0'; *user = '\0';
user++; user++;
nick = target; nick = target;
host = server; // <msgto> form: nick!user@host host = server; /* not "@server" but "@host" */
} else { } else {
user = target; user = target;
} }
if (user != NULL) { for (cl = Client_First(); cl != NULL; cl = Client_Next(cl)) {
for (cl = Client_First(); cl != NULL; cl = Client_Next(cl)) { if (Client_Type(cl) != CLIENT_USER)
if (Client_Type(cl) != CLIENT_USER) continue;
if (nick != NULL) {
if (strcmp(nick, Client_ID(cl)) == 0 &&
strcmp(user, Client_User(cl)) == 0 &&
strcasecmp(host, Client_Hostname(cl)) == 0)
break;
else
continue; continue;
if (nick != NULL) {
if (strcmp(nick, Client_ID(cl)) == 0 && strcmp(user, Client_User(cl)) == 0 && strcasecmp(host, Client_Hostname(cl)) == 0)
break;
else
continue;
}
if (strcasecmp(user, Client_User(cl)) != 0)
continue;
if (host != NULL && strcasecmp(host, Client_Hostname(cl)) != 0)
continue;
if (server != NULL && strcasecmp(server, Client_ID(Client_Introducer(cl))) != 0)
continue;
break;
} }
if (strcasecmp(user, Client_User(cl)) != 0)
continue;
if (host != NULL && strcasecmp(host, Client_Hostname(cl)) != 0)
continue;
if (server != NULL && strcasecmp(server,
Client_ID(Client_Introducer(cl))) != 0)
continue;
break;
} }
} }
@ -416,8 +423,8 @@ Send_Message(CLIENT * Client, REQUEST * Req, int ForceType, bool SendErrors)
Client_ID(from), Client_ID(from),
currentTarget)) currentTarget))
return false; return false;
} else if ((Client_Type(Client) != CLIENT_SERVER } else if (SendErrors && (Client_Type(Client) != CLIENT_SERVER)
&& (strchr(Client_Modes(cl), 'a')))) { && strchr(Client_Modes(cl), 'a')) {
/* Target is away */ /* Target is away */
if (!SendErrors) if (!SendErrors)
return true; return true;
@ -425,18 +432,22 @@ Send_Message(CLIENT * Client, REQUEST * Req, int ForceType, bool SendErrors)
(from, RPL_AWAY_MSG, Client_ID(from), Client_ID(cl), (from, RPL_AWAY_MSG, Client_ID(from), Client_ID(cl),
Client_Away(cl))) Client_Away(cl)))
return DISCONNECTED; return DISCONNECTED;
} if (Client_Conn(from) > NONE) { }
if (Client_Conn(from) > NONE) {
Conn_UpdateIdle(Client_Conn(from)); Conn_UpdateIdle(Client_Conn(from));
} }
if (!IRC_WriteStrClientPrefix(cl, from, "PRIVMSG %s :%s", if (!IRC_WriteStrClientPrefix(cl, from, "PRIVMSG %s :%s",
Client_ID(cl), Req->argv[1])) Client_ID(cl), Req->argv[1]))
return false; return false;
} else if (strchr("$#", currentTarget[0]) && strchr(currentTarget, '.')) { } else if (strchr("$#", currentTarget[0]) && strchr(currentTarget, '.')) {
if (!Send_Message_Mask(from, currentTarget, Req->argv[1], SendErrors)) /* targetmask */
if (!Send_Message_Mask(from, currentTarget, Req->argv[1],
SendErrors))
return false; return false;
} else if ((chan = Channel_Search(currentTarget))) { } else if ((chan = Channel_Search(currentTarget))) {
if (!Channel_Write(chan, from, Client, Req->argv[1])) /* channel */
return false; if (!Channel_Write(chan, from, Client, Req->argv[1]))
return false;
} else { } else {
if (!SendErrors) if (!SendErrors)
return true; return true;
@ -445,11 +456,7 @@ Send_Message(CLIENT * Client, REQUEST * Req, int ForceType, bool SendErrors)
return false; return false;
} }
while (*currentTarget) currentTarget = strtok_r(NULL, ",", &lastCurrentTarget);
currentTarget++;
currentTarget++;
targetCount--;
} }
return CONNECTED; return CONNECTED;
@ -478,16 +485,19 @@ Send_Message_Mask(CLIENT * from, char * targetMask, char * message, bool SendErr
continue; continue;
client_match = MatchCaseInsensitive(mask, Client_Hostname(cl)); client_match = MatchCaseInsensitive(mask, Client_Hostname(cl));
if (client_match) if (client_match)
if (!IRC_WriteStrClientPrefix(cl, from, "PRIVMSG %s :%s", Client_ID(cl), message)) if (!IRC_WriteStrClientPrefix(cl, from, "PRIVMSG %s :%s",
Client_ID(cl), message))
return false; return false;
} }
} else { } else {
for (cl = Client_First(); cl != NULL; cl = Client_Next(cl)) { for (cl = Client_First(); cl != NULL; cl = Client_Next(cl)) {
if (Client_Type(cl) != CLIENT_USER) if (Client_Type(cl) != CLIENT_USER)
continue; continue;
client_match = MatchCaseInsensitive(mask, Client_ID(Client_Introducer(cl))); client_match = MatchCaseInsensitive(mask,
Client_ID(Client_Introducer(cl)));
if (client_match) if (client_match)
if (!IRC_WriteStrClientPrefix(cl, from, "PRIVMSG %s :%s", Client_ID(cl), message)) if (!IRC_WriteStrClientPrefix(cl, from, "PRIVMSG %s :%s",
Client_ID(cl), message))
return false; return false;
} }
} }
@ -495,16 +505,4 @@ Send_Message_Mask(CLIENT * from, char * targetMask, char * message, bool SendErr
} /* Send_Message_Mask */ } /* Send_Message_Mask */
static bool
MatchCaseInsensitive(const char *pattern, const char *searchme)
{
char haystack[COMMAND_LEN];
strlcpy(haystack, searchme, sizeof(haystack));
ngt_LowerStr(haystack);
return Match(pattern, haystack);
}
/* -eof- */ /* -eof- */

View File

@ -22,6 +22,8 @@ static char UNUSED id[] = "$Id: match.c,v 1.5 2006/10/06 21:23:47 fw Exp $";
#include "exp.h" #include "exp.h"
#include "match.h" #include "match.h"
#include "defines.h"
#include "tool.h"
/* /*
@ -53,6 +55,19 @@ Match( const char *Pattern, const char *String )
} /* Match */ } /* Match */
GLOBAL bool
MatchCaseInsensitive(const char *pattern, const char *searchme)
{
char haystack[COMMAND_LEN];
strlcpy(haystack, searchme, sizeof(haystack));
ngt_LowerStr(haystack);
return Match(pattern, haystack);
} /* MatchCaseInsensitive */
static int static int
Matche( const char *p, const char *t ) Matche( const char *p, const char *t )
{ {

View File

@ -19,6 +19,7 @@
GLOBAL bool Match PARAMS(( const char *Pattern, const char *String )); GLOBAL bool Match PARAMS(( const char *Pattern, const char *String ));
GLOBAL bool MatchCaseInsensitive PARAMS(( const char *Pattern, const char *searchme ));
#endif #endif

View File

@ -1,5 +1,3 @@
# $Id: mode-test.e,v 1.7 2008/02/16 11:27:49 fw Exp $
spawn telnet localhost 6789 spawn telnet localhost 6789
expect { expect {
timeout { exit 1 } timeout { exit 1 }
@ -43,14 +41,31 @@ expect {
"@* PRIVMSG nick :test\r*401*@* PRIVMSG nick :test" "@* PRIVMSG nick :test\r*401*@* PRIVMSG nick :test"
} }
send "JOIN #testChannel\r"
send "privmsg doesnotexist :test\r" send "privmsg doesnotexist :test\r"
expect { expect {
timeout { exit 1 } timeout { exit 1 }
"401" "401"
} }
send "privmsg ~user@ngircd.test.server :test\r"
expect {
timeout { exit 1 }
"@* PRIVMSG nick :test"
}
send "privmsg ~user\%localhost :test\r"
expect {
timeout { exit 1 }
"@* PRIVMSG nick :test"
}
send "privmsg nick!~user@localhost :test\r"
expect {
timeout { exit 1 }
"@* PRIVMSG nick :test"
}
send "away :away\r" send "away :away\r"
expect { expect {
timeout { exit 1 } timeout { exit 1 }