]> jfr.im git - solanum.git/blob - include/s_conf.h
client: use sequential connection ids for ssld connections in ssld RPC, instead of...
[solanum.git] / include / s_conf.h
1 /*
2 * charybdis: Advanced, scalable Internet Relay Chat.
3 * s_conf.h: A header for the configuration functions.
4 *
5 * Copyright (C) 1990 Jarkko Oikarinen and University of Oulu, Co Center
6 * Copyright (C) 1996-2002 Hybrid Development Team
7 * Copyright (C) 2002-2004 ircd-ratbox development team
8 *
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.
13 *
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.
18 *
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
22 * USA
23 *
24 * $Id: s_conf.h 3550 2007-08-09 06:47:26Z nenolod $
25 */
26
27 #ifndef INCLUDED_s_conf_h
28 #define INCLUDED_s_conf_h
29 #include "setup.h"
30
31 #ifdef HAVE_LIBCRYPTO
32 #include <openssl/rsa.h>
33 #endif
34
35 #include "ircd_defs.h"
36 #include "class.h"
37 #include "client.h"
38 #include "common.h"
39
40 struct Client;
41 struct DNSReply;
42 struct hostent;
43
44 /* used by new parser */
45 /* yacc/lex love globals!!! */
46
47 struct ip_value
48 {
49 struct rb_sockaddr_storage ip;
50 int ip_mask;
51 int type;
52 };
53
54 extern FILE *conf_fbfile_in;
55 extern char conf_line_in[256];
56
57 struct ConfItem
58 {
59 unsigned int status; /* If CONF_ILLEGAL, delete when no clients */
60 unsigned int flags;
61 int clients; /* Number of *LOCAL* clients using this */
62 union
63 {
64 char *name; /* IRC name, nick, server name, or original u@h */
65 const char *oper;
66 } info;
67 char *host; /* host part of user@host */
68 char *passwd; /* doubles as kline reason *ugh* */
69 char *spasswd; /* Password to send. */
70 char *user; /* user part of user@host */
71 int port;
72 time_t hold; /* Hold action until this time (calendar time) */
73 time_t created; /* Creation time (for klines etc) */
74 time_t lifetime; /* Propagated lines: remember until this time */
75 char *className; /* Name of class */
76 struct Class *c_class; /* Class of connection */
77 rb_patricia_node_t *pnode; /* Our patricia node */
78 };
79
80 #define CONF_ILLEGAL 0x80000000
81 #define CONF_CLIENT 0x0002
82 #define CONF_KILL 0x0040
83 #define CONF_XLINE 0x0080
84 #define CONF_RESV_CHANNEL 0x0100
85 #define CONF_RESV_NICK 0x0200
86 #define CONF_RESV (CONF_RESV_CHANNEL | CONF_RESV_NICK)
87
88 #define CONF_DLINE 0x20000
89 #define CONF_EXEMPTDLINE 0x100000
90
91 #define IsIllegal(x) ((x)->status & CONF_ILLEGAL)
92
93 /* aConfItem->flags */
94
95 /* Generic flags... */
96 #define CONF_FLAGS_TEMPORARY 0x00800000
97 #define CONF_FLAGS_NEED_SSL 0x00000002
98 #define CONF_FLAGS_MYOPER 0x00080000 /* need to rewrite info.oper on burst */
99 /* auth{} flags... */
100 #define CONF_FLAGS_NO_TILDE 0x00000004
101 #define CONF_FLAGS_NEED_IDENTD 0x00000008
102 #define CONF_FLAGS_EXEMPTKLINE 0x00000040
103 #define CONF_FLAGS_NOLIMIT 0x00000080
104 #define CONF_FLAGS_SPOOF_IP 0x00000200
105 #define CONF_FLAGS_SPOOF_NOTICE 0x00000400
106 #define CONF_FLAGS_REDIR 0x00000800
107 #define CONF_FLAGS_EXEMPTRESV 0x00002000 /* exempt from resvs */
108 #define CONF_FLAGS_EXEMPTFLOOD 0x00004000
109 #define CONF_FLAGS_EXEMPTSPAMBOT 0x00008000
110 #define CONF_FLAGS_EXEMPTSHIDE 0x00010000
111 #define CONF_FLAGS_EXEMPTJUPE 0x00020000 /* exempt from resv generating warnings */
112 #define CONF_FLAGS_NEED_SASL 0x00040000
113 #define CONF_FLAGS_ENCRYPTED 0x00200000
114 #define CONF_FLAGS_EXEMPTDNSBL 0x04000000
115
116
117 /* Macros for struct ConfItem */
118 #define IsConfBan(x) ((x)->status & (CONF_KILL|CONF_XLINE|CONF_DLINE|\
119 CONF_RESV_CHANNEL|CONF_RESV_NICK))
120
121 #define IsNoTilde(x) ((x)->flags & CONF_FLAGS_NO_TILDE)
122 #define IsNeedIdentd(x) ((x)->flags & CONF_FLAGS_NEED_IDENTD)
123 #define IsConfExemptKline(x) ((x)->flags & CONF_FLAGS_EXEMPTKLINE)
124 #define IsConfExemptLimits(x) ((x)->flags & CONF_FLAGS_NOLIMIT)
125 #define IsConfExemptFlood(x) ((x)->flags & CONF_FLAGS_EXEMPTFLOOD)
126 #define IsConfExemptSpambot(x) ((x)->flags & CONF_FLAGS_EXEMPTSPAMBOT)
127 #define IsConfExemptShide(x) ((x)->flags & CONF_FLAGS_EXEMPTSHIDE)
128 #define IsConfExemptJupe(x) ((x)->flags & CONF_FLAGS_EXEMPTJUPE)
129 #define IsConfExemptResv(x) ((x)->flags & CONF_FLAGS_EXEMPTRESV)
130 #define IsConfDoSpoofIp(x) ((x)->flags & CONF_FLAGS_SPOOF_IP)
131 #define IsConfSpoofNotice(x) ((x)->flags & CONF_FLAGS_SPOOF_NOTICE)
132 #define IsConfEncrypted(x) ((x)->flags & CONF_FLAGS_ENCRYPTED)
133 #define IsNeedSasl(x) ((x)->flags & CONF_FLAGS_NEED_SASL)
134 #define IsConfExemptDNSBL(x) ((x)->flags & CONF_FLAGS_EXEMPTDNSBL)
135 #define IsConfSSLNeeded(x) ((x)->flags & CONF_FLAGS_NEED_SSL)
136
137 /* flag definitions for opers now in client.h */
138
139 struct config_file_entry
140 {
141 const char *dpath; /* DPATH if set from command line */
142 const char *configfile;
143
144 char *default_operstring;
145 char *default_adminstring;
146 char *servicestring;
147 char *kline_reason;
148
149 char *identifyservice;
150 char *identifycommand;
151
152 char *sasl_service;
153
154 char *fname_userlog;
155 char *fname_fuserlog;
156 char *fname_operlog;
157 char *fname_foperlog;
158 char *fname_serverlog;
159 char *fname_killlog;
160 char *fname_klinelog;
161 char *fname_operspylog;
162 char *fname_ioerrorlog;
163
164 unsigned char compression_level;
165 int disable_fake_channels;
166 int dots_in_ident;
167 int failed_oper_notice;
168 int anti_nick_flood;
169 int anti_spam_exit_message_time;
170 int max_accept;
171 int max_monitor;
172 int max_nick_time;
173 int max_nick_changes;
174 int ts_max_delta;
175 int ts_warn_delta;
176 int dline_with_reason;
177 int kline_with_reason;
178 int kline_delay;
179 int warn_no_nline;
180 int nick_delay;
181 int non_redundant_klines;
182 int stats_e_disabled;
183 int stats_c_oper_only;
184 int stats_y_oper_only;
185 int stats_h_oper_only;
186 int stats_o_oper_only;
187 int stats_k_oper_only;
188 int stats_i_oper_only;
189 int stats_P_oper_only;
190 int map_oper_only;
191 int operspy_admin_only;
192 int pace_wait;
193 int pace_wait_simple;
194 int short_motd;
195 int no_oper_flood;
196 int hide_server;
197 int hide_spoof_ips;
198 int hide_error_messages;
199 int client_exit;
200 int oper_only_umodes;
201 int oper_umodes;
202 int oper_snomask;
203 int max_targets;
204 int caller_id_wait;
205 int min_nonwildcard;
206 int min_nonwildcard_simple;
207 int default_floodcount;
208 int default_ident_timeout;
209 int ping_cookie;
210 int tkline_expire_notices;
211 int use_whois_actually;
212 int disable_auth;
213 int connect_timeout;
214 int burst_away;
215 int reject_ban_time;
216 int reject_after_count;
217 int reject_duration;
218 int throttle_count;
219 int throttle_duration;
220 int target_change;
221 int collision_fnc;
222 int resv_fnc;
223 int default_umodes;
224 int global_snotices;
225 int operspy_dont_care_user_info;
226 int use_propagated_bans;
227 int max_ratelimit_tokens;
228 int away_interval;
229
230 int client_flood_max_lines;
231 int client_flood_burst_rate;
232 int client_flood_burst_max;
233 int client_flood_message_time;
234 int client_flood_message_num;
235
236 unsigned int nicklen;
237 int certfp_method;
238 };
239
240 struct config_channel_entry
241 {
242 int use_except;
243 int use_invex;
244 int use_forward;
245 int use_knock;
246 int knock_delay;
247 int knock_delay_channel;
248 int max_bans;
249 int max_bans_large;
250 int max_chans_per_user;
251 int no_create_on_split;
252 int no_join_on_split;
253 int default_split_server_count;
254 int default_split_user_count;
255 int burst_topicwho;
256 int kick_on_split_riding;
257 int only_ascii_channels;
258 int resv_forcepart;
259 int channel_target_change;
260 int disable_local_channels;
261 unsigned int autochanmodes;
262 };
263
264 struct config_server_hide
265 {
266 int flatten_links;
267 int links_delay;
268 int hidden;
269 int disable_hidden;
270 };
271
272 struct server_info
273 {
274 char *name;
275 char sid[4];
276 char *description;
277 char *network_name;
278 int hub;
279 struct sockaddr_in ip;
280 int default_max_clients;
281 #ifdef RB_IPV6
282 struct sockaddr_in6 ip6;
283 #endif
284 int specific_ipv4_vhost;
285 #ifdef RB_IPV6
286 int specific_ipv6_vhost;
287 #endif
288 char *ssl_private_key;
289 char *ssl_ca_cert;
290 char *ssl_cert;
291 char *ssl_dh_params;
292 int ssld_count;
293 };
294
295 struct admin_info
296 {
297 char *name;
298 char *description;
299 char *email;
300 };
301
302 struct alias_entry
303 {
304 char *name;
305 char *target;
306 int flags; /* reserved for later use */
307 int hits;
308 };
309
310 /* All variables are GLOBAL */
311 extern int specific_ipv4_vhost; /* used in s_bsd.c */
312 extern int specific_ipv6_vhost;
313 extern struct config_file_entry ConfigFileEntry; /* defined in ircd.c */
314 extern struct config_channel_entry ConfigChannel; /* defined in channel.c */
315 extern struct config_server_hide ConfigServerHide; /* defined in s_conf.c */
316 extern struct server_info ServerInfo; /* defined in ircd.c */
317 extern struct admin_info AdminInfo; /* defined in ircd.c */
318 /* End GLOBAL section */
319
320 extern rb_dlink_list service_list;
321
322 extern rb_dlink_list prop_bans;
323
324 typedef enum temp_list
325 {
326 TEMP_MIN,
327 TEMP_HOUR,
328 TEMP_DAY,
329 TEMP_WEEK,
330 LAST_TEMP_TYPE
331 } temp_list;
332
333 extern rb_dlink_list temp_klines[LAST_TEMP_TYPE];
334 extern rb_dlink_list temp_dlines[LAST_TEMP_TYPE];
335
336 extern void init_s_conf(void);
337
338 extern struct ConfItem *make_conf(void);
339 extern void free_conf(struct ConfItem *);
340
341 extern rb_dlink_node *find_prop_ban(unsigned int status, const char *user, const char *host);
342 extern void deactivate_conf(struct ConfItem *, rb_dlink_node *, time_t);
343 extern void replace_old_ban(struct ConfItem *);
344
345 extern void read_conf_files(int cold);
346
347 extern int attach_conf(struct Client *, struct ConfItem *);
348 extern int check_client(struct Client *client_p, struct Client *source_p, const char *);
349
350 extern int detach_conf(struct Client *);
351
352 extern struct ConfItem *find_tkline(const char *, const char *, struct sockaddr *);
353 extern char *show_iline_prefix(struct Client *, struct ConfItem *, char *);
354 extern void get_printable_conf(struct ConfItem *,
355 char **, char **, const char **, char **, int *, char **);
356 extern char *get_user_ban_reason(struct ConfItem *aconf);
357 extern void get_printable_kline(struct Client *, struct ConfItem *,
358 char **, char **, char **, char **);
359
360 extern void yyerror(const char *);
361 extern int conf_yy_fatal_error(const char *);
362 extern int conf_fgets(char *, int, FILE *);
363
364 extern int valid_wild_card(const char *, const char *);
365 extern void add_temp_kline(struct ConfItem *);
366 extern void add_temp_dline(struct ConfItem *);
367 extern void report_temp_klines(struct Client *);
368 extern void show_temp_klines(struct Client *, rb_dlink_list *);
369
370 extern int rehash(int);
371 extern void rehash_bans(int);
372
373 extern int conf_add_server(struct ConfItem *, int);
374 extern void conf_add_class_to_conf(struct ConfItem *);
375 extern void conf_add_me(struct ConfItem *);
376 extern void conf_add_class(struct ConfItem *, int);
377 extern void conf_add_d_conf(struct ConfItem *);
378 extern void flush_expired_ips(void *);
379
380 extern char *get_oper_name(struct Client *client_p);
381
382 extern int yylex(void);
383
384 extern unsigned long cidr_to_bitmask[];
385
386 extern char conffilebuf[IRCD_BUFSIZE + 1];
387 extern int lineno;
388
389 #define NOT_AUTHORISED (-1)
390 #define SOCKET_ERROR (-2)
391 #define I_LINE_FULL (-3)
392 #define BANNED_CLIENT (-4)
393 #define TOO_MANY_LOCAL (-6)
394 #define TOO_MANY_GLOBAL (-7)
395 #define TOO_MANY_IDENT (-8)
396
397 #endif /* INCLUDED_s_conf_h */