"Prepend 'Client Exit:' to user QUIT messages"
},
{
- "client_flood",
+ "client_flood_max_lines",
OUTPUT_DECIMAL,
- &ConfigFileEntry.client_flood,
+ &ConfigFileEntry.client_flood_max_lines,
"Number of lines before a client Excess Flood's",
},
+ {
+ "client_flood_burst_rate",
+ OUTPUT_DECIMAL,
+ &ConfigFileEntry.client_flood_burst_rate,
+ "Rate at which burst lines are processed",
+ },
+ {
+ "client_flood_burst_max",
+ OUTPUT_DECIMAL,
+ &ConfigFileEntry.client_flood_burst_max,
+ "Number of lines to permit at client_flood_burst_rate",
+ },
+ {
+ "client_flood_message_num",
+ OUTPUT_DECIMAL,
+ &ConfigFileEntry.client_flood_message_num,
+ "Number of messages to allow per client_flood_message_time outside of burst",
+ },
+ {
+ "client_flood_message_time",
+ OUTPUT_DECIMAL,
+ &ConfigFileEntry.client_flood_message_time,
+ "Time to allow per client_flood_message_num outside of burst",
+ },
{
"connect_timeout",
OUTPUT_DECIMAL,
&ConfigFileEntry.connect_timeout,
"Connect timeout for connections to servers"
},
+ {
+ "default_ident_timeout",
+ OUTPUT_DECIMAL,
+ &ConfigFileEntry.default_ident_timeout,
+ "Amount of time the server waits for ident responses from clients",
+ },
{
"default_floodcount",
OUTPUT_DECIMAL,
&ConfigChannel.kick_on_split_riding,
"Kick users riding splits to join +i or +k channels"
},
+ {
+ "disable_local_channels",
+ OUTPUT_BOOLEAN_YN,
+ &ConfigChannel.disable_local_channels,
+ "Disable local channels (&channels)"
+ },
{
"max_bans",
OUTPUT_DECIMAL,
{
"resv_forcepart",
OUTPUT_BOOLEAN_YN,
- { &ConfigChannel.resv_forcepart },
+ &ConfigChannel.resv_forcepart,
"Force-part local users on channel RESV"
},
{
/* *INDENT-ON* */
/*
-** m_info
-** parv[1] = servername
-*/
+ ** m_info
+ ** parv[1] = servername
+ */
static int
m_info(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
{
/* safe enough to give this on a local connect only */
sendto_one(source_p, form_str(RPL_LOAD2HI),
- me.name, source_p->name, "INFO");
+ me.name, source_p->name, "INFO");
sendto_one_numeric(source_p, RPL_ENDOFINFO, form_str(RPL_ENDOFINFO));
return 0;
}
}
/*
-** mo_info
-** parv[1] = servername
-*/
+ ** mo_info
+ ** parv[1] = servername
+ */
static int
mo_info(struct Client *client_p, struct Client *source_p, int parc, const char *parv[])
{
{
char tbuf[26]; /* this needs to be 26 - see ctime_r manpage */
sendto_one(source_p, ":%s %d %s :Birth Date: %s, compile # %s",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p), creation, generation);
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p), creation, generation);
sendto_one(source_p, ":%s %d %s :On-line since %s",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p), rb_ctime(startup_time, tbuf, sizeof(tbuf)));
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p), rb_ctime(startup_time, tbuf, sizeof(tbuf)));
}
/*
if(infoptr->intvalue)
{
sendto_one(source_p, ":%s %d %s :%-30s %-5d [%-30s]",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p),
- infoptr->name, infoptr->intvalue,
- infoptr->desc);
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p),
+ infoptr->name, infoptr->intvalue,
+ infoptr->desc);
}
else
{
sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p),
- infoptr->name, infoptr->strvalue,
- infoptr->desc);
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p),
+ infoptr->name, infoptr->strvalue,
+ infoptr->desc);
}
}
/*
* For "char *" references
*/
- case OUTPUT_STRING:
- {
- char *option = *((char **) info_table[i].option);
-
- sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p),
- info_table[i].name,
- option ? option : "NONE",
- info_table[i].desc ? info_table[i].desc : "<none>");
-
- break;
- }
- /*
- * For "char foo[]" references
- */
- case OUTPUT_STRING_PTR:
- {
- char *option = (char *) info_table[i].option;
-
- sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p),
- info_table[i].name,
- EmptyString(option) ? "NONE" : option,
- info_table[i].desc ? info_table[i].desc : "<none>");
-
- break;
- }
- /*
- * Output info_table[i].option as a decimal value.
- */
- case OUTPUT_DECIMAL:
- {
- int option = *((int *) info_table[i].option);
-
- sendto_one(source_p, ":%s %d %s :%-30s %-5d [%-30s]",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p),
- info_table[i].name,
- option,
- info_table[i].desc ? info_table[i].desc : "<none>");
-
- break;
- }
-
- /*
- * Output info_table[i].option as "ON" or "OFF"
- */
- case OUTPUT_BOOLEAN:
- {
- int option = *((int *) info_table[i].option);
-
- sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p),
- info_table[i].name,
- option ? "ON" : "OFF",
- info_table[i].desc ? info_table[i].desc : "<none>");
-
- break;
- }
- /*
- * Output info_table[i].option as "YES" or "NO"
- */
- case OUTPUT_BOOLEAN_YN:
- {
- int option = *((int *) info_table[i].option);
-
- sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
- get_id(&me, source_p), RPL_INFO,
- get_id(source_p, source_p),
- info_table[i].name,
- option ? "YES" : "NO",
- info_table[i].desc ? info_table[i].desc : "<none>");
-
- break;
- }
-
- case OUTPUT_BOOLEAN2:
- {
- int option = *((int *) info_table[i].option);
-
- sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
- me.name, RPL_INFO, source_p->name,
- info_table[i].name,
- option ? ((option == 1) ? "MASK" : "YES") : "NO",
- info_table[i].desc ? info_table[i].desc : "<none>");
- } /* switch (info_table[i].output_type) */
+ case OUTPUT_STRING:
+ {
+ char *option = *((char **) info_table[i].option);
+
+ sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p),
+ info_table[i].name,
+ option ? option : "NONE",
+ info_table[i].desc ? info_table[i].desc : "<none>");
+
+ break;
+ }
+ /*
+ * For "char foo[]" references
+ */
+ case OUTPUT_STRING_PTR:
+ {
+ char *option = (char *) info_table[i].option;
+
+ sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p),
+ info_table[i].name,
+ EmptyString(option) ? "NONE" : option,
+ info_table[i].desc ? info_table[i].desc : "<none>");
+
+ break;
+ }
+ /*
+ * Output info_table[i].option as a decimal value.
+ */
+ case OUTPUT_DECIMAL:
+ {
+ int option = *((int *) info_table[i].option);
+
+ sendto_one(source_p, ":%s %d %s :%-30s %-5d [%-30s]",
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p),
+ info_table[i].name,
+ option,
+ info_table[i].desc ? info_table[i].desc : "<none>");
+
+ break;
+ }
+
+ /*
+ * Output info_table[i].option as "ON" or "OFF"
+ */
+ case OUTPUT_BOOLEAN:
+ {
+ int option = *((int *) info_table[i].option);
+
+ sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p),
+ info_table[i].name,
+ option ? "ON" : "OFF",
+ info_table[i].desc ? info_table[i].desc : "<none>");
+
+ break;
+ }
+ /*
+ * Output info_table[i].option as "YES" or "NO"
+ */
+ case OUTPUT_BOOLEAN_YN:
+ {
+ int option = *((int *) info_table[i].option);
+
+ sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
+ get_id(&me, source_p), RPL_INFO,
+ get_id(source_p, source_p),
+ info_table[i].name,
+ option ? "YES" : "NO",
+ info_table[i].desc ? info_table[i].desc : "<none>");
+
+ break;
+ }
+
+ case OUTPUT_BOOLEAN2:
+ {
+ int option = *((int *) info_table[i].option);
+
+ sendto_one(source_p, ":%s %d %s :%-30s %-5s [%-30s]",
+ me.name, RPL_INFO, source_p->name,
+ info_table[i].name,
+ option ? ((option == 1) ? "MASK" : "YES") : "NO",
+ info_table[i].desc ? info_table[i].desc : "<none>");
+ } /* switch (info_table[i].output_type) */
}
} /* forloop */