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 'Client Exit:' to user QUIT messages"
127 &ConfigFileEntry
.client_flood
,
128 "Number of lines before a client Excess Flood's",
133 &ConfigFileEntry
.connect_timeout
,
134 "Connect timeout for connections to servers"
137 "default_floodcount",
139 &ConfigFileEntry
.default_floodcount
,
140 "Startup value of FLOODCOUNT",
143 "default_adminstring",
145 &ConfigFileEntry
.default_adminstring
,
146 "Default adminstring at startup.",
149 "default_operstring",
151 &ConfigFileEntry
.default_operstring
,
152 "Default operstring at startup.",
157 &ConfigFileEntry
.servicestring
,
158 "String shown in whois for opered services.",
163 &ConfigFileEntry
.disable_auth
,
164 "Controls whether auth checking is disabled or not"
167 "disable_fake_channels",
169 &ConfigFileEntry
.disable_fake_channels
,
170 "Controls whether bold etc are disabled for JOIN"
175 &ConfigFileEntry
.dots_in_ident
,
176 "Number of permissable dots in an ident"
179 "failed_oper_notice",
181 &ConfigFileEntry
.failed_oper_notice
,
182 "Inform opers if someone /oper's with the wrong password"
187 &ConfigFileEntry
.fname_userlog
,
193 &ConfigFileEntry
.fname_fuserlog
,
194 "Failed user log file"
200 &ConfigFileEntry
.fname_operlog
,
206 &ConfigFileEntry
.fname_foperlog
,
207 "Failed operator log file"
212 &ConfigFileEntry
.fname_serverlog
,
213 "Server connect/disconnect log file"
218 &ConfigFileEntry
.fname_klinelog
,
224 &ConfigFileEntry
.fname_operspylog
,
230 &ConfigFileEntry
.fname_ioerrorlog
,
236 &ConfigFileEntry
.global_snotices
,
237 "Send out certain server notices globally"
240 "hide_error_messages",
242 &ConfigFileEntry
.hide_error_messages
,
243 "Hide ERROR messages coming from servers"
248 &ConfigFileEntry
.hide_spoof_ips
,
249 "Hide IPs of spoofed users"
260 &ConfigFileEntry
.kline_delay
,
261 "Duration of time to delay kline checking"
266 &ConfigFileEntry
.kline_reason
,
267 "K-lined clients sign off with this reason"
272 &ConfigFileEntry
.dline_with_reason
,
273 "Display D-line reason to client on disconnect"
278 &ConfigFileEntry
.kline_with_reason
,
279 "Display K-line reason to client on disconnect"
284 &ConfigFileEntry
.max_accept
,
285 "Maximum nicknames on accept list",
290 &ConfigFileEntry
.max_nick_changes
,
291 "NICK change threshhold setting"
296 &ConfigFileEntry
.max_nick_time
,
297 "NICK flood protection time interval"
302 &ConfigFileEntry
.max_targets
,
303 "The maximum number of PRIVMSG/NOTICE targets"
308 &ConfigFileEntry
.min_nonwildcard
,
309 "Minimum non-wildcard chars in K lines",
312 "min_nonwildcard_simple",
314 &ConfigFileEntry
.min_nonwildcard_simple
,
315 "Minimum non-wildcard chars in xlines/resvs",
320 &ServerInfo
.network_name
,
326 &ServerInfo
.network_desc
,
327 "Network description"
332 &ConfigFileEntry
.nick_delay
,
333 "Delay nicks are locked for on split",
338 &ConfigFileEntry
.no_oper_flood
,
339 "Disable flood control for operators",
342 "non_redundant_klines",
344 &ConfigFileEntry
.non_redundant_klines
,
345 "Check for and disallow redundant K-lines"
348 "operspy_admin_only",
350 &ConfigFileEntry
.operspy_admin_only
,
351 "Send +Z operspy notices to admins only"
354 "operspy_dont_care_user_info",
356 &ConfigFileEntry
.operspy_dont_care_user_info
,
357 "Remove accountability and some '!' requirement from non-channel operspy"
362 &ConfigFileEntry
.pace_wait
,
363 "Minimum delay between uses of certain commands"
368 &ConfigFileEntry
.pace_wait_simple
,
369 "Minimum delay between less intensive commands"
374 &ConfigFileEntry
.ping_cookie
,
375 "Require ping cookies to connect",
378 "reject_after_count",
380 &ConfigFileEntry
.reject_after_count
,
381 "Client rejection threshold setting",
386 &ConfigFileEntry
.reject_ban_time
,
387 "Client rejection time interval",
392 &ConfigFileEntry
.reject_duration
,
393 "Client rejection cache duration",
398 &ConfigFileEntry
.short_motd
,
399 "Do not show MOTD; only tell clients they should read it"
404 &ConfigFileEntry
.stats_e_disabled
,
405 "STATS e output is disabled",
410 &ConfigFileEntry
.stats_c_oper_only
,
411 "STATS C output is only shown to operators",
416 &ConfigFileEntry
.stats_h_oper_only
,
417 "STATS H output is only shown to operators",
422 &ConfigFileEntry
.stats_i_oper_only
,
423 "STATS I output is only shown to operators",
428 &ConfigFileEntry
.stats_k_oper_only
,
429 "STATS K output is only shown to operators",
434 &ConfigFileEntry
.stats_o_oper_only
,
435 "STATS O output is only shown to operators",
440 &ConfigFileEntry
.stats_P_oper_only
,
441 "STATS P is only shown to operators",
446 &ConfigFileEntry
.stats_y_oper_only
,
447 "STATS Y is only shown to operators",
452 &ConfigFileEntry
.throttle_count
,
453 "Connection throttle threshold",
458 &ConfigFileEntry
.throttle_duration
,
459 "Connection throttle duration",
462 "tkline_expire_notices",
464 &ConfigFileEntry
.tkline_expire_notices
,
465 "Notices given to opers when tklines expire"
470 &ConfigFileEntry
.ts_max_delta
,
471 "Maximum permitted TS delta from another server"
476 &ConfigFileEntry
.ts_warn_delta
,
477 "Maximum permitted TS delta before displaying a warning"
482 &ConfigFileEntry
.warn_no_nline
,
483 "Display warning if connecting server lacks N-line"
486 "default_split_server_count",
488 &ConfigChannel
.default_split_server_count
,
489 "Startup value of SPLITNUM",
492 "default_split_user_count",
494 &ConfigChannel
.default_split_user_count
,
495 "Startup value of SPLITUSERS",
500 &ConfigChannel
.knock_delay
,
501 "Delay between a users KNOCK attempts"
504 "knock_delay_channel",
506 &ConfigChannel
.knock_delay_channel
,
507 "Delay between KNOCK attempts to a channel",
510 "kick_on_split_riding",
512 &ConfigChannel
.kick_on_split_riding
,
513 "Kick users riding splits to join +i or +k channels"
518 &ConfigChannel
.max_bans
,
519 "Total +b/e/I/q modes allowed in a channel",
524 &ConfigChannel
.max_bans_large
,
525 "Total +b/e/I/q modes allowed in a +L channel",
528 "max_chans_per_user",
530 &ConfigChannel
.max_chans_per_user
,
531 "Maximum number of channels a user can join",
534 "no_create_on_split",
536 &ConfigChannel
.no_create_on_split
,
537 "Disallow creation of channels when split",
542 &ConfigChannel
.no_join_on_split
,
543 "Disallow joining channels when split",
548 &ConfigChannel
.use_except
,
549 "Enable chanmode +e (ban exceptions)",
554 &ConfigChannel
.use_invex
,
555 "Enable chanmode +I (invite exceptions)",
560 &ConfigChannel
.use_forward
,
561 "Enable chanmode +f (channel forwarding)",
566 &ConfigChannel
.use_knock
,
572 &ConfigServerHide
.disable_hidden
,
573 "Prevent servers from hiding themselves from a flattened /links",
578 &ConfigServerHide
.flatten_links
,
579 "Flatten /links list",
584 &ConfigServerHide
.hidden
,
585 "Hide this server from a flattened /links on remote servers",
590 &ConfigServerHide
.links_delay
,
593 /* --[ END OF TABLE ]---------------------------------------------- */
594 { (char *) 0, (unsigned int) 0, (void *) 0, (char *) 0}
600 ** parv[0] = sender prefix
601 ** parv[1] = servername
604 m_info(struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
606 static time_t last_used
= 0L;
608 if((last_used
+ ConfigFileEntry
.pace_wait
) > rb_current_time())
610 /* safe enough to give this on a local connect only */
611 sendto_one(source_p
, form_str(RPL_LOAD2HI
),
612 me
.name
, source_p
->name
, "INFO");
613 sendto_one_numeric(source_p
, RPL_ENDOFINFO
, form_str(RPL_ENDOFINFO
));
617 last_used
= rb_current_time();
619 if(hunt_server(client_p
, source_p
, ":%s INFO :%s", 1, parc
, parv
) != HUNTED_ISME
)
624 send_info_text(source_p
);
625 send_birthdate_online_time(source_p
);
627 sendto_one_numeric(source_p
, RPL_ENDOFINFO
, form_str(RPL_ENDOFINFO
));
633 ** parv[0] = sender prefix
634 ** parv[1] = servername
637 mo_info(struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
639 if(hunt_server(client_p
, source_p
, ":%s INFO :%s", 1, parc
, parv
) == HUNTED_ISME
)
642 send_info_text(source_p
);
645 send_conf_options(source_p
);
647 send_birthdate_online_time(source_p
);
649 sendto_one_numeric(source_p
, RPL_ENDOFINFO
, form_str(RPL_ENDOFINFO
));
658 * inputs - client pointer to send info text to
660 * side effects - info text is sent to client
663 send_info_text(struct Client
*source_p
)
665 const char **text
= infotext
;
669 sendto_one_numeric(source_p
, RPL_INFO
, form_str(RPL_INFO
), *text
++);
672 sendto_one_numeric(source_p
, RPL_INFO
, form_str(RPL_INFO
), "");
676 * send_birthdate_online_time
678 * inputs - client pointer to send to
680 * side effects - birthdate and online time are sent
683 send_birthdate_online_time(struct Client
*source_p
)
685 char tbuf
[26]; /* this needs to be 26 - see ctime_r manpage */
686 sendto_one(source_p
, ":%s %d %s :Birth Date: %s, compile # %s",
687 get_id(&me
, source_p
), RPL_INFO
,
688 get_id(source_p
, source_p
), creation
, generation
);
690 sendto_one(source_p
, ":%s %d %s :On-line since %s",
691 get_id(&me
, source_p
), RPL_INFO
,
692 get_id(source_p
, source_p
), rb_ctime(startup_time
, tbuf
, sizeof(tbuf
)));
698 * inputs - client pointer to send to
700 * side effects - send config options to client
703 send_conf_options(struct Client
*source_p
)
709 * Now send them a list of all our configuration options
710 * (mostly from config.h)
712 for (infoptr
= MyInformation
; infoptr
->name
; infoptr
++)
714 if(infoptr
->intvalue
)
716 sendto_one(source_p
, ":%s %d %s :%-30s %-5d [%-30s]",
717 get_id(&me
, source_p
), RPL_INFO
,
718 get_id(source_p
, source_p
),
719 infoptr
->name
, infoptr
->intvalue
,
724 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
725 get_id(&me
, source_p
), RPL_INFO
,
726 get_id(source_p
, source_p
),
727 infoptr
->name
, infoptr
->strvalue
,
733 * Parse the info_table[] and do the magic.
735 for (i
= 0; info_table
[i
].name
; i
++)
737 switch (info_table
[i
].output_type
)
740 * For "char *" references
744 char *option
= *((char **) info_table
[i
].option
);
746 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
747 get_id(&me
, source_p
), RPL_INFO
,
748 get_id(source_p
, source_p
),
750 option
? option
: "NONE",
751 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
756 * For "char foo[]" references
758 case OUTPUT_STRING_PTR
:
760 char *option
= (char *) info_table
[i
].option
;
762 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
763 get_id(&me
, source_p
), RPL_INFO
,
764 get_id(source_p
, source_p
),
766 EmptyString(option
) ? "NONE" : option
,
767 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
772 * Output info_table[i].option as a decimal value.
776 int option
= *((int *) info_table
[i
].option
);
778 sendto_one(source_p
, ":%s %d %s :%-30s %-5d [%-30s]",
779 get_id(&me
, source_p
), RPL_INFO
,
780 get_id(source_p
, source_p
),
783 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
789 * Output info_table[i].option as "ON" or "OFF"
793 int option
= *((int *) info_table
[i
].option
);
795 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
796 get_id(&me
, source_p
), RPL_INFO
,
797 get_id(source_p
, source_p
),
799 option
? "ON" : "OFF",
800 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
805 * Output info_table[i].option as "YES" or "NO"
807 case OUTPUT_BOOLEAN_YN
:
809 int option
= *((int *) info_table
[i
].option
);
811 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
812 get_id(&me
, source_p
), RPL_INFO
,
813 get_id(source_p
, source_p
),
815 option
? "YES" : "NO",
816 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
821 case OUTPUT_BOOLEAN2
:
823 int option
= *((int *) info_table
[i
].option
);
825 sendto_one(source_p
, ":%s %d %s :%-30s %-5s [%-30s]",
826 me
.name
, RPL_INFO
, source_p
->name
,
828 option
? ((option
== 1) ? "MASK" : "YES") : "NO",
829 info_table
[i
].desc
? info_table
[i
].desc
: "<none>");
830 } /* switch (info_table[i].output_type) */
835 /* Don't send oper_only_umodes...it's a bit mask, we will have to decode it
836 ** in order for it to show up properly to opers who issue INFO
839 sendto_one_numeric(source_p
, RPL_INFO
, form_str(RPL_INFO
), "");
844 * input - pointer to client
846 * side effects - hook doing_info is called
849 info_spy(struct Client
*source_p
)
853 hd
.client
= source_p
;
854 hd
.arg1
= hd
.arg2
= NULL
;
856 call_hook(doing_info_hook
, &hd
);