ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/svn/ircd-hybrid/trunk/include/client.h
(Generate patch)

Comparing ircd-hybrid-8/include/client.h (file contents):
Revision 1219 by michael, Sun Sep 18 09:02:38 2011 UTC vs.
Revision 1220 by michael, Sun Sep 18 10:07:10 2011 UTC

# Line 1 | Line 1
1   /*
2   *  ircd-hybrid: an advanced Internet Relay Chat Daemon(ircd).
3 *  client.h: The ircd client header.
3   *
4   *  Copyright (C) 2002 by the past and present ircd coders, and others.
5   *
# Line 18 | Line 17
17   *  along with this program; if not, write to the Free Software
18   *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307
19   *  USA
21 *
22 *  $Id$
20   */
21  
22 + /*! \file client.h
23 + * \brief Header including structures, macros and prototypes for client handling
24 + * \version $Id$
25 + */
26 +
27 +
28   #ifndef INCLUDED_client_h
29   #define INCLUDED_client_h
30  
# Line 34 | Line 37
37   #include "channel.h"
38   #include "irc_res.h"
39  
40 < #define HOSTIPLEN       53 /* sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255.ipv6") */
40 > #define HOSTIPLEN       53 /* sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255.ipv6") */
41   #define PASSWDLEN       20
42   #define CIPHERKEYLEN    64 /* 512bit */
43   #define IDLEN           12 /* this is the maximum length, not the actual
# Line 50 | Line 53 | struct Client;
53   struct LocalUser;
54  
55  
56 + /*! \brief Server structure */
57   struct Server
58   {
59 <  struct ConfItem *sconf; /* ConfItem connect{} pointer for this server */
60 <  dlink_list server_list; /* Servers on this server            */
61 <  dlink_list client_list; /* Clients on this server            */
62 <  char by[NICKLEN];       /* who activated this connection     */
59 >  struct ConfItem *sconf; /**< ConfItem connect{} pointer for this server */
60 >  dlink_list server_list; /**< Servers on this server */
61 >  dlink_list client_list; /**< Clients on this server */
62 >  char by[NICKLEN];       /**< who activated this connection */
63   };
64  
65 + /*! \brief SlinkRpl structure */
66   struct SlinkRpl
67   {
68    int command;
# Line 67 | Line 72 | struct SlinkRpl
72    unsigned char *data;
73   };
74  
75 + /*! \brief ZipStats structure */
76   struct ZipStats
77   {
78    uint64_t in;
# Line 77 | Line 83 | struct ZipStats
83    double out_ratio;
84   };
85  
86 + /*! \brief ListTask structure */
87   struct ListTask
88   {
89 <  unsigned int hash_index; /* the bucket we are currently in */
90 <  dlink_list show_mask; /* show these channels..          */
91 <  dlink_list hide_mask; /* ..and hide these ones          */
92 <  unsigned int users_min, users_max;
93 <  unsigned int created_min, created_max;
94 <  unsigned int topicts_min, topicts_max;
89 >  dlink_list show_mask; /**< show these channels.. */
90 >  dlink_list hide_mask; /**< ..and hide these ones */
91 >
92 >  unsigned int hash_index; /**< the bucket we are currently in */
93 >  unsigned int users_min
94 >  unsigned int users_max;
95 >  unsigned int created_min;
96 >  unsigned int created_max;
97 >  unsigned int topicts_min;
98 >  unsigned int topicts_max;
99   };
100  
101 + /*! \brief Client structure */
102   struct Client
103   {
104    dlink_node node;
105 <  dlink_node lnode;             /* Used for Server->servers/users */
105 >  dlink_node lnode;             /**< Used for Server->servers/users */
106  
107    struct LocalUser *localClient;
108 <  struct Client    *hnext;              /* For client hash table lookups by name */
109 <  struct Client    *idhnext;    /* For SID hash table lookups by sid */
110 <  struct Server    *serv;       /* ...defined, if this is a server */
111 <  struct Client    *servptr;    /* Points to server this Client is on */
112 <  struct Client    *from;       /* == self, if Local Client, *NEVER* NULL! */
113 <  struct Whowas    *whowas;     /* Pointers to whowas structs */
114 <  char             *away;
115 <
116 <  time_t            lasttime;   /* ...should be only LOCAL clients? --msa */
117 <  time_t            firsttime;  /* time client was created */
118 <  time_t            since;      /* last time we parsed something */
119 <  time_t            tsinfo;     /* TS on the nick, SVINFO on server */
120 <  time_t            servicestamp;
121 <  uint64_t          flags;      /* client flags */
122 <
123 <  unsigned int      umodes;     /* opers, normal users subset */
124 <  unsigned int      hopcount;   /* number of servers to this 0 = local */
125 <  unsigned int      status;     /* Client type */
126 <  unsigned int      handler;    /* Handler index */
108 >  struct Client    *hnext;      /**< For client hash table lookups by name */
109 >  struct Client    *idhnext;    /**< For SID hash table lookups by sid */
110 >  struct Server    *serv;       /**< ...defined, if this is a server */
111 >  struct Client    *servptr;    /**< Points to server this Client is on */
112 >  struct Client    *from;       /**< == self, if Local Client, *NEVER* NULL! */
113 >  struct Whowas    *whowas;     /**< Pointers to whowas structs */
114 >  char             *away;       /**< Client's AWAY message. Can be set/unset via AWAY command */
115 >
116 >  time_t            lasttime;   /**< ...should be only LOCAL clients? --msa */
117 >  time_t            firsttime;  /**< time client was created */
118 >  time_t            since;      /**< last time we parsed something */
119 >  time_t            tsinfo;     /**< TS on the nick, SVINFO on server */
120 >  time_t            servicestamp; /**< Last time client has been identified for its nick */
121 >  uint64_t          flags;      /**< client flags */
122 >
123 >  unsigned int      umodes;     /**< opers, normal users subset */
124 >  unsigned int      hopcount;   /**< number of servers to this 0 = local */
125 >  unsigned int      status;     /**< Client type */
126 >  unsigned int      handler;    /**< Handler index */
127  
128 <  dlink_list        channel;   /* chain of channel pointer blocks */
128 >  dlink_list        channel;   /**< chain of channel pointer blocks */
129  
130 <  /*
131 <   * client->name is the unique name for a client nick or host
120 <   */
121 <  char name[HOSTLEN + 1];
122 <  char id[IDLEN + 1];       /* client ID, unique ID per client */
130 >  char name[HOSTLEN + 1]; /**< unique name for a client nick or host */
131 >  char id[IDLEN + 1];       /**< client ID, unique ID per client */
132  
133    /*
134     * client->username is the username from ident or the USER message,
135     * If the client is idented the USER message is ignored, otherwise
136     * the username part of the USER message is put here prefixed with a
137 <   * tilde depending on the I:line, Once a client has registered, this
138 <   * field should be considered read-only.
137 >   * tilde depending on the auth{} block. Once a client has registered,
138 >   * this field should be considered read-only.
139     */
140    char              username[USERLEN + 1]; /* client's username */
141  
# Line 153 | Line 162 | struct Client
162                                                  socket ip address as string */
163   };
164  
165 + /*! \brief LocalUser structure
166 + *
167 + * Allocated only for local clients, that are directly connected
168 + * to \b this server with a socket.
169 + */
170   struct LocalUser
171   {
158  /*
159   * The following fields are allocated only for local clients
160   * (directly connected to *this* server with a socket.
161   */
172    dlink_node   lclient_node;
173  
174    char         client_host[HOSTLEN + 1];
175    char         client_server[HOSTLEN + 1];
176  
177    unsigned int registration;
178 <  unsigned int cap_client;    /* Client capabilities (from us) */
179 <  unsigned int cap_active;    /* Active capabilities (to us) */
178 >  unsigned int cap_client;    /**< Client capabilities (from us) */
179 >  unsigned int cap_active;    /**< Active capabilities (to us) */
180  
181 <  unsigned int operflags;     /* oper priv flags */
182 <  unsigned int random_ping;
181 >  unsigned int operflags;     /**< IRC Operator privilege flags */
182 >  unsigned int random_ping; /**< Holding a 32bit value used for PING cookies */
183  
184 <  unsigned int serial;     /* used to enforce 1 send per nick */
184 >  unsigned int serial;     /**< used to enforce 1 send per nick */
185  
186 <  /* Anti flooding part, all because of lamers... */
187 <  time_t       last_knock;    /* time of last knock */
188 <  time_t       last_away; /* Away since... */
179 <  time_t       last_join_time;   /* when this client last
186 >  time_t       last_knock;    /**< time of last knock */
187 >  time_t       last_away; /**< Away since... */
188 >  time_t       last_join_time;   /**< when this client last
189                                      joined a channel */
190 <  time_t       last_leave_time;  /* when this client last
190 >  time_t       last_leave_time;  /**< when this client last
191                                         * left a channel */
192 <  int          join_leave_count; /* count of JOIN/LEAVE in less than
192 >  int          join_leave_count; /**< count of JOIN/LEAVE in less than
193                                           MIN_JOIN_LEAVE_TIME seconds */
194 <  int          oper_warn_count_down; /* warn opers of this possible
194 >  int          oper_warn_count_down; /**< warn opers of this possible
195                                            spambot every time this gets to 0 */
196    time_t       reject_delay;
197    time_t       last_caller_id_time;
198    time_t       first_received_message_time;
199    time_t       last_nick_change;
200 <  time_t       last_privmsg; /* Last time we got a PRIVMSG */
200 >  time_t       last_privmsg; /**< Last time we got a PRIVMSG */
201  
202    int          received_number_of_privmsgs;
203    unsigned int number_of_nick_changes;
204  
205    struct ListTask  *list_task;
206 <  /* Send and receive dbufs .. */
206 >
207    struct dbuf_queue buf_sendq;
208    struct dbuf_queue buf_recvq;
209  
210    struct {
211 <    unsigned int messages;      /* Statistics: protocol messages sent/received */
212 <    uint64_t bytes;             /* Statistics: total bytes sent/received */
211 >    unsigned int messages;      /**< Statistics: protocol messages sent/received */
212 >    uint64_t bytes;             /**< Statistics: total bytes sent/received */
213    } recv, send;
214  
215    struct AuthRequest *auth;
216 <  struct Listener *listener;   /* listener accepted from */
217 <  dlink_list        acceptlist; /* clients I'll allow to talk to me */
218 <  dlink_list        watches;   /* chain of Watch pointer blocks */
219 <  dlink_list        confs;     /* Configuration record associated */
220 <  dlink_list        invited;   /* chain of invite pointer blocks */
216 >  struct Listener *listener;   /**< listener accepted from */
217 >  dlink_list        acceptlist; /**< clients I'll allow to talk to me */
218 >  dlink_list        watches;   /**< chain of Watch pointer blocks */
219 >  dlink_list        confs;     /**< Configuration record associated */
220 >  dlink_list        invited;   /**< chain of invite pointer blocks */
221    struct irc_ssaddr ip;
222 <  int               aftype;     /* Makes life easier for DNS res in IPV6 */
222 >  int               aftype;    /**< Makes life easier for DNS res in IPV6 */
223  
224    char              *passwd;
225 <  unsigned int       caps;       /* capabilities bit-field */
226 <  unsigned int       enc_caps;   /* cipher capabilities bit-field */
225 >  unsigned int       caps;       /**< capabilities bit-field */
226 >  unsigned int       enc_caps;   /**< cipher capabilities bit-field */
227  
228   #ifdef HAVE_LIBCRYPTO
229    struct EncCapability *in_cipher;
# Line 225 | Line 234 | struct LocalUser
234   #endif
235  
236    fde_t             fd;
237 <  fde_t             ctrlfd;     /* For servers: control fd used for sending commands
237 >  fde_t             ctrlfd;     /**< For servers: control fd used for sending commands
238                                     to servlink */
239  
240 <  struct SlinkRpl  slinkrpl;    /* slink reply being parsed */
241 <  char    *slinkq;              /* sendq for control data */
242 <  int              slinkq_ofs;  /* ofset into slinkq */
243 <  int              slinkq_len;  /* length remaining after slinkq_ofs */
240 >  struct SlinkRpl  slinkrpl;    /**< slink reply being parsed */
241 >  char    *slinkq;              /**< sendq for control data */
242 >  int              slinkq_ofs;  /**< ofset into slinkq */
243 >  int              slinkq_len;  /**< length remaining after slinkq_ofs */
244  
245    struct ZipStats  zipstats;
246  
# Line 240 | Line 249 | struct LocalUser
249     * decay to avoid flooding.
250     *   -- adrian
251     */
252 <  int allow_read;       /* how many we're allowed to read in this second */
253 <  int sent_parsed;      /* how many messages we've parsed in this second */
252 >  int allow_read;       /**< how many we're allowed to read in this second */
253 >  int sent_parsed;      /**< how many messages we've parsed in this second */
254  
255 <  char*          response;  /* expected response from client */
256 <  char*          auth_oper; /* Operator to become if they supply the response.*/
255 >  char*          response;  /**< expected response from client */
256 >  char*          auth_oper; /**< Operator to become if they supply the response.*/
257   };
258  
259   /*
# Line 299 | Line 308 | struct LocalUser
308   /*
309   * ts stuff
310   */
311 < #define TS_CURRENT      6       /* current TS protocol version */
312 < #define TS_MIN          5       /* minimum supported TS protocol version */
311 > #define TS_CURRENT      6       /**< current TS protocol version */
312 > #define TS_MIN          5       /**< minimum supported TS protocol version */
313   #define TS_DOESTS       0x20000000
314   #define DoesTS(x)       ((x)->tsinfo == TS_DOESTS)
315  
# Line 311 | Line 320 | struct LocalUser
320   #define HasCap(x, y) ((x)->localClient->cap_active & (y))
321  
322   /* housekeeping flags */
323 < #define FLAGS_PINGSENT      0x0000000000000001 /* Unreplied ping sent                      */
324 < #define FLAGS_DEADSOCKET    0x0000000000000002 /* Local socket is dead--Exiting soon       */
325 < #define FLAGS_KILLED        0x0000000000000004 /* Prevents "QUIT" from being sent for this */
326 < #define FLAGS_CLOSING       0x0000000000000008 /* set when closing to suppress errors      */
327 < #define FLAGS_GOTID         0x0000000000000010 /* successful ident lookup achieved         */
328 < #define FLAGS_NEEDID        0x0000000000000020 /* I-lines say must use ident return        */
329 < #define FLAGS_SENDQEX       0x0000000000000040 /* Sendq exceeded                           */
330 < #define FLAGS_IPHASH        0x0000000000000080 /* iphashed this client                     */
331 < #define FLAGS_CRYPTIN       0x0000000000000100 /* incoming data must be decrypted          */
332 < #define FLAGS_CRYPTOUT      0x0000000000000200 /* outgoing data must be encrypted          */
333 < #define FLAGS_WAITAUTH      0x0000000000000400 /* waiting for CRYPTLINK AUTH command       */
334 < #define FLAGS_SERVLINK      0x0000000000000800 /* servlink has servlink process            */
335 < #define FLAGS_MARK          0x0000000000001000 /* marked client                            */
336 < #define FLAGS_CANFLOOD      0x0000000000002000 /* client has the ability to flood          */
337 < #define FLAGS_EXEMPTGLINE   0x0000000000004000 /* client can't be G-lined                  */
338 < #define FLAGS_EXEMPTKLINE   0x0000000000008000 /* client is exempt from kline              */
339 < #define FLAGS_NOLIMIT       0x0000000000010000 /* client is exempt from limits             */
340 < #define FLAGS_UNUSED___     0x0000000000020000 /* Unused                                   */
341 < #define FLAGS_PING_COOKIE   0x0000000000040000 /* PING Cookie                              */
342 < #define FLAGS_UNUSED____    0x0000000000080000 /* Unused                                   */
343 < #define FLAGS_IP_SPOOFING   0x0000000000100000 /* client IP is spoofed                     */
344 < #define FLAGS_FLOODDONE     0x0000000000200000 /* Flood grace period has been ended.       */
345 < #define FLAGS_EOB           0x0000000000400000 /* server has received EOB                  */
346 < #define FLAGS_HIDDEN        0x0000000000800000 /* a hidden server. not shown in /links     */
347 < #define FLAGS_BLOCKED       0x0000000001000000 /* must wait for COMM_SELECT_WRITE          */
348 < #define FLAGS_SBLOCKED      0x0000000002000000 /* slinkq is blocked                        */
349 < #define FLAGS_USERHOST      0x0000000004000000 /* client is in userhost hash               */
350 < #define FLAGS_BURSTED       0x0000000008000000 /* user was already bursted                 */
351 < #define FLAGS_EXEMPTRESV    0x0000000010000000 /* client is exempt from RESV               */
352 < #define FLAGS_GOTUSER       0x0000000020000000 /* if we received a USER command            */
353 < #define FLAGS_PINGWARNING   0x0000000040000000 /* unreplied ping warning already sent      */
354 < #define FLAGS_FINISHED_AUTH 0x0000000080000000 /* Client has been released from auth       */
355 < #define FLAGS_FLOOD_NOTICED 0x0000000100000000
356 < #define FLAGS_SERVICE       0x0000000200000000 /* Client/server is a network service       */
323 > #define FLAGS_PINGSENT      0x0000000000000001 /**< Unreplied ping sent */
324 > #define FLAGS_DEADSOCKET    0x0000000000000002 /**< Local socket is dead--Exiting soon */
325 > #define FLAGS_KILLED        0x0000000000000004 /**< Prevents "QUIT" from being sent for this */
326 > #define FLAGS_CLOSING       0x0000000000000008 /**< set when closing to suppress errors */
327 > #define FLAGS_GOTID         0x0000000000000010 /**< successful ident lookup achieved */
328 > #define FLAGS_NEEDID        0x0000000000000020 /**< auth{} block say must use ident return */
329 > #define FLAGS_SENDQEX       0x0000000000000040 /**< Sendq exceeded */
330 > #define FLAGS_IPHASH        0x0000000000000080 /**< iphashed this client */
331 > #define FLAGS_CRYPTIN       0x0000000000000100 /**< incoming data must be decrypted */
332 > #define FLAGS_CRYPTOUT      0x0000000000000200 /**< outgoing data must be encrypted */
333 > #define FLAGS_WAITAUTH      0x0000000000000400 /**< waiting for CRYPTLINK AUTH command */
334 > #define FLAGS_SERVLINK      0x0000000000000800 /**< servlink has servlink process */
335 > #define FLAGS_MARK          0x0000000000001000 /**< marked client */
336 > #define FLAGS_CANFLOOD      0x0000000000002000 /**< client has the ability to flood */
337 > #define FLAGS_EXEMPTGLINE   0x0000000000004000 /**< client can't be G-lined */
338 > #define FLAGS_EXEMPTKLINE   0x0000000000008000 /**< client is exempt from kline */
339 > #define FLAGS_NOLIMIT       0x0000000000010000 /**< client is exempt from limits */
340 > #define FLAGS_UNUSED___     0x0000000000020000 /**< Unused */
341 > #define FLAGS_PING_COOKIE   0x0000000000040000 /**< PING Cookie */
342 > #define FLAGS_UNUSED____    0x0000000000080000 /**< Unused */
343 > #define FLAGS_IP_SPOOFING   0x0000000000100000 /**< client IP is spoofed */
344 > #define FLAGS_FLOODDONE     0x0000000000200000 /**< Flood grace period has been ended. */
345 > #define FLAGS_EOB           0x0000000000400000 /**< server has sent us an EOB */
346 > #define FLAGS_HIDDEN        0x0000000000800000 /**< a hidden server. not shown in /links */
347 > #define FLAGS_BLOCKED       0x0000000001000000 /**< must wait for COMM_SELECT_WRITE */
348 > #define FLAGS_SBLOCKED      0x0000000002000000 /**< slinkq is blocked */
349 > #define FLAGS_USERHOST      0x0000000004000000 /**< client is in userhost hash */
350 > #define FLAGS_BURSTED       0x0000000008000000 /**< user was already bursted */
351 > #define FLAGS_EXEMPTRESV    0x0000000010000000 /**< client is exempt from RESV */
352 > #define FLAGS_GOTUSER       0x0000000020000000 /**< if we received a USER command */
353 > #define FLAGS_PINGWARNING   0x0000000040000000 /**< unreplied ping warning already sent */
354 > #define FLAGS_FINISHED_AUTH 0x0000000080000000 /**< Client has been released from auth */
355 > #define FLAGS_FLOOD_NOTICED 0x0000000100000000 /**< Notice to opers about this flooder has been sent */
356 > #define FLAGS_SERVICE       0x0000000200000000 /**< Client/server is a network service */
357  
358   #define HasFlag(x, y) ((x)->flags &   (y))
359   #define AddFlag(x, y) ((x)->flags |=  (y))
# Line 353 | Line 362 | struct LocalUser
362  
363  
364   /* umodes, settable flags */
365 < #define UMODE_SERVNOTICE   0x00000001 /* server notices such as kill */
366 < #define UMODE_CCONN        0x00000002 /* Client Connections */
367 < #define UMODE_REJ          0x00000004 /* Bot Rejections */
368 < #define UMODE_SKILL        0x00000008 /* Server Killed */
369 < #define UMODE_FULL         0x00000010 /* Full messages */
370 < #define UMODE_SPY          0x00000020 /* see STATS / LINKS */
371 < #define UMODE_DEBUG        0x00000040 /* 'debugging' info */
372 < #define UMODE_NCHANGE      0x00000080 /* Nick change notice */
373 < #define UMODE_WALLOP       0x00000100 /* send wallops to them */
374 < #define UMODE_OPERWALL     0x00000200 /* Operwalls */
375 < #define UMODE_INVISIBLE    0x00000400 /* makes user invisible */
376 < #define UMODE_BOTS         0x00000800 /* shows bots */
377 < #define UMODE_EXTERNAL     0x00001000 /* show servers introduced and splitting */
378 < #define UMODE_CALLERID     0x00002000 /* block unless caller id's */
379 < #define UMODE_SOFTCALLERID 0x00004000 /* block unless on common channel */
380 < #define UMODE_UNAUTH       0x00008000 /* show unauth connects here */
381 < #define UMODE_LOCOPS       0x00010000 /* show locops */
382 < #define UMODE_DEAF         0x00020000 /* don't receive channel messages */
383 < #define UMODE_CCONN_FULL   0x00040000 /* add unused fields to connection monitoring */
384 < #define UMODE_REGISTERED   0x00080000 /* User has identified for that nick. */
385 < #define UMODE_REGONLY      0x00100000 /* Only registered nicks may PM */
386 < #define UMODE_OPER         0x40000000 /* Operator */
387 < #define UMODE_ADMIN        0x80000000 /* Admin on server */
365 > #define UMODE_SERVNOTICE   0x00000001 /**< server notices such as kill */
366 > #define UMODE_CCONN        0x00000002 /**< Client Connections */
367 > #define UMODE_REJ          0x00000004 /**< Bot Rejections */
368 > #define UMODE_SKILL        0x00000008 /**< Server Killed */
369 > #define UMODE_FULL         0x00000010 /**< Full messages */
370 > #define UMODE_SPY          0x00000020 /**< see STATS / LINKS */
371 > #define UMODE_DEBUG        0x00000040 /**< 'debugging' info */
372 > #define UMODE_NCHANGE      0x00000080 /**< Nick change notice */
373 > #define UMODE_WALLOP       0x00000100 /**< send wallops to them */
374 > #define UMODE_OPERWALL     0x00000200 /**< Operwalls */
375 > #define UMODE_INVISIBLE    0x00000400 /**< makes user invisible */
376 > #define UMODE_BOTS         0x00000800 /**< shows bots */
377 > #define UMODE_EXTERNAL     0x00001000 /**< show servers introduced and splitting */
378 > #define UMODE_CALLERID     0x00002000 /**< block unless caller id's */
379 > #define UMODE_SOFTCALLERID 0x00004000 /**< block unless on common channel */
380 > #define UMODE_UNAUTH       0x00008000 /**< show unauth connects here */
381 > #define UMODE_LOCOPS       0x00010000 /**< show locops */
382 > #define UMODE_DEAF         0x00020000 /**< don't receive channel messages */
383 > #define UMODE_CCONN_FULL   0x00040000 /**< add unused fields to connection monitoring */
384 > #define UMODE_REGISTERED   0x00080000 /**< User has identified for that nick. */
385 > #define UMODE_REGONLY      0x00100000 /**< Only registered nicks may PM */
386 > #define UMODE_OPER         0x40000000 /**< Operator */
387 > #define UMODE_ADMIN        0x80000000 /**< Admin on server */
388  
389 < #define UMODE_ALL          UMODE_SERVNOTICE
389 > #define UMODE_ALL          UMODE_SERVNOTICE
390  
391   #define HasUMode(x, y) ((x)->umodes &   (y))
392   #define AddUMode(x, y) ((x)->umodes |=  (y))

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines