Cleaned up PRIVMSG and NOTICE patches.
This commit is contained in:
parent
2546a13ad2
commit
d4eb55c79f
|
@ -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 )
|
||||||
{
|
{
|
||||||
|
|
116
src/ngircd/irc.c
116
src/ngircd/irc.c
|
@ -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- */
|
||||||
|
|
|
@ -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 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 }
|
||||||
|
|
Loading…
Reference in New Issue