/* Defaults and limits for IRC commands */
-/** Default count of WHOWAS command replies */
-#define DEF_RPL_WHOWAS 5
+/** Max. number of LIST replies. */
+#define MAX_RPL_LIST 100
-/** Max. number of channel modes with arguments per MODE command */
+/** 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
+
+/** Max count of WHOWAS command replies. */
+#define MAX_RPL_WHOWAS 25
+
#endif
#include "match.h"
#include "messages.h"
#include "parse.h"
+#include "irc.h"
#include "irc-info.h"
#include "irc-write.h"
#include "conf.h"
char *pattern;
CHANNEL *chan;
CLIENT *from, *target;
+ int count = 0;
assert(Client != NULL);
assert(Req != NULL);
/* Gotcha! */
if (!strchr(Channel_Modes(chan), 's')
|| Channel_IsMemberOf(chan, from)) {
+ if (IRC_CheckListTooBig(from, count,
+ MAX_RPL_LIST,
+ "LIST"))
+ break;
if (!IRC_WriteStrClient(from,
RPL_LIST_MSG, Client_ID(from),
Channel_Name(chan),
Channel_MemberCount(chan),
Channel_Topic( chan )))
return DISCONNECTED;
+ count++;
}
}
chan = Channel_Next(chan);
pattern = NULL;
}
+ IRC_SetPenalty(from, 2);
return IRC_WriteStrClient(from, RPL_LISTEND_MSG, Client_ID(from));
} /* IRC_LIST */
#include "match.h"
#include "tool.h"
#include "parse.h"
+#include "irc.h"
#include "irc-write.h"
#include "exp.h"
const char *chan_user_modes;
char flags[8];
CLIENT *c;
+ int count = 0;
assert( Client != NULL );
assert( Chan != NULL );
is_visible = strchr(client_modes, 'i') == NULL;
if (is_member || is_visible) {
+ if (IRC_CheckListTooBig(Client, count, MAX_RPL_WHO, "WHO"))
+ break;
+
strcpy(flags, who_flags_status(client_modes));
if (is_ircop)
strlcat(flags, "*", sizeof(flags));
if (!write_whoreply(Client, c, Channel_Name(Chan),
flags))
return DISCONNECTED;
+ count++;
}
}
return IRC_WriteStrClient(Client, RPL_ENDOFWHO_MSG, Client_ID(Client),
CHANNEL *chan;
bool client_match, is_visible;
char flags[4];
+ int count = 0;
assert (Client != NULL);
if (!is_visible) /* target user is not visible */
continue;
+ if (IRC_CheckListTooBig(Client, count, MAX_RPL_WHO, "WHO"))
+ break;
+
strcpy(flags, who_flags_status(Client_Modes(c)));
if (strchr(Client_Modes(c), 'o'))
strlcat(flags, "*", sizeof(flags));
if (!write_whoreply(Client, c, "*", flags))
return DISCONNECTED;
-
+ count++;
}
return IRC_WriteStrClient(Client, RPL_ENDOFWHO_MSG, Client_ID(Client),
* - no wildcards for remote clients
* - 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) {
c = Client_Search(query);
got_wildcard = true;
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)
continue;
if (!MatchCaseInsensitive(query, Client_ID(c)))
continue;
if (!IRC_WHOIS_SendReply(Client, from, c))
return DISCONNECTED;
+
match_count++;
}
if (Req->argc > 1) {
max = atoi(Req->argv[1]);
if (max < 1)
- max = MAX_WHOWAS;
+ max = MAX_RPL_WHOWAS;
}
/*