mirror of
https://github.com/osmarks/ngircd.git
synced 2025-01-31 17:49:11 +00:00
Limit list replies of LIST, WHO, WHOIS, and MAX_RPL_WHOWAS
Introduce new #define's MAX_RPL_LIST(100), MAX_RPL_WHO(25), MAX_RPL_WHOIS(10), and MAX_RPL_WHOWAS(25).
This commit is contained in:
parent
f8405b1a4f
commit
c5beca8aab
@ -178,11 +178,23 @@
|
|||||||
|
|
||||||
/* Defaults and limits for IRC commands */
|
/* Defaults and limits for IRC commands */
|
||||||
|
|
||||||
/** Default count of WHOWAS command replies */
|
/** Max. number of LIST replies. */
|
||||||
|
#define MAX_RPL_LIST 100
|
||||||
|
|
||||||
|
/** Max. number of channel modes with arguments per MODE command. */
|
||||||
|
#define MAX_HNDL_MODES_ARG 5
|
||||||
|
|
||||||
|
/** Max. number of WHO replies. */
|
||||||
|
#define MAX_RPL_WHO 25
|
||||||
|
|
||||||
|
/** Max. number of WHOIS replies. */
|
||||||
|
#define MAX_RPL_WHOIS 10
|
||||||
|
|
||||||
|
/** Default count of WHOWAS command replies. */
|
||||||
#define DEF_RPL_WHOWAS 5
|
#define DEF_RPL_WHOWAS 5
|
||||||
|
|
||||||
/** Max. number of channel modes with arguments per MODE command */
|
/** Max count of WHOWAS command replies. */
|
||||||
#define MAX_HNDL_MODES_ARG 5
|
#define MAX_RPL_WHOWAS 25
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
#include "match.h"
|
#include "match.h"
|
||||||
#include "messages.h"
|
#include "messages.h"
|
||||||
#include "parse.h"
|
#include "parse.h"
|
||||||
|
#include "irc.h"
|
||||||
#include "irc-info.h"
|
#include "irc-info.h"
|
||||||
#include "irc-write.h"
|
#include "irc-write.h"
|
||||||
#include "conf.h"
|
#include "conf.h"
|
||||||
@ -602,6 +603,7 @@ IRC_LIST( CLIENT *Client, REQUEST *Req )
|
|||||||
char *pattern;
|
char *pattern;
|
||||||
CHANNEL *chan;
|
CHANNEL *chan;
|
||||||
CLIENT *from, *target;
|
CLIENT *from, *target;
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
assert(Client != NULL);
|
assert(Client != NULL);
|
||||||
assert(Req != NULL);
|
assert(Req != NULL);
|
||||||
@ -654,12 +656,17 @@ IRC_LIST( CLIENT *Client, REQUEST *Req )
|
|||||||
/* Gotcha! */
|
/* Gotcha! */
|
||||||
if (!strchr(Channel_Modes(chan), 's')
|
if (!strchr(Channel_Modes(chan), 's')
|
||||||
|| Channel_IsMemberOf(chan, from)) {
|
|| Channel_IsMemberOf(chan, from)) {
|
||||||
|
if (IRC_CheckListTooBig(from, count,
|
||||||
|
MAX_RPL_LIST,
|
||||||
|
"LIST"))
|
||||||
|
break;
|
||||||
if (!IRC_WriteStrClient(from,
|
if (!IRC_WriteStrClient(from,
|
||||||
RPL_LIST_MSG, Client_ID(from),
|
RPL_LIST_MSG, Client_ID(from),
|
||||||
Channel_Name(chan),
|
Channel_Name(chan),
|
||||||
Channel_MemberCount(chan),
|
Channel_MemberCount(chan),
|
||||||
Channel_Topic( chan )))
|
Channel_Topic( chan )))
|
||||||
return DISCONNECTED;
|
return DISCONNECTED;
|
||||||
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
chan = Channel_Next(chan);
|
chan = Channel_Next(chan);
|
||||||
@ -672,6 +679,7 @@ IRC_LIST( CLIENT *Client, REQUEST *Req )
|
|||||||
pattern = NULL;
|
pattern = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
IRC_SetPenalty(from, 2);
|
||||||
return IRC_WriteStrClient(from, RPL_LISTEND_MSG, Client_ID(from));
|
return IRC_WriteStrClient(from, RPL_LISTEND_MSG, Client_ID(from));
|
||||||
} /* IRC_LIST */
|
} /* IRC_LIST */
|
||||||
|
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include "match.h"
|
#include "match.h"
|
||||||
#include "tool.h"
|
#include "tool.h"
|
||||||
#include "parse.h"
|
#include "parse.h"
|
||||||
|
#include "irc.h"
|
||||||
#include "irc-write.h"
|
#include "irc-write.h"
|
||||||
|
|
||||||
#include "exp.h"
|
#include "exp.h"
|
||||||
@ -833,6 +834,7 @@ IRC_WHO_Channel(CLIENT *Client, CHANNEL *Chan, bool OnlyOps)
|
|||||||
const char *chan_user_modes;
|
const char *chan_user_modes;
|
||||||
char flags[8];
|
char flags[8];
|
||||||
CLIENT *c;
|
CLIENT *c;
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
assert( Client != NULL );
|
assert( Client != NULL );
|
||||||
assert( Chan != NULL );
|
assert( Chan != NULL );
|
||||||
@ -855,6 +857,9 @@ IRC_WHO_Channel(CLIENT *Client, CHANNEL *Chan, bool OnlyOps)
|
|||||||
|
|
||||||
is_visible = strchr(client_modes, 'i') == NULL;
|
is_visible = strchr(client_modes, 'i') == NULL;
|
||||||
if (is_member || is_visible) {
|
if (is_member || is_visible) {
|
||||||
|
if (IRC_CheckListTooBig(Client, count, MAX_RPL_WHO, "WHO"))
|
||||||
|
break;
|
||||||
|
|
||||||
strcpy(flags, who_flags_status(client_modes));
|
strcpy(flags, who_flags_status(client_modes));
|
||||||
if (is_ircop)
|
if (is_ircop)
|
||||||
strlcat(flags, "*", sizeof(flags));
|
strlcat(flags, "*", sizeof(flags));
|
||||||
@ -866,6 +871,7 @@ IRC_WHO_Channel(CLIENT *Client, CHANNEL *Chan, bool OnlyOps)
|
|||||||
if (!write_whoreply(Client, c, Channel_Name(Chan),
|
if (!write_whoreply(Client, c, Channel_Name(Chan),
|
||||||
flags))
|
flags))
|
||||||
return DISCONNECTED;
|
return DISCONNECTED;
|
||||||
|
count++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return IRC_WriteStrClient(Client, RPL_ENDOFWHO_MSG, Client_ID(Client),
|
return IRC_WriteStrClient(Client, RPL_ENDOFWHO_MSG, Client_ID(Client),
|
||||||
@ -889,6 +895,7 @@ IRC_WHO_Mask(CLIENT *Client, char *Mask, bool OnlyOps)
|
|||||||
CHANNEL *chan;
|
CHANNEL *chan;
|
||||||
bool client_match, is_visible;
|
bool client_match, is_visible;
|
||||||
char flags[4];
|
char flags[4];
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
assert (Client != NULL);
|
assert (Client != NULL);
|
||||||
|
|
||||||
@ -939,13 +946,16 @@ IRC_WHO_Mask(CLIENT *Client, char *Mask, bool OnlyOps)
|
|||||||
if (!is_visible) /* target user is not visible */
|
if (!is_visible) /* target user is not visible */
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if (IRC_CheckListTooBig(Client, count, MAX_RPL_WHO, "WHO"))
|
||||||
|
break;
|
||||||
|
|
||||||
strcpy(flags, who_flags_status(Client_Modes(c)));
|
strcpy(flags, who_flags_status(Client_Modes(c)));
|
||||||
if (strchr(Client_Modes(c), 'o'))
|
if (strchr(Client_Modes(c), 'o'))
|
||||||
strlcat(flags, "*", sizeof(flags));
|
strlcat(flags, "*", sizeof(flags));
|
||||||
|
|
||||||
if (!write_whoreply(Client, c, "*", flags))
|
if (!write_whoreply(Client, c, "*", flags))
|
||||||
return DISCONNECTED;
|
return DISCONNECTED;
|
||||||
|
count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
return IRC_WriteStrClient(Client, RPL_ENDOFWHO_MSG, Client_ID(Client),
|
return IRC_WriteStrClient(Client, RPL_ENDOFWHO_MSG, Client_ID(Client),
|
||||||
@ -1182,7 +1192,7 @@ IRC_WHOIS( CLIENT *Client, REQUEST *Req )
|
|||||||
* - no wildcards for remote clients
|
* - no wildcards for remote clients
|
||||||
* - only one wildcard target per local client
|
* - only one wildcard target per local client
|
||||||
*
|
*
|
||||||
* also, at most ten matches are returned.
|
* Also, at most MAX_RPL_WHOIS matches are returned.
|
||||||
*/
|
*/
|
||||||
if (!has_wildcards || is_remote) {
|
if (!has_wildcards || is_remote) {
|
||||||
c = Client_Search(query);
|
c = Client_Search(query);
|
||||||
@ -1208,13 +1218,18 @@ IRC_WHOIS( CLIENT *Client, REQUEST *Req )
|
|||||||
got_wildcard = true;
|
got_wildcard = true;
|
||||||
IRC_SetPenalty(Client, 3);
|
IRC_SetPenalty(Client, 3);
|
||||||
|
|
||||||
for (c = Client_First(); c && match_count < 10; c = Client_Next(c)) {
|
for (c = Client_First(); c; c = Client_Next(c)) {
|
||||||
|
if (IRC_CheckListTooBig(Client, match_count,
|
||||||
|
MAX_RPL_WHOIS, "WHOIS"))
|
||||||
|
break;
|
||||||
|
|
||||||
if (Client_Type(c) != CLIENT_USER)
|
if (Client_Type(c) != CLIENT_USER)
|
||||||
continue;
|
continue;
|
||||||
if (!MatchCaseInsensitive(query, Client_ID(c)))
|
if (!MatchCaseInsensitive(query, Client_ID(c)))
|
||||||
continue;
|
continue;
|
||||||
if (!IRC_WHOIS_SendReply(Client, from, c))
|
if (!IRC_WHOIS_SendReply(Client, from, c))
|
||||||
return DISCONNECTED;
|
return DISCONNECTED;
|
||||||
|
|
||||||
match_count++;
|
match_count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1310,7 +1325,7 @@ IRC_WHOWAS( CLIENT *Client, REQUEST *Req )
|
|||||||
if (Req->argc > 1) {
|
if (Req->argc > 1) {
|
||||||
max = atoi(Req->argv[1]);
|
max = atoi(Req->argv[1]);
|
||||||
if (max < 1)
|
if (max < 1)
|
||||||
max = MAX_WHOWAS;
|
max = MAX_RPL_WHOWAS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user