2 * ircd-ratbox: A slightly useful ircd.
3 * m_info.c: Sends information about the server.
5 * Copyright (C) 1990 Jarkko Oikarinen and University of Oulu, Co Center
6 * Copyright (C) 1996-2002 Hybrid Development Team
7 * Copyright (C) 2002-2005 ircd-ratbox development team
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
24 * $Id: m_info.c 3396 2007-04-05 00:38:52Z jilles $
44 static void send_conf_options(struct Client
*source_p
);
45 static void send_birthdate_online_time(struct Client
*source_p
);
46 static void send_info_text(struct Client
*source_p
);
47 static void info_spy(struct Client
*);
49 static int m_info(struct Client
*, struct Client
*, int, const char **);
50 static int mo_info(struct Client
*, struct Client
*, int, const char **);
52 struct Message info_msgtab
= {
53 "INFO", 0, 0, 0, MFLG_SLOW
,
54 {mg_unreg
, {m_info
, 0}, {mo_info
, 0}, mg_ignore
, mg_ignore
, {mo_info
, 0}}
59 mapi_clist_av1 info_clist
[] = { &info_msgtab
, NULL
};
60 mapi_hlist_av1 info_hlist
[] = {
61 { "doing_info", &doing_info_hook
},
65 DECLARE_MODULE_AV1(info
, NULL
, NULL
, info_clist
, info_hlist
, NULL
, "$Revision: 3396 $");
68 * jdc -- Structure for our configuration value table
72 const char *name
; /* Displayed variable name */
73 unsigned int output_type
; /* See below #defines */
74 void *option
; /* Pointer reference to the value */
75 const char *desc
; /* ASCII description of the variable */
77 /* Types for output_type in InfoStruct */
78 #define OUTPUT_STRING 0x0001 /* Output option as %s w/ dereference */
79 #define OUTPUT_STRING_PTR 0x0002 /* Output option as %s w/out deference */
80 #define OUTPUT_DECIMAL 0x0004 /* Output option as decimal (%d) */
81 #define OUTPUT_BOOLEAN 0x0008 /* Output option as "ON" or "OFF" */
82 #define OUTPUT_BOOLEAN_YN 0x0010 /* Output option as "YES" or "NO" */
83 #define OUTPUT_BOOLEAN2 0x0020 /* Output option as "YES/NO/MASKED" */
86 static struct InfoStruct info_table
[] = {
87 /* --[ START OF TABLE ]-------------------------------------------- */
89 "opers_see_all_users",
92 "Farconnect notices available or operspy accountability limited"
98 "Max number connections"
103 &ConfigFileEntry
.anti_nick_flood
,
104 "NICK flood protection"
107 "anti_spam_exit_message_time",
109 &ConfigFileEntry
.anti_spam_exit_message_time
,
110 "Duration a client must be connected for to have an exit message"
115 &ConfigFileEntry
.caller_id_wait
,
116 "Minimum delay between notifying UMODE +g users of messages"
121 &ConfigFileEntry
.client_exit
,
122 "Prepend 'Quit:' to user QUIT messages"
125 "client_flood_max_lines",
127 &ConfigFileEntry
.client_flood_max_lines
,
128 "Number of lines before a client Excess Flood's",
131 "client_flood_burst_rate",
133 &ConfigFileEntry
.client_flood_burst_rate
,
134 "Maximum lines per second during flood grace period",
137 "client_flood_burst_max",
139 &ConfigFileEntry
.client_flood_burst_max
,
140 "Number of lines to process at once before delaying",
143 "client_flood_message_num",
145 &ConfigFileEntry
.client_flood_message_num
,
146 "Number of messages to allow per client_flood_message_time outside of burst",
149 "client_flood_message_time",
151 &ConfigFileEntry
.client_flood_message_time
,
152 "Time to allow per client_flood_message_num outside of burst",
157 &ConfigFileEntry
.connect_timeout
,
158 "Connect timeout for connections to servers"
161 "default_ident_timeout",
163 &ConfigFileEntry
.default_ident_timeout
,
164 "Amount of time the server waits for ident responses from clients",
167 "default_floodcount",
169 &ConfigFileEntry
.default_floodcount
,
170 "Startup value of FLOODCOUNT",
173 "default_adminstring",
175 &ConfigFileEntry
.default_adminstring
,
176 "Default adminstring at startup.",
179 "default_operstring",
181 &ConfigFileEntry
.default_operstring
,
182 "Default operstring at startup.",
187 &ConfigFileEntry
.servicestring
,
188 "String shown in whois for opered services.",
193 &ConfigFileEntry
.disable_auth
,
194 "Controls whether auth checking is disabled or not"
197 "disable_fake_channels",
199 &ConfigFileEntry
.disable_fake_channels
,
200 "Controls whether bold etc are disabled for JOIN"
205 &ConfigFileEntry
.dots_in_ident
,
206 "Number of permissable dots in an ident"
209 "failed_oper_notice",
211 &ConfigFileEntry
.failed_oper_notice
,
212 "Inform opers if someone /oper's with the wrong password"
217 &ConfigFileEntry
.fname_userlog
,
223 &ConfigFileEntry
.fname_fuserlog
,
224 "Failed user log file"
230 &ConfigFileEntry
.fname_operlog
,
236 &ConfigFileEntry
.fname_foperlog
,
237 "Failed operator log file"
242 &ConfigFileEntry
.fname_serverlog
,
243 "Server connect/disconnect log file"
248 &ConfigFileEntry
.fname_klinelog
,
254 &ConfigFileEntry
.fname_operspylog
,
260 &ConfigFileEntry
.fname_ioerrorlog
,
266 &ConfigFileEntry
.global_snotices
,
267 "Send out certain server notices globally"
270 "hide_error_messages",
272 &ConfigFileEntry
.hide_error_messages
,
273 "Hide ERROR messages coming from servers"
278 &ConfigFileEntry
.hide_spoof_ips
,
279 "Hide IPs of spoofed users"
290 &ConfigFileEntry
.kline_delay
,
291 "Duration of time to delay kline checking"
296 &ConfigFileEntry
.kline_reason
,
297 "K-lined clients sign off with this reason"
302 &ConfigFileEntry
.dline_with_reason
,
303 "Display D-line reason to client on disconnect"
308 &ConfigFileEntry
.kline_with_reason
,
309 "Display K-line reason to client on disconnect"
314 &ConfigFileEntry
.max_accept
,
315 "Maximum nicknames on accept list",
320 &ConfigFileEntry
.max_nick_changes
,
321 "NICK change threshhold setting"
326 &ConfigFileEntry
.max_nick_time
,
327 "NICK flood protection time interval"
332 &ConfigFileEntry
.max_targets
,
333 "The maximum number of PRIVMSG/NOTICE targets"
338 &ConfigFileEntry
.min_nonwildcard
,
339 "Minimum non-wildcard chars in K lines",
342 "min_nonwildcard_simple",
344 &ConfigFileEntry
.min_nonwildcard_simple
,
345 "Minimum non-wildcard chars in xlines/resvs",
350 &ServerInfo
.network_name
,
356 &ServerInfo
.network_desc
,
357 "Network description"
362 &ConfigFileEntry
.nick_delay
,
363 "Delay nicks are locked for on split",
368 &ConfigFileEntry
.no_oper_flood
,
369 "Disable flood control for operators",
372 "non_redundant_klines",
374 &ConfigFileEntry
.non_redundant_klines
,
375 "Check for and disallow redundant K-lines"
378 "operspy_admin_only",
380 &ConfigFileEntry
.operspy_admin_only
,
381 "Send +Z operspy notices to admins only"
384 "operspy_dont_care_user_info",
386 &ConfigFileEntry
.operspy_dont_care_user_info
,
387 "Remove accountability and some '!' requirement from non-channel operspy"
392 &ConfigFileEntry
.pace_wait
,
393 "Minimum delay between uses of certain commands"
398 &ConfigFileEntry
.pace_wait_simple
,
399 "Minimum delay between less intensive commands"
404 &ConfigFileEntry
.ping_cookie
,
405 "Require ping cookies to connect",
408 "reject_after_count",
410 &ConfigFileEntry
.reject_after_count
,
411 "Client rejection threshold setting",
416 &ConfigFileEntry
.reject_ban_time
,
417 "Client rejection time interval",
422 &ConfigFileEntry
.reject_duration
,
423 "Client rejection cache duration",
428 &ConfigFileEntry
.short_motd
,
429 "Do not show MOTD; only tell clients they should read it"
434 &ConfigFileEntry
.stats_e_disabled
,
435 "STATS e output is disabled",
440 &ConfigFileEntry
.stats_c_oper_only
,
441 "STATS C output is only shown to operators",
446 &ConfigFileEntry
.stats_h_oper_only
,
447 "STATS H output is only shown to operators",
452 &ConfigFileEntry
.stats_i_oper_only
,
453 "STATS I output is only shown to operators",
458 &ConfigFileEntry
.stats_k_oper_only
,
459 "STATS K output is only shown to operators",
464 &ConfigFileEntry
.stats_o_oper_only
,
465 "STATS O output is only shown to operators",
470 &ConfigFileEntry
.stats_P_oper_only
,
471 "STATS P is only shown to operators",
476 &ConfigFileEntry
.stats_y_oper_only
,
477 "STATS Y is only shown to operators",
482 &ConfigFileEntry
.throttle_count
,
483 "Connection throttle threshold",
488 &ConfigFileEntry
.throttle_duration
,
489 "Connection throttle duration",
492 "tkline_expire_notices",
494 &ConfigFileEntry
.tkline_expire_notices
,
495 "Notices given to opers when tklines expire"
500 &ConfigFileEntry
.ts_max_delta
,
501 "Maximum permitted TS delta from another server"
506 &ConfigFileEntry
.ts_warn_delta
,
507 "Maximum permitted TS delta before displaying a warning"
512 &ConfigFileEntry
.warn_no_nline
,
513 "Display warning if connecting server lacks N-line"
516 "use_propagated_bans",
518 &ConfigFileEntry
.use_propagated_bans
,
519 "KLINE sets fully propagated bans"
522 "max_ratelimit_tokens",
524 &ConfigFileEntry
.max_ratelimit_tokens
,
525 "The maximum number of tokens that can be accumulated for executing rate-limited commands",
530 &ConfigFileEntry
.away_interval
,
531 "The minimum time between aways",
534 "default_split_server_count",
536 &ConfigChannel
.default_split_server_count
,
537 "Startup value of SPLITNUM",
540 "default_split_user_count",
542 &ConfigChannel
.default_split_user_count
,
543 "Startup value of SPLITUSERS",
548 &ConfigChannel
.knock_delay
,
549 "Delay between a users KNOCK attempts"
552 "knock_delay_channel",
554 &ConfigChannel
.knock_delay_channel
,
555 "Delay between KNOCK attempts to a channel",
558 "kick_on_split_riding",
560 &ConfigChannel
.kick_on_split_riding
,
561 "Kick users riding splits to join +i or +k channels"
564 "disable_local_channels",
566 &ConfigChannel
.disable_local_channels
,
567 "Disable local channels (&channels)"
572 &ConfigChannel
.max_bans
,
573 "Total +b/e/I/q modes allowed in a channel",
578 &ConfigChannel
.max_bans_large
,
579 "Total +b/e/I/q modes allowed in a +L channel",
582 "max_chans_per_user",
584 &ConfigChannel
.max_chans_per_user
,
585 "Maximum number of channels a user can join",
588 "no_create_on_split",
590 &ConfigChannel
.no_create_on_split
,
591 "Disallow creation of channels when split",
596 &ConfigChannel
.no_join_on_split
,
597 "Disallow joining channels when split",
600 "only_ascii_channels",
602 &ConfigChannel
.only_ascii_channels
,
603 "Controls whether non-ASCII is disabled for JOIN"
608 &ConfigChannel
.use_except
,
609 "Enable chanmode +e (ban exceptions)",
614 &ConfigChannel
.use_invex
,
615 "Enable chanmode +I (invite exceptions)",
620 &ConfigChannel
.use_forward
,
621 "Enable chanmode +f (channel forwarding)",
626 &ConfigChannel
.use_knock
,
632 &ConfigChannel
.resv_forcepart
,
633 "Force-part local users on channel RESV"
638 &ConfigServerHide
.disable_hidden
,
639 "Prevent servers from hiding themselves from a flattened /links",
644 &ConfigServerHide
.flatten_links
,
645 "Flatten /links list",
650 &ConfigServerHide
.hidden
,
651 "Hide this server from a flattened /links on remote servers",
656 &ConfigServerHide
.links_delay
,
659 /* --[ END OF TABLE ]---------------------------------------------- */
660 { (char *) 0, (unsigned int) 0, (void *) 0, (char *) 0}
666 ** parv[1] = servername
669 m_info(struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
671 static time_t last_used
= 0L;
673 if((last_used
+ ConfigFileEntry
.pace_wait
) > rb_current_time())
675 /* safe enough to give this on a local connect only */
676 sendto_one(source_p
, form_str(RPL_LOAD2HI
),
677 me
.name
, source_p
->name
, "INFO");
678 sendto_one_numeric(source_p
, RPL_ENDOFINFO
, form_str(RPL_ENDOFINFO
));
682 last_used
= rb_current_time();
684 if(hunt_server(client_p
, source_p
, ":%s INFO :%s", 1, parc
, parv
) != HUNTED_ISME
)
689 send_info_text(source_p
);
690 send_birthdate_online_time(source_p
);
692 sendto_one_numeric(source_p
, RPL_ENDOFINFO
, form_str(RPL_ENDOFINFO
));
698 ** parv[1] = servername
701 mo_info(struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
703 if(hunt_server(client_p
, source_p
, ":%s INFO :%s", 1, parc
, parv
) == HUNTED_ISME
)
706 send_info_text(source_p
);
710 send_conf_options(source_p
);
711 sendto_one_numeric(source_p
, RPL_INFO
, ":%s",
715 send_birthdate_online_time(source_p
);
717 sendto_one_numeric(source_p
, RPL_ENDOFINFO
, form_str(RPL_ENDOFINFO
));
726 * inputs - client pointer to send info text to
728 * side effects - info text is sent to client
731 send_info_text(struct Client
*source_p
)
733 const char **text
= infotext
;
737 sendto_one_numeric(source_p
, RPL_INFO
, form_str(RPL_INFO
), *text
++);
740 sendto_one_numeric(source_p
, RPL_INFO
, form_str(RPL_INFO
), "");
744 * send_birthdate_online_time
746 * inputs - client pointer to send to
748 * side effects - birthdate and online time are sent
751 send_birthdate_online_time(struct Client
*source_p
)
753 char tbuf
[26]; /* this needs to be 26 - see ctime_r manpage */
754 sendto_one(source_p
, ":%s %d %s :Birth Date: %s, compile # %s",
755 get_id(&me
, source_p
), RPL_INFO
,
756 get_id(source_p
, source_p
), creation
, generation
);
758 sendto_one(source_p
, ":%s %d %s :On-line since %s",
759 get_id(&me
, source_p
), RPL_INFO
,
760 get_id(source_p
, source_p
), rb_ctime(startup_time
, tbuf
, sizeof(tbuf
)));
766 * inputs - client pointer to send to
768 * side effects - send config options to client
771 send_conf_options(struct Client
*source_p
)
777 * Now send them a list of all our configuration options
778 * (mostly from config.h)
780 for (infoptr
= MyInformation
; infoptr
->name
; infoptr
++)
782 if(infoptr
->intvalue
)
784 sendto_one(source_p
, ":%s %d %s :%-30s %-5d [%-30s]",
785 get_id(&me
, source_p
), RPL_INFO
,
786 get_id(source_p
, source_p
),
787 infoptr
->name
, infoptr
->intvalue
,
792 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
793 get_id(&me
, source_p
), RPL_INFO
,
794 get_id(source_p
, source_p
),
795 infoptr
->name
, infoptr
->strvalue
,
801 * Parse the info_table[] and do the magic.
803 for (i
= 0; info_table
[i
].name
; i
++)
805 switch (info_table
[i
].output_type
)
808 * For "char *" references
812 char *option
= *((char **) info_table
[i
].option
);
814 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
815 get_id(&me
, source_p
), RPL_INFO
,
816 get_id(source_p
, source_p
),
818 option
? option
: "NONE",
819 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
824 * For "char foo[]" references
826 case OUTPUT_STRING_PTR
:
828 char *option
= (char *) info_table
[i
].option
;
830 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
831 get_id(&me
, source_p
), RPL_INFO
,
832 get_id(source_p
, source_p
),
834 EmptyString(option
) ? "NONE" : option
,
835 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
840 * Output info_table[i].option as a decimal value.
844 int option
= *((int *) info_table
[i
].option
);
846 sendto_one(source_p
, ":%s %d %s :%-30s %-5d [%-30s]",
847 get_id(&me
, source_p
), RPL_INFO
,
848 get_id(source_p
, source_p
),
851 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
857 * Output info_table[i].option as "ON" or "OFF"
861 int option
= *((int *) info_table
[i
].option
);
863 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
864 get_id(&me
, source_p
), RPL_INFO
,
865 get_id(source_p
, source_p
),
867 option
? "ON" : "OFF",
868 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
873 * Output info_table[i].option as "YES" or "NO"
875 case OUTPUT_BOOLEAN_YN
:
877 int option
= *((int *) info_table
[i
].option
);
879 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
880 get_id(&me
, source_p
), RPL_INFO
,
881 get_id(source_p
, source_p
),
883 option
? "YES" : "NO",
884 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
889 case OUTPUT_BOOLEAN2
:
891 int option
= *((int *) info_table
[i
].option
);
893 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
894 me
.name
, RPL_INFO
, source_p
->name
,
896 option
? ((option
== 1) ? "MASK" : "YES") : "NO",
897 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
898 } /* switch (info_table[i].output_type) */
903 /* Don't send oper_only_umodes...it's a bit mask, we will have to decode it
904 ** in order for it to show up properly to opers who issue INFO
907 sendto_one_numeric(source_p
, RPL_INFO
, form_str(RPL_INFO
), "");
912 * input - pointer to client
914 * side effects - hook doing_info is called
917 info_spy(struct Client
*source_p
)
921 hd
.client
= source_p
;
922 hd
.arg1
= hd
.arg2
= NULL
;
924 call_hook(doing_info_hook
, &hd
);