]> jfr.im git - irc/quakenet/snircd.git/blob - include/client.h
Update my e-mail address.
[irc/quakenet/snircd.git] / include / client.h
1 /*
2 * IRC - Internet Relay Chat, include/client.h
3 * Copyright (C) 1990 Jarkko Oikarinen and
4 * University of Oulu, Computing Center
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2, or (at your option)
9 * any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 */
20 /** @file
21 * @brief Structures and functions for handling local clients.
22 * @version $Id: client.h,v 1.48.2.1 2006/02/16 03:49:54 entrope Exp $
23 */
24 #ifndef INCLUDED_client_h
25 #define INCLUDED_client_h
26 #ifndef INCLUDED_ircd_defs_h
27 #include "ircd_defs.h"
28 #endif
29 #ifndef INCLUDED_dbuf_h
30 #include "dbuf.h"
31 #endif
32 #ifndef INCLUDED_msgq_h
33 #include "msgq.h"
34 #endif
35 #ifndef INCLUDED_ircd_events_h
36 #include "ircd_events.h"
37 #endif
38 #ifndef INCLUDED_ircd_handler_h
39 #include "ircd_handler.h"
40 #endif
41 #ifndef INCLUDED_res_h
42 #include "res.h"
43 #endif
44 #ifndef INCLUDED_sys_types_h
45 #include <sys/types.h> /* time_t, size_t */
46 #define INCLUDED_sys_types_h
47 #endif
48
49 struct ConfItem;
50 struct Listener;
51 struct ListingArgs;
52 struct SLink;
53 struct Server;
54 struct User;
55 struct Whowas;
56 struct hostent;
57 struct Privs;
58 struct AuthRequest;
59
60 /*
61 * Structures
62 *
63 * Only put structures here that are being used in a very large number of
64 * source files. Other structures go in the header file of there corresponding
65 * source file, or in the source file itself (when only used in that file).
66 */
67
68 /** Single element in a flag bitset array. */
69 typedef unsigned long flagpage_t;
70
71 /** Number of bits in a flagpage_t. */
72 #define FLAGSET_NBITS (8 * sizeof(flagpage_t))
73 /** Element number for flag \a flag. */
74 #define FLAGSET_INDEX(flag) ((flag) / FLAGSET_NBITS)
75 /** Element bit for flag \a flag. */
76 #define FLAGSET_MASK(flag) (1ul<<((flag) % FLAGSET_NBITS))
77
78 /** Declare a flagset structure of a particular size. */
79 #define DECLARE_FLAGSET(name,max) \
80 struct name \
81 { \
82 unsigned long bits[((max + FLAGSET_NBITS - 1) / FLAGSET_NBITS)]; \
83 }
84
85 /** Test whether a flag is set in a flagset. */
86 #define FlagHas(set,flag) ((set)->bits[FLAGSET_INDEX(flag)] & FLAGSET_MASK(flag))
87 /** Set a flag in a flagset. */
88 #define FlagSet(set,flag) ((set)->bits[FLAGSET_INDEX(flag)] |= FLAGSET_MASK(flag))
89 /** Clear a flag in a flagset. */
90 #define FlagClr(set,flag) ((set)->bits[FLAGSET_INDEX(flag)] &= ~FLAGSET_MASK(flag))
91
92 /** String containing valid user modes, in no particular order. */
93 #define infousermodes "dioswkgxRXInP"
94
95 /** Character to indicate no oper name available */
96 #define NOOPERNAMECHARACTER '-'
97
98 /** Operator privileges. */
99 enum Priv
100 {
101 PRIV_CHAN_LIMIT, /**< no channel limit on oper */
102 PRIV_MODE_LCHAN, /**< oper can mode local chans */
103 PRIV_WALK_LCHAN, /**< oper can walk through local modes */
104 PRIV_DEOP_LCHAN, /**< no deop oper on local chans */
105 PRIV_SHOW_INVIS, /**< show local invisible users */
106 PRIV_SHOW_ALL_INVIS, /**< show all invisible users */
107 PRIV_UNLIMIT_QUERY, /**< unlimit who queries */
108 PRIV_KILL, /**< oper can KILL */
109 PRIV_LOCAL_KILL, /**< oper can local KILL */
110 PRIV_REHASH, /**< oper can REHASH */
111 PRIV_RESTART, /**< oper can RESTART */
112 PRIV_DIE, /**< oper can DIE */
113 PRIV_GLINE, /**< oper can GLINE */
114 PRIV_LOCAL_GLINE, /**< oper can local GLINE */
115 PRIV_JUPE, /**< oper can JUPE */
116 PRIV_LOCAL_JUPE, /**< oper can local JUPE */
117 PRIV_OPMODE, /**< oper can OP/CLEARMODE */
118 PRIV_LOCAL_OPMODE, /**< oper can local OP/CLEARMODE */
119 PRIV_SET, /**< oper can SET */
120 PRIV_WHOX, /**< oper can use /who x */
121 PRIV_BADCHAN, /**< oper can BADCHAN */
122 PRIV_LOCAL_BADCHAN, /**< oper can local BADCHAN */
123 PRIV_SEE_CHAN, /**< oper can see in secret chans */
124 PRIV_PROPAGATE, /**< propagate oper status */
125 PRIV_DISPLAY, /**< "Is an oper" displayed */
126 PRIV_SEE_OPERS, /**< display hidden opers */
127 PRIV_WIDE_GLINE, /**< oper can set wider G-lines */
128 PRIV_LIST_CHAN, /**< oper can list secret channels */
129 PRIV_FORCE_OPMODE, /**< can hack modes on quarantined channels */
130 PRIV_FORCE_LOCAL_OPMODE, /**< can hack modes on quarantined local channels */
131 PRIV_APASS_OPMODE, /**< can hack modes +A/-A/+U/-U */
132 PRIV_CHANSERV, /* oper can set usermode +k */
133 PRIV_XTRA_OPER, /* oper can set usermode +X */
134 PRIV_NOIDLE, /* oper can set usermode +I */
135 PRIV_FREEFORM, /* oper can use freeform sethost */
136 PRIV_PARANOID, /* oper can set paranoid */
137 PRIV_CHECK, /* oper can use /check */
138 PRIV_LAST_PRIV /**< number of privileges */
139 };
140
141 /** Client flags and modes.
142 * Note that flags at least FLAG_LOCAL_UMODES but less than
143 * FLAG_GLOBAL_UMODES are treated as local modes, and flags at least
144 * FLAG_GLOBAL_UMODES (but less than FLAG_LAST_FLAG) are treated as
145 * global modes.
146 */
147 enum Flag
148 {
149 FLAG_PINGSENT, /**< Unreplied ping sent */
150 FLAG_DEADSOCKET, /**< Local socket is dead--Exiting soon */
151 FLAG_KILLED, /**< Prevents "QUIT" from being sent for this */
152 FLAG_BLOCKED, /**< socket is in a blocked condition */
153 FLAG_CLOSING, /**< set when closing to suppress errors */
154 FLAG_UPING, /**< has active UDP ping request */
155 FLAG_HUB, /**< server is a hub */
156 FLAG_IPV6, /**< server understands P10 IPv6 addrs */
157 FLAG_SERVICE, /**< server is a service */
158 FLAG_GOTID, /**< successful ident lookup achieved */
159 FLAG_DOID, /**< I-lines say must use ident return */
160 FLAG_NONL, /**< No \n in buffer */
161 FLAG_TS8, /**< Why do you want to know? */
162 FLAG_MAP, /**< Show server on the map */
163 FLAG_JUNCTION, /**< Junction causing the net.burst. */
164 FLAG_BURST, /**< Server is receiving a net.burst */
165 FLAG_BURST_ACK, /**< Server is waiting for eob ack */
166 FLAG_IPCHECK, /**< Added or updated IPregistry data */
167 FLAG_LOCOP, /**< Local operator -- SRB */
168 FLAG_SERVNOTICE, /**< server notices such as kill */
169 FLAG_OPER, /**< Operator */
170 FLAG_INVISIBLE, /**< makes user invisible */
171 FLAG_WALLOP, /**< send wallops to them */
172 FLAG_DEAF, /**< Makes user deaf */
173 FLAG_CHSERV, /**< Disallow KICK or MODE -o on the user;
174 don't display channels in /whois */
175 FLAG_DEBUG, /**< send global debug/anti-hack info */
176 FLAG_ACCOUNT, /**< account name has been set */
177 FLAG_ACCOUNTONLY, /**< ASUKA_R: hide privmsgs/notices if
178 user is not authed or opered */
179 FLAG_PARANOID, /**< ASUKA_P: sends notices on whois */
180 FLAG_HIDDENHOST, /**< user's host is hidden */
181 FLAG_SETHOST, /**< ASUKA_h: oper's host is changed */
182 FLAG_NOCHAN, /**< user's channels are hidden */
183 FLAG_NOIDLE, /**< user's idletime is hidden */
184 FLAG_XTRAOP, /**< oper has special powers */
185 FLAG_OPERNAME, /**< Server sends oper name in mode string */
186
187 FLAG_LAST_FLAG, /**< number of flags */
188 FLAG_LOCAL_UMODES = FLAG_LOCOP, /**< First local mode flag */
189 FLAG_GLOBAL_UMODES = FLAG_OPER /**< First global mode flag */
190 };
191
192 /** Declare flagset type for operator privileges. */
193 DECLARE_FLAGSET(Privs, PRIV_LAST_PRIV);
194 /** Declare flagset type for user flags. */
195 DECLARE_FLAGSET(Flags, FLAG_LAST_FLAG);
196
197 #include "capab.h" /* client capabilities */
198
199 /** Represents a local connection.
200 * This contains a lot of stuff irrelevant to server connections, but
201 * those are so rare as to not be worth special-casing.
202 */
203 struct Connection
204 {
205 unsigned long con_magic; /**< magic number */
206 struct Connection* con_next; /**< Next connection with queued data */
207 struct Connection** con_prev_p; /**< What points to us */
208 struct Client* con_client; /**< Client associated with connection */
209 unsigned int con_count; /**< Amount of data in buffer */
210 int con_freeflag; /**< indicates if connection can be freed */
211 int con_error; /**< last socket level error for client */
212 int con_sentalong; /**< sentalong marker for connection */
213 unsigned int con_snomask; /**< mask for server messages */
214 time_t con_nextnick; /**< Next time a nick change is allowed */
215 time_t con_nexttarget;/**< Next time a target change is allowed */
216 time_t con_lasttime; /**< Last time data read from socket */
217 time_t con_since; /**< Last time we accepted a command */
218 struct MsgQ con_sendQ; /**< Outgoing message queue */
219 struct DBuf con_recvQ; /**< Incoming data yet to be parsed */
220 unsigned int con_sendM; /**< Stats: protocol messages sent */
221 unsigned int con_receiveM; /**< Stats: protocol messages received */
222 uint64_t con_sendB; /**< Bytes sent. */
223 uint64_t con_receiveB; /**< Bytes received. */
224 struct Listener* con_listener; /**< Listening socket which we accepted
225 from. */
226 struct SLink* con_confs; /**< Associated configuration records. */
227 HandlerType con_handler; /**< Message index into command table
228 for parsing. */
229 struct ListingArgs* con_listing; /**< Current LIST status. */
230 unsigned int con_max_sendq; /**< cached max send queue for client */
231 unsigned int con_ping_freq; /**< cached ping freq */
232 unsigned short con_lastsq; /**< # 2k blocks when sendqueued
233 called last. */
234 unsigned char con_targets[MAXTARGETS]; /**< Hash values of
235 current targets. */
236 char con_sock_ip[SOCKIPLEN + 1]; /**< Remote IP address as a string. */
237 char con_sockhost[HOSTLEN + 1]; /**< This is the host name from
238 the socket and after which the
239 connection was accepted. */
240 char con_passwd[PASSWDLEN + 1]; /**< Password given by user. */
241 char con_buffer[BUFSIZE]; /**< Incoming message buffer; or
242 the error that caused this
243 clients socket to close. */
244 struct Socket con_socket; /**< socket descriptor for
245 client */
246 struct Timer con_proc; /**< process latent messages from
247 client */
248 struct Privs con_privs; /**< Oper privileges */
249 struct CapSet con_capab; /**< Client capabilities (from us) */
250 struct CapSet con_active; /**< Active capabilities (to us) */
251 struct AuthRequest* con_auth; /**< Auth request for client */
252 };
253
254 /** Magic constant to identify valid Connection structures. */
255 #define CONNECTION_MAGIC 0x12f955f3
256
257 /** Represents a client anywhere on the network. */
258 struct Client {
259 unsigned long cli_magic; /**< magic number */
260 struct Client* cli_next; /**< link in GlobalClientList */
261 struct Client* cli_prev; /**< link in GlobalClientList */
262 struct Client* cli_hnext; /**< link in hash table bucket or this */
263 struct Connection* cli_connect; /**< Connection structure associated with us */
264 struct User* cli_user; /**< Defined if this client is a user */
265 struct Server* cli_serv; /**< Defined if this client is a server */
266 struct Whowas* cli_whowas; /**< Pointer to ww struct to be freed on quit */
267 char cli_yxx[4]; /**< Numeric Nick: YY if this is a
268 server, XXX if this is a user */
269 time_t cli_firsttime; /**< time client was created */
270 time_t cli_lastnick; /**< TimeStamp on nick */
271 int cli_marker; /**< /who processing marker */
272 struct Flags cli_flags; /**< client flags */
273 unsigned int cli_hopcount; /**< number of servers to this 0 = local */
274 struct irc_in_addr cli_ip; /**< Real IP of client */
275 short cli_status; /**< Client type */
276 char cli_name[HOSTLEN + 1]; /**< Unique name of the client, nick or host */
277 char cli_username[USERLEN + 1]; /**< Username determined by ident lookup */
278 char cli_info[REALLEN + 1]; /**< Free form additional client information */
279 };
280
281 /** Magic constant to identify valid Client structures. */
282 #define CLIENT_MAGIC 0x4ca08286
283
284 /** Verify that a client is valid. */
285 #define cli_verify(cli) ((cli)->cli_magic == CLIENT_MAGIC)
286 /** Get client's magic number. */
287 #define cli_magic(cli) ((cli)->cli_magic)
288 /** Get global next client. */
289 #define cli_next(cli) ((cli)->cli_next)
290 /** Get global previous client. */
291 #define cli_prev(cli) ((cli)->cli_prev)
292 /** Get next client in hash bucket chain. */
293 #define cli_hnext(cli) ((cli)->cli_hnext)
294 /** Get connection associated with client. */
295 #define cli_connect(cli) ((cli)->cli_connect)
296 /** Get local client that links us to \a cli. */
297 #define cli_from(cli) con_client(cli_connect(cli))
298 /** Get User structure for client, if client is a user. */
299 #define cli_user(cli) ((cli)->cli_user)
300 /** Get Server structure for client, if client is a server. */
301 #define cli_serv(cli) ((cli)->cli_serv)
302 /** Get Whowas link for client. */
303 #define cli_whowas(cli) ((cli)->cli_whowas)
304 /** Get client numnick. */
305 #define cli_yxx(cli) ((cli)->cli_yxx)
306 /** Get time we last read data from the client socket. */
307 #define cli_lasttime(cli) con_lasttime(cli_connect(cli))
308 /** Get time we last parsed something from the client. */
309 #define cli_since(cli) con_since(cli_connect(cli))
310 /** Get time client was created. */
311 #define cli_firsttime(cli) ((cli)->cli_firsttime)
312 /** Get time client last changed nickname. */
313 #define cli_lastnick(cli) ((cli)->cli_lastnick)
314 /** Get WHO marker for client. */
315 #define cli_marker(cli) ((cli)->cli_marker)
316 /** Get flags flagset for client. */
317 #define cli_flags(cli) ((cli)->cli_flags)
318 /** Get hop count to client. */
319 #define cli_hopcount(cli) ((cli)->cli_hopcount)
320 /** Get client IP address. */
321 #define cli_ip(cli) ((cli)->cli_ip)
322 /** Get status bitmask for client. */
323 #define cli_status(cli) ((cli)->cli_status)
324 /** Return non-zero if the client is local. */
325 #define cli_local(cli) (cli_from(cli) == cli)
326 /** Get oper privileges for client. */
327 #define cli_privs(cli) con_privs(cli_connect(cli))
328 /** Get client capabilities for client */
329 #define cli_capab(cli) con_capab(cli_connect(cli))
330 /** Get active client capabilities for client */
331 #define cli_active(cli) con_active(cli_connect(cli))
332 /** Get client name. */
333 #define cli_name(cli) ((cli)->cli_name)
334 /** Get client username (ident). */
335 #define cli_username(cli) ((cli)->cli_username)
336 /** Get client realname (information field). */
337 #define cli_info(cli) ((cli)->cli_info)
338
339 /** Get number of incoming bytes queued for client. */
340 #define cli_count(cli) con_count(cli_connect(cli))
341 /** Get file descriptor for sending in client's direction. */
342 #define cli_fd(cli) con_fd(cli_connect(cli))
343 /** Get free flags for the client's connection. */
344 #define cli_freeflag(cli) con_freeflag(cli_connect(cli))
345 /** Get last error code for the client's connection. */
346 #define cli_error(cli) con_error(cli_connect(cli))
347 /** Get server notice mask for the client. */
348 #define cli_snomask(cli) con_snomask(cli_connect(cli))
349 /** Get next time a nick change is allowed for the client. */
350 #define cli_nextnick(cli) con_nextnick(cli_connect(cli))
351 /** Get next time a target change is allowed for the client. */
352 #define cli_nexttarget(cli) con_nexttarget(cli_connect(cli))
353 /** Get SendQ for client. */
354 #define cli_sendQ(cli) con_sendQ(cli_connect(cli))
355 /** Get RecvQ for client. */
356 #define cli_recvQ(cli) con_recvQ(cli_connect(cli))
357 /** Get count of messages sent to client. */
358 #define cli_sendM(cli) con_sendM(cli_connect(cli))
359 /** Get number of messages received from client. */
360 #define cli_receiveM(cli) con_receiveM(cli_connect(cli))
361 /** Get number of bytes (modulo 1024) sent to client. */
362 #define cli_sendB(cli) con_sendB(cli_connect(cli))
363 /** Get number of bytes (modulo 1024) received from client. */
364 #define cli_receiveB(cli) con_receiveB(cli_connect(cli))
365 /** Get listener that accepted the client's connection. */
366 #define cli_listener(cli) con_listener(cli_connect(cli))
367 /** Get list of attached conf lines. */
368 #define cli_confs(cli) con_confs(cli_connect(cli))
369 /** Get handler type for client. */
370 #define cli_handler(cli) con_handler(cli_connect(cli))
371 /** Get LIST status for client. */
372 #define cli_listing(cli) con_listing(cli_connect(cli))
373 /** Get cached max SendQ for client. */
374 #define cli_max_sendq(cli) con_max_sendq(cli_connect(cli))
375 /** Get ping frequency for client. */
376 #define cli_ping_freq(cli) con_ping_freq(cli_connect(cli))
377 /** Get lastsq for client's connection. */
378 #define cli_lastsq(cli) con_lastsq(cli_connect(cli))
379 /** Get the array of current targets for the client. */
380 #define cli_targets(cli) con_targets(cli_connect(cli))
381 /** Get the string form of the client's IP address. */
382 #define cli_sock_ip(cli) con_sock_ip(cli_connect(cli))
383 /** Get the resolved hostname for the client. */
384 #define cli_sockhost(cli) con_sockhost(cli_connect(cli))
385 /** Get the client's password. */
386 #define cli_passwd(cli) con_passwd(cli_connect(cli))
387 /** Get the unprocessed input buffer for a client's connection. */
388 #define cli_buffer(cli) con_buffer(cli_connect(cli))
389 /** Get the Socket structure for sending to a client. */
390 #define cli_socket(cli) con_socket(cli_connect(cli))
391 /** Get Timer for processing waiting messages from the client. */
392 #define cli_proc(cli) con_proc(cli_connect(cli))
393 /** Get auth request for client. */
394 #define cli_auth(cli) con_auth(cli_connect(cli))
395 /** Get sentalong marker for client. */
396 #define cli_sentalong(cli) con_sentalong(cli_connect(cli))
397
398 /** Verify that a connection is valid. */
399 #define con_verify(con) ((con)->con_magic == CONNECTION_MAGIC)
400 /** Get connection's magic number. */
401 #define con_magic(con) ((con)->con_magic)
402 /** Get global next connection. */
403 #define con_next(con) ((con)->con_next)
404 /** Get global previous connection. */
405 #define con_prev_p(con) ((con)->con_prev_p)
406 /** Get locally connected client for connection. */
407 #define con_client(con) ((con)->con_client)
408 /** Get number of unprocessed data bytes from connection. */
409 #define con_count(con) ((con)->con_count)
410 /** Get file descriptor for connection. */
411 #define con_fd(con) s_fd(&(con)->con_socket)
412 /** Get freeable flags for connection. */
413 #define con_freeflag(con) ((con)->con_freeflag)
414 /** Get last error code on connection. */
415 #define con_error(con) ((con)->con_error)
416 /** Get sentalong marker for connection. */
417 #define con_sentalong(con) ((con)->con_sentalong)
418 /** Get server notice mask for connection. */
419 #define con_snomask(con) ((con)->con_snomask)
420 /** Get next nick change time for connection. */
421 #define con_nextnick(con) ((con)->con_nextnick)
422 /** Get next new target time for connection. */
423 #define con_nexttarget(con) ((con)->con_nexttarget)
424 /** Get last time we read from the connection. */
425 #define con_lasttime(con) ((con)->con_lasttime)
426 /** Get last time we accepted a command from the connection. */
427 #define con_since(con) ((con)->con_since)
428 /** Get SendQ for connection. */
429 #define con_sendQ(con) ((con)->con_sendQ)
430 /** Get RecvQ for connection. */
431 #define con_recvQ(con) ((con)->con_recvQ)
432 /** Get number of messages sent to connection. */
433 #define con_sendM(con) ((con)->con_sendM)
434 /** Get number of messages received from connection. */
435 #define con_receiveM(con) ((con)->con_receiveM)
436 /** Get number of bytes (modulo 1024) sent to connection. */
437 #define con_sendB(con) ((con)->con_sendB)
438 /** Get number of bytes (modulo 1024) received from connection. */
439 #define con_receiveB(con) ((con)->con_receiveB)
440 /** Get listener that accepted the connection. */
441 #define con_listener(con) ((con)->con_listener)
442 /** Get list of ConfItems attached to the connection. */
443 #define con_confs(con) ((con)->con_confs)
444 /** Get command handler for the connection. */
445 #define con_handler(con) ((con)->con_handler)
446 /** Get the LIST status for the connection. */
447 #define con_listing(con) ((con)->con_listing)
448 /** Get the maximum permitted SendQ size for the connection. */
449 #define con_max_sendq(con) ((con)->con_max_sendq)
450 /** Get the ping frequency for the connection. */
451 #define con_ping_freq(con) ((con)->con_ping_freq)
452 /** Get the lastsq for the connection. */
453 #define con_lastsq(con) ((con)->con_lastsq)
454 /** Get the current targets array for the connection. */
455 #define con_targets(con) ((con)->con_targets)
456 /** Get the string-formatted IP address for the connection. */
457 #define con_sock_ip(con) ((con)->con_sock_ip)
458 /** Get the resolved hostname for the connection. */
459 #define con_sockhost(con) ((con)->con_sockhost)
460 /** Get the password sent by the remote end of the connection. */
461 #define con_passwd(con) ((con)->con_passwd)
462 /** Get the buffer of unprocessed incoming data from the connection. */
463 #define con_buffer(con) ((con)->con_buffer)
464 /** Get the Socket for the connection. */
465 #define con_socket(con) ((con)->con_socket)
466 /** Get the Timer for processing more data from the connection. */
467 #define con_proc(con) ((con)->con_proc)
468 /** Get the oper privilege set for the connection. */
469 #define con_privs(con) (&(con)->con_privs)
470 /** Get the peer's capabilities for the connection. */
471 #define con_capab(con) (&(con)->con_capab)
472 /** Get the active capabilities for the connection. */
473 #define con_active(con) (&(con)->con_active)
474 /** Get the auth request for the connection. */
475 #define con_auth(con) ((con)->con_auth)
476
477 #define STAT_CONNECTING 0x001 /**< connecting to another server */
478 #define STAT_HANDSHAKE 0x002 /**< pass - server sent */
479 #define STAT_ME 0x004 /**< this server */
480 #define STAT_UNKNOWN 0x008 /**< unidentified connection */
481 #define STAT_UNKNOWN_USER 0x010 /**< connection on a client port */
482 #define STAT_UNKNOWN_SERVER 0x020 /**< connection on a server port */
483 #define STAT_SERVER 0x040 /**< fully registered server */
484 #define STAT_USER 0x080 /**< fully registered user */
485
486 /*
487 * status macros.
488 */
489 /** Return non-zero if the client is registered. */
490 #define IsRegistered(x) (cli_status(x) & (STAT_SERVER | STAT_USER))
491 /** Return non-zero if the client is an outbound connection that is
492 * still connecting. */
493 #define IsConnecting(x) (cli_status(x) == STAT_CONNECTING)
494 /** Return non-zero if the client is an outbound connection that has
495 * sent our password. */
496 #define IsHandshake(x) (cli_status(x) == STAT_HANDSHAKE)
497 /** Return non-zero if the client is this server. */
498 #define IsMe(x) (cli_status(x) == STAT_ME)
499 /** Return non-zero if the client has not yet registered. */
500 #define IsUnknown(x) (cli_status(x) & \
501 (STAT_UNKNOWN | STAT_UNKNOWN_USER | STAT_UNKNOWN_SERVER))
502 /** Return non-zero if the client is an unregistered connection on a
503 * server port. */
504 #define IsServerPort(x) (cli_status(x) == STAT_UNKNOWN_SERVER )
505 /** Return non-zero if the client is an unregistered connection on a
506 * user port. */
507 #define IsUserPort(x) (cli_status(x) == STAT_UNKNOWN_USER )
508 /** Return non-zero if the client is a real client connection. */
509 #define IsClient(x) (cli_status(x) & \
510 (STAT_HANDSHAKE | STAT_ME | STAT_UNKNOWN |\
511 STAT_UNKNOWN_USER | STAT_UNKNOWN_SERVER | STAT_SERVER | STAT_USER))
512 /** Return non-zero if the client ignores flood limits. */
513 #define IsTrusted(x) (cli_status(x) & \
514 (STAT_CONNECTING | STAT_HANDSHAKE | STAT_ME | STAT_SERVER))
515 /** Return non-zero if the client is a registered server. */
516 #define IsServer(x) (cli_status(x) == STAT_SERVER)
517 /** Return non-zero if the client is a registered user. */
518 #define IsUser(x) (cli_status(x) == STAT_USER)
519
520
521 /** Mark a client with STAT_CONNECTING. */
522 #define SetConnecting(x) (cli_status(x) = STAT_CONNECTING)
523 /** Mark a client with STAT_HANDSHAKE. */
524 #define SetHandshake(x) (cli_status(x) = STAT_HANDSHAKE)
525 /** Mark a client with STAT_SERVER. */
526 #define SetServer(x) (cli_status(x) = STAT_SERVER)
527 /** Mark a client with STAT_ME. */
528 #define SetMe(x) (cli_status(x) = STAT_ME)
529 /** Mark a client with STAT_USER. */
530 #define SetUser(x) (cli_status(x) = STAT_USER)
531
532 /** Return non-zero if a client is directly connected to me. */
533 #define MyConnect(x) (cli_from(x) == (x))
534 /** Return non-zero if a client is a locally connected user. */
535 #define MyUser(x) (MyConnect(x) && IsUser(x))
536 /** Return non-zero if a client is a locally connected IRC operator. */
537 #define MyOper(x) (MyConnect(x) && IsOper(x))
538 /** Return protocol version used by a server. */
539 #define Protocol(x) ((cli_serv(x))->prot)
540
541 /*
542 * flags macros
543 */
544 /** Set a flag in a client's flags. */
545 #define SetFlag(cli, flag) FlagSet(&cli_flags(cli), flag)
546 /** Clear a flag from a client's flags. */
547 #define ClrFlag(cli, flag) FlagClr(&cli_flags(cli), flag)
548 /** Return non-zero if a flag is set in a client's flags. */
549 #define HasFlag(cli, flag) FlagHas(&cli_flags(cli), flag)
550
551 /** Return non-zero if the client is an IRC operator (global or local). */
552 #define IsAnOper(x) (HasFlag(x, FLAG_OPER) || HasFlag(x, FLAG_LOCOP))
553 /** Return non-zero if the client's connection is blocked. */
554 #define IsBlocked(x) HasFlag(x, FLAG_BLOCKED)
555 /** Return non-zero if the client's connection is still being burst. */
556 #define IsBurst(x) HasFlag(x, FLAG_BURST)
557 /** Return non-zero if we have received the peer's entire burst but
558 * not their EOB ack. */
559 #define IsBurstAck(x) HasFlag(x, FLAG_BURST_ACK)
560 /** Return non-zero if we are still bursting to the client. */
561 #define IsBurstOrBurstAck(x) (HasFlag(x, FLAG_BURST) || HasFlag(x, FLAG_BURST_ACK))
562 /** Return non-zero if the client has set mode +k (channel service). */
563 #define IsChannelService(x) HasFlag(x, FLAG_CHSERV)
564 /** Return non-zero if the client's socket is disconnected. */
565 #define IsDead(x) HasFlag(x, FLAG_DEADSOCKET)
566 /** Return non-zero if the client has set mode +d (deaf). */
567 #define IsDeaf(x) HasFlag(x, FLAG_DEAF)
568 /** Return non-zero if the client has been IP-checked for clones. */
569 #define IsIPChecked(x) HasFlag(x, FLAG_IPCHECK)
570 /** Return non-zero if we have received an ident response for the client. */
571 #define IsIdented(x) HasFlag(x, FLAG_GOTID)
572 /** Return non-zero if the client has set mode +i (invisible). */
573 #define IsInvisible(x) HasFlag(x, FLAG_INVISIBLE)
574 /** Return non-zero if the client caused a net.burst. */
575 #define IsJunction(x) HasFlag(x, FLAG_JUNCTION)
576 /** Return non-zero if the client has set mode +O (local operator). */
577 #define IsLocOp(x) HasFlag(x, FLAG_LOCOP)
578 /** Return non-zero if the client has set mode +o (global operator). */
579 #define IsOper(x) HasFlag(x, FLAG_OPER)
580 /** Return non-zero if the client has an active UDP ping request. */
581 #define IsUPing(x) HasFlag(x, FLAG_UPING)
582 /** Return non-zero if the client has no '\n' in its buffer. */
583 #define NoNewLine(x) HasFlag(x, FLAG_NONL)
584 /** Return non-zero if the client has set mode +g (debugging). */
585 #define SendDebug(x) HasFlag(x, FLAG_DEBUG)
586 /** Return non-zero if the client has set mode +s (server notices). */
587 #define SendServNotice(x) HasFlag(x, FLAG_SERVNOTICE)
588 /** Return non-zero if the client has set mode +w (wallops). */
589 #define SendWallops(x) HasFlag(x, FLAG_WALLOP)
590 /** Return non-zero if the client claims to be a hub. */
591 #define IsHub(x) HasFlag(x, FLAG_HUB)
592 /** Return non-zero if the client understands IPv6 addresses in P10. */
593 #define IsIPv6(x) HasFlag(x, FLAG_IPV6)
594 /** Return non-zero if the client claims to be a services server. */
595 #define IsService(x) HasFlag(x, FLAG_SERVICE)
596 /** Return non-zero if the client has an account stamp. */
597 #define IsAccount(x) HasFlag(x, FLAG_ACCOUNT)
598 /** Return non-zero if the client has set mode +x (hidden host). */
599 #define IsHiddenHost(x) HasFlag(x, FLAG_HIDDENHOST)
600 /** Return non-zero if the client has set mode +X (xtraop) */
601 #define IsXtraOp(x) HasFlag(x, FLAG_XTRAOP)
602 /** Return non-zero if the client has set mode +n (hide channels) */
603 #define IsNoChan(x) HasFlag(x, FLAG_NOCHAN)
604 /** Return non-zero if the client has set mode +I (hide idletime) */
605 #define IsNoIdle(x) HasFlag(x, FLAG_NOIDLE)
606 /** Return non-zero if the client has an active PING request. */
607 #define IsPingSent(x) HasFlag(x, FLAG_PINGSENT)
608 /** Return non-zero if the client should not receive privmsgs/notices
609 * from unauthed users */
610 #define IsAccountOnly(x) HasFlag(x, FLAG_ACCOUNTONLY)
611 /** Return non-zero if the client should receive notices when someone
612 * does a whois on it. */
613 #define IsParanoid(x) HasFlag(x, FLAG_PARANOID)
614 /** Return non-zero if the server should send opername information */
615 #define IsSendOperName(x) HasFlag(x, FLAG_OPERNAME)
616
617 /** Return non-zero if the client has operator or server privileges. */
618 #define IsPrivileged(x) (IsAnOper(x) || IsServer(x))
619 /** Return non-zero if the client's host is hidden. */
620 #define HasHiddenHost(x) (IsHiddenHost(x) && IsAccount(x))
621 /** Return non-zero if the client is using a spoofhost */
622 #define IsSetHost(x) HasFlag(x, FLAG_SETHOST)
623 #define HasSetHost(x) (IsSetHost(x))
624
625 /** Mark a client as having an in-progress net.burst. */
626 #define SetBurst(x) SetFlag(x, FLAG_BURST)
627 /** Mark a client as being between EOB and EOB ACK. */
628 #define SetBurstAck(x) SetFlag(x, FLAG_BURST_ACK)
629 /** Mark a client as having mode +k (channel service). */
630 #define SetChannelService(x) SetFlag(x, FLAG_CHSERV)
631 /** Mark a client as having mode +d (deaf). */
632 #define SetDeaf(x) SetFlag(x, FLAG_DEAF)
633 /** Mark a client as having mode +g (debugging). */
634 #define SetDebug(x) SetFlag(x, FLAG_DEBUG)
635 /** Mark a client as having ident looked up. */
636 #define SetGotId(x) SetFlag(x, FLAG_GOTID)
637 /** Mark a client as being IP-checked. */
638 #define SetIPChecked(x) SetFlag(x, FLAG_IPCHECK)
639 /** Mark a client as having mode +i (invisible). */
640 #define SetInvisible(x) SetFlag(x, FLAG_INVISIBLE)
641 /** Mark a client as causing a net.join. */
642 #define SetJunction(x) SetFlag(x, FLAG_JUNCTION)
643 /** Mark a client as having mode +O (local operator). */
644 #define SetLocOp(x) SetFlag(x, FLAG_LOCOP)
645 /** Mark a client as having mode +o (global operator). */
646 #define SetOper(x) SetFlag(x, FLAG_OPER)
647 /** Mark a client as having a pending UDP ping. */
648 #define SetUPing(x) SetFlag(x, FLAG_UPING)
649 /** Mark a client as having mode +w (wallops). */
650 #define SetWallops(x) SetFlag(x, FLAG_WALLOP)
651 /** Mark a client as having mode +s (server notices). */
652 #define SetServNotice(x) SetFlag(x, FLAG_SERVNOTICE)
653 /** Mark a client as being a hub server. */
654 #define SetHub(x) SetFlag(x, FLAG_HUB)
655 /** Mark a client as being an IPv6-grokking server. */
656 #define SetIPv6(x) SetFlag(x, FLAG_IPV6)
657 /** Mark a server as sending opername */
658 #define SetOperName(x) SetFlag(x, FLAG_OPERNAME)
659 /** Mark a client as being a services server. */
660 #define SetService(x) SetFlag(x, FLAG_SERVICE)
661 /** Mark a client as having an account stamp. */
662 #define SetAccount(x) SetFlag(x, FLAG_ACCOUNT)
663 /** Mark a client as having mode +x (hidden host). */
664 #define SetHiddenHost(x) SetFlag(x, FLAG_HIDDENHOST)
665 /** Mark a client as having mode +h (spoofhost). */
666 #define SetSetHost(x) SetFlag(x, FLAG_SETHOST)
667 /** Mark a client as having mode +X (xtraop). */
668 #define SetXtraOp(x) SetFlag(x, FLAG_XTRAOP)
669 /** Mark a client as having mode +n (hide channels). */
670 #define SetNoChan(x) SetFlag(x, FLAG_NOCHAN)
671 /** Mark a client as having mode +I (hide idletime). */
672 #define SetNoIdle(x) SetFlag(x, FLAG_NOIDLE)
673 /** Mark a client as having a pending PING. */
674 #define SetPingSent(x) SetFlag(x, FLAG_PINGSENT)
675 /** Mark a client as having mode +R (account only). */
676 #define SetAccountOnly(x) SetFlag(x, FLAG_ACCOUNTONLY)
677 /** Mark a client as having mode +P (paranoid). */
678 #define SetParanoid(x) SetFlag(x, FLAG_PARANOID)
679
680 /** Return non-zero if \a sptr sees \a acptr as an operator. */
681 #define SeeOper(sptr,acptr) (IsAnOper(acptr) && (HasPriv(acptr, PRIV_DISPLAY) \
682 || HasPriv(sptr, PRIV_SEE_OPERS)))
683
684 /** Clear the client's net.burst in-progress flag. */
685 #define ClearBurst(x) ClrFlag(x, FLAG_BURST)
686 /** Clear the client's between EOB and EOB ACK flag. */
687 #define ClearBurstAck(x) ClrFlag(x, FLAG_BURST_ACK)
688 /** Remove mode +k (channel service) from the client. */
689 #define ClearChannelService(x) ClrFlag(x, FLAG_CHSERV)
690 /** Remove mode +d (deaf) from the client. */
691 #define ClearDeaf(x) ClrFlag(x, FLAG_DEAF)
692 /** Remove mode +g (debugging) from the client. */
693 #define ClearDebug(x) ClrFlag(x, FLAG_DEBUG)
694 /** Remove the client's IP-checked flag. */
695 #define ClearIPChecked(x) ClrFlag(x, FLAG_IPCHECK)
696 /** Remove mode +i (invisible) from the client. */
697 #define ClearInvisible(x) ClrFlag(x, FLAG_INVISIBLE)
698 /** Remove mode +O (local operator) from the client. */
699 #define ClearLocOp(x) ClrFlag(x, FLAG_LOCOP)
700 /** Remove mode +o (global operator) from the client. */
701 #define ClearOper(x) ClrFlag(x, FLAG_OPER)
702 /** Clear the client's pending UDP ping flag. */
703 #define ClearUPing(x) ClrFlag(x, FLAG_UPING)
704 /** Remove mode +w (wallops) from the client. */
705 #define ClearWallops(x) ClrFlag(x, FLAG_WALLOP)
706 /** Remove mode +s (server notices) from the client. */
707 #define ClearServNotice(x) ClrFlag(x, FLAG_SERVNOTICE)
708 /** Remove mode +x (hidden host) from the client. */
709 #define ClearHiddenHost(x) ClrFlag(x, FLAG_HIDDENHOST)
710 /** Remove mode +h (spoofhost) from a client. */
711 #define ClearSetHost(x) ClrFlag(x, FLAG_SETHOST)
712 /** Remove mode +X (xtraop) from a client. */
713 #define ClearXtraOp(x) ClrFlag(x, FLAG_XTRAOP)
714 /** Remove mode +n (hide channels) from a client. */
715 #define ClearNoChan(x) ClrFlag(x, FLAG_NOCHAN)
716 /** Remove mode +I (hide idletime) from a client. */
717 #define ClearNoIdle(x) ClrFlag(x, FLAG_NOIDLE)
718 /** Clear the client's pending PING flag. */
719 #define ClearPingSent(x) ClrFlag(x, FLAG_PINGSENT)
720 /** Remove mode +R (account only) from a client */
721 #define ClearAccountOnly(x) ClrFlag(x, FLAG_ACCOUNTONLY)
722 /** Remove mode +P (paranoid) from a client */
723 #define ClearParanoid(x) ClrFlag(x, FLAG_PARANOID)
724
725 /* free flags */
726 #define FREEFLAG_SOCKET 0x0001 /**< socket needs to be freed */
727 #define FREEFLAG_TIMER 0x0002 /**< timer needs to be freed */
728
729 /* server notice stuff */
730
731 #define SNO_ADD 1 /**< Perform "or" on server notice mask. */
732 #define SNO_DEL 2 /**< Perform "and ~x" on server notice mask. */
733 #define SNO_SET 3 /**< Set server notice mask. */
734 /* DON'T CHANGE THESE VALUES ! */
735 /* THE CLIENTS DEPEND ON IT ! */
736 #define SNO_OLDSNO 0x1 /**< unsorted old messages */
737 #define SNO_SERVKILL 0x2 /**< server kills (nick collisions) */
738 #define SNO_OPERKILL 0x4 /**< oper kills */
739 #define SNO_HACK2 0x8 /**< desyncs */
740 #define SNO_HACK3 0x10 /**< temporary desyncs */
741 #define SNO_UNAUTH 0x20 /**< unauthorized connections */
742 #define SNO_TCPCOMMON 0x40 /**< common TCP or socket errors */
743 #define SNO_TOOMANY 0x80 /**< too many connections */
744 #define SNO_HACK4 0x100 /**< Uworld actions on channels */
745 #define SNO_GLINE 0x200 /**< glines */
746 #define SNO_NETWORK 0x400 /**< net join/break, etc */
747 #define SNO_IPMISMATCH 0x800 /**< IP mismatches */
748 #define SNO_THROTTLE 0x1000 /**< host throttle add/remove notices */
749 #define SNO_OLDREALOP 0x2000 /**< old oper-only messages */
750 #define SNO_CONNEXIT 0x4000 /**< client connect/exit (ugh) */
751 #define SNO_AUTO 0x8000 /**< AUTO G-Lines */
752 #define SNO_DEBUG 0x10000 /**< debugging messages (DEBUGMODE only) */
753 #define SNO_AUTH 0x20000 /**< IAuth notices */
754
755 /** Bitmask of all valid server notice bits. */
756 #ifdef DEBUGMODE
757 # define SNO_ALL 0x3ffff
758 #else
759 # define SNO_ALL 0x2ffff
760 #endif
761
762 /** Server notice bits allowed to normal users. */
763 #define SNO_USER (SNO_ALL & ~SNO_OPER)
764
765 /** Server notice bits enabled by default for normal users. */
766 #define SNO_DEFAULT (SNO_NETWORK|SNO_OPERKILL|SNO_GLINE)
767 /** Server notice bits enabled by default for IRC operators. */
768 #define SNO_OPERDEFAULT (SNO_DEFAULT|SNO_HACK2|SNO_THROTTLE|SNO_OLDSNO)
769 /** Server notice bits reserved to IRC operators. */
770 #define SNO_OPER (SNO_CONNEXIT|SNO_OLDREALOP|SNO_AUTH)
771 /** Noisy server notice bits that cause other bits to be cleared during connect. */
772 #define SNO_NOISY (SNO_SERVKILL|SNO_UNAUTH)
773
774 /** Test whether a privilege has been granted to a client. */
775 #define HasPriv(cli, priv) FlagHas(cli_privs(cli), priv)
776 /** Grant a privilege to a client. */
777 #define SetPriv(cli, priv) FlagSet(cli_privs(cli), priv)
778 /** Revoke a privilege from a client. */
779 #define ClrPriv(cli, priv) FlagClr(cli_privs(cli), priv)
780
781 /** Test whether a client has a capability */
782 #define HasCap(cli, cap) CapHas(cli_capab(cli), (cap))
783 /** Test whether a client has the capability active */
784 #define CapActive(cli, cap) CapHas(cli_active(cli), (cap))
785
786 #define HIDE_IP 0 /**< Do not show IP address in get_client_name() */
787 #define SHOW_IP 1 /**< Show ident and IP address in get_client_name() */
788
789 extern const char* get_client_name(const struct Client* sptr, int showip);
790 extern const char* client_get_default_umode(const struct Client* sptr);
791 extern int client_get_ping(const struct Client* local_client);
792 extern void client_drop_sendq(struct Connection* con);
793 extern void client_add_sendq(struct Connection* con,
794 struct Connection** con_p);
795 extern void client_set_privs(struct Client *client, struct ConfItem *oper);
796 extern int client_report_privs(struct Client* to, struct Client* client);
797
798 #endif /* INCLUDED_client_h */
799