Fix bugs and memory leaks in ban management.
[ircu2.10.12-pk.git] / ChangeLog
1 2004-12-17  Michael Poole <mdpoole@troilus.org>
2
3         * ircd/channel.h (apply_ban): Add new flag to indicate whether
4         newban should be free()'d after it is used.
5
6         * ircd/channel.c (apply_ban): Likewise.  Also set BAN_DEL flag
7         when setting BAN_OVERLAPPED, and free newban when BAN_DEL.
8         (mode_parse_ban): Delete buggy shortcut when channel banlist is
9         empty.
10         (mode_process_bans): Always give ownership of ban->banstr to the
11         mode buffer, avoiding a memory leak.
12
13         * ircd/m_silence.c (apply_silence): Pass new parameter to
14         apply_ban.
15
16 2004-12-17  Michael Poole <mdpoole@troilus.org>
17
18         * ircd/channel.c (sub1_from_channel): Immediately destroy
19         non-Apass channels when oplevels are enabled; otherwise, they can
20         stay opless for a considerable period.
21         (mode_parse_ban): Initialize banstr to NULL so that set_ban_mask()
22         does not try to free() an invalid pointer.
23
24         * ircd/ircd_parser.y (uworldblock): Put UWorld server name into
25         aconf->host, not aconf->name.
26
27         * ircd/m_server.c (mr_server, ms_server): Attach CONF_UWORLD items
28         by host here..
29
30         * ircd/s_conf.c (conf_check_server): .. rather than by name here.
31         (attach_conf_uworld): New function to attach CONF_UWORLD items.
32         (rehash): Use attach_conf_uworld() instead of attaching by name.
33
34 2004-12-15  Michael Poole <mdpoole@troilus.org>
35
36         * ircd/m_topic.c (do_settopic): Allow +k services to set topics on
37         channels they are not joined.
38
39 2004-12-15  Michael Poole <mdpoole@troilus.org>
40
41         * ircd/IPcheck.c (IPTargetEntry): Make count unsigned to squash
42         warning.
43         (ip_registry_canonicalize): New function to convert an IP address
44         into a canonical form for clone checks.
45         (ip_registry_hash): Update to reflect canonical form.
46         (ip_registry_find): Use ip_registry_canonicalize().
47         (ip_registry_check_local, ip_registry_check_remote): Likewise.
48
49         * ircd/numnicks.c (iptobase64): Map 6to4 addresses to IPv4 when
50         sending them to a non-IPv6 server.
51
52 2004-02-17  Michael Poole <mdpoole@troilus.org>
53
54         * ircd/s_user.c (hide_hostmask): Preserve user's visibility in a
55         +D channel when they hide their hostmask.
56
57 2004-12-15  Michael Poole <dmpoole@troilus.org>
58
59         * doc/example.conf: Remove the example Server blocks since they
60         are no longer used (were merged into Connect).
61
62         * ircd/ircd_res.c (restart_resolver): Fix typo in previous commit.
63
64         * ircd/m_server.c (check_loop_and_lh): Use a different argument to
65         test whether an introduced server is directly connected or not.
66
67 2004-12-14  Michael Poole <mdpoole@troilus.org>
68
69         * include/client.h (FLAG_IPV6): New value for enum Flag.
70         (IsIPv6, SetIPv6): Accessor macros for it.
71
72         * include/numnicks.h (iptobase64): Add flag indicating whether to
73         use full IPv6 addresses or fake them in an IPv4-compatible way.
74
75         * ircd/numnicks.c (iptobase64): Use the new flag.
76
77         * include/send.h (sendcmdto_flag_serv_butone): New function to
78         send different lines to servers based on flags (like FLAG_IPV6).
79
80         * ircd/send.c (sendcmdto_flag_serv_butone): Implement it.
81
82         * ircd/s_bsd.c (completed_connection): Advertise IPv6 support in
83         our server flags.
84
85         * ircd/s_serv.c (server_estab): Likewise.  Also make sure we send
86         compatible IP addresses for the new server.
87
88         * ircd/s_user.c (register_user): Only send full IPv6 addresses to
89         links that have FLAG_IPV6 set.
90
91 2004-12-13  Michael Poole <mdpoole@troilus.org>
92
93         * doc/example.conf: Update General block comment to mention
94         new RESOLVER option and to explain IPv6 support.
95
96         * ircd/ircd_lexer.l: Recognize RESOLVER token.
97
98         * ircd/ircd_parser.y: Declare RESOLVER token and use it in an
99         alternative for generalitem.
100
101         * ircd/ircd_res.c: Define global ResolverAddr variable.  If it is
102         valid, use it instead of VirtualHost in restart_resolver().
103
104 2004-12-13  Michael Poole <mdpoole@troilus.org>
105
106         * doc/example.conf: Update configuration to move Client block
107         comment after sample Class blocks, and update entries in it.
108
109         * ircd/ircd_lexer.y: Recognize IP and USERNAME tokens.
110
111         * ircd/ircd_parser.y: Add ip and username global variables and IP
112         and USERNAME tokens.  Add clientip and clientusername alternatives
113         for clientitem, and update clientblock to correspond.
114
115         * ircd/ircd_res.c (delete_resolver_queries): Do not try to walk
116         the request_list before request_list is initialized.
117         (cres_mem): Likewise.
118
119         * ircd/os_generic.c (sockaddr_from_irc): Improve guessing of
120         proper address family.
121
122         * ircd/s_conf.c (attach_iline): Allow aconf->host == NULL, which
123         means DNS reply is optional.  If aconf->addrbits >= 0, test it.
124
125         * tools/crypter: Delete.
126
127 2004-12-11  Kevin L Mitchell  <klmitch@mit.edu>
128
129         * ircd/*.c: use new assert() in ircd_log.h in preference to system
130         assert()
131
132         * ircd/umkpasswd.c: use new assert in ircd_log.h; add necessary
133         glue so that umkpasswd will successfully compile and link
134
135         * ircd/test/ircd_chattr_t.c: comment out include of assert.h since
136         there are no calls to assert()
137
138         * ircd/ircd_log.c: add sentinel (log_inassert) to prevent assert()
139         from looping should there be an assertion failure somewhere in the
140         logging subsystem
141
142         * include/ircd_log.h: custom implementation of assert() that calls
143         log_write()
144
145 2004-11-21  Michael Poole <mdpoole@troilus.org>
146
147         * ircd/channel.c (mode_parse_upass): Allow forced mode changes to
148         be done by non-channel-managers, fixing a crash from OPMODE.
149         (mode_parse_apass): Likewise.
150
151 2004-11-20  Michael Poole <mdpoole@troilus.org>
152
153         * ircd/m_create.c (ms_create): Complain if a user tries to CREATE
154         a channel they are already in, but do not add them again.
155
156 2004-11-09  Michael Poole <mdpoole@troilus.org>
157
158         * include/res.h (init_resolver): Delete, and initialize lazily.
159
160         * ircd/ircd.c (main): Do not call init_resolver().
161
162         * ircd/ircd_res.c (restart_resolver): Use default VirtualHost for
163         local resolver socket address.
164         (init_resolver): Delete.
165         (make_request): Call restart_resolver() if necessary.
166         (query_name): Use ircrandom() instead of rand().
167
168         * ircd/os_generic.c (sockaddr_from_irc): Convert last argument to
169         a file descriptor that indicates the socket family to use.
170         (os_sendto_nonb,os_socket,os_connect_nonb): Update to match.
171
172 2004-11-09  Michael Poole <mdpoole@troilus.org>
173
174         * ircd/engine_epoll.c (engine_delete): Do not attempt to remove a
175         socket from epoll on delete, since the kernel does that for us.
176
177 2004-11-07  Michael Poole <mdpoole@troilus.org>
178
179         * ircd/m_server.c (m_server, ms_server): Assign timestamp before
180         it might be used in exit_new_server().
181
182 2004-11-07  Michael Poole <mdpoole@troilus.org>
183
184         * aclocal.m4, config.h.in, configure, ircd/Makefile.in: Regenerate
185         to reflect the changes since these files' last rebuild.
186
187 2004-11-07  Michael Poole <mdpoole@troilus.org>
188
189         * include/ircd_crypt.h (ircd_crypt): This should return char*, not
190         const char*, since it does not own the returned pointer.
191
192         * ircd/ircd_crypt.c (ircd_crypt): Change return type.
193
194         * ircd/ircd_crypt_smd5.c (irc_crypt_smd5): Make passwd a static
195         field since it is returned but this function must own the buffer.
196
197         * ircd/m_oper.c (oper_password_match): Free the string returned by
198         ircd_crypt().
199
200         * ircd/engine_epoll.c (engine_loop): Fix a memory leak.
201
202 2004-11-07  Michael Poole <mdpoole@troilus.org>
203
204         * acinclude.m4: Look for a 64-bit integer type.
205
206         * configure.in: Look for inttypes.h, since some systems have that
207         but not stdint.h (and define 64-bit integers therein).
208
209         * include/client.h: Delete con_sendK, con_receiveK.  Make
210         con_sendB and con_receiveB 64 bits wide.
211
212         * include/s_misc.h: Delete is_cks, is_ckr, is_sks, is_skr.
213         Convert the other byte counters and the connected time counters to
214         64 bits wide.
215
216         * ircd/ircd_snprintf.c (doprintf): Unconditionalize the
217         HAVE_LONG_LONG bits, and use the 64-bit integer types from above.
218
219         * ircd/packet.c (update_bytes_received): Remove use of
220         cli_receiveK().
221
222         * ircd/s_bsd.c (deliver_it): Likewise.
223         (close_connection): Likewise.
224
225         * ircd/s_misc.c (tstats): Likewise.  Update format strings to use
226         %Lu for 64-bit integer parameters.
227
228         * ircd/s_stats (stats_links): Convert cli_sendK() and
229         cli_receiveK() use shifted versions of the byte counters, and
230         update format strings to use %Lu for 64-bit integer parameters.
231
232 2004-11-07  Michael Poole <mdpoole@troilus.org>
233
234         * include/s_user.h (add_silence): Delete.
235         (del_silence): Delete.
236
237         * include/struct.h (struct User): Convert silence list to struct Ban.
238
239         * ircd/m_silence.c (apply_silence, forward_silences): New functions.
240         (m_silence): Use forward_silences() instead of add_silence().
241         (ms_silence): Likewise.
242
243         * ircd/s_err.c (replyTable): Update RPL_SILELIST.
244
245         * ircd/s_misc.c (exit_one_client): Update to new silence list type.
246
247         * ircd/s_user.c (is_silenced): Use find_ban() to search for
248         silences.  If one is found, send it plus any silence exceptions.
249         (del_silence): Delete.
250         (add_silence): Delete.
251
252 2004-11-07  Michael Poole <mdpoole@troilus.org>
253
254         * include/channel.h: Remove declarations for undefined functions
255         cancel_mode(), add_token_to_sendbuf(), IsMember().  Delete
256         add_banid(), next_removed_overlapped_ban().  Add BAN_EXCEPTION
257         flag and new functions find_ban(), apply_ban().
258
259         * ircd/channel.c (PartFmt*, next_ban, prev_ban, removed_bans_list,
260         LocalChanOperMode): Remove unused variable definitions.
261         (make_nick_user_host): Delete.
262         (add_banid): Delete.
263         (next_removed_overlapped_ban): Delete.
264         (find_ban): New function, which knows about exceptions.
265         (is_banned): Use find_ban() and only work on a struct Membership.
266         (bmatch): New function, which knows about CIDR bans.
267         (apply_ban): New function to replace add_banid().
268         (mode_parse_ban): Use apply_ban().
269
270 2004-10-28  Michael Poole <mdpoole@troilus.org>
271
272         * configure.in (AC_PREREQ): Depend on autoconf 2.50 since we use
273         new macros like AC_LINK_IFELSE and AC_LANG_PROGRAM.
274
275 2004-10-22  Michael Poole <mdpoole@troilus.org>
276
277         * ircd/m_invite.c (m_invite, ms_invite): Fix INVITE forwarding
278         with announcements enabled (do not "announce" to the recipient,
279         and unconditionally send to the recipient).
280
281         * ircd/send.c (sendcmdto_channel_servers_butone): Properly skip
282         the "from" client and implement SKIP_NONOPS and SKIP_NONVOICES.
283
284 2004-10-21  Michael Poole <mdpoole@troilus.org>
285
286         * include/channel.h (Ban): Add fields address, nu_len, addrbits to
287         support netmask-based bans.
288
289         * ircd/channel.c (set_ban_mask): New function to parse a ban as
290         either netmask-based or not.
291         (make_ban): Use set_ban_mask().
292         (make_nick_user_ip): Becomes unused; remove it.
293         (is_banned): Rewrite to match only once against the nick!user part
294         of a ban, and compare addresses if BAN_IPMASK is set.
295         (mode_parse_ban): Use set_ban_mask().
296
297 2004-10-21  Michael Poole <mdpoole@troilus.org>
298
299         * ircd/s_conf.c (attach_iline): Test resolved host names against
300         aconf->host, not the (NULL) aconf->name.
301
302 2004-10-19  Michael Poole <mdpoole@troilus.org>
303
304         * include/channel.h: Move ban flags out of channel flags and
305         rename to reflect this.
306
307         * ircd/channel.c: Update ban constant names.
308
309         * ircd/m_burst.c: Likewise.
310
311 2004-10-18  Michael Poole <mdpoole@troilus.org>
312
313         * include/list.h (SLink): Remove ban elements from here...
314
315         * include/channel.h (Ban): And move to the new struct Ban.
316         (Channel): Update banlist field to match.
317         (next_removed_overlapped_ban): Update return type to match.
318         (make_ban, free_ban): New functions.
319
320         * ircd/channel.c (next_ban, prev_ban, removed_bans_list): Update
321         list types.
322         (free_bans): New variable to hold unused Ban elements.
323         (make_ban, free_ban): New functions.
324         (destruct_channel, add_banid, next_removed_overlapped_ban): Update
325         to use struct Ban.
326         (is_banned, send_channel_modes, send_ban_list): Likewise.
327         (ParseState, mode_parse_ban, mode_process_bans): Likewise.
328         (mode_parse): Likewise.
329
330         * ircd/m_burst.c (ms_burst): Update to use struct Ban.
331
332         * ircd/m_clearmode.c (do_clearmode): Update to use struct Ban.
333
334         * ircd/s_debug.c (count_memory): Update to use struct Ban.
335
336 2004-10-18  Kevin L Mitchell  <klmitch@mit.edu>
337
338         * ircd/gline.c (gline_find): unless we're looking for an exact
339         match, we should call match() on hostnames, not ircd_strcmp()
340
341 2004-10-17  Michael Poole <mdpoole@troilus.org>
342
343         * include/s_conf.h (ConfItem): Add new field username.  Replace
344         unused field bits with addrbits.
345         (find_conf_exact): Replace user and host arguments with cptr.
346         (find_conf_name, read_tlines, find_restrict): Remove declaration
347         for undefined functions.
348         (conf_parse_userhost): New function.
349
350         * ircd/m_oper.c (m_oper): Update calls to find_conf_exact(): both
351         resolved hostname and IP are matched in one pass now.
352
353         * ircd/s_bsd.c (close_connection): Update call to find_conf_exact().
354
355         * ircd/s_conf.c (conf_parse_userhost): New function.
356         (check_limit_and_attach): Use correct ConfItem field to determine
357         maximum connections per IP.
358         (attach_iline): Replace user@host matching with shorter, clearer
359         matching against username and host/IP fields.
360         (find_conf_exact): Likewise.
361
362         * ircd/ircd_parser.y: Replace assignment to aconf->host for
363         CONF_CLIENT and CONF_OPERATOR with calls the CIDR-aware
364         conf_parse_userhost().  This means CONF_CLIENT ConfItems no longer
365         use the name field or the IP token.  Remove the latter.
366
367         * ircd/ircd_lexer.l: Remove unused token IP.
368
369 2004-10-17  Michael Poole <mdpoole@troilus.org>
370
371         * ircd/crule.c (crule_via): Simplify the lookup for the directly
372         connected server name.
373
374 2004-10-16  Michael Poole <mdpoole@troilus.org>
375
376         * ircd/class.c: Make find_class() return NULL for unknown classes,
377         rather than returning the start of connClassList.
378
379         * ircd/match.c (parse_ipmask): Translate IPv4 masks as
380         IPv4-compatible addresses.
381         (check_ipmask): Fix comparison of IP masks.
382
383         * ircd/motd.h, ircd/motd.c: Add a new MOTD type, MOTD_IPMASK, that
384         uses CIDR style masks in the hostname field of a Motd block.
385
386 2004-10-16  Michael Poole <mdpoole@troilus.org>
387
388         * ircd/numeric.h: Remove the unused RPL_STATMEM and
389         RPL_STATMEMTOT.  Move the RPL_BOUNCE comment to its current
390         value (the former RPL_STATMEM).
391
392         * ircd/s_err.c: Remove format strings for RPL_STATMEM and
393         RPL_STATMEMTOT.
394
395 2004-10-16  Michael Poole <mdpoole@troilus.org>
396
397         * ircd/m_server.c: Look up server configuration by name of our
398         directly connected peer rather than the server being introduced.
399
400 2004-10-13  Michael Poole <mdpoole@troilus.org>
401
402         * include/channel.h: Delete MODE_LISTED and is_listed().  Replace
403         ListingArgs.chptr with ListingArgs.bucket.  Move declaration of
404         list_next_channels() to..
405
406         * include/hash.h: here, and drop the "nr" argument.
407
408         * ircd/channel.c: Remove redundant scan of local clients for
409         channels being listed.  Delete list_next_channels() function.
410
411         * ircd/hash.c: Add list_next_channels() here, revising to not use
412         MODE_LISTED and to use ListingArgs.bucket instead of chptr.  Also
413         decide when to stop sending RPL_LISTs based on a half-full sendq.
414
415         * ircd/m_burst.c, ircd/s_misc.c: Delete mention of MODE_LISTED.
416
417         * ircd/m_list.c: Delete mention of MODE_LISTED.  Unconditionally
418         call list_next_channels(sptr).
419
420         * ircd/s_bsd.c: Remove the "nr" argument to list_next_channels().
421
422         * ircd/Makefile.in: Update dependencies (for hash.c).
423
424 2004-10-13  Michael Poole <mdpoole@troilus.org>
425
426         * ircd/ircd_parser.y: Consistently zero out global variables after
427         they are used (prevents double frees and other problems).
428
429 2004-10-12  Michael Poole <mdpoole@troilus.org>
430
431         * include/client.h: Rename FLAGSET_ISSET, _SET, _CLEAR to FlagHas,
432         Set, Clr respectively.  Get rid of FLAG_CHKACCESS and FLAG_LOCAL.
433         Delete con_fd (get from con_socket) and con_port.  Move sentalong
434         from send.c to struct Connection, and cli_lasttime and cli_since
435         from struct Client to struct Connection.  Update cli_*() macros to
436         use con_*(cli_connect(cli)).
437
438         * ircd/client.c: Replace PrivSet() with FlagSet(), PrivClr() with
439         FlagClr(), PrivHas() with FlagHas().
440
441         * ircd/ircd_parser.y: Likewise.
442
443         * ircd/list.c: Remove assignment to cli_local() since it is now a
444         calculated value.
445
446         * ircd/s_bsd.c: Remove uses of cli_port().
447
448         * ircd/s_conf.c: Remove uses of ClearAccess().
449
450         * ircd/send.c: Delete sentalong array and replace with references
451         to con_sentalong().
452
453 2004-10-12  Michael Poole <mdpoole@troilus.org>
454
455         * doc/example.conf: Update example config to reflect the changes
456         made in the remainder of this patch.
457
458         * include/list.h: Make make_conf() take a type argument.
459
460         * include/s_conf.h: Delete CONF_LEAF and CONF_HUB.  Add "maximum"
461         and "hub_limit" to ConfItem to compensate.
462
463         * ircd/ircd_lexer.l: Recognize MAXHOPS token.
464
465         * ircd/ircd_parser.y: Get rid of aconf global variable and add
466         hub_limit global variable.  Add MAXHOPS token, and productions
467         inside connectblock to recognize it and hub masks.  Allow maxlinks
468         field in a Client block, rather than overloading password field.
469         Convert serverblock to uworldblock and remove extraneous fields.
470
471         * ircd/m_server.c: Make check_loop_and_lh() look up ConfItem and
472         calculate LHcptr and active_lh_line.  Merge some duplicated code
473         so handling active_lh_line cases is clearer.
474
475         * ircd/s_conf.c: Make make_conf() take a type argument.  Delete
476         CONF_LEAF and CONF_HUB.  Do not overwrite server name with what
477         is specified in the config file.
478
479         * ircd/s_err.c: Remove the unused RPL_STATSNLINE and
480         RPL_STATSHLINE.  Remove useless parameters and format fields from
481         RPL_STATSCLINE, RPL_STATSILINE, RPL_STATSLLINE, RPL_STATSOLINE and
482         RPL_STATSULINE.
483
484         * ircd/s_serv.c: Delete CONF_LEAF and CONF_HUB.
485
486         * ircd/s_stats.c: Get rid of report_array and make
487         stats_configured_links() directly use RPL_STATSxLINE (adding the
488         new fields for Server and Client blocks).  Remove /stats h, since
489         that has no meaning.
490
491 2004-10-12  Michael Poole <mdpoole@troilus.org>
492
493         * ircd/m_burst.c: Mask off channel modes in a wiped-out channel by
494         default rather than by listing which should be wiped out.
495
496 2004-10-09  Michael Poole <mdpoole@troilus.org>
497
498         * ircd/m_server.c: Forward port checks for leaf and hub config
499         rules, and reorganize mr_server() and ms_server() by moving out
500         common code.  Add doxygen comments for the file.
501
502 2004-10-09  Michael Poole <mdpoole@troilus.org>
503
504         * ircd/hash.c: Fix thinko in hash function: It is not indexed
505         simply by character value, so we cannot just remap the values
506         by case.
507
508 2004-10-05  Michael Poole <mdpoole@troilus.org>
509
510         * ircd/hash.c: Replace the old hash function with one based on
511         randomized CRC-32.  The new one avoids a big table from the old
512         function.
513
514 2004-10-05  Michael Poole <mdpoole@troilus.org>
515
516         * ircd/random.c: Convert to use ircd_md5 interface and hopefully
517         keep more internal random state.
518
519 2004-10-05  Michael Poole <mdpoole@troilus.org>
520
521         * include/ircd_md5.h, ircd/ircd_md5.c, ircd_crypt_smd5.c,
522         ircd/umkpasswd.c: Get rid of the GoodMD5xxx/BrokenMD5xxx
523         prefixes.
524
525 2004-10-05  Michael Poole <mdpoole@troilus.org>
526
527         * adns, lib/adns: Remove unused adns library.
528
529 2004-10-05  Michael Poole <mdpoole@troilus.org>, hikari <hikari@undernet.org>, Perry Lorier <isomer@undernet.org>
530
531         * include/*.h, ircd/*.c: Convert comments to Doxygen-compatible
532         format, and add new comments where needed.
533
534         * Doxyfile: New file to tell Doxygen how to run.
535
536 2004-09-21  Michael Poole <mdpoole@troilus.org>
537
538         * ircd/s_auth.c (HeaderMessages): Make the compiler, not the
539         programmer, generate magic numbers.
540         (AuthIncompleteList): Remove.
541         (AuthPollList): Remove.
542
543 2004-09-19  Michael Poole <mdpoole@troilus.org>
544
545         * acinclude.m4: Clean up AC_DEFINE()s so we no longer need
546         acconfig.h.
547
548         * acconfig.h: Remove since it is now redundant.
549
550         * aclocal.m4, config.h.in, configure: Regenerate.
551
552 2004-09-19  hikari <hikari@undernet.org>
553
554         * configure.in: Fixed configure script rules to fail if (f)lex or yacc/bison 
555         aren't found as they're essential for compilation.  Regenerated files with 
556         autreconf.
557                 
558 2004-09-18  Michael Poole <mdpoole@troilus.org>
559
560         * doc/example.conf: Add NETWORK feature example.  Fix typos in
561         eaxmples for HANGONGOODLINK and IRCD_RES_TIMEOUT.
562
563         * include.class.h: Make max_links and ref_count unsigned ints.
564         Make ping_freq and conn_freq unsigned short. (No more negative
565         numbers in /stats y.)
566
567         * ircd/ircd.c: Report configuration file name for "ircd -k".
568
569 2004-09-18  hikari <hikari@undernet.org>
570
571         * ircd/Makefile.in: Fixed a missing internal build dependency.
572         
573 2004-09-16  Michael Poole <mdpoole@troilus.org>
574
575         * INSTALL: Fix name of example.conf and mention its installed
576         location.
577
578         * include/supported.h (FEATURESVALUES2): Fix a reference to
579         channel mode +u that escaped earlier rename attempts.
580
581         * ircd/ircd_auth.c (iauth_connect): Assign port number after
582         zeroing out the destination address.
583         Add some additional debug statements to help follow operations.
584
585         * ircd/ircd_parser.y (iauthblock): Do not require "name" to be set.
586
587 2004-09-11  Bas Steendijk <steendijk@xs4all.nl>
588
589         * include/channel.h, include/supported.h, ircd/channel.c,
590         ircd/s_err.c: Use +U instead of +u for user keys.
591
592 2004-09-13  Michael Poole <mdpoole@troilus.org>
593
594         * doc/example.conf: Remove sample VIRTUAL_HOST setting.
595
596         * doc/readme.features: Remove VIRTUAL_HOST documentation, and
597         update NODNS documentation to match current behavior.
598
599         * include/s_conf.h: Remove now-unused vhost_address field and
600         set_virtual_host() function.
601
602         * include/ircd_features.h, ircd/ircd_features.c, ircd/s_debug.c:
603         Remove VIRTUAL_HOST.
604
605         * ircd/ircd_auth.c, ircd/s_bsd.c: Use VirtualHost as local address
606         if we do not have a more specific alternate.
607
608         * ircd/ircd_parser.y: Check for sanity in General blocks (from old
609         conf_add_local()) and assign vhost directly to VirtualHost.
610
611         * ircd/ircd_res.c (irc_in_addr_valid): Fix thinko; obviously any
612         value will be either != 0 or != 0xffff.
613
614         * ircd/os_generic.c: Use AF_INET instead of AF_INET6 when the
615         local addresses are specified as IPv4 addresses.
616
617         * ircd/s_conf.c: Remove unused conf_add_local() and
618         set_virtual_host().
619
620 2004-09-13  Michael Poole <mdpoole@troilus.org>
621
622         * ircd/listener.c (add_listener): Consolidate duplicated code, and
623         make sure listener->server is set before calling inetport() on it.
624
625 2004-09-12  Michael Poole <mdpoole@troilus.org>
626
627         * include/channel.c (mode_parse_upass, mode_parse_apass): Only let
628         services (not normal opers) force a change of +A or +u.
629
630 2004-09-11  Michael Poole <mdpoole@troilus.org>
631
632         * include/s_stats.h: Add sd_name to struct StatDesc.  Stop
633         publishing the statsinfo and statsmap arrays; replace them with
634         stats_find().  Change argument list of StatFunc() to work with
635         names.
636
637         * ircd/m_stats.c: Use stats_find() instead of statsmap[].  Use the
638         full argument instead of just the first character in reports.
639
640         * ircd/s_stats.c: Adapt individual stats handler functions to new
641         argument list.  Add long names to statsinfo[].  Add new functions
642         stats_cmp(), stats_search(), stats_find().  Sort statsinfo[] in
643         stats_init().
644
645         * ircd/s_err.c: Change ENDOFSTATS to display a string rather than
646         a single character.
647
648         * ircd/s_user.c: Send an error to the user when a message loses
649         its target in transit.
650
651         * include/class.h include/gline.h include/ircd_features.h
652         include/listener.h include/motd.h include/msgq.h include/res.h
653         include/s_debug.h include/s_misc.h include/userload.h ircd/class.c
654         ircd/gline.c ircd/ircd_features.c ircd/ircd_res.c ircd/listener.c
655         ircd/motd.c ircd/msgq.c ircd/s_debug.c ircd/s_misc.c
656         ircd/userload.c: Adjust stats handlers to new argument list.
657
658 2004-09-11  Michael Poole <mdpoole@troilus.org>
659
660         * include/numeric.h, ircd/s_err.c: Remove RPL_TRACEPING, and
661         replace with RPL_TRACEEND.
662
663         * ircd/s_trace.c: Move all the duplicated code in m*_trace() to
664         do_trace().  Implement RPL_TRACEEND, per RFE#830291.
665
666 2003-06-20  Alexander Maassen <outsider@key2peace.org>
667
668         * ircd/m_topic.c : Don't allow banned users to set a topic in a
669         channel.
670
671 2004-09-11  Kevin L Mitchell  <klmitch@mit.edu>
672
673         * config.h.in, tools/Makefile.crypt: Remove wrong pathname from
674         comment in header.
675
676         * ircd/m_clearmode.c, ircd/m_opmode.c: Fix wrong pathname in
677         header comment.
678
679         * ircd/m_away.c, ircd/m_kill.c, ircd/m_notice.c, ircd/m_ping.c,
680         ircd/m_pong.c, ircd/m_privmsg.c, ircd/m_quit.c, ircd/m_topic.c,
681         ircd/m_version.c: Remove "template" moniker from comments.
682
683         * ircd/test/ircd_chattr.0.dat (IsChannelPrefix): Drop + from
684         channel prefix list.
685
686 2004-09-11  Michael Poole <mdpoole@troilus.org>
687
688         * doc/example.conf: Add examples for FEAT_HIS_* features.
689
690 2003-06-08 Matthias Crauwels <ultimate_@wol.be>
691         [Feature renamed to FEAT_HIS_WHOIS_LOCALCHAN by Michael Poole.]
692
693         * include/ircd_features.h: new feature FEAT_HIS_LOCAL_CHAN_WHOIS
694
695         * ircd/ircd_features.c: new feature FEAT_HIS_LOCAL_CHAN_WHOIS
696
697         * ircd/m_whois.c: hide local channels in local WHOIS, this breaks HIS
698
699         * doc/readme.features: documented FEAT_HIS_LOCAL_CHAN_WHOIS
700
701         * doc/ircd.conf.sample: default value for FEAT_HIS_LOCAL_CHAN_WHOIS
702
703 2004-09-11  Michael Poole <mdpoole@troilus.org>
704
705         * ircd/ircd_relay.c (server_relay_channel_message,
706         server_relay_channel_notice): Do not allow other servers to send
707         or relay to local channels.
708
709         * ircd/m_wallchops (ms_wallchops): Likewise.
710
711         * ircd/m_wallvoices (ms_wallvoices): Likewise.
712
713 2004-09-11  Kevin L Mitchell  <klmitch@mit.edu>
714
715         * ircd/gline.c (gline_add): fix GLINE logging (Bug #750927)
716
717         * ircd/channel.c: removing limits shouldn't gobble an argument;
718         this was a subtle interaction issue with modebuf...fixed by adding
719         MODE_LIMIT to modebuf_flush_int() and short-circuiting
720         modebuf_mode_uint() to add MODE_LIMIT to mbuf->mb_rem in the
721         removal case.  Note that this is not proof against the sequence,
722         "modebuf_mode_uint(mbuf, MODE_ADD | MODE_LIMIT, 10);
723         modebuf_mode_uint(mbuf, MODE_DEL | MODE_LIMIT, 10);"
724         (Bug #916138)
725
726 2004-09-11  Michael Poole <mdpoole@troilus.org>
727
728         * include/supported.h: Kev pointed out I misinterpreted the
729         meaning of CHANMODES; fix this.  Also define CHANNELLEN and
730         STATUSMSG from the ISUPPORT draft.
731
732 2004-09-10  Michael Poole <mdpoole@troilus.org>
733
734         * include/supported.h (FEATURESVALUES2): Include A,u, in CHANMODES
735         when oplevels are enabled.
736
737 2004-09-10  Michael Poole <mdpoole@troilus.org>
738
739         * ircd/channel.c (send_channel_modes): Only send oplevels for
740         channels that actually use them -- for -A channels, send chanops
741         as :o even if OPLEVELS is enabled.
742
743         * ircd/ircd.c: Fix -k (chkconf mode) and show in usage help.
744
745         * ircd/numnicks.c (base64toip): Fill in the right number of 0
746         words when we see _ in a base64-encoded IPv6 address.
747
748 2004-09-10  Michael Poole <mdpoole@troilus.org>
749
750         * ircd/ircd.c: Add -k as a chkconf-like option to exit after
751         reading the configuration file.
752
753         * ircd/chkconf.c: Remove as unused.
754
755         * ircd/Makefile.in: Remove last mentions of chkconf from Makefile.
756
757 2004-09-10  Michael Poole <mdpoole@troilus.org>
758
759         * doc/example.conf: Remove examples for unused features (TIMESEC,
760         CRYPT_OPER_PASSWORD) and add for new feature (ANNOUNCE_INVITES).
761
762         * doc/readme.features: Remove documentation for unused features
763         (TIMESEC, CRYPT_OPER_PASSWORD, oper/locop privileges,
764         HIS_DESYNCS), update defaults for SOCKSENDBUF and SOCKRECVBUF, and
765         add documentation for ANNOUNCE_INVITES.
766
767         * include/ircd_features.h: Remove unused features (TIMESEC,
768         CRYPT_OPER_PASSWORD, LIST_CHAN, HIS_DESYNCS).
769
770         * include/ircd_features.c: Likewise.
771
772         * ircd/ircd_res.c: Actually use FEAT_IRCD_RES_RETRIES and
773         FEAT_IRCD_RES_TIMEOUT where appropriate.
774
775         * ircd/s_debug.c: Do not display setting of unused (and now
776         non-existent) FEAT_CRYPT_OPER_PASSWORD.
777
778 2004-09-10  Michael Poole <mdpoole@troilus.org>
779
780         * ircd/os_generic.c (sockaddr_from_irc): Fix IPv4 implementation
781         to use the correct address family and IP offset.
782
783 2004-09-10  Michael Poole <mdpoole@troilus.org>
784
785         * include/s_conf.h (struct ConfItem): Add origin and origin_name
786         fields.
787
788         * ircd/ircd_parser.y: Add new global variable "origin."  Add a new
789         "connectionvhost" production that accepts vhost = "IP" inside a
790         Connect block and assigns the IP to origin_name.
791
792         * ircd/s_bsd (connect_inet): If aconf has a valid origin, use it
793         as the local address.  Otherwise, fall back to the old logic (if
794         VIRTUAL_HOST="TRUE", use the virtual host setting).
795
796         * ircd/s_conf.c (lookup_confhost): If the ConfItem has an
797         origin_name, try to parse it as an IP address.
798
799 2004-04-17  Isomer <isomer@undernet.org>
800         * ircd/parse.c: Don't rate limit /gline messages
801
802 2004-09-10  Michael Poole <mdpoole@troilus.org>
803
804         * ircd/ircd_parser.y: Replace references to yylval.whatever with
805         references to the appropriate term.  This fixes bugs like
806         "1 hour 30 minutes" being misrecognized as 30 seconds.
807
808 2004-09-10  Michael Poole <mdpoole@troilus.org>
809
810         * ircd/ircd_features.c (features): Change default values for
811         SOCKSENDBUF and SOCKRECVBUF to SERVER_TCP_WINDOW, so that users
812         need not specify them in ircd.conf.
813
814 2004-09-10  Michael Poole <mdpoole@troilus.org>
815
816         * ircd/ircd_parser.y (serverblock): Server blocks should default
817         to CONF_LEAF status.
818
819         * doc/example.conf: Update example to reflect this.
820
821 2004-09-10  Michael Poole <mdpoole@troilus.org>
822
823         * ircd/parse.c (msg_tree_parse): Reject commands that contain
824         non-alphabetic characters.
825
826 2004-09-09  Michael Poole <mdpoole@troilus.org>
827
828         * config.h.in: Remove duplicated and unused macro definitions.
829
830 2004-08-24  Michael Poole <mdpoole@troilus.org>
831
832         * ircd/client.h: Properly parenthesize "flag" argument to
833         FLAGSET_INDEX() and FLAGSET_MASK() macros.
834
835 2004-08-22  Michael Poole <mdpoole@troilus.org>
836
837         * ircd/channel.c (send_channel_modes): If oplevels are disabled,
838         send 'o' for chanops instead of the member's oplevel.
839
840 2004-08-22  Michael Poole <mdpoole@troilus.org>
841
842         * ircd/s_conf.c: find_conf_byip() should use irc_in_addr_cmp()
843         instead of memcmp().  (Fixes IPv4 servers linking to an IPv6
844         server.)
845
846 2004-08-22  Alex Badea  <decampos@users.sourceforge.net>
847
848         * include/ircd_defs.h: increased SOCKIPLEN to fit ipv6 addresses
849
850 2004-08-19  Michael Poole <mdpoole@troilus.org>
851
852         * include/res.h: Remove unused function gethost_byname_type().
853
854         * ircd/ircd_res.c: Likewise, and clean up some small functions
855         only used once (remove_dlink(), timeout_resolver()).  Use rand()
856         for random request IDs instead of the deprecated *rand48().  Make
857         resolver timeout event fire only when needed instead of once a
858         second.
859
860 2004-08-17  Michael Poole <mdpoole@troilus.org>
861
862         IPv6 support, with lots of code and design borrowed from a patch
863         by Alex Badea.
864
865         * config.h.in: Add place to #define IPV6 support.
866
867         * configure.in: Check for struct sockaddr_in6, and use that as
868         the default choice for IPv6 support.
869
870         * configure: Regenerate.
871
872         * include/IPcheck.h, include/client.h, include/gline.h,
873         include/ircd_string.h, include/listener.h, include/match.h,
874         include/res.h, include/s_bsd.h: Convert from struct in_addr (from
875         <netinet/in.h>) to struct irc_in_addr (from "res.h").
876
877         * include/ircd_osdep.h, include/s_conf.h, include/uping.h: Convert
878         from struct sockaddr_in (from <netinet/in.h>) to struct
879         irc_sockaddr (from "res.h").  Add new functions os_socket(),
880         os_accept(), os_sendto_nonb() to help abstract away actual
881         sockaddr types.
882
883         * include/ircd_chattr.h, ircd/table_gen.c: Define new bit to mark
884         characters valid in IPv6 addresses.
885
886         * include/numnicks.h, ircd/numnicks.c: New functions iptobase64()
887         and base64toip() to convert from base64 to struct irc_in_addr.
888
889         * ircd/IPcheck.c, ircd/channel.c, ircd/m_nick.c, ircd/m_oper.c,
890         ircd/m_userip.c, ircd/m_who.c, ircd/m_whois.c, ircd/s_misc.c,
891         ircd/s_serv.c, ircd/s_user.c, ircd/whocmds.c: Use struct
892         irc_in_addr instead of unsigned int or struct in_addr.
893
894         * ircd/gline.c: Use new more-generic ipmask functions.
895
896         * ircd/ircd.c: Use struct irc_sockaddr instead of separate port
897         fields.
898
899         * ircd/ircd_reslib.c: Use struct irc_sockaddr and ircd_aton()
900         instead of irc_ssaddr and irc_getaddrinfo().
901
902         * ircd/ircd_string.c: Implement new functions: IPv6-capable
903         ircd_ntoa_r(), ircd_aton_ip4(), ircd_aton().
904
905         * ircd/match.c: Delete IPv4-only matchcompIP().  Replace with
906         IPv6-capable ipmask_parse() and ipmask_check().
907
908         * ircd/numnicks.c: Implement new functions: iptobase64() and
909         base64toip().
910
911         * ircd/os_generic: Convert external parameters to be struct
912         irc_addrinfo.  When using IPv6 support, sockaddr_in6 is native.
913         Implement new functions os_sendto_nonb(), os_socket() and
914         os_accept().
915
916         * ircd/ircd_auth.c, ircd/ircd_parser.y, ircd/ircd_res.c,
917         ircd/listener.c, ircd/m_connect.c, ircd/s_auth.c, ircd/s_bsd.c,
918         ircd/s_conf.c, ircd/s_stats.c, ircd/uping.c: Use struct
919         irc_sockaddr instead of separate in_addr and port fields and new
920         OS support functions.
921
922         * include/ircd_addrinfo.h, ircd/ircd_getaddrinfo.c,
923         ircd/ircd_getnameinfo.c: Remove, since these functions are no
924         longer used.
925
926         * ircd/os_bsd.c, ircd/os_linux.c, ircd/os_openbsd.c,
927         ircd/os_solaris.c, ircd/res_adns.c, ircd/res_libresolv.c: Remove,
928         since these are unused and not compatible with IPv6 support.
929
930         * ircd/Makefile.in: Remove references to ircd_getXxxxinfo.c.
931         Regenerate dependencies.
932
933 2004-08-17  Michael Poole <mdpoole@troilus.org>
934
935         * ircd/ircd_lexer.l: Change tokenizer to reduce number of lexer
936         states and be case-insensitive again.
937
938 2004-08-15  Michael Poole <mdpoole@troilus.org>
939
940         * aclocal.m4: Check for uintNN_t instead of u_intNN_t, since the
941         former is from C99 (and the latter is absent on Solaris).
942
943         * configure.in: Remove check for inttypes.h (which is a C99 format
944         string header); replace with check for stdint.h.  Add checks for
945         sys/param.h and sys/socket.h.  Check for socklen_t being defined
946         (OS X does not set it).  Run program tests for lex and yacc, and
947         use them rather than assuming flex and bison.  Remove OSDEP_C and
948         mention to adns.  Remove check for res_mkquery().
949
950         * config.h.in: Update u_intNN_t #undef lines.  Add #undef
951         socklen_t so configure test can set it.
952
953         * configure: Regenerate.
954
955         * include/ircd_addrinfo.h: #include headers needed for netdb.h and
956         to define struct addrinfo and uintNN_t.
957
958         * include/ircd_reslib.h: Replace u_intNN_t with uintNN_t.
959
960         * include/res.h: #include "ircd_addrinfo.h" to get proper type
961         definitions.  #define INADDR_NONE if it is not defined (as on
962         Solaris).
963
964         * ircd/Makefile.in: Replace LEX and YACC definitions.  Remove
965         OSDEP_C and OSDEP_SRC; always compile os_generic.c.  Remove adns
966         directory from CPPFLAGS.  Regenerate dependencies.
967
968         * ircd/client.c: Return when no propagation set for oper, to
969         squash warning about use of "defaults" before it is set.
970
971         * ircd/engine_epoll.c: #include correct C99 integer header.
972
973         * ircd/engine_poll.c: Last argument to getsockopt() should be of
974         socklen_t, not size_t; fix.
975
976         * ircd/engine_select.c: Squash warning about bzero().
977
978         * ircd/ircd_auth.c: OS X does not define in_addr_t, so replace it
979         with uint32_t.  We need <stdint.h> for that, so include it.
980
981         * ircd/ircd_getnameinfo.c, ircd/memdebug.c: Replace u_int32_t with
982         uint32_t.
983
984         * ircd/ircd_lexer.l: Replace flex-isms with portable syntax.
985         There is no portable way to do %option, so remove that.  lex on
986         Solaris needs several of its internal tables to be bigger, so
987         increase those sizes.
988
989         * ircd/ircd_parser.y: Remove the second declarations of two
990         tokens, since standard yacc warns about changing precedence.
991
992         * ircd/os_generic.c: Make this compile on common OSes (Linux,
993         Solaris, OS X, FreeBSD, OpenBSD).
994
995         * ircd/table_gen.c: Make arguments to isprint() all unsigned char
996         to squash warnings on Solaris that array index is "char."
997
998         * ircd/umkpasswd.c: Remove #include <libgen.h> since it is not
999         portable, and replace basename() with an equivalent.
1000
1001         * ircd/uping.c: Typecast printf arguments for 64-bit OSes.
1002
1003 2004-07-27  Michael Poole <mdpoole@troilus.org>
1004
1005         * ircd/m_burst.c: Add new netride_modes() function to check
1006         which modes could be used in a net.ride.  Use this instead
1007         of the old check for just +i or +k.
1008         (Based on patches by beware and pomac.)
1009
1010 2004-07-25  Michael Poole <mdpoole@troilus.org>
1011
1012         * ircd/ircd_parser.y: Remove redundant semicolon; it causes
1013         errors on some versions of yacc.
1014
1015 2004-07-21  Michael Poole <mdpoole@troilus.org>
1016
1017         * include/client.h, ircd/ircd_auth.c, ircd/ircd_crypt_smd5.c,
1018         ircd/ircd_reslib.c: Fix warnings from gcc -pedantic.
1019
1020 2004-07-21  Michael Poole <mdpoole@troilus.org>
1021
1022         New DNS resolver code, courtesy of Dianora and the rest of the
1023         Hybrid team.  (Bugs are of course my fault.)
1024
1025         * configure.in, Makefile.in, ircd/Makefile.in: Remove adns and
1026         libresolv from the build process.  Update dependencies.
1027
1028         * configure: Regenerate.
1029
1030         * include/client.h: Change connection's DNS reply type.
1031
1032         * include/ircd_features.h, ircd/ircd_features.c: New HIS_STATS_a.
1033
1034         * include/numeric.h, ircd/s_err.c, ircd/s_stats.c: Add new
1035         RPL_STATSALINE and /stats a to list DNS servers.
1036
1037         * include/ircd_addrinfo.h, include/ircd_reslib.h, include/res.h,
1038         ircd/ircd_getaddrinfo.c, ircd/ircd_getnameinfo.c, ircd/ircd_res.c,
1039         ircd/ircd_reslib.c: New resolver files.
1040
1041         * ircd/ircd_auth.c, ircd/s_auth.c, ircd/s_bsd.c, ircd/s_conf.c:
1042         Update to new resolver callback interface and to only deal with
1043         one IP and one name per DNS reply.
1044
1045         * ircd/parse.c: Remove /DNS command, since new resolver does not
1046         track those statistics.
1047
1048 2004-07-20  Michael Poole <mdpoole@troilus.org>
1049
1050         * doc/readme.features: Change references to O:, Y:, etc lines into
1051         references to the appropriate block types.
1052
1053 2004-07-01  Michael Poole <mdpoole@troilus.org>
1054
1055         * include/fileio.h: Elaborate on "works for any file descriptor."
1056
1057         * include/iauth.h: Remove unused file.
1058
1059 2004-07-01  Michael Poole <mdpoole@troilus.org>
1060
1061         * include/map.h, ircd/map.c: Remove unused code.
1062
1063         * ircd/m_links.c, ircd/m_map.c, ircd/s_misc.c: Remove includes of
1064         map.h and a call to map_update().
1065
1066         * ircd/Makefile.in: Remove map.c and regenerate dependencies.
1067
1068         * ircd/ircd_parser.y: Recognize Diane Bruce as a copyright holder
1069         for the new config parser.
1070
1071         * ircd/match.c: Remove pointless pointer dereference (Reed points
1072         out that this generates a warning with old gcc).
1073
1074         * ircd/s_user.c: Display connection class in CONNEXIT connection
1075         notice as a string rather than an integer.
1076
1077         * tools/ringlog.c, tools/ringlog.pl: At Kevin's request, remove
1078         lines (falsely) identifying ringlog as related to IRC; the files
1079         are general purpose.
1080
1081         * configure.in, include/ircd_snprintf.h: Add checks for
1082         va_copy()-like alternatives and use them if va_copy() is missing.
1083
1084         * configure, config.h.in: Regenerate.
1085
1086 2004-02-01  beware <steendijk@xs4all.nl>
1087
1088         * ircd/channel.c: Check bans that look like IP bans against user's
1089         hostname just in case they have a host like 1234.domain.tld.
1090
1091 2003-12-18  Timothy Grant Vogelsang <net@astrolink.org>
1092
1093         * ircd/ircd_log.c, ircd/send.c: va_list is not a scalar type
1094
1095 2004-04-02  Gavin Grieve <hektik@dimebox.net>
1096
1097         * ircd/ircd_parser.y: Fix rehash warnings for servername and
1098         numeric so they only warn if changed in the config file.
1099
1100 2004-06-30  Michael Poole <mdpoole@troilus.org>
1101
1102         * doc/readme.iauth, include/ircd_auth.h, ircd/ircd_auth.c: New
1103         files.
1104
1105         * doc/example.conf: Illustrate IAUTH configuration.
1106
1107         * include/client.h: Add fields to record IAUTH status.
1108
1109         * ircd/Makefile.in: Add ircd_auth.c to Makefile.
1110
1111         * ircd/ircd_lexer.l, ircd/ircd_parser.y: Add new IAUTH section.
1112
1113         * ircd/s_conf.c: Notify IAUTH code when reloading a configuration
1114         so that an obsolete connection can be abandoned.
1115
1116         * ircd/s_misc.c: Report client exits via IAUTH.
1117
1118         * ircd/s_user.c: If IAUTH is active and a connecting user has not
1119         been checked against it, interrogate the IAUTH server.
1120
1121 2004-06-25  Michael Poole <mdpoole@troilus.org>
1122
1123         * configure.in: Check for crypt.h as well.
1124
1125         * configure: Regenerate.
1126
1127         * ircd/ircd_crypt_native.c: Move XOPEN defines earlier so they
1128         affect the first includes of system headers.  Include crypt.h if
1129         it is available.
1130
1131         * ircd/umkpasswd.c: Quash a gcc warning.
1132         
1133 2004-06-23  Michael Poole <mdpoole@troilus.org>
1134
1135         * doc/Authors: Add contributors to ircu2.10.11 and myself.
1136
1137         * ircd/gline.c: Fix buglet in my forward port of Alex Badea's fix.
1138
1139         * configure.in: Add missing check for inttypes.h; remove obsolete
1140         display of Head-in-sand, add display of epoll() engine.
1141
1142         * INSTALL, INSTALL_FR, doc/readme.cvs: Update descriptions of how
1143         to use SourceForge's CVS server, from the u2.10.11 branch.
1144
1145 2003-11-09 beware <steendijk@xs4all.nl>
1146
1147         * ircd/s_user.c: move assigning a numeric to a local client from
1148         when nick is set, to when connection becomes client, to not waste
1149         numerics.
1150
1151 2004-06-08  Kevin L Mitchell  <klmitch@mit.edu>
1152
1153         * ircd/parse.c: don't let rank-and-file users escape HIS
1154         limitations with /jupe...
1155
1156 2004-06-18  Alex Badea  <decampos@users.sourceforge.net>
1157
1158         * ircd/gline.c (gline_lookup): only return a gline if it's
1159         active
1160
1161         * ircd/s_conf.c (find_kill): don't check for active gline,
1162         since gline_lookup does now
1163
1164 2002-11-11  hikari <shadow@undernet.org>
1165         * ircd/ircd.c: added call to irc_crypt_init() - someone hurry up and 
1166         modularise :P
1167
1168         * ircd/ircd_xopen.c: removed, superseded by new crypto system.
1169
1170         * ircd/ircd_crypt.c: wrote scary ircd_crypt() interface function,
1171         wrote ircd_crypt_mech_register() function, various other bits 
1172         designed to create a near-pluggable crypto system for ircu.  currently
1173         this code also loads the various mechanisms i've written code for.
1174
1175         * ircd/ircd_crypt_smd5.c: imported the crypt_md5 function from 
1176         elsewhere, manipulated to suit ircu, returns a salted MD5 password.
1177
1178         * ircd/ircd_crypt_native.c: replaces the old ircd_xopen.c file,
1179         generate a crypted password using the systems native crypt() function.
1180
1181         * ircd/ircd_crypt_plain.c: plain text crypt mechanism, should really
1182         only be used for testing purposes.
1183
1184         * ircd/ircd_md5.c: main gubbins of the MD5 hashing code, lifted from
1185         elsewhere, ircuified.
1186
1187         * ircd/umkpasswd.c: mkpasswd program for ircu.
1188
1189         * include/ircd_xopen.h: removed, superseded by new crypto system.
1190
1191         * include/ircd_crypt.h: external definitions for the new ircd_crypt()
1192         function and definition of the ircd_crypt_mech structure for containing
1193         crypto mechanism data.
1194
1195         * include/ircd_crypt_smd5.h: sundary definitions for the salted MD5
1196         mechanism.
1197
1198         * include/ircd_crypt_native.h: sundary definitions for the native 
1199         crypt() mechanism.
1200
1201         * include/ircd_crypt_plain.h: sundary definitions for the plain text
1202         mechanism.
1203
1204         * include/umkpasswd.h: fluff for umkpasswd.
1205
1206 2003-03-11  Landon Fuller (landonf) <landonf@sf.net>
1207
1208         * configure.in: allow ircu to build on OS X.
1209
1210 2004-05-24  Michael Poole <mdpoole@troilus.org>
1211
1212         * ircd/m_invite.c (m_invite): Include channel name in invitation
1213         announcements.
1214         (ms_invite): Likewise, and also fix a use-before-assignment bug in
1215         them.
1216
1217 2004-05-18  Michael Poole <mdpoole@troilus.org>
1218
1219         Announce invitations to other channel operators.
1220
1221         * include/ircd_features.h, ircd/ircd_features.c
1222         (ANNOUNCE_INVITES): Add new boolean feature, default off.
1223
1224         * include/numeric.h, ircd/s_err.c (RPL_ISSUEDINVITE): Add new
1225         reply.
1226
1227         * include/send.h, ircd/send.c (sendcmdto_channel_butserv_butone):
1228         Add 'skip' parameter that is needed elsewhere.
1229         (sendcmdto_channel_servers_butone): New function.
1230
1231         * ircd/channel.c, ircd/m_burst.c, ircd/m_kick.c, ircd/m_topic.c,
1232         ircd/s_user.c: Add argument for 'skip' to calls to s_c_b_b.
1233
1234         * ircd/m_invite.c (m_invite, ms_invite): If ANNOUNCE_INVITES, send
1235         the INVITE message to all interested servers, and send a numeric
1236         to all local chanops.
1237
1238 2004-05-18  Michael Poole <mdpoole@troilus.org>
1239
1240         * ircd/res_adns.c (res_ourserver): Remove unused function.
1241         (validate_name): Likewise.
1242
1243 2004-05-17  Michael Poole <mdpoole@troilus.org>
1244
1245         * include/ircd_features.h, ircd/ircd_features.c, ircd/s_debug.c:
1246         Rip out feature settings related to oper privileges.
1247
1248         * include/client.h: Comment a few unexplained privileges.
1249
1250         * ircd/ircd_lexer.l: Rename privilege keywords to match their
1251         names in code and /PRIVS output.  Add support for two "new"
1252         privileges (FORCE_OPMODE, FORCE_LOCAL_OPMODE).
1253
1254         * include/class.h, ircd/client.c, ircd/ircd_parser.y,
1255         ircd/m_oper.c: Replace the removed feature settings with
1256         per-connection class operator privileges.
1257
1258         * doc/example.conf: Document the change.
1259
1260         * ircd/ircd_parser.y (portblock): Fix slight memory leak.
1261
1262 2004-05-16  Michael Poole <mdpoole@troilus.org>
1263
1264         * doc/example.conf: Make this show the new NICKLEN default.
1265
1266 2004-05-14  Kevin L Mitchell  <klmitch@mit.edu>
1267
1268         * ircd/ircd_features.c: per CFV-0243, NICKLEN default is increased
1269         to 12
1270
1271 2004-05-14  Kevin L Mitchell  <klmitch@mit.edu>
1272
1273         * ircd/s_user.c: process account creation timestamp if present in
1274         user mode portion of a N protocol message; add account creation
1275         timestamp to outgoing N protocol messages if that timestamp is
1276         non-zero
1277
1278         * ircd/m_account.c: process account creation timestamp if present
1279         in AC protocol message
1280
1281         * include/struct.h: add account creation timestamp
1282
1283 2004-05-16  Michael Poole <mdpoole@troilus.org>
1284
1285         * doc/example.conf: Document operator privilege settings.
1286
1287 2004-05-16  Michael Poole <mdpoole@troilus.org>
1288
1289         Get rid of CONF_LOCOP; use PRIV_PROPAGATE instead.
1290
1291         * ircd/ircd_parser.y (invert): New variable.
1292         (operlocal): Remove production.
1293         (operpriv): Use "invert" variable.
1294         (privtype): Add LOCAL alternative production.
1295
1296         * ircd/m_oper.c (m_oper): Remove references to CONF_LOCOP; replace
1297         with CONF_OPERATOR or PRIV_PROPAGATE checks, as appropriate.
1298
1299         * ircd/s_conf.c (AuthorizationCheckResult, find_conf_exact):
1300         Likewise.
1301
1302         * ircd/s_stats.c (report_array, statsinfo): Likewise.
1303
1304         * ircd/s_user.c (set_user_mode): Likewise.
1305
1306 2004-05-15  Michael Poole <mdpoole@troilus.org>
1307
1308         * patches/diffs/astralnet.diff, patches/diffs/nocfv.diff: Remove
1309         patches obsoleted by F: lines.
1310
1311         * patches/diffs/topicburst.diff: Remove patch that was integrated
1312         into the main code.
1313
1314 2004-05-15  Isomer <isomer@undernet.org>
1315
1316         [Original ChangeLog date: 2003-11-05 -MDP]
1317
1318         * ircd/m_whois.c: On remote whois, show +s local channels with a *
1319         prefix to opers.
1320
1321 2004-05-15  Michael Poole <mdpoole@troilus.org>
1322
1323         * include/gline.h, ircd/gline.c, ircd/s_err.c: Forward port a lot
1324         of gline-related fixes from 2.10.11.  Things that work are due to
1325         Kev, Isomer, Spike, hikari, and probably others; CVS makes it hard
1326         to figure out who did what.  Any mistakes are mine.
1327
1328 2004-05-15  Isomer <isomer@undernet.org>
1329
1330         [Original ChangeLog date: 2003-11-05 -MDP]
1331
1332         * ircd/s_misc.c, ircd/s_user.c: added numnick to SNO_CONNEXIT
1333         messages (so you can match EXIT's to CONN's)
1334
1335 2004-05-15  Reed Loden <reed@reedloden.com>
1336
1337         [Original ChangeLog date: 2003-05-01 -MDP]
1338
1339         * ircd/s_err.c: Added network to text and edited 001 a bit.
1340
1341         * ircd/s_user.c: Send network with 001.
1342
1343 2004-05-15  Michael Poole <mdpoole@troilus.org>
1344
1345         * ircd/s_user.c (add_target): Move free target invite check...
1346
1347         * ircd/s_user.c (check_target_limit): to here, matching 2.10.11's
1348         behavior.
1349
1350 2004-05-15  Isomer <isomer@undernet.org>
1351
1352         [Original ChangeLog date: 2003-11-23 -MDP]
1353
1354         * ircd/s_user.c: Don't credit users with an extra attempt if they
1355         are klined/glined, throttle them!
1356
1357 2004-05-15  Jeekay <jeekay@netgamers.org>
1358
1359         [Original ChangeLog date: 2003-04-24 -MDP]
1360
1361         * ircd/s_user.c: Altered (K-lined) to depend on find_kill type
1362
1363 2004-05-15  splidge <splidge@quakenet.org>
1364
1365         [Original ChangeLog date: 2003-09-03 -MDP]
1366
1367         * ircd/s_user.c: Made hide_hostmask() not show bogus joins for
1368         channels where the user is a zombie.
1369
1370 2004-05-15  beware <steendijk@xs4all.nl>
1371
1372         [Original ChangeLog date: 2003-10-25 -MDP]
1373         
1374         * ircd/m_whois.c: Fixed /whois comma separated list with wildcards
1375         cpu hog bug
1376
1377 2004-05-15  Michael Poole <mdpoole@troilus.org>
1378
1379         * ircd/s_conf.c (rehash): Call clear_quarantines on rehash since
1380         2.10.11 does.  Show ident and IP for clients being killed by new
1381         G-lines and K-lines.
1382
1383 2004-05-15  hikari <shadow@undernet.org>
1384
1385         [Original ChangeLog date: 2003-06-27 -MDP]
1386         
1387         * ircd/ircd.c: After thought, update the next check time based on
1388         when an unregistered client should expire.
1389
1390 2004-05-15   hikari <shadow@undernet.org>
1391
1392         [Original ChangeLog date: 2003-06-22 -MDP]
1393
1394         * ircd/ircd.c: Fixed check_pings() - shouldn't be any problem with
1395         clients not being able to connect anymore.
1396
1397 2004-05-15  Michael Poole <mdpoole@troilus.org>
1398
1399         * ircd/channel.c (can_join): Revert to using IsInvited() rather
1400         than walking the list directly.
1401         (modebuf_flush_int): Fix errant HEAD_IN_SAND_SNOTICES check to
1402         use feature_bool(FEAT_HIS_SNOTICES) instead.
1403
1404 2004-05-15  Kevin L Mitchell  <klmitch@mit.edu>
1405
1406         [Original ChangeLog date: 2004-01-31 -MDP]
1407
1408         * ircd/channel.c (mode_parse_key): don't allow , in keys!
1409
1410 2003-04-12  David Mansell (splidge) <splidge@sf.net>
1411
1412         [Original ChangeLog date: 2003-04-14 -MDP]
1413
1414         * ircd/channel.c: When keys and limits conflict on burst, the key
1415         which is first alphabetically or the limit which is lower will be 
1416         used by both servers. This matches pre-2.10.11 behaviour.  
1417         Closes: (#713930)
1418
1419 2004-05-15  David Mansell <splidge@quakenet.org>
1420
1421         [Original ChangeLog date: 2002-12-28 -MDP]
1422
1423         * ircd/channel.c (mode_parse_limit): don't allow -l when no limit is
1424         set, don't allow -l with negative parameter (or unsigned >2^31).
1425  
1426 2004-05-15  David Mansell <splidge@quakenet.org>
1427
1428         [Original ChangeLog date: 2002-12-31 -MDP]
1429
1430         * ircd/m_burst.c (ms_burst): when kicking net riders, clear
1431         invites too.
1432
1433 2004-05-15  Isomer <isomer@undernet.org>
1434
1435         [Original ChangeLog date: 2003-11-04 -MDP]
1436
1437         * ircd/s_serv.c: Burst glines/jupes early
1438
1439 2004-05-15  volta <volta2@gmx.de>
1440
1441         [Original ChangeLog date: 2003-04-26 -MDP]
1442
1443          * ircd/m_userip.c, ircd/m_userhost.c: Small fix, that
1444          allows users to see their own ip & hostname. (Should solve
1445          all problems with dcc)
1446
1447 2004-05-15  Kevin L Mitchell  <klmitch@mit.edu>
1448
1449         [Original ChangeLog date: 2003-06-13 -MDP]
1450
1451         * ircd/m_settime.c: it's supposed to be %ld, not %l
1452
1453 2004-05-15  Isomer <isomer@undernet.org>
1454
1455         [Original ChangeLog date: 2004-03-20 -MDP]
1456
1457         * ircd/m_invite.c: Disallow invites to non existant channels
1458
1459 2004-05-15  David Mansell <splidge@quakenet.org>
1460
1461         [Original ChangeLog date: 2003-04-26 -MDP]
1462
1463         * ircd/m_invite.c: let +k users invite into channels they aren't on.
1464
1465 2004-05-15  hikari <shadow@undernet.org>
1466
1467         [Original ChangeLog date: 2003-07-13 -MDP]
1468         
1469         * ircd/IPcheck.c: Fixed (another) overflow problem in
1470         ip_registry_check_local()
1471
1472         [Original ChangeLog date: 2003-06-29 -MDP]
1473
1474         * ircd/IPcheck.c: Fixed overflow problem in
1475         ip_registry_connect_fail()
1476
1477 2004-05-15 Isomer <isomer@undernet.org>
1478
1479         [Original ChangeLog date: 2003-05-02 -MDP]
1480         
1481         * ircd/IPcheck.c: Added assert()'s to check for underflow
1482
1483 2004-05-15  Kevin L Mitchell  <klmitch@mit.edu>
1484
1485         [Original ChangeLog date: 2003-11-22 -MDP]
1486
1487         * tools/wrapper.c: commit uid on chroot fix from ubra
1488
1489         * ircd/version.c.SH: fix generation generation
1490
1491 2004-05-15  Isomer <isomer@undernet.org>
1492
1493         [Original ChangeLog date: 2003-11-23 -MDP]
1494         
1495         * ircd/os_*.c, ircd/ircd_features.c: Default changing window sizes
1496         to off.  if an admin is smart enough to understand these features
1497         they can enable them manually.
1498
1499 2004-05-15  splidge  <splidge@quakenet.org>
1500
1501         [Original ChangeLog date: 2003-03-26 -MDP]
1502
1503         * ircd/include/ircd_features.h, include/ircd_osdep.h,
1504           ircd/ircd_features.c, ircd/listener.c, ircd/os_bsd.c, 
1505           ircd/os_generic.c, ircd/os_linux.c, ircd/os_openbsd.c
1506           ircd/os_solaris.c, ircd/s_bsd.c: Patch to allow socket bufs to be 
1507           altered via F: lines
1508
1509 2004-05-15  Isomer <isomer@undernet.org>
1510
1511         [Original ChangeLog date: 2003-11-18 -MDP]
1512
1513         * ircd/s_auth.c, ircd/res_libresolv.c, ircd/res_adns.c: Clean up
1514         the preregistration subsystem allowing customisation of timers,
1515         make the dns resolver stats oper only, and make it much more clear
1516         what all the numbers are.
1517
1518 2004-05-15  Spike <spike@undernet.org>
1519
1520         [Original ChangeLog date: 2003-11-23 -MDP]
1521
1522         * ircd/IPcheck.c: Make IPcheck constants configurable
1523
1524 2004-05-14  Kevin L Mitchell  <klmitch@mit.edu>
1525
1526         [Original ChangeLog date: 2003-11-22 -MDP]
1527
1528         * ircd/m_nick.c (m_nick): truncate the nickname to the minimum of
1529         the maximum allowed length (NICKLEN) or the allowed nickname
1530         length specified as the NICKLEN feature
1531
1532         * ircd/ircd_features.c: declare NICKLEN and set its default value
1533         to 9
1534
1535         * include/supported.h: add MAXNICKLEN to ISUPPORT and do a little
1536         rearranging...
1537
1538         * include/ircd_features.h: add NICKLEN feature
1539
1540         * include/ircd_defs.h (NICKLEN): raise max NICKLEN to 15
1541
1542         * doc/readme.features: document new NICKLEN feature
1543
1544         * doc/example.conf: list new NICKLEN F-line
1545
1546 2004-05-14  Matthias Crauwels <ultimate_@wol.be>
1547
1548         [Original ChangeLog date: 2003-06-08 -MDP]
1549         
1550         * ircd/gline.c: fixed the counting bug in gline_memory_count
1551  
1552         * ircd/jupe.c: fixed the counting bug in jupe_memory_count
1553
1554 2004-05-14  Michael Poole <mdpoole@troilus.org>
1555
1556         * ircd/m_mode.c (ms_mode): Do not always try to call
1557         set_user_mode() when parv[1] is a channel name.
1558
1559 2004-05-10  Michael Poole <mdpoole@troilus.org>
1560
1561         Implement a per-connection-class default usermode option.
1562
1563         * doc/example.conf: Illustrate how to use the option.
1564
1565         * include/class.h (struct ConnectionClass): New "default_umode"
1566         field.
1567         (ConfUmode): New macro.
1568
1569         * include/client.h (client_get_default_umode): New function.
1570
1571         * ircd/client.c (client_get_default_umode): Implement it.
1572
1573         * ircd/ircd_lexer.l (usermode): New token.
1574
1575         * ircd/ircd_parser.y (classblock, etc): New syntax.
1576
1577         * ircd/s_user.c (register_user): Set default user modes for user.
1578         This sends the new mode to the user, so the explicit send later
1579         is no longer necessary.
1580
1581 2004-05-10  Michael Poole <mdpoole@troilus.org>
1582
1583         Forward port of asuka-topicburst.patch from Quakenet's "Asuka"
1584         patch set.
1585
1586         * include/ircd_features.h (FEAT_TOPIC_BURST): Add new feature.
1587
1588         * ircd/channel.c (send_channel_modes): If F:TOPIC_BURST:TRUE,
1589         also send a TOPIC to the peer.
1590
1591         * ircd/ircd_features.c (FEAT_TOPIC_BURST): Add new boolean
1592         feature, defaulting to FALSE.
1593
1594         * ircd/m_topic.c (do_settopic): Add argument for topic timestamp,
1595         and allow F:HIS_BANWHO to hide the originator of the topic.
1596         (ms_topic): Parse optional timestamp arguments to TOPIC, and use
1597         them to decide whether to ignore the topic.
1598
1599 2004-05-10  Michael Poole <mdpoole@troilus.org>
1600
1601         Forward port of delayed-join.patch from Quakenet's "Asuka" patch
1602         set (which was a port of code I wrote for the other ircu).
1603
1604         * include/channel.h (CHFL_DELAYED): New membership flag.
1605         (MODE_DELJOINS, MODE_WASDELJOINS): New channel modes.
1606         (infochanmodes): Add +D to list of supported channel modes.
1607         (IsDelayedJoin, SetDelayedJoin, ClearDelayedJoin): New macros.
1608         (member_can_send_to_channel, client_can_send_to_channel): Add
1609         "reveal" parameter to indicate whether a request should cause
1610         a join-delayed user to become visible.
1611         (RevealDelayedJoin, CheckDelayedJoins): New functions.
1612
1613         * include/numeric.h (RPL_DELNAMREPLY): New numeric.
1614         
1615         * include/s_user.h (NAMES_DEL): New flag for do_names().
1616
1617         * include/supported.h (FEATURESVALUES2): Add +D to list of
1618         supported channel modes.
1619
1620         * ircd/channel.c (remove_member_from_channel,
1621         member_can_send_to_channel, client_can_send_to_channel,
1622         joinbuf_join): Handle join-delayed users.
1623         (channel_modes, modebuf_flush_int, modebuf_mode, modebuf_flush,
1624         modebuf_extract, mode_process_clients, mode_parse_mode,
1625         mode_parse): Handle delayed-join channels.
1626         (RevealDelayedJoin, CheckDelayedJoins): New functions.
1627
1628         * ircd/ircd_relay.c (relay_channel_message, relay_channel_notice,
1629         server_relay_channel_message, server_relay_channel_notice): Add
1630         argument for "reveal" parameter to client_can_send_to_channel().
1631
1632         * ircd/m_burst.c (ms_burst): Support MODE_DELJOINS channels.
1633
1634         * ircd/m_clearmode.c (do_clearmode): Support clearing mode +D.
1635
1636         * ircd/m_join.c (join0): Pass the CHFL_DELAYED flag when parting a
1637         channel with JOIN 0.
1638
1639         * ircd/m_kick.c (m_kick): For join-delayed members, only send the
1640         KICK to the kicker and kickee.  Then check whether +d can be
1641         removed.
1642
1643         * ircd/m_names.c (do_names): Show join-delayed users if and only
1644         if the NAMES_DEL flag is given.  If NAMES_DEL is given, also use
1645         RPL_DELNAMREPLY instead of RPL_NAMREPLY.
1646         (m_names): If NAMES -D, pass NAMES_DEL to do_names().
1647
1648         * ircd/m_part.c (m_part, ms_part): Add "reveal" argument for
1649         member_can_send_to_channel().  Set CHFL_DELAYED join in joinbuf if
1650         the user is join-delayed.
1651
1652         * ircd/m_quit.c (m_quit): Handle join-delayed users and new
1653         argument for member_can_send_to_channel().
1654
1655         * ircd/m_topic.c (do_settopic): If a join-delayed channel member
1656         changes the topic, reveal the member.
1657
1658         * ircd/m_wallchops.c (m_wallchops, ms_wallchops): Add argument for
1659         "reveal" parameter to client_can_send_to_channel().
1660
1661         * ircd/m_wallvoices.c (m_wallvoices, ms_wallvoices): Likewise.
1662
1663         * ircd/m_who.c (m_who): Skip join-delayed members where we skip
1664         zombies.
1665
1666         * ircd/m_whois.c (do_whois): Use '<' as a prefix for join-delayed
1667         users.  Use slightly more efficient macros rather than function
1668         calls to test for ops and voice.
1669
1670         * ircd/s_err.c (RPL_DELNAMREPLY): New numeric response string.
1671
1672         * ircd/s_user.c (hide_hostmask): For users with no modes in a
1673         join-delayed channel, do not send JOIN to other members after the
1674         QUIT :Registered.
1675
1676         * ircd/send.c (sendcmdto_common_channels_butone): Skip
1677         join-delayed users where we skip zombies.
1678         
1679 2004-05-10  Michael Poole <mdpoole@troilus.org>
1680
1681         * ircd/ircd_events.c: Actually reference and try to use the epoll
1682         event engine.  Omitted from yesterday's commit.
1683
1684 2004-05-09  Michael Poole <mdpoole@troilus.org>
1685
1686         Forward port of Paul "Zoot" Chang's pseudo-command.patch and
1687         pseudo-support.patch.
1688
1689         * doc/example.conf: Illustrate how to use the feature.
1690
1691         * include/handlers.h (m_pseudo): Declare new handler function.
1692
1693         * include/ircd_features.h (HIS_STATS_R): Add a feature to control
1694         user visibility of the pseudo-commands.
1695
1696         * include/msg.h: Add flag and field for the extra information used
1697         to select a pseudo-command's target.
1698
1699         * include/numeric.h (RPL_STATSRLINE, ERR_SERVICESDOWN): Add
1700         definitions.
1701
1702         * include/parse.h (register_mapping, unregister_mapping): Declare.
1703
1704         * include/s_conf.h (struct nick_host, struct s_map,
1705         GlobalServiceMapList): Define.
1706
1707         * ircd/Makefile.in: Add m_pseudo.c to IRCD_SRC.  Add generated
1708         files to "make depend" dependency list.  Update dependencies.
1709
1710         * ircd/ircd_features.c (HIS_STATS_R): Define feature type and
1711         default value.
1712
1713         * ircd/ircd_lexer.l (pseudo, prepend): Recognize new tokens.
1714
1715         * ircd/ircd_parser.y: Support "Pseudo" configuration blocks.
1716
1717         * ircd/parse.c (msgtab): Add initializer for field "extra" to all
1718         commands.
1719         (msg_tree_insert, msg_tree_remove, register_mapping,
1720         unregister_mapping): New functions.
1721         (parse_client): Implement MFLG_EXTRA extra argument passing.
1722
1723         * ircd/s_conf.c (GlobalServiceMapList): New variable.
1724
1725         * ircd/s_err.c (RPL_STATRLINE, ERR_SERVICESDOWN): Add format
1726         strings for new numeric responses.
1727
1728         * ircd/s_stats.c (stats_mapping): New function.
1729         (statsinfo): Add entry for /stats R and make old /stats r entry
1730         case-sensitive.
1731         
1732 2004-05-09  Michael Poole <mdpoole@troilus.org>
1733
1734         * ircd/ircd_parser.y (parse_error): Convert to being a wrapper for
1735         yyerror() so that configuration errors all go to the same place.
1736
1737         * ircd/s_conf.c: New variables conf_error and conf_already_read.
1738         conf_error is cleared by read_configuration_file() and set by
1739         yyerror(); conf_already_read is set by read_configuration_file()
1740         and never cleared.  Make yyerror() display error to stderr before
1741         conf_already_read is set.  Make configuration errors a fatal
1742         condition in init_conf().
1743
1744 2004-05-09  Michael Poole <mdpoole@troilus.org>
1745
1746         * ircd/Makefile.in: Pass the source directory as an argument to
1747         version.c.SH so it knows where to find the source files for an
1748         out-of-srcdir build.
1749
1750         * ircd/version.c.SH: Use that information.
1751
1752 2004-05-09  Michael Poole <mdpoole@troilus.org>
1753
1754         * Makefile.in: Ensure ${prefix}/include exists, since the adns
1755         install puts files in that directory.  (The adns Makefile does
1756         not use configure's ${includedir}.)
1757
1758 2004-05-09  Michael Poole <mdpoole@troilus.org>
1759
1760         * doc/readme.features: The logic for F:AUTOHIDE was removed, but
1761         not its documentation.  Fix that omission.
1762
1763         * include/ircd_features.h, ircd/ircd_features.c: Remove the unused
1764         definitions for FEATURE_AUTOHIDE.
1765
1766 2004-05-09  Michael Poole <mdpoole@troilus.org>
1767
1768         * doc/readme.who: Document the support for account matching and
1769         display in the WHO command.
1770
1771 2004-05-09  Michael Poole <mdpoole@troilus.org>
1772
1773         * ircd/ircd.c (main): Move check_pid() call until after we read
1774         the configuration file so that F:PPATH works correctly.
1775
1776 2004-05-09  Michael Poole <mdpoole@troilus.org>
1777
1778         * ircd/match.c (match): Use ToLower() instead of tolower() for
1779         character comparisons.
1780
1781 2004-05-09  Michael Poole <mdpoole@troilus.org>
1782
1783         * ircd/s_user.c (register_user): Initialize "flag" (user's old
1784         modes) passed to send_umode() so that the real set of modes are
1785         sent to the user.
1786         
1787 2004-05-09  Michael Poole <mdpoole@troilus.org>
1788
1789         * ircd/m_server.c (ms_server): Apply +h/+s flags only to the new
1790         server, not to a hub between us and the new server.
1791
1792         * ircd/ircd_relay.c (relay_directed_message): Check FLAG_SERVICE
1793         on target server rather than FLAG_CHSERV (so that directed
1794         messages work at all).
1795
1796 2004-05-09  Michael Poole <mdpoole@troilus.org>
1797
1798         * configure.in: Add checks for epoll_* system call family.
1799
1800         * configure: Regenerate.
1801
1802         * ircd/engine_epoll.c: New file; forward ported from 2.10.11
1803         branch.
1804
1805 2004-05-09  Michael Poole <mdpoole@troilus.org>
1806
1807         * include/ircd_alloc.h: Add definitions for MyRealloc, since they
1808         are needed by kqueue and epoll event engines; kill #if 0'd block.
1809
1810         * include/memdebug.h: Declare dbg_realloc() helper function.
1811
1812         * ircd/ircd_alloc.c: Implement DoRealloc() helper function.
1813
1814         * ircd/memdebug.c: Implement dbg_realloc() helper function.
1815
1816 2004-05-09  Michael Poole <mdpoole@troilus.org>
1817
1818         * ircd/channel.c (find_no_nickchange_channel): Disallow nick
1819         changes on a moderated channel with neither ops nor voice.
1820
1821         * ircd/s_err.c: Update ERR_BANNICKCHANGE message to match.
1822
1823 2004-01-20  Perry Lorier <isomer@undernet.org>
1824
1825         * ircd/ircd_parser.y: Fixed parser to work with a more modern bison
1826
1827 2004-01-21 Gavin Grieve <hektik@dimebox.net>
1828
1829         * ircd/channel.c, include/channel.h: bring forward the IsUserParting()
1830           code to resolve the multiple part messages bug written by Entrope.
1831
1832 2003-08-12 Timothy Vogelsang <net@astrolink.org>
1833
1834         * ircd/match.c: (match) rewrote function based on existing
1835           code from the hybrid ircd -- death to goto
1836
1837 2003-07-07  Bas Steendijk <steendijk@xs4all.nl>
1838
1839         * ircd/s_user.c: invalidate ban cache for user on host hiding/account
1840
1841 2003-07-04  Bas Steendijk <steendijk@xs4all.nl>
1842
1843         * include/client.h, ircd/m_userhost.c, ircd/m_userip.c, ircd/m_who.c,
1844         ircd/m_whois.c, ircd/whocmds.c: the same code, for "can user A see user
1845         B is an oper", appeared in a lot of places. made it a define SeeOper.
1846
1847 2003-07-04  Bas Steendijk  <steendijk@xs4all.nl>
1848         * ircd/s_user.c: umode_str (user modes in N token) internal flags var
1849         was not initialized to the user's flags, returned a string with
1850         random modes set.
1851
1852 2003-07-01  Bas Steendijk  <steendijk@xs4all.nl>
1853
1854         * ircd/m_names.c: length counter being incremented one too many
1855         for each nick, resulting names reply messages are about 50 chars
1856         shorter than possible. fixed.
1857
1858 2003-06-29  Bas Steendijk  <steendijk@xs4all.nl>
1859
1860         * ircd/channel.c: don't ever send mode changes for local channels to
1861         servers.
1862
1863 2003-06-27  Bas Steendijk  <steendijk@xs4all.nl>
1864
1865         * include/channel.h, include/client.h, ircd/s_user.c, ircd/s_err.c:
1866         moved the supported channel/user mode strings of the 004 reply from
1867         s_err.c to the header files where the channels/user modes are
1868         defined, and show or hide +Au based on OPLEVELS setting.
1869
1870 2003-06-25  Bas Steendijk  <steendijk@xs4all.nl>
1871
1872         * ircd/m_burst.c: Clear topic set by netrider on burst.
1873
1874 2003-08-05 Diane Bruce  <db@db.net>
1875
1876         * ircd/parse.c: Fixed the typo the fix of the typo created
1877
1878 2003-08-01 Diane Bruce  <db@db.net>
1879
1880         * ircd/parse.c: Fixed typo
1881
1882 2003-06-22  Diane Bruce  <db@db.net>
1883
1884         * ircd/parse.c: Completely rewritten June 2, 2003 - Dianora
1885
1886 2003-06-22  Bas Steendijk  <steendijk@xs4all.nl>
1887
1888         * include/ircd_features.h, include/supported.h, ircd/ircd_features.c,
1889         ircd/ircd_features.c, ircu2.10/ircd/m_join.c, doc/example.conf: 
1890         Make ability to create local channels a feature which can be disabled.
1891
1892 2003-06-22  Bas Steendijk  <steendijk@xs4all.nl>
1893
1894         * include/ircd_features.h, ircd/channel.c, ircd/ircd_features.c,
1895         ircd/m_kick.c, doc/example.conf: Added OPLEVELS feature, which
1896         makes it possible to disable the +Au/oplevels functions.
1897
1898 2003-06-17  Alex Badea  <vampire@p16.pub.ro>
1899
1900         * ircd/res_adns.c: included sys/types.h, for non-Linux
1901         headers
1902
1903 2003-03-06  Kevin L. Mitchell  <klmitch@mit.edu>
1904
1905         * libs/dbprim: database primitives library, including
1906         flexible linked lists, auto-resizing hash tables, and sparse
1907         matrices.  Has a test suite for everything but portions of
1908         the sparse matrix routines (I'm lazy; someone help me write
1909         them!).  Documentation generated by doxygen--feel free to
1910         critique, suggest phrasing improvements, etc.
1911
1912 2003-01-22  Kevin L. Mitchell  <klmitch@mit.edu>
1913         * libs: put third-party libraries in this subdirectory.
1914         Started by copying adns into it--will fix the rest and remove
1915         the top-level copy later.
1916
1917 2003-01-14  Andrew Miller <a1kmm@mware.virtualave.net>
1918         * ircd/m_settime.c: Fixed a minor format string issue.
1919         
1920 2003-01-12  Thomas Helvey <tom.helvey@cox.net>
1921         * adns/src/check.c, adns/src/transmit.c, ircd/m_opmode.c,
1922         ircd/motd.c, ircd/s_user.c: Cleanup warnings, fix precedence
1923         bugs in transmit.c and m_opmode.c.
1924
1925 2003-01-12  Thomas Helvey <tom.helvey@cox.net>
1926         * include/class.h, include/ircd_string.h, ircd/class.c,
1927         ircd/gline.c, ircd_string.c: Fix undefined order
1928         of evaluation bug in gline.c, add general purpose hasher for
1929         conf entries. 
1930
1931 2003-01-11  Thomas Helvey <tom.helvey@cox.net>
1932         * include/channel.h, include/ircd_alloc.h, ircd/channel.c,
1933         ircd/client.c, ircd/gline.c, ircd/ircd_alloc.c,
1934         ircd/ircd_events.c, ircd/ircd_log.c, ircd/ircd_parser.y,
1935         ircd/ircd_snprintf.c, ircd/listener.c, ircd/m_nick.c,
1936         ircd/m_opmode.c, ircd/m_whois.c, ircd/motd.c,
1937         ircd/s_auth.c, ircd/s_bsd.c, ircd/uping.c: Server compiles
1938         with g++ again, type safety, const correctness fixes,
1939         remove C++ keywords again :/
1940
1941 2003-01-11  Thomas Helvey <tom.helvey@cox.net>
1942         * ircd/client.c, ircd/ircd_feature.c: Bugfix, the feature
1943         table data was in a different order than the feature data
1944         structure, which resulted in a wild index being used in
1945         feature_bool. The feature_bool function didn't check it's
1946         index before indexing the features array resulting in
1947         a core dump on /oper.
1948
1949 2003-01-10  Thomas Helvey <tom.helvey@cox.net>
1950         * include/client.h, include/res.h, include/s_bsd.h,
1951         ircd/ircd.c, ircd/list.c ircd/m_connect.c, ircd/res_adns.c,
1952         ircd/res_libresolv.c, ircd/s_auth.c, ircd/s_bsd.c, ircd/s_conf.c:
1953         Remove resolver cache wart, change hostent representation, cleanup
1954         resolver clients.
1955
1956 2003-01-10  Thomas Helvey <tom.helvey@cox.net>
1957         * ircd/map.c, ircd/Makefile.in, include/map.h: Remove 
1958         HEAD_IN_SAND macros to get server to build, rebuild dependencies.
1959
1960 2003-01-08  Fredrik Soderblom <froo@quakenet.org>
1961         * ircd/s_err.c, ircd/s_user.c (hide_hostmask): Simplify
1962         RPL_HOSTHIDDEN and the use of it.
1963
1964 2003-01-07  Kevin L Mitchell  <klmitch@mit.edu>
1965
1966         * BUGS: removed from distribution
1967
1968         * ChangeLog.07: moved into doc/history
1969
1970         * ChangeLog.10: moved into doc/history
1971
1972         * INSTALL: pulled up from u2.10.11.04
1973
1974         * README: pulled up from u2.10.11.04
1975
1976         * README.FreeBSD: pulled up from u2.10.11.04
1977
1978         * README.Solaris: pulled up from u2.10.11.04
1979
1980         * RELEASE.NOTES: add sysctl note from u2.10.11.04
1981
1982         * TODO: removed from distribution
1983
1984         * configure.in: add extra check for res_mkquery; remove
1985         --disable-headinsand since it no longer has any effect; pull up
1986         "Enable" vs. "Disable" changes from u2.10.11.04
1987
1988         * doc/readme.asll: pulled up from u2.10.11.04
1989
1990         * doc/readme.features: pull up missing documentation, including a
1991         couple of corrections
1992
1993         * doc/readme.log: correct text to read FACILITY instead of SYSLOG
1994         in the documentation for configuring syslog facility
1995
1996         * include/channel.h: declare IsInvited()
1997
1998         * include/handlers.h: do some minor reorderings
1999
2000         * include/ircd_defs.h: remove deprecated NETWORK and URL_CLIENTS
2001         #define's
2002
2003         * include/ircd_policy.h: removed from the distribution
2004
2005         * include/jupe.h: declare jupe_memory_count()
2006
2007         * include/msgq.h: remove MsgCounts structure
2008
2009         * include/numeric.h: add a blank line after RPL_STATSQLINE; add
2010         RPL_HOSTHIDDEN
2011
2012         * include/s_stats.h: include ircd_features.h for definition of the
2013         enum; remove extraneous declarations
2014
2015         * ircd/Makefile.in: add LDFLAGS to table_gen
2016
2017         * ircd/engine_poll.c: remove commented-out assertion
2018
2019         * ircd/ircd.c: include s_stats.h and call stats_init()
2020
2021         * ircd/ircd_features.c: feature names have to be case-sensitive
2022         because of some of the HIS features
2023
2024         * ircd/ircd_relay.c: reorder includes
2025
2026         * ircd/m_account.c: include string.h for strlen()
2027
2028         * ircd/m_clearmode.c: remove extraneous clean_channelname(); make
2029         sure to refer to chname, not parv[1]
2030
2031         * ircd/m_create.c: remove the broken code that squits servers that
2032         are >5 minutes fast; fix "badop || CHFL_CHANOP" bug that caused op
2033         desyncs
2034
2035         * ircd/m_gline.c: if it's a server, force the gline; don't
2036         gline_find() before determining if the oper had the privilege
2037
2038         * ircd/m_kick.c: kicks by servers should appear to be from the
2039         local server thanks to HIS
2040
2041         * ircd/m_lusers.c: needs ircd_features.h, not ircd_policy.h
2042
2043         * ircd/m_map.c: needs ircd_features.h, not ircd_policy.h
2044
2045         * ircd/m_nick.c: added an assertion and some explanatory comments
2046         pulled up from u2.10.11.04
2047
2048         * ircd/m_opmode.c: no longer requiring oper to be on the channel;
2049         search for quarantines before allowing ops
2050
2051         * ircd/m_privmsg.c: one character typo that probably means nothing
2052
2053         * ircd/m_settime.c: add back comments I left in the code
2054
2055         * ircd/m_squit.c: remove protocol_violation() notices
2056
2057         * ircd/m_userhost.c: return realhost if user is an oper
2058
2059         * ircd/m_wallvoices.c: only m_wallvoices() should add a +
2060
2061         * ircd/m_who.c: add handling for the 'a' field
2062
2063         * ircd/m_whois.c: correct a typo of FEAT_HIS_SERVERNAME for
2064         FEAT_HIS_SERVERINFO
2065
2066         * ircd/s_bsd.c: close file descriptors 0, 1, and 2; pull up some
2067         ancient bug fixes from the u2.10.11 branch
2068
2069         * ircd/s_debug.c: include gline.h, jupe.h, motd.h, and s_stats.h;
2070         call motd_memory_count(), gline_memory_count(), and
2071         jupe_memory_count() when reporting memory usage; add back a
2072         comment regarding "DBuf caveats"
2073
2074         * ircd/s_err.c: add RPL_STATSQLINE, RPL_HOSTHIDDEN, and pull up
2075         change to ERR_NOPRIVILEGES wording
2076
2077         * ircd/s_misc.c: include ircd_features.h and not ircd_policy.h
2078
2079         * ircd/s_stats.c: count from 0 and not 1 when initializing the
2080         stats
2081
2082         * ircd/s_user.c: comment out assertion; remove extraneous
2083         definition of FLAGS_HOST_HIDDEN; add in hikari's "your host is now
2084         hidden" reply; don't detach oper confs unless sptr is not an oper
2085
2086         * ircd/table_gen.c: pull up change to NTL_CHPFX (removing +);
2087         change channel name character range to be from '\041' (!) to
2088         UCHAR_MAX
2089
2090         * ircd/whocmds.c: pull up fix to /who idle time from u2.10.11.04
2091
2092         * tools/linesync/linesync.conf: pull up from u2.10.11.04
2093
2094         * tools/linesync/linesync.sh: pull up from u2.10.11.04
2095
2096 2003-01-07 Andrew Miller <a1kmm@mware.virtualave.net>
2097         * almost everything: Forward ported numerous changes from .11 to .12
2098         
2099 2002-07-05 Andrew Miller <a1kmm@mware.virtualave.net>
2100         * ircd/packet.c(connect_dopacket): Pass the job on to server_dopacket
2101         when they become a server.
2102         * ircd/s_bsd.c(read_packet): Check they are now a server *after* the
2103         packet is sent.
2104         * ircd/class.c(make_class): Fixed an assert to be more useful.
2105         
2106 2002-07-05 Andrew Miller <a1kmm@mware.virtualave.net>
2107         * ircd/packet.c
2108         * ircd/packet.h: (connect_dopacket): Made a dopacket function for
2109         connecting links which sends the messages through the correct message
2110         handler.
2111         * ircd/s_bsd.c(read_packet): Put packets through the correct handler
2112         for connecting links. Properly handle unknown links becoming
2113         connecting or servers.
2114
2115 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
2116         * include/ircd_alloc.h (MyFree): Accept NULL pointers to do nothing
2117         with, this is used quite a lot.
2118         * ircd/class.c (make_class): Initialise the ref_count to 1 so that
2119         we don't leak.
2120         * ircd/class.c (add_class): When updating a class, free the old name
2121         first to prevent leakage.
2122         * ircd/class.c (class_delete_marked): Decrement the ref_count for the
2123         class after it is removed from the linked list.
2124         * ircd/ircd_parser.y: Changed a free to MyFree().
2125         * ircd/ircd_parser.y: Removed a few debugging messages.
2126
2127 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
2128         * s_bsd.c (read_packet): Our daily addition to the list of entities to
2129         treat as servers - Connecting servers.
2130         
2131 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
2132         * doc/debug_memleak_gc.patch,
2133         * include/ircd_ircd_alloc.h,
2134         * include/memdebug.h,
2135         * configure.in,
2136         * ircd/Makefile.in,
2137         * ircd/memdebug.c: added a Boehm's gc based leak detector to find leaks
2138         and notify the operators.
2139         
2140 2002-06-29  Andrew Miller <a1kmm@mware.virtualave.net>
2141
2142         * ircd/s_bsd.c (read_packet): don't make handshaking servers go through
2143         the dbufs.
2144         
2145 2002-06-18  Andrew Miller <a1kmm@mware.virtualave.net>
2146
2147         * ircd/s_bsd.c (read_packet): don't allow unregistered clients to flood
2148         the server.
2149         
2150 2002-06-18  Alex Badea  <vampire@p16.pub.ro>
2151
2152         * ircd/m_burst.c (ms_burst): kick local members if the channel
2153         has a larger local TS and it's +i or +k remotely (anti net.ride)
2154
2155         * ircd/ircd_parser.y: fixed a bug that broke IP-based C:lines
2156
2157         * ircd/s_err.c: connection classes are now strings (RPL_STATSCLINE)
2158
2159         * include/s_conf.h: externalized lookup_confhost
2160
2161         * adns/Makefile.in: compilation-outside-source-tree fix
2162
2163 2002-06-17  Alex Badea  <vampire@p16.pub.ro>
2164
2165         * adns/*: added a slightly hacked copy of adns
2166
2167         * configure.in: added a --disable-adns switch if you want
2168         to use the old libresolv res.c
2169
2170         * configure: ran autoconf
2171
2172         * ircd/res_libresolv.c: renamed from res.c
2173
2174         * ircd/res_adns.c: added adns resolver
2175
2176 2002-06-17  Alex Badea  <vampire@p16.pub.ro>
2177
2178         * ircd/ircd_parser.y: fixed 'Connect' block processing so now
2179         you can actually connect to other servers
2180
2181 2002-06-04  Alex Badea  <vampire@p16.pub.ro>
2182
2183         * ircd/m_stats.c (report_servers_verbose): oops, fixed it so
2184         it displays all servers, not just local connects
2185
2186 2002-05-30  Jean-Edouard Babin  <Jeb@jeb.com.fr>
2187
2188         * ircd/m_server.c (mr_server): fixed core bug on insufficient
2189         arguments
2190
2191 2002-05-26  Jeekay  <jeekay@irc.planetarion.com>
2192         
2193         * ircd/m_join.c (HasControlChars): fixed unsigned vs signed
2194
2195 2002-05-26  Jeekay  <jeekay@irc.planetarion.com>
2196  
2197         * ircd/m_join.c (m_join,HasControlChars): check if a channel
2198         name has any control chars (<=32) in it before allowing a
2199         local user to join.
2200  
2201 2002-21-05 Andrew Miller <a1kmm@mware.virtualave.net>
2202         * ircd/ircd_relay.c: stop an information leak about the
2203         the network topography from relayed messages.
2204
2205 2002-04-19  Alex Badea  <vampire@p16.pub.ro>
2206
2207         * ircd/m_who.c (m_who): disallow non-opers to /who server.name
2208
2209 2002-04-18  Alex Badea  <vampire@p16.pub.ro>
2210
2211         * ircd/s_err.c (RPL_STATSILINE): connection classes are now
2212         strings
2213
2214 2002-04-17  beware <steendijk@tomaatnet.nl>
2215
2216         * m_whois.c (m_whois): disallow remote queries for non-existent
2217         local users when originated by a non-oper
2218
2219 2002-04-16  Alex Badea  <vampire@p16.pub.ro>
2220
2221         * ircd/s_user.c (hunt_server_cmd): also send a "no such server"
2222         reply if the servername contains a '*' and it doesn't exist
2223
2224         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2225
2226 2002-04-16  beware <steendijk@tomaatnet.nl>
2227
2228         * ircd/m_whois.c: the previous patch broke whois, fixed it
2229         another way
2230
2231         * ircd/m_admin.c: cleaned up m_admin too while we're here,
2232         hunt_server_cmd can do all the work for us
2233
2234 2002-04-15  Alex Badea  <vampire@p16.pub.ro>
2235
2236         * ircd/m_stats.c: added verbose server reporting (/stats v
2237         or /stats V for machine-readable format) (bugzilla bug 52)
2238
2239         * include/numeric.h: added RPL_STATSVERBOSE 236
2240
2241         * ircd/s_err.c: added RPL_STATSVERBOSE
2242
2243         * ircd/s_stats.c: added help for stats 'v'
2244
2245 2002-04-15  Alex Badea  <vampire@p16.pub.ro>
2246
2247         * ircd/class.c (get_client_class): fixed typo which caused
2248         /trace (and perhaps motd) to core
2249
2250 2002-04-15  beware <steendijk@tomaatnet.nl>
2251
2252         * ircd/m_whois.c: Fixed /whois servermask nomatch bug
2253         where normal users could use the function to discover servers,
2254         also the NOSUCHSERVER check code was missing.
2255
2256 2002-04-14  Alex Badea  <vampire@p16.pub.ro>
2257
2258         * ircd/ircd_parser.y: fixed cli_info(&me) not being set
2259         from 'description' conf
2260
2261 2002-04-13  Stephane Thiell <mbuna@undernet.org>
2262
2263         * ircd/m_whois.c: removed FindUser() in ms_whois to fix
2264         remote whois relaying.
2265
2266         * ircd/class.c: removed unused (and duplicated) code
2267         get_client_ping().
2268         
2269         * include/class.h: removed unused function prototype.
2270         
2271         * config.guess: upgraded with latest
2272         
2273         * config.sub: upgraded with latest
2274
2275 2002-04-12  Alex Badea  <vampire@p16.pub.ro>
2276
2277         * ircd-patch: report which files failed the dry run (so the
2278         user may force the patch if the rejects are in less-than-vital
2279         files, such as ChangeLog or documentation)
2280
2281 2002-04-12  Alex Badea  <vampire@p16.pub.ro>
2282
2283         * ircd/m_invite.c: don't propagate invites for local channels
2284
2285         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2286
2287 2002-04-10 Joseph Bongaarts <foxxe@wtfs.net>
2288
2289         * ircd/ircd.c: The last fix broke autoconnects completely.
2290         Fixed it another way.
2291         
2292 2002-04-09  Brian Cline  <clineb@cs.winthrop.edu>
2293
2294         * ircd/ircd.c (try_connections): To avoid problems with infinite event
2295         loops, don't try connecting to servers whose connect frequency is 0.
2296         
2297 2002-04-10  Alex Badea  <vampire@p16.pub.ro>
2298
2299         * ircd/ircd_parser.y: fixed a "features" block parse bug
2300
2301         * tools/convert-conf.py: added a configuration file converter
2302         from 2.10.11 to 2.10.12 format
2303
2304         * ircd-patch: added GPL information to top of file
2305
2306 2002-04-09  Alex Badea  <vampire@p16.pub.ro>
2307
2308         * configure.in: added a human-readable report of configured
2309         options at the end of the configure process
2310
2311         * configure: regenerated with autoconf
2312
2313 2002-04-08  Gavin Grieve  <ggrieve@ihug.co.nz>
2314
2315         * include/supported.h: change CHARSET to CASEMAPPING after
2316         discussions as to what would be the preferred name.
2317
2318 2002-04-05 Andrew Miller <a1kmm@mware.virtualave.net>
2319         * ircd/s_conf.c, ircd_parser.y, ircd_lexer.l: Add privilege
2320         specification.
2321         * Fix a minor parser bug that meant rehash didn't always
2322         work correctly.
2323
2324 2002-04-03  Alex Badea  <vampire@p16.pub.ro>
2325
2326         * include/channel.h: fix compiler warnings (paratheses around &&)
2327
2328         * ircd/channel.c (modebuf_extract): fix compiler warnings
2329         (uninitialized variables)
2330
2331         * ircd/Makefile.in: make ircd properly compile outside the
2332         source tree
2333
2334 2002-04-03  Alex Badea  <vampire@p16.pub.ro>
2335
2336         * include/s_user.h: added a sptr parameter to InfoFormatter
2337         function type
2338
2339         * ircd/m_who.c: don't match IPs for clients which have a hidden host,
2340         except when the inquiring user is an oper
2341
2342         * ircd/whocmds.c: show the fake IP from FEAT_HIDDEN_IP if the
2343         target has a hidden host, but show real IP to opers
2344
2345         * ircd/m_userip.c (userip_formatter): add sptr parameter; show the
2346         fake IP from FEAT_HIDDEN_IP if the target has a hidden host, but
2347         show real IP to opers
2348
2349         * ircd/m_userhost.c (userhost_formatter): add (unused) sptr parameter
2350
2351         * ircd/s_user.c (send_user_info): pass sptr to the formatting function
2352
2353         * include/ircd_features.h: new feature FEAT_HIDDEN_IP (stores which
2354         fake IP to show for clients with a hidden host)
2355
2356         * ircd/ircd_features.c: new feature FEAT_HIDDEN_IP
2357
2358         * doc/example.conf: default value for FEAT_HIDDEN_IP
2359
2360         * doc/readme.features: documented FEAT_HIDDEN_IP
2361
2362 2002-04-03 Andrew Miller <a1kmm@mware.virtualave.net>
2363         * doc/example.conf: Cleaned up some comments that ended up in
2364           strange places due to problems in the merge process.
2365         * ircd/m_nick.c: Cleaned up ms_nick, and fixed a bug that
2366           probably dates back to Jarkko code.
2367
2368 2002-04-02  Kevin L Mitchell  <klmitch@mit.edu>
2369
2370         * ircd/m_kill.c: let ms_kill() and mo_kill() seperate the message
2371         from the path before calling do_kill(); add a msg argument to
2372         do_kill() and use it in preference to comment; remove all that old
2373         code that fiddled with the buf and the comment
2374
2375         * ircd/ircd_log.c (log_write_kill): add a seperate msg argument
2376
2377         * include/ircd_log.h: add a seperate msg argument to
2378         log_write_kill()
2379
2380         * ircd/ircd.c: display event engine and MAXCONNECTIONS information
2381  
2382 2002-04-02  Alex Badea <vampire@p16.pub.ro>
2383
2384         * ircd-patch: Automatically generate a version string from patches
2385
2386 2002-04-02  Alex Badea <vampire@p16.pub.ro>
2387         
2388         * ircd-patch: Test before doing anything dangerous, provide -f to
2389                 to it anyway.  exit levels for easy scripting.
2390
2391 2002-04-01  Kevin L Mitchell  <klmitch@mit.edu>
2392
2393         * ircd/channel.c (joinbuf_join): don't add a channel to the list
2394         in the joinbuf unless when we flush it, we empty the list
2395
2396 2002-04-02 Andrew Miller <a1kmm@mware.virtualave.net>
2397         * ircd/ircd_parser.y: Added ircd parser, lexer, to replace the
2398           old configuration file format.
2399         * ircd/ircd_lexer.l
2400         * ircd/s_conf.c
2401         * doc/example.conf
2402
2403 2002-03-23 Bert Faes <bert.faes@pandora.be>
2404
2405         * s_misc.c made /trace reply always show the username
2406         
2407 2002-03-28  Kevin L Mitchell  <klmitch@mit.edu>
2408
2409         * configure.in: use AC_CHECK_FUNCS to define HAVE_* macros; test
2410         for setrlimit, getrusage, and times
2411
2412         * configure: rerun auto-conf
2413
2414         * config.h.in: rerun autoheader
2415
2416 2002-03-27  Kevin L Mitchell  <klmitch@mit.edu>
2417
2418         * ircd/m_burst.c (ms_burst): use MODEBUF_DEST_NOKEY to suppress
2419         sending of the key to the channel
2420
2421         * ircd/channel.c (modebuf_flush_int): when processing keys, only
2422         include the actual key in the mode sent to the channel if
2423         MODEBUF_DEST_NOKEY is not set
2424
2425         * include/channel.h: needed more bits for MODEBUF_DEST_*,
2426         especially when adding MODEBUF_DEST_NOKEY to force keys in the
2427         BURST to be reported as "*" to the channel
2428
2429         * ircd/m_oper.c (m_oper): clear the new oper's sendq so it gets
2430         inherited from the class associated with the O-line
2431
2432 2002-03-25  Kevin L Mitchell  <klmitch@mit.edu>
2433
2434         * ircd/s_user.c (set_nick_name): invalidate all ban valid caching
2435         when a user changes his nickname so we can catch if he now matches
2436         a ban
2437
2438 2002-03-20 Reed Loden <reed@redmagnet.com>
2439         * doc/example.conf: Added OPER_LIST_CHAN and LOCOP_LIST_CHAN.
2440
2441         * doc/readme.features: Added OPER_LIST_CHAN and LOCOP_LIST_CHAN.
2442
2443 2002-03-20 LordLuke <lordluke@undernet.org>
2444         * ircd/client.c: Add LOCOP_LIST_CHAN feature.
2445
2446         * ircd/ircd_features.h: Add LOCOP_LIST_CHAN feature.
2447
2448 2002-03-19 Joseph Bongaarts <foxxe@wtfs.net>
2449
2450         * ircd/m_links.c: Make /links behave like /map for head_in_sand.
2451         cleaned up excess code.
2452
2453         * ircd/map.c: Added map_dump_links_head_in_sand() Made changes in
2454         map_add() and map_update() for links changes.
2455
2456         * include/map.h: Added info and prot to struct Map
2457
2458         * include/ircd_defs.h: Added MAP_CACHE_TIME for length of time
2459         servers are cached in MapList
2460
2461         * ircd/s_misc.c: changed #ifdef for map_update()
2462
2463         * ircd/m_server.c: changed #ifdef for map_update()
2464
2465         * include/ircd_policy.h: added NO_HEAD_IN_SAND for easier removal of
2466         hiding features.
2467
2468         * configure.in: add --disable-headinsand
2469
2470         * configure: Ran autoconf
2471
2472         * ircd/m_stats.c: Fixed a bug in /stats i and made /stats i show 
2473         connect limits
2474
2475         * ircd/s_stats.c: Made /stats i report connect limits
2476
2477         * ircd/s_err.c: Modified RPL_STATSILINE to use %s instead of 
2478         "*" for the password field.
2479         
2480 2002-03-19 LordLuke <lordluke@undernet.org>
2481
2482         * include/channel.h: Allow opers to view +s channels in /list
2483
2484         * include/client.h: Add "PRIV_LIST_CHAN" oper privilege
2485
2486         * include/ircd_features.h: added "LIST_CHAN" feature
2487
2488         * ircd/channel.c: Allow opers to view +s channels in /list
2489
2490         * ircd/client.c: Add "PRIV_LIST_CHAN"
2491
2492         * ircd/ircd_features.c: Add "LIST_CHAN" feature
2493
2494 2002-03-13 Joseph Bongaarts <foxxe@wtfs.net>
2495
2496         * ircd/m_kill.c: Last of the last of the bug fixes (Thanks Spike).
2497         Must be more careful when forward porting by hand...
2498         
2499 2002-03-13  Carlo Wood  <run@alinoe.com>
2500
2501         * include/channel.h: CHFL_CHANNEL_MANAGER, new local
2502         channel flag set when someone creates a channel or joins
2503         using the Apass.  IsChannelManager(), SetChannelManager():
2504         macros to manipulate new channel flag.
2505         channel_modes: Added new argument to avoid calling
2506         find_member_link more often than needed.
2507
2508         * include/numeric.h: RPL_APASSWARN, ERR_NOTLOWEROPLEVEL,
2509         ERR_NOTMANAGER, ERR_CHANSECURED, ERR_UPASSSET,
2510         ERR_UPASSNOTSET: new numeric replies.
2511
2512         * ircd/channel.c: is_level0_op: removed.
2513         member_can_send_to_channel: disallow channel manager
2514         to talk.  channel_modes: show upass to level0 ops.
2515         mode_parse_upass: Only the channel manager is allowed
2516         to change the upass.  Only allow to set upass when apass
2517         is also set.  mode_parse_apass: Don't allow to change the
2518         Apass if the channel is older than 48 hours.  Only allow
2519         to remove the apass when upass is not set.  Send clear
2520         warnings regarding the importance of apass.
2521         mode_process_clients: Don't change the oplevel of an opped
2522         member in a channel where upass is not set.
2523
2524         * ircd/destruct_event.c: exec_expired_destruct_events:
2525         Bug fix: send DESTRUCT message when destructing a channel.
2526
2527         * ircd/m_destruct.c: ms_destruct: Bug fix: use self as
2528         prefix for DESTRUCT message.
2529
2530         * ircd/m_join.c: m_join: Handle apass and upass.
2531
2532         * ircd/m_kick.c: m_kick: Don't allow to kick member with
2533         a higher or equal op-level.
2534
2535         * ircd/m_mode.c: m_mode: Now pass member to channel_modes.
2536         ms_mode: Allow server to do modes on channels with apass
2537         set.
2538
2539         * ircd/s_err.c: RPL_APASSWARN, ERR_NOTLOWEROPLEVEL,
2540         ERR_NOTMANAGER, ERR_CHANSECURED, ERR_UPASSSET,
2541         ERR_UPASSNOTSET: new numeric replies.
2542
2543
2544 2002-03-10 Joseph Bongaarts <foxxe@wtfs.net>
2545
2546         * ircd/m_kill.c: Last of the bug fixes for do_kill()
2547
2548         * ircd/list.c: Don't remove clients from the linked list
2549         that aren't actually in the list.
2550         
2551 2002-03-08  Carlo Wood  <run@alinoe.com>
2552         * include/channel.h: Added CHFL_BURST_ALREADY_OPPED
2553         and CHFL_BURST_ALREADY_VOICED.
2554
2555         * ircd/m_burst.c: Allow BURST outside net-burst
2556         and take into account that users are already joined
2557         to the channel in that case.
2558
2559         * ircd/m_destruct.c: Implementation of DESTRUCT
2560         handling code.
2561
2562         * ircd/m_join.c: Set the channel creationtime to
2563         the timestamp of a message when that timestamp is
2564         smaller.
2565 2002-02-27 Reed Loden <reed@redmagnet.com>
2566        * tools/crypter: Updated some variables, added another notice,
2567        added CVS Id tag, and updated Perl location.
2568
2569        * tools/ringlog.c: Added IRC - Internet Relay Chat, 
2570        tools/ringlog.c
2571
2572        * tools/ringlog.pl: Added IRC - Internet Relay Chat, 
2573        tools/ringlog.pl
2574
2575        * tools/wrapper.c: Added IRC - Internet Relay Chat, 
2576        tools/wrapper.c
2577
2578        * tools/mkpasswd.c: Added CVS Id tag
2579
2580        * tools/sums: Updated to comply with sums being moved to tools/
2581        and added CVS Id tag
2582
2583        * tools/README: Updated location of file and partly rewrote to fit 
2584        u2.10.11's Features
2585
2586        * tools/Makefile.crypt: Updated location of file and added CVS Id 
2587        tag
2588
2589        * acconfig.h: Updated location of file
2590
2591        * config.h.in: Updated location of file
2592
2593        * tools/Bounce/bounce.conf: Added CVS Id tag
2594
2595        * tools/Bounce/Bounce.cpp: Updated location of file
2596
2597        * tools/Bounce/Bounce.h: Updated location of file
2598
2599        * tools/hashtoy: Added CVS Id Tag
2600
2601 2002-02-27  Carlo Wood  <run@alinoe.com>
2602
2603         * /ircd/ircd.c: check_pings: First check if a PING was sent at all.
2604
2605 2002-03-01  Carlo Wood  <run@alinoe.com>
2606
2607         * include/channel.h: struct Channel: new attribute destruct_event.
2608         Prototype for destruct_channel().
2609
2610         * include/destruct_event.h: new header file for destruct_event.c.
2611
2612         * ircd/Makefile.in: New source file: destruct_event.c.
2613
2614         * ircd/channel.c: sub1_from_channel: Don't destruct channel
2615         immedeately but instead schedule it for destruction after
2616         some time when a channel becomes empty (and clear invite
2617         only and limit in that case).
2618         destruct_channel: new function, was previously the destructing
2619         part of sub1_from_channel.
2620         add_user_to_channel: remove destruction request if any.
2621
2622         * ircd/destruct_event.c: New file.  Implementation of functions
2623         schedule_destruct_event_1m, schedule_destruct_event_48h,
2624         remove_destruct_event and exec_expired_destruct_events.
2625
2626         * ircd/ircd.c: destruct_event_timer: new timer.
2627         main: use destruct_event_timer to call exec_expired_destruct_events
2628         once per minute.
2629
2630         * ircd/m_endburst.c: ms_end_of_burst: Don't complain about empty
2631         channels.  Schedule new empty channels for destruction.
2632
2633         * ircd/m_join.c: m_join: Destruct just-created channel immedeately.
2634
2635 2002-03-01  Carlo Wood  <run@alinoe.com>
2636         * ircd/s_misc.c: exit_client: Only call map_update()
2637         for servers.
2638
2639 2002-02-28  Carlo Wood  <run@alinoe.com>
2640         * include/channel.h: New attribute 'oplevel' in struct Membership.
2641         Added defines MAXOPLEVELDIGITS and MAXOPLEVEL.
2642         New macros:  OpLevel(member): returns op-level of member and
2643         SetOpLevel(member, value): sets op-level of member.
2644         Prototype of add_user_to_channel: add oplevel to parameters.
2645         Prototype of mode_parse: add member to to parameters.
2646
2647         * include/numeric.h: added ERR_NOTLOWEROPLEVEL.
2648
2649         * ircd/s_err.c: idem.
2650
2651         * ircd/channel.c: Removed unmatched '{' braces from comments
2652         (confuses vi).  add_user_to_channel: oplevel is passed to function
2653         and added in the created MemberShip structure.  send_channel_modes:
2654         Generate the nick:mode list of the BURST msg in the new style (with
2655         op-levels).  DONE_UPASS/DONE_APASS: fixed typo in comment.  struct
2656         ParseState: New attribute: member.  mode_process_clients: Disallow
2657         deopping someone with an equal or higher op-level, take care of
2658         inheritance of op-level.  mode_parse: member is passed to function      
2659         and added in the created ParseState structure.  joinbuf_join: pass 0
2660         as oplevel to add_user_to_channel as needed initialization of oplevel
2661         in struct MemberShip.
2662
2663         * ircd/m_burst.c: ms_burst: Implementation of op-levels in the
2664         decoding of a BURST message and passing on a BURST message.
2665         Renamed default_mode to current_mode.
2666
2667         * ircd/m_mode.c: m_mode/ms_mode: pass on `member' to mode_parse.
2668
2669         * ircd/m_opmode.c: ms_opmode/mo_opmode: pass on NULL as member
2670         to mode_parse (causes opped member to get op-level 0).                  
2671
2672 2002-02-25  Carlo Wood  <run@alinoe.com>
2673         * include/channel.h: Added two new strings to struct Mode,
2674         upass and apass, both with maximum length PASSLEN (a new
2675         define in this file).  Two new mode defines MODE_UPASS and
2676         MODE_APASS.
2677
2678         * ircd/channel.c: is_level0_op: Added as dummy function.
2679         channel_modes/modebuf_flush_int/modebuf_extract/mode_parse:
2680         Added support for MODE_APASS (+A) and MODE_UPASS (+u).
2681         mode_parse_upass: New function to parse mode +u.
2682         mode_parse_apass: New function to parse mode +A.
2683
2684         * ircd/s_err.c: Added 'A' and 'u' to mode list (RPL_MYINFO).            
2685
2686 2002-02-25  Carlo Wood  <carlo@alinoe.com>
2687
2688         * ircd/m_server.c: remove unused variables
2689
2690 2002-02-25 Joseph Bongaarts <foxxe@wtfs.net>
2691
2692         * ircd/m_map.c: Modified to show a useful output to non-opered
2693           clients when HEAD_IN_SAND_MAP is defined. Servers are added to
2694           the list when first seen (after receiving SERVER) and that list
2695           is sent to clients. Servers are excluded from the list if they are
2696           hubs, services, or have been missing for more than 1 week.
2697         
2698         * ircd/map.c: Created file for map_* functions
2699
2700         * include/map.h: Created file for map_* functions
2701
2702         * ircd/m_server.c: Added calls to map_update()
2703
2704         * ircd/s_misc.c: Added call to map_update()
2705
2706         * ircd/parse.c: Changed to use m_map() and mo_map()
2707         
2708 2002-02-22 Reed Loden <reed@redmagnet.com>
2709
2710        * ircd/m_connect.c: Removed an extra : in remote connect message.
2711
2712 2002-02-19 Joseph Bongaarts <foxxe@wtfs.net>
2713
2714         * ircd/whocmds.c: Local opers should also be able to
2715         see servernames in /who
2716
2717         * ircd/gline.c: Fix core bug in gline_find()
2718
2719         * ircd/m_kill.c: Bug fix for HIS_KILLWHO
2720
2721 2002-02-19 John Buttery <john@io.com>
2722
2723         * ircd/ircd.c: Updated "No such file" error message.
2724         
2725 2002-02-18 Joseph Bongaarts <foxxe@wtfs.net>
2726
2727         * ircd/m_kill.c: Changed m_kill() to do_kill() because its not
2728         a message handler, and some general cleanups and bug fixes. 
2729
2730         * include/ircd_policy.h: Added HEAD_IN_SAND_KILLWHO for hiding
2731         kill source.
2732         
2733 2002-02-16  Tim Vogelsang <net@astrolink.org>
2734
2735         * ircd/m_kill.c: added a new static function, m_kill, which
2736         performs the actual kill.
2737         
2738 2002-02-14 Joseph Bongaarts <foxxe@wtfs.net>
2739
2740         * Added support for LIST STOP
2741         
2742 2002-02-13 Joseph Bongaarts <foxxe@wtfs.net>
2743
2744         * Merged changes from u2_10_11 to main branch.
2745         
2746 2002-02-08  Tim Vogelsang  <net@astrolink.org>
2747
2748        * ircd/m_quit.c: don't prefix user quits with "Quit:" unless a
2749        reason is supplied.
2750
2751 2002-02-06  Kevin L Mitchell  <klmitch@mit.edu>
2752
2753         * ircd/s_auth.c (read_auth_reply): left out an = in an
2754         assertion--shouldn't have had any impact, though
2755
2756         * ircd/Makefile.in: add a hook for using ringlog; run make depend
2757
2758         * tools/ringlog.c: for the heck of it, add a comment including
2759         rules for /etc/magic
2760
2761 2002-02-05  Kevin L Mitchell  <klmitch@mit.edu>
2762
2763         * tools/ringlog.pl: perl script to take output from ringlog and
2764         pass it to addr2line to get function, file, and line number
2765         information
2766
2767         * tools/ringlog.c: program/object to help in building function
2768         trace information
2769
2770 2002-02-04  Alex Badea  <vampire@p16.pub.ro>
2771
2772         * include/ircd_features.h: added new feature MOTD_BANNER
2773
2774         * ircd/ircd_features.c: added new feature MOTD_BANNER
2775
2776         * ircd/motd.c (motd_signon): send a one-line banner from
2777         FEAT_MOTD_BANNER if it's not NULL and FEAT_NODEFAULTMOTD
2778         is set
2779
2780         * doc/example.conf: default value for MOTD_BANNER feature
2781
2782         * doc/readme.features: documented the MOTD_BANNER feature
2783
2784 2002-02-04  Kevin L Mitchell  <klmitch@mit.edu>
2785
2786         * ircd/s_debug.c (debug_serveropts): remove deprecated CHROOTDIR
2787         check; added character 'A' to the server options string to
2788         indicate when assertion checking is enabled
2789
2790 2002-02-03  Kevin L Mitchell  <klmitch@mit.edu>
2791
2792         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2793
2794         * ircd/engine_kqueue.c (set_or_clear): don't generate an ET_ERROR
2795         event if the errno is EBADF, since the caller probably already
2796         knows about it and just hasn't gotten around to processing it yet
2797
2798         * ircd/ircd_events.c: set the GEN_ERROR flag if an ET_ERROR event
2799         is generated; don't process socket_events() or socket_state() if
2800         an error occurred; add GEN_ERROR to list of flags in gen_flags()
2801
2802         * include/ircd_events.h: define new GEN_ERROR flag; add a macro to
2803         clear it
2804
2805 2002-02-01  Kevin L Mitchell  <klmitch@mit.edu>
2806
2807         * ircd/channel.c: change make_nick_user_{ip,host} to not use a
2808         static buffer--instead, a buffer of the right size (NUH_BUFSIZE or
2809         NUI_BUFSIZE--I confess they're not well-named) is allocated by the
2810         caller
2811
2812 2002-02-02  Alex Badea  <vampire@p16.pub.ro>
2813
2814         * include/client.h: added user flag FLAGS_HIDDENHOST
2815
2816         * include/ircd_features.h: added FEAT_HOST_HIDING and
2817         FEAT_HIDDEN_HOST
2818
2819         * include/numeric.h: defined numeric 338 (RPL_WHOISACTUALLY)
2820         to report real hostnames and IPs to opers
2821
2822         * include/s_user.h: exported hide_hostmask()
2823
2824         * include/send.h: changed sendcmdto_channel_butserv to
2825         sendcmdto_channel_butserv_butone; ditto for
2826         sendcmdto_common_channels
2827
2828         * include/struct.h: added realhost to struct User
2829
2830         * include/whowas.h: added realhost to struct Whowas
2831
2832         * ircd/channel.c: match bans against both real and hidden
2833         hostmasks; moved some calls to use sendcmdto_*_butone
2834
2835         * ircd/gline.c: match glines agains real host
2836
2837         * ircd/ircd_features.c: added FEAT_HOST_HIDING and
2838         FEAT_HIDDEN_HOST
2839
2840         * ircd/m_account.c: call hide_hostmask() for possibly
2841         hiding the user's host
2842
2843         * ircd/m_burst.c: moved some calls to use sendcmdto_*_butone
2844
2845         * ircd/m_topic.c: moved some calls to use sendcmdto_*_butone
2846
2847         * ircd/m_userip.c: report IP 127.0.0.1 if the user has a hidden
2848         host
2849
2850         * ircd/m_who.c: match real hosts, if the query comes from an oper
2851
2852         * ircd/m_whois.c: report real hostname and IP to opers
2853
2854         * ircd/m_whowas.c: report real hostname to opers
2855
2856         * ircd/s_err.c: added user mode 'x' to the list of supported user
2857         modes in RPL_MYINFO (004); added RPL_WHOISACTUALLY for reporting
2858         real hostnames to opers
2859
2860         * ircd/s_misc.c: moved some calls to use sendcmdto_*_butone
2861
2862         * ircd/s_serv.c: send real hostname to servers
2863
2864         * ircd/s_user.c: send real hostname to servers; added processing
2865         of usermode 'x'; added hide_hostmask() which actually does the work
2866         of hiding a user's host; moved some calls to use sendcmdto_*_butone
2867
2868         * ircd/send.c: changed sendcmdto_channel_butserv to
2869         sendcmdto_channel_butserv_butone; ditto for
2870         sendcmdto_common_channels
2871
2872         * ircd/whocmds.c: extra letter 'x' in WHO reply if the user has
2873         it's host hidden
2874
2875         * ircd/whowas.c: if needed, store a user's real host so we can
2876         report it to opers later
2877
2878         * doc/readme.features: documented HOST_HIDING and HIDDEN_HOST
2879         features
2880
2881         * doc/example.conf: default values for HOST_HIDING and
2882         HIDDEN_HOST features
2883
2884 2002-02-01  Tim Vogelsang  <net@astrolink.org>
2885
2886         * ircd/send.c (sendwallto_group_butone): don't sent wallops to
2887         ordinary users
2888
2889 2002-01-28  Kevin L Mitchell  <klmitch@mit.edu>
2890
2891         * ircd/jupe.c (jupe_activate): remove a bogus assertion
2892
2893         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2894
2895         * ircd/s_err.c: added new channel mode 'r' to list of supported
2896         channel modes in RPL_MYINFO (004); migrated RPL_USERIP to use
2897         numeric 340 instead of 307; add ERR_NEEDREGGEDNICK (477) for
2898         informing users why they can't join a +r channel
2899
2900         * ircd/m_clearmode.c (do_clearmode): add support for MODE_REGONLY
2901         (+r) to do_clearmode(); note that it is *not* being added to the
2902         default clearmode mask!
2903
2904         * ircd/channel.c: don't allow non-+r users to send messages to +r
2905         channels from off the channel; add support for MODE_REGONLY (+r)
2906         to channel_modes(); don't allow non-+r users to join +r channels
2907         without an invite; add support for MODE_REGONLY to the modebuf_*()
2908         family of functions (changes in modebuf_flush_int(),
2909         modebuf_mode(), and modebuf_extract()); add support for
2910         MODE_REGONLY to mode_parse()
2911
2912         * include/supported.h (FEATURESVALUES2): added the new channel
2913         mode 'r' to the list of supported channel modes
2914
2915         * include/numeric.h: move RPL_USERIP to 340 to avoid the 307
2916         conflict; add ERR_NEEDREGGEDNICK (477) for the new +r channels
2917
2918         * include/channel.h: remove unused MODE_SENDTS; add new
2919         MODE_REGONLY
2920
2921         * ircd/s_bsd.c (read_packet): remove call to timer_verify()
2922
2923         * ircd/list.c: remove calls to timer_verify() from
2924         alloc_connection() and dealloc_connection()
2925
2926         * ircd/ircd_events.c: turn off timer_verify(); remove calls to it
2927         from timer_run()
2928
2929 2002-01-27  Kevin L Mitchell  <klmitch@mit.edu>
2930
2931         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2932
2933         * ircd/ircd_events.c (timer_run): why did I ever use a next
2934         pointer when the algorithm guarantees that the head pointer will
2935         always be the next pointer?
2936
2937 2002-01-26  Kevin L Mitchell  <klmitch@mit.edu>
2938
2939         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2940
2941         * ircd/s_bsd.c (read_packet): call timer_verify() after adding the
2942         client process timer to catch any list corruption
2943
2944         * ircd/list.c: surround alloc_connection() and
2945         dealloc_connection() with calls to timer_verify()
2946
2947         * ircd/ircd_events.c: add sledgehammer known as timer_verify() to
2948         verify the timer list's structure; call it around timer_run()
2949
2950 2002-01-22  Kevin L Mitchell  <klmitch@mit.edu>
2951
2952         * ircd/send.c (sendcmdto_common_channels): don't send message to a
2953         channel that the source is a zombie on
2954
2955 2002-01-13  Kevin L Mitchell  <klmitch@mit.edu>
2956
2957         * ircd/ircd_events.c (timer_enqueue): one more assertion--make
2958         sure a timer has the ACTIVE flag set before enqueueing the timer
2959
2960         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2961
2962         * ircd/list.c (dealloc_connection): assert that the process timer
2963         has been removed from the timer queue before dealloc_connection()
2964         is called
2965
2966 2002-01-12  Kevin L Mitchell  <klmitch@mit.edu>
2967
2968         * ircd/res.c: don't accept T_A when we're looking for T_PTR
2969
2970         * ircd/channel.c (modebuf_flush_int): nuke the code that would
2971         send a HACK DESYNCH notice on a HACK(2)--it would be far too
2972         chatty
2973
2974         * ircd/m_away.c (user_set_away): use AWAYLEN instead of TOPICLEN
2975
2976         * include/supported.h: add AWAYLEN to the list of supported
2977         features
2978
2979         * include/ircd_defs.h: add AWAYLEN to specify the maximum length
2980         of an away message
2981
2982         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2983
2984         * ircd/m_mode.c (m_mode): pass extra parameter to channel_modes()
2985
2986         * ircd/channel.c: pass a buflen parameter to channel_modes() for
2987         pbuf--we were using sizeof(pbuf), which would always be
2988         sizeof(char*) before; change send_channel_modes() to pass extra
2989         parameter to channel_modes()
2990
2991         * include/channel.h: pass a buflen parameter to channel_modes()
2992         for pbuf
2993
2994         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
2995
2996         * ircd/uping.c (uping_start): initialize some timers
2997
2998         * ircd/s_bsd.c (read_packet): use new t_onqueue() macro to figure
2999         out when we need to re-add the process timer
3000
3001         * ircd/s_auth.c (make_auth_request): initialize a timer
3002
3003         * ircd/res.c (init_resolver): initialize some timers
3004
3005         * ircd/list.c (alloc_connection): initialize the client process
3006         timer
3007
3008         * ircd/ircd_events.c: add a function, timer_init(), to initialize
3009         a struct Timer; recast timer_add() to catch when adding a marked
3010         timer and not re-enqueue it--but mark it for re-enqueuing; update
3011         timer_del() to turn off the GEN_READD flag and to ignore reference
3012         counts when destroying the timer--we're using GEN_MARKED as an
3013         ersatz referance count; changed timer_run() to work with the new
3014         way of doing things; add GEN_ACTIVE and GEN_READD to gen_flags()'s
3015         map[]
3016
3017         * ircd/ircd.c: initialize some timers
3018
3019         * ircd/engine_select.c (engine_loop): initialize a timer
3020
3021         * ircd/engine_poll.c (engine_loop): initialize a timer
3022
3023         * ircd/engine_kqueue.c (engine_loop): initialize a timer
3024
3025         * ircd/engine_devpoll.c (engine_loop): initialize a timer
3026
3027         * ircd/IPcheck.c (IPcheck_init): initialize a timer
3028
3029         * include/ircd_events.h: add GEN_READD flag for timers to indicate
3030         that a timer must be readded; add t_onqueue() macro to check to
3031         see if a timer is on the queue (this is a hack, though); added
3032         timer_init() to initialize a struct Timer--we're no longer doing
3033         the initialization in timer_add()
3034
3035 2002-01-11  Kevin L Mitchell  <klmitch@mit.edu>
3036
3037         * ircd/engine_devpoll.c (engine_loop): relocate an assertion to
3038         prevent a core bug *in* the assertion
3039
3040         * doc/readme.features: document new POLLS_PER_LOOP feature; change
3041         documentation to reflect that OPER_SET now defaults to FALSE
3042
3043         * doc/p10.html: documented the new ACCOUNT stuff
3044
3045         * doc/example.conf: document new POLLS_PER_LOOP default; change
3046         default for OPER_SET
3047
3048         * RELEASE.NOTES: changed documentation to reflect the fact that
3049         assertions are now enabled by default and do not cause memory
3050         leaks
3051
3052         * ircd/res.c (make_cache): removed a bogus assertion we probably
3053         never caught because assertions haven't been enabled on production
3054         servers for any length of time before
3055
3056         * ircd/engine_devpoll.c (engine_loop): ditto for POLLS_PER_DEVPOLL
3057
3058         * ircd/engine_kqueue.c (engine_loop): stupid me forgot one
3059         instance of POLLS_PER_KQUEUE
3060
3061         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
3062
3063         * ircd/s_bsd.c (client_timer_callback): only clear the
3064         FREEFLAG_TIMER flag when the timer is being destroyed
3065
3066         * ircd/ircd_features.c: create a new feature, POLLS_PER_LOOP, and
3067         default it to 200; turn OPER_SET off by default
3068
3069         * ircd/engine_kqueue.c: dynamically allocate and reallocate the
3070         array of events to obtain from the kernel
3071
3072         * ircd/engine_devpoll.c: dynamically allocate and reallocate the
3073         array of events to obtain from the kernel
3074
3075         * include/ircd_features.h: add a new feature for tuning how many
3076         events to get from the kernel, for engines that support that
3077
3078         * ircd/Makefile.in: re-run make depend to correct dependancies
3079
3080         * ircd/m_who.c: remove unneeded inclusion of list.h
3081
3082         * ircd/ircd_events.c: remove unneeded inclusion of list.h
3083
3084         * ircd/whocmds.c (do_who): hide server name in /who unless
3085         requester is an operator; simplify hop count insertion
3086
3087         * ircd/s_misc.c (exit_one_client): make sure client's snomask is
3088         cleared
3089
3090         * ircd/parse.c: use mo_version and mo_admin when opers do /version
3091         or /admin
3092
3093         * ircd/m_whowas.c (m_whowas): use HEAD_IN_SAND_SERVERNAME instead
3094         of the static string "*.undernet.org"
3095
3096         * ircd/m_version.c: only let ordinary users get version
3097         information for the server they are on
3098
3099         * ircd/m_admin.c: only let ordinary users get admin information
3100         for the server they are on
3101
3102         * ircd/channel.c (client_can_send_to_channel): check is_banned()
3103         before letting the client speak on a channel s/he is not on
3104
3105         * include/supported.h: add NETWORK to feature list
3106
3107         * include/handlers.h: declare mo_admin() and mo_version()
3108
3109 2002-01-10  Kevin L Mitchell  <klmitch@mit.edu>
3110
3111         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
3112
3113         * ircd/s_debug.c (count_memory): conditionalize on MDEBUG instead
3114         of !NDEBUG
3115
3116         * ircd/m_stats.c: conditionalize /stats M on MDEBUG instead of
3117         !NDEBUG
3118
3119         * ircd/ircd_alloc.c: conditionalize on MDEBUG instead of on
3120         !NDEBUG
3121
3122         * ircd/fda.c: conditionalize on MDEBUG instead of on !NDEBUG
3123
3124         * ircd/Makefile.in: run make depend on chkconf.c as well
3125
3126         * include/ircd_alloc.h: instead of conditionalizing on !NDEBUG,
3127         conditionalize on MDEBUG
3128
3129         * include/fda.h: instead of conditionalizing on !NDEBUG,
3130         conditionalize on MDEBUG
3131
3132         * configure: rebuild configure script
3133
3134         * configure.in: enable assertion checking by default, since we
3135         have now decoupled memory debugging from the NDEBUG macro
3136
3137         * ircd/s_user.c (set_nick_name): remove calls to
3138         verify_client_list()
3139
3140         * ircd/s_misc.c (exit_one_client): remove calls to
3141         verify_client_list()
3142
3143         * ircd/s_conf.c (rehash): remove calls to verify_client_list()
3144
3145         * ircd/m_who.c (m_who): remove calls to verify_client_list()
3146
3147         * ircd/list.c: remove calls to verify_client_list(); keep
3148         verify_client_list() around just in case we ever need it again,
3149         but never compile it in
3150
3151         * ircd/ircd_events.c (event_execute): remove calls to
3152         verify_client_list()
3153
3154         * ircd/client.c (client_get_ping): remove calls to
3155         verify_client_list()
3156
3157         * include/list.h (send_listinfo): remove temporary debugging
3158         function verify_client_list()
3159
3160         * ircd/uping.c: don't die if the event type is ET_ERROR in socket
3161         callback functions
3162
3163         * ircd/res.c (res_callback): don't die if the event type is
3164         ET_ERROR
3165
3166         * ircd/listener.c (accept_connection): don't die if the event type
3167         is ET_ERROR
3168
3169 2002-01-09  Kevin L Mitchell  <klmitch@mit.edu>
3170
3171         * ircd/s_user.c (set_nick_name): bracket call to
3172         add_client_to_list() with calls to verify_client_list()
3173
3174         * include/patchlevel.h (PATCHLEVEL): bump patchlevel (again)
3175
3176         * ircd/list.c (verify_client_list): add a probabilistic loop
3177         detector: for every client added, there is a 2% probability that
3178         it will be used to replace the value of sentinel; if at any time,
3179         sentinel is found again, we know we're in a loop
3180
3181         * ircd/ircd_events.c (event_execute): add verify_client_list()
3182         calls wrapping event_execute; at the very least, I'll figure out
3183         what event the corruption occurred in
3184
3185         * ircd/list.c: moved verify_client_list() to try to keep it from
3186         being inlined
3187
3188         * ircd/Makefile.in (version.c): version.c wasn't dependant on
3189         version.h and patchlevel.h, like it was supposed to be
3190
3191         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
3192
3193         * ircd/s_auth.c (destroy_auth_request): overload send_reports
3194         argument to also indicate whether or not to call
3195         release_auth_client() and thereby enter the client into the linked
3196         list
3197
3198         * ircd/engine_devpoll.c (engine_loop): remove bogus assertion
3199
3200         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
3201
3202         * ircd/list.c (free_client): verify that destroy_auth_request()
3203         didn't automagically re-add us to the list; we might have to think
3204         about this interaction more carefully, actually
3205
3206         * ircd/s_auth.c (auth_kill_client): zero the auth pointer before
3207         calling free_client(); otherwise, free_client() will try to free
3208         the auth by calling destroy_auth_request(), which will call
3209         add_client_to_list()
3210
3211         * ircd/s_misc.c (exit_one_client): liberally sprinkle calls to
3212         verify_client_list() around to catch any corruption that might
3213         occur here
3214
3215         * ircd/s_conf.c (rehash): liberally sprinkle calls to
3216         verify_client_list() here, since this is about the only routine I
3217         can think of that could cause the "core on kill -HUP" bug
3218
3219         * ircd/m_who.c: sprinkle calls to verify_client_list() around
3220         liberally, since we've seen crashes here; temporarily include the
3221         otherwise unneeded list.h header
3222
3223         * ircd/list.c: sprinkle calls to verify_client_list() around quite
3224         liberally; add debugging asserts to list manipulation functions to
3225         catch strange settings for next and prev pointers; define
3226         verify_client_list(), which walks the client list and verifies
3227         that everything is as it's supposed to be
3228
3229         * ircd/client.c: wrap client_get_ping with calls to
3230         verify_client_list() to see if that's where we're dying
3231
3232         * include/patchlevel.h (PATCHLEVEL): bump to 03
3233
3234         * include/list.h: declare verify_client_list() if DEBUGMODE
3235         enabled; otherwise, define it to be empty
3236
3237 2002-01-08  Kevin L Mitchell  <klmitch@mit.edu>
3238
3239         * ircd/m_quit.c (m_quit): remove an unused variable
3240
3241         * include/patchlevel.h (PATCHLEVEL): bump PATCHLEVEL to 2
3242
3243         * ircd/s_user.c: when building the user mode to send to the user,
3244         don't include +r; add an extra set of parens to squelch a warning
3245
3246         * ircd/m_quit.c (m_quit): use exit_client_msg()
3247
3248         * include/patchlevel.h (PATCHLEVEL): bump patch level, so we can
3249         keep track of who's running what version
3250
3251         * ircd/m_squit.c (ms_squit): remove debugging calls to
3252         protocol_violation()
3253
3254         * Makefile.in: change MAKEFILES to IRCD_MAKEFILES to work around a
3255         new gmake "feature" (pull-up from trunk)
3256
3257         * ircd/m_quit.c (m_quit): prefix user quits with "Quit:" (pull-up
3258         from trunk)
3259
3260 2002-01-07  Kevin L Mitchell  <klmitch@mit.edu>
3261
3262         * ircd/s_user.c: add FLAGS_ACCOUNT, represented as 'r', to the
3263         list of user modes; process account name as part of user mode in
3264         NICK decoding (set_nick_name()); add account name to usermode when
3265         building the usermode to incorporate in outgoing NICK messages
3266
3267         * ircd/s_err.c: add RPL_WHOISACCOUNT for reporting what account a
3268         user is logged in to
3269
3270         * ircd/parse.c: define the new ACCOUNT command, usable only by
3271         servers and ignored by everything else
3272
3273         * ircd/m_whois.c: report what account name is associated with a
3274         user, if any
3275
3276         * ircd/m_account.c: implement the ACCOUNT command
3277
3278         * ircd/Makefile.in: add m_account.c to the list of sources; ran
3279         make depend
3280
3281         * include/struct.h: add an account field to struct User
3282
3283         * include/numeric.h: add a reply, RPL_WHOISACCOUNT, for reporting
3284         what username a user is logged in under
3285
3286         * include/msg.h: add ACCOUNT command and token (AC)
3287
3288         * include/ircd_defs.h: define ACCOUNTLEN to be 12--this matches
3289         the maximum length of a username for X
3290
3291         * include/handlers.h: add declaration for ms_account()
3292
3293         * include/client.h: add FLAGS_ACCOUNT to flag when a user account
3294         name has been set; added FLAGS_ACCOUNT to SEND_UMODES; added
3295         IsAccount() and SetAccount() to manipulate the flag
3296
3297         * ircd/m_squit.c (ms_squit): if we call FindNServer() on a server
3298         name like "Amsterdam2.NL.EU.undernet.org", we get the struct
3299         Client for the server with numeric "Am", which happens to be
3300         stockholm!  To fix this, we look up the full name *first*; if that
3301         doesn't get it, *then* we look up by numeric.
3302
3303 2001-12-24  Perry Lorier <isomer@coders.net>
3304         * ircd/m_server.c: cleanups, maybe this will make the bug easier
3305         to find.
3306
3307         * ircd/m_stats.c: display maximum number of connects in an I:
3308
3309 2001-11-22  Perry Lorier  <isomer@coders.net>
3310         * ircd/m_squit.c: Bug fix in squit
3311
3312 2001-11-03  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3313         * ircd/parse.c, include/handlers.h: Give remote whois the correct
3314         handler.
3315         
3316 2001-11-01  Kevin L Mitchell  <klmitch@mit.edu>
3317
3318         * ircd/send.c: some minor white-space fiddling; recast selector
3319         test in sendwallto_group_butone() to remove a warning regarding
3320         putting & within parentheses
3321
3322         * ircd/m_create.c (ms_create): use time_t instead of int as a
3323         declaration for rate
3324
3325         * ircd/ircd_reply.c (protocol_violation): it's supposed to be
3326         WALL_DESYNCH, not CMD_DESYNCH, if I understand things right--no
3327         wonder we weren't seeing any protocol violations!
3328
3329         * include/send.h: include time.h for time_t; move WALL_* closer to
3330         the function they're used in; some white-space fiddling; add
3331         declaration of sendto_opmask_butone_ratelimited()
3332
3333         * ircd/m_squit.c (ms_squit): add protocol_violation() calls in the
3334         cases where we ignore a squit, so we aren't taken by surprise, at
3335         least...
3336
3337         * ircd/m_create.c (ms_create): Display origin server, not origin
3338         user
3339
3340         * ircd/m_create.c (ms_create): Fix "Timestamp drift" server notice
3341
3342 2001-10-31  Perry Lorier  <isomer@coders.net>
3343         * include/m_ping.c: Forward port ping bug
3344
3345 2001-10-31  Perry Lorier  <isomer@coders.net>
3346         * include/patchlevel.h: We're beta now
3347
3348 2001-10-31  Perry Lorier  <isomer@coders.net>
3349         * ircd/s_user.c: fixed hunt_server
3350
3351 2001-09-21  Perry Lorier  <isomer@coders.net>
3352         * ircd/send.c and various: replace sendcmdto_flag_butone with
3353         sendwallto_group_butone
3354
3355 2001-09-21  Vampire-  <unknown>
3356         * ircd/ircd_string.c: unique_name_vector round II.
3357
3358 2001-09-21  mbuna  <mbuna@undernet.org>
3359         * configure.in: Add support for darwin
3360
3361 2001-09-21  Perry Lorier  <isomer@coders.net>
3362         * ircd/s_user.c I'm stupid, s/acptr/from/, Hektik pointed it out
3363
3364 2001-09-20  Perry Lorier  <isomer@coders.net>
3365
3366         * Pullups from 2.10.10.pl16
3367         * Added some warnings, and the concept of rate limited snotices
3368
3369 2001-08-31  Kevin L Mitchell  <klmitch@mit.edu>
3370
3371         * ircd/channel.c: use "%u" to format limit arguments; use
3372         strtoul() to process limit arguments in a /mode command--note:
3373         most clients seem to truncate the integer, probably because
3374         they're using atoi, and perhaps signed ints
3375
3376 2001-08-17  Kevin L Mitchell  <klmitch@mit.edu>
3377
3378         * ircd/numnicks.c: include stdlib.h for exit()
3379
3380         * ircd/ircd_log.c: include stdlib.h for exit()
3381
3382         * ircd/ircd_events.c: include stdlib.h for exit()
3383
3384         * ircd/s_stats.c: remove description of /stats v, since it's gone
3385
3386         * ircd/m_wallops.c (mo_wallops): add "*" to the beginning of
3387         /wallops to distinguish wallops from wallusers
3388
3389         * ircd/m_error.c (mr_error): ignore ERROR from clients that aren't
3390         in the "handshake" or "connecting" states--I think the latter will
3391         never happen, but...
3392
3393         * doc/Authors: apply delete's Authors patch
3394
3395         * RELEASE.NOTES: rewrite RELEASE.NOTES, basing it a little on
3396         Braden's version
3397
3398         * README: rewrite README
3399
3400 2001-07-31  Kevin L. Mitchell  <klmitch@mit.edu>
3401
3402         * ircd/s_serv.c (server_estab): remove unused variable split
3403
3404         * ircd/parse.c: add mr_error to the parse table
3405
3406         * ircd/m_error.c (mr_error): add mr_error() to handle ERRORs from
3407         unregistered connections--if IsUserPort() is true, the ERROR is
3408         ignored, otherwise, the message is saved
3409
3410 2001-07-28  Kevin L. Mitchell  <klmitch@mit.edu>
3411
3412         * ircd/m_kill.c (ms_kill): another minor typo *sigh*
3413
3414         * ircd/s_user.c (send_supported): oops, minor typo...
3415
3416         * ircd/s_user.c: implement send_supported() to send two ISUPPORT
3417         messages containing our feature buffers; make register_user() use
3418         send_supported()
3419
3420         * ircd/s_misc.c (exit_client): make sure not to give away a remote
3421         server in the ERROR message sent to the client; if the killer is a
3422         server, we substitute our name in its place
3423
3424         * ircd/m_version.c (m_version): use send_supported() to send the
3425         ISUPPORT values to the user
3426
3427         * ircd/m_nick.c: shave nick collision kills here a bit, too, for
3428         the same reasons as for m_kill.c
3429
3430         * ircd/m_kill.c: shave kills a bit so that the results look
3431         exactly the same no matter where you are; if we didn't do this, it
3432         would be possible to map the network by looking at the differences
3433         between kills originating under various circumstances
3434
3435         * include/supported.h: split the features into two, so as to not
3436         bust the parameter count when sending the features list
3437
3438         * include/s_user.h: declare new send_supported() function to send
3439         the ISUPPORT information
3440
3441 2001-07-27  Kevin L. Mitchell  <klmitch@mit.edu>
3442
3443         * ircd/s_bsd.c: disable IP (*not* TCP) options to prevent
3444         source-routed spoofing attacks; this is only available under
3445         u2.10.11, so don't even bother, since no one but testers are using
3446         the source base
3447
3448 2001-07-25  Kevin L. Mitchell  <klmitch@mit.edu>
3449
3450         * include/ircd_policy.h: enable HEAD_IN_SAND_REMOTE by default
3451
3452         * ircd/s_err.c: put in a . for reporting link version on /trace,
3453         to match what /version does
3454
3455 2001-07-21  Kevin L. Mitchell  <klmitch@mit.edu>
3456
3457         * ircd/s_misc.c (exit_client): servers don't understand what the
3458         numeric nick ERROR is supposed to mean, so they ignore error
3459         messages, resulting in not knowing why we were rejected; use
3460         sendcmdto_one for servers and sendrawto_one for clients
3461
3462 2001-07-17  Kevin L. Mitchell  <klmitch@mit.edu>
3463
3464         * ircd/m_burst.c (ms_burst): in the case of a modeless channel and
3465         a nick collide, a bare BURST may be propagated; adjust the
3466         enforced parameter count to accept the bare BURST
3467
3468 2001-07-12  Kevin L. Mitchell  <klmitch@mit.edu>
3469
3470         * ircd/s_bsd.c: mark a client as having been IP checked
3471
3472         * ircd/IPcheck.c (ip_registry_check_remote): remove unneeded
3473         second call to SetIPChecked()
3474
3475 2001-07-11  Kevin L. Mitchell  <klmitch@mit.edu>
3476
3477         * ircd/engine_poll.c: deal with POLLHUP properly (hopefully)
3478
3479         * ircd/engine_devpoll.c: deal with POLLHUP properly (hopefully)
3480
3481 2001-07-09  Kevin L. Mitchell  <klmitch@mit.edu>
3482
3483         * ircd/os_bsd.c (os_get_rusage): move buf into the two ifdef'd
3484         sections so that if neither is used, the declaration of buf will
3485         not elicit an "unused variable" warning under NetBSD
3486
3487         * ircd/m_map.c: include string.h to declare strcpy (fix warnings
3488         on alpha)
3489
3490         * ircd/m_away.c: include string.h to declare strcpy/strlen (fix
3491         warnings on alpha)
3492
3493         * ircd/ircd_log.c: include string.h to declare strcpy/strlen (fix
3494         warnings on alpha)
3495
3496         * ircd/client.c: include string.h to declare memset (fix warnings
3497         on alpha)
3498
3499         * ircd/channel.c: remove unused functions next_overlapped_ban,
3500         del_banid, and is_deopped (fix warnings under -O1)
3501
3502         * ircd/IPcheck.c: include string.h to declare memset/memcpy (fix
3503         warnings on alpha)
3504
3505 2001-06-29  Kevin L. Mitchell  <klmitch@mit.edu>
3506
3507         * ircd/s_user.c (set_user_mode): clear the snomask if the user
3508         isn't supposed to receive server notices anymore
3509
3510         * ircd/ircd_features.c: change CONFIG_OPERCMDS to default to FALSE
3511
3512         * configure.in: use AC_MSG_CHECKING/AC_MSG_RESULT when checking
3513         installation prefix; default devpoll and kqueue to on (they get
3514         turned off if the required headers aren't present)
3515
3516         * ircd/whocmds.c (do_who): use ircd_snprintf() instead of
3517         sprintf_irc(); it's a bit hackish, but it'll do for now
3518
3519         * ircd/support.c: remove unused #include
3520
3521         * ircd/send.c: remove unused #include
3522
3523         * ircd/s_user.c: use ircd_snprintf() instead of sprintf_irc()
3524
3525         * ircd/s_serv.c: remove unused #include
3526
3527         * ircd/s_misc.c: use ircd_snprintf() and friends instead of
3528         sprintf_irc() and friends
3529
3530         * ircd/s_err.c: moved atoi_tab[] from ircd/sprintf_irc.c to
3531         ircd/s_err.c, which is the only other file to refer to it
3532
3533         * ircd/s_conf.c (conf_add_deny): use ircd_snprintf() instead of
3534         sprintf_irc()
3535
3536         * ircd/s_bsd.c (connect_server): use ircd_snprintf() instead of
3537         sprintf_irc()
3538
3539         * ircd/s_auth.c: use ircd_snprintf() instead of sprintf_irc()
3540
3541         * ircd/res.c: use ircd_snprintf() instead of sprintf_irc()
3542
3543         * ircd/m_version.c: use ircd_snprintf() instead of sprintf_irc()
3544
3545         * ircd/m_kill.c: use ircd_snprintf() instead of sprintf_irc()
3546
3547         * ircd/listener.c: use ircd_snprintf() instead of sprintf_irc()
3548
3549         * ircd/gline.c: use ircd_snprintf() instead of sprintf_irc()
3550
3551         * ircd/channel.c: don't include sprintf_irc.h; use ircd_snprintf()
3552         instead of sprintf_irc()
3553
3554         * ircd/Makefile.in: remove sprintf_irc.c from sources list; run
3555         make depend
3556
3557         * include/ircd_string.h: remove declaration of sprintf_irc() (what
3558         was it doing here anyway?)
3559
3560         * include/sprintf_irc.h: removed unneeded source file
3561
3562         * ircd/sprintf_irc.c: removed unneeded source file
3563
3564         * ircd/s_debug.c (count_memory): remove some dead code
3565
3566         * ircd/s_auth.c: remove some dead code
3567
3568         * ircd/res.c (update_list): remove some dead code
3569
3570         * ircd/m_whowas.c: remove some dead code
3571
3572         * ircd/m_whois.c: remove some dead code
3573
3574         * ircd/m_who.c: remove some dead code
3575
3576         * ircd/m_wallusers.c: remove some dead code
3577
3578         * ircd/m_wallops.c: remove some dead code
3579
3580         * ircd/m_wallchops.c: remove some dead code
3581
3582         * ircd/m_version.c: remove some dead code
3583
3584         * ircd/m_userip.c: remove some dead code
3585
3586         * ircd/m_userhost.c: remove some dead code
3587
3588         * ircd/m_uping.c: remove some dead code
3589
3590         * ircd/m_trace.c: remove some dead code
3591
3592         * ircd/m_topic.c: remove some dead code
3593
3594         * ircd/m_tmpl.c: remove some dead code
3595
3596         * ircd/m_time.c: remove some dead code
3597
3598         * ircd/m_squit.c: remove some dead code
3599
3600         * ircd/m_silence.c: remove some dead code
3601
3602         * ircd/m_settime.c: remove some dead code
3603
3604         * ircd/m_set.c: remove some dead code
3605
3606         * ircd/m_server.c: remove some dead code
3607
3608         * ircd/m_rpong.c: remove some dead code
3609
3610         * ircd/m_rping.c: remove some dead code
3611
3612         * ircd/m_restart.c: remove some dead code
3613
3614         * ircd/m_reset.c: remove some dead code
3615
3616         * ircd/m_rehash.c: remove some dead code
3617
3618         * ircd/m_quit.c: remove some dead code
3619
3620         * ircd/m_proto.c: remove some dead code
3621
3622         * ircd/m_privs.c: remove some dead code
3623
3624         * ircd/m_privmsg.c: remove some dead code
3625
3626         * ircd/m_pong.c: remove some dead code
3627
3628         * ircd/m_ping.c: remove some dead code
3629
3630         * ircd/m_pass.c: remove some dead code
3631
3632         * ircd/m_part.c: remove some dead code
3633
3634         * ircd/m_opmode.c: remove some dead code
3635
3636         * ircd/m_oper.c: remove some dead code
3637
3638         * ircd/m_notice.c: remove some dead code
3639
3640         * ircd/m_nick.c: remove some dead code
3641
3642         * ircd/m_map.c: remove some dead code
3643
3644         * ircd/m_lusers.c: remove some dead code
3645
3646         * ircd/m_list.c: remove some dead code
3647
3648         * ircd/m_links.c: remove some dead code
3649
3650         * ircd/m_kill.c: remove some dead code
3651
3652         * ircd/m_kick.c: remove some dead code
3653
3654         * ircd/m_jupe.c: remove some dead code
3655
3656         * ircd/m_join.c: remove some dead code
3657
3658         * ircd/m_ison.c: remove some dead code
3659
3660         * ircd/m_invite.c: remove some dead code
3661
3662         * ircd/m_info.c: remove some dead code
3663
3664         * ircd/m_help.c: remove some dead code
3665
3666         * ircd/m_gline.c: remove some dead code
3667
3668         * ircd/m_get.c: remove some dead code
3669
3670         * ircd/m_error.c: remove some dead code
3671
3672         * ircd/m_endburst.c: remove some dead code
3673
3674         * ircd/m_die.c: remove some dead code
3675
3676         * ircd/m_desynch.c: remove some dead code
3677
3678         * ircd/m_destruct.c: remove some dead code
3679
3680         * ircd/m_defaults.c: remove some dead code
3681
3682         * ircd/m_create.c: remove some dead code, along with an #if 1
3683
3684         * ircd/m_cprivmsg.c: remove some dead code
3685
3686         * ircd/m_connect.c: remove some dead code
3687
3688         * ircd/m_close.c: remove some dead code
3689
3690         * ircd/m_clearmode.c: remove some dead code
3691
3692         * ircd/m_burst.c: remove some dead code
3693
3694         * ircd/m_away.c: remove some dead code
3695
3696         * ircd/m_admin.c: remove some dead code
3697
3698         * ircd/listener.c (accept_connection): remove some dead code
3699
3700         * ircd/ircd_reply.c (need_more_params): remove some dead code
3701
3702         * ircd/channel.c (add_banid): remove some dead code
3703
3704         * include/support.h: remove some dead code
3705
3706         * include/querycmds.h: remove some dead code
3707
3708         * doc/readme.chroot: document how to do chroot operation
3709
3710 2001-06-28  Kevin L. Mitchell  <klmitch@mit.edu>
3711
3712         * ircd/Makefile.in: tune for VPATH builds/installs; add a rule to
3713         force bin directory to be created if necessary prior to
3714         installation; run make depend
3715
3716         * doc/Makefile.in (install): tune for VPATH installs by cd'ing to
3717         the ${srcdir}
3718
3719         * Makefile.in: tune to detect Makefile.in changes in
3720         subdirectories and to create installation directory indicated by
3721         ${prefix}
3722
3723         * ircd/whocmds.c (count_users): routine to count the number of
3724         users matching a given user@host mask
3725
3726         * ircd/s_err.c: add error messages for ERR_LONGMASK,
3727         ERR_TOOMANYUSERS, and ERR_MASKTOOWIDE
3728
3729         * ircd/m_gline.c: look for and advance past '!' flag on G-lines
3730         from operators; only set GLINE_OPERFORCE flag if oper has the
3731         PRIV_WIDE_GLINE privilege
3732
3733         * ircd/ircd_features.c: add GLINEMAXUSERCOUNT, which is the
3734         maximum number of users a G-line can impact before it has to be
3735         forced; OPER_WIDE_GLINE, to allow operators to use ! to force a
3736         wide G-line to be set; and LOCOP_WIDE_GLINE, to allow local
3737         operators to use ! to force a wide G-line to be set
3738
3739         * ircd/gline.c: make make_gline() be called with separate user and
3740         host arguments, and not call canon_userhost() directly; implement
3741         gline_checkmask() to verify that a host mask is acceptable; move
3742         BADCHAN check up in gline_add(), and check passed-in mask under
3743         certain circumstances for acceptability; fix call to
3744         sendto_opmask_butone() to handle separation of userhost into user
3745         and host in gline_add(); update call to make_gline()
3746
3747         * ircd/client.c: use FEAT_OPER_WIDE_GLINE and
3748         FEAT_LOCOP_WIDE_GLINE to set PRIV_WIDE_GLINE for an operator; add
3749         PRIV_WIDE_GLINE to privtab[] for client_report_privs()
3750
3751         * include/whocmds.h (count_users): declare routine to count users
3752         matching a given user@host mask
3753
3754         * include/numeric.h: added three new error returns: ERR_LONGMASK
3755         -- mask can't be formatted into a buffer; ERR_TOOMANYUSERS -- too
3756         many users would be impacted by the mask; ERR_MASKTOOWIDE -- mask
3757         contains wildcards in the wrong places
3758
3759         * include/ircd_features.h: add FEAT_GLINEMAXUSERCOUNT,
3760         FEAT_OPER_WIDE_GLINE, and FEAT_LOCOP_WIDE_GLINE
3761
3762         * include/gline.h (GLINE_OPERFORCE): provides a way for m_gline()
3763         to signal to gline_add() that the operator attempted to force the
3764         G-line to be set
3765
3766         * include/client.h (PRIV_WIDE_GLINE): new privilege for operators
3767
3768         * doc/readme.gline: update to document new "!" prefix to a G-line
3769         user@host mask
3770
3771         * doc/readme.features: document GLINEMAXUSERCOUNT,
3772         OPER_WIDE_GLINE, and LOCOP_WIDE_GLINE
3773
3774         * doc/example.conf: update to mention new features along with
3775         their defaults
3776
3777 2001-06-27  Kevin L. Mitchell  <klmitch@mit.edu>
3778
3779         * doc/example.conf: updated example.conf from Braden
3780         <dbtem@yahoo.com>
3781
3782         * include/supported.h: forward-port from pl15
3783
3784 2001-06-25  Kevin L. Mitchell  <klmitch@mit.edu>
3785
3786         * ircd/whocmds.c: include ircd_policy.h and implement
3787         HEAD_IN_SAND_WHO_OPCOUNT--forward-port from pl15
3788
3789         * ircd/m_whois.c: forward-port of the idle-time hiding code from
3790         pl15; this also required passing parc into do_whois(), which also
3791         meant passing parc into do_wilds()--*sigh*
3792
3793         * include/ircd_policy.h: add a couple more HEAD_IN_SAND
3794         #define's--WHOIS_IDLETIME and WHO_HOPCOUNT
3795
3796 2001-06-22  Kevin L. Mitchell  <klmitch@mit.edu>
3797
3798         * tools/wrapper.c: add a wrapper program that can be used to
3799         adjust file descriptor limits and root directories; program must
3800         be run as root--NOT SETUID!--and given appropriate -u arguments
3801
3802         * doc/readme.log: documentation of how to configure logging
3803
3804         * doc/readme.features: documentation of each feature (except for
3805         logging)
3806
3807 2001-06-21  Kevin L. Mitchell  <klmitch@mit.edu>
3808
3809         * Makefile.in (config): add a deprecation notice with a pointer to
3810         tools/transition
3811
3812         * tools/transition: shell script to convert old compile-time
3813         options into new compile-time options and appropriate F-lines
3814
3815         * tools/mkchroot: shell-script to prepare the chroot area by
3816         copying over all the necessary libraries so they can be found
3817
3818 2001-06-20  Kevin L. Mitchell  <klmitch@mit.edu>
3819
3820         * INSTALL: partial update of INSTALL for u2.10.11 release...
3821
3822 2001-06-14  Kevin L. Mitchell  <klmitch@mit.edu>
3823
3824         * ircd/table_gen.c (makeTables): finally got tired of the
3825         "overflow in implicit conversion" warning, so just got rid of it
3826         by explicitly casting UCHAR_MAX to a (default) char; diffs show no
3827         differences in the tables generated
3828
3829 2001-06-11  Kevin L. Mitchell  <klmitch@mit.edu>
3830
3831         * ircd/send.c (sendcmdto_match_butone): don't let the server crash
3832         if a client is in the STAT_CONNECTING status
3833
3834 2001-06-10  Kevin L. Mitchell  <klmitch@mit.edu>
3835
3836         * ircd/send.c: remove unused vsendcmdto_one(), consolidating it
3837         into sendcmdto_one(); define new sendcmdto_prio_one(), which
3838         places the message into the priority queue
3839
3840         * ircd/s_user.c (hunt_server_prio_cmd): definition of
3841         hunt_server_prio_cmd(), which simply calls sendcmdto_prio_one()
3842         instead of sendcmdto_one()
3843
3844         * ircd/m_settime.c: use sendcmdto_prio_one() and
3845         hunt_server_prio_cmd() to send SETTIME
3846
3847         * ircd/m_server.c: use sendcmdto_prio_one() to send SETTIME
3848
3849         * include/send.h: removed declaration for unused vsendcmdto_one();
3850         added a declaration for sendcmdto_prio_one()
3851
3852         * include/s_user.h: declare hunt_server_prio_cmd(), which calls
3853         sendcmdto_prio_one()
3854
3855         * ircd/send.c (sendcmdto_flag_butone): oops; /wallops should be
3856         put in the server's priority queue, too...
3857
3858         * ircd/ircd.c: don't check LPATH for accessibility at all
3859
3860 2001-06-08  Kevin L. Mitchell  <klmitch@mit.edu>
3861
3862         * ircd/s_serv.c (server_estab): send a +h flag in our SERVER
3863         command if we're configured as a hub; send individual server flags
3864         in SERVER commands
3865
3866         * ircd/s_bsd.c (completed_connection): send a +h flag in our
3867         SERVER command if we're configured as a hub
3868
3869         * ircd/m_server.c: implement parv[7] as a mode-like string; +h
3870         sets the FLAGS_HUB flag for a server; +s sets the FLAGS_SERVICE
3871         flag for a server; +hs sets both flags; also modify CMD_SERVER
3872         format string to send the flags
3873
3874         * include/client.h: define two new flags, FLAGS_HUB and
3875         FLAGS_SERVICE to mark services and hubs as such; define testing
3876         macros, setting macros
3877
3878         * ircd/s_user.c: remove deprecated struct Gline* argument to
3879         register_user(); remove GLINE rebroadcast; do not send GLINE
3880         acknowledgement parameter to NICK; do not look for GLINE
3881         acknowledgement parameter to NICK while parsing
3882
3883         * ircd/s_serv.c (server_estab): remove deprecated struct Jupe*
3884         argument to server_estab(); do not send JUPE/GLINE acknowledgement
3885         parameters for SERVER or NICK
3886
3887         * ircd/m_user.c (m_user): remove deprecated argument to
3888         register_user()
3889
3890         * ircd/m_server.c: remove deprecated argument to server_estab();
3891         remove documentation comment regarding JUPE acknowledgement
3892         parameter to SERVER; remove JUPE rebroadcast
3893
3894         * ircd/m_pong.c (mr_pong): remove deprecated argument to
3895         register_user()
3896
3897         * ircd/m_nick.c: remove documentation comment regarding GLINE
3898         acknowledgement parameter to NICK
3899
3900         * ircd/jupe.c: use user's real name in JUPE server notices if
3901         HEAD_IN_SAND_SNOTICES is defined
3902
3903         * ircd/ircd.c: remove deprecated chroot() code; remove deprecated
3904         setuid code; correct ancient DEBUG vs DEBUGMODE typo
3905
3906         * ircd/gline.c: use user's real name in GLINE server notices if
3907         HEAD_IN_SAND_SNOTICES is defined
3908
3909         * ircd/channel.c (modebuf_flush_int): make apparent source be
3910         local server, not oper's server; use user's real name in hack
3911         notices and DESYNC notices if HEAD_IN_SAND_SNOTICES is defined
3912
3913         * include/s_user.h: remove struct Gline pre-declaration; remove
3914         deprecated struct Gline argument from register_user()
3915
3916         * include/s_serv.h: remove struct Jupe pre-declaration; remove
3917         deprecated struct Jupe argument from server_estab()
3918
3919 2001-06-07  Kevin L. Mitchell  <klmitch@mit.edu>
3920
3921         * ircd/s_stats.c (hunt_stats): forward-port from pl15 of all the
3922         changes required to control remote stats
3923
3924         * ircd/s_numeric.c (do_numeric): rewrite numeric origins if
3925         recipient is not an operator and HEAD_IN_SAND_REWRITE is defined
3926         [forward-port from pl15]
3927
3928         * ircd/m_whowas.c (m_whowas): report server name only if requester
3929         is an operator [forward-port from pl15]
3930
3931         * ircd/m_whois.c (do_whois): /whois <mynick> now correctly reports
3932         my server; if HEAD_IN_SAND_REMOTE is 1, ignore the middle argument
3933         and obtain the report from the user's server [forward-port from
3934         pl15]
3935
3936         * ircd/m_who.c: add missing include for ircd_policy.h
3937         [forward-port from pl15]
3938
3939         * ircd/m_version.c (m_version): require oper access for remote
3940         /version if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
3941
3942         * ircd/m_time.c (m_time): require oper access for remote /time if
3943         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
3944
3945         * ircd/m_stats.c: pass extra argument to hunt_stats(); correct
3946         missing semicolon [forward-port from pl15]
3947
3948         * ircd/m_nick.c (ms_nick): hide the origin of certain collision
3949         kills [forward-port from pl15]
3950
3951         * ircd/m_motd.c (m_motd): require oper access for remote /motd if
3952         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
3953
3954         * ircd/m_lusers.c (m_lusers): require oper access for remote
3955         /lusers if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
3956
3957         * ircd/m_burst.c (ms_burst): server-added bans are stored using
3958         local server name, to hide remote server names; modes also are to
3959         originate from the local server [forward-port from pl15]
3960
3961         * ircd/m_admin.c (m_admin): require oper access for remote /admin
3962         if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
3963
3964         * ircd/channel.c (add_banid): if a server is adding a ban, use my
3965         server name to hide the remote server's name [forward-port from
3966         pl15]
3967
3968         * ircd/Makefile.in: ran make depend
3969
3970         * include/s_stats.h: hunt_stats() has to have an extra argument to
3971         support the forward-port from pl15
3972
3973         * include/ircd_policy.h: #define HEAD_IN_SAND_STATS_P; add
3974         HEAD_IN_SAND_{BANWHO,REWRITE,REMOTE} [forward-port from pl15]
3975
3976         * ircd/engine_poll.c (engine_loop): remove bogus assert that I
3977         forgot to check in the events branch
3978
3979 2001-06-06  Kevin L. Mitchell  <klmitch@mit.edu>
3980
3981         * ircd/res.c (init_resolver): don't start DNS expires with a 0
3982         relative timeout--if the server starts slow, timeouts could be
3983         messy...there's probably a better solution, but this'll do for now
3984
3985         * ircd/os_solaris.c: _XOPEN_SOURCE doesn't get along with Solaris
3986         headers very well; include stropts.h; define an os_set_tos()
3987
3988         * ircd/os_generic.c (os_set_tos): added an os_set_tos() for
3989         os_generic.c
3990
3991         * ircd/ircd.c: if there are no C-lines, we don't want to have a
3992         timer that expires at the absolute time of 0--it kinda blocks all
3993         the other timers!
3994
3995         * ircd/engine_devpoll.c: some includes for open(); declare errcode
3996         and codesize in engine_loop()
3997
3998         * ircd/list.c (free_client): remove bogus check on timer active
3999         flag
4000
4001         * ircd/s_auth.c: pull out destruction code in
4002         auth_timeout_request() into an externally-visible
4003         destroy_auth_request(); manage cli_auth pointer in client
4004         structure; use it for an extra assertion check
4005
4006         * ircd/list.c: include s_auth.h for destroy_auth_request(); add
4007         debugging notices to show flow when deallocating
4008         connections/clients; call destroy_auth_request() when free'ing a
4009         client that has an auth outstanding; don't free the connection if
4010         the process timer is unmarked but still active
4011
4012         * ircd/ircd_events.c: set GEN_ACTIVE when initializing a generator
4013         and reset it before calling the event handler for an ET_DESTROY
4014         event
4015
4016         * include/s_auth.h (destroy_auth_request): declare
4017         destroy_auth_request(), which can be used to destroy an
4018         outstanding auth request if a client socket goes away before the
4019         auth exchange is completed
4020
4021         * include/ircd_events.h: add an active flag to keep track of
4022         whether or not particular generators are active, for the
4023         convenience of functions using the API
4024
4025         * include/client.h: add a pointer for auth requests to struct
4026         Connection so we can kill outstanding auth requests if a client
4027         socket closes unexpectedly
4028
4029         * ircd/s_bsd.c: cli_connect() could become 0 during the course of
4030         the sock or timer callback; take that into account in the assert
4031
4032         * ircd/list.c: add magic number checking and setting--magic
4033         numbers are zero'd on frees to detect double-frees; add back
4034         setting of cli_from() to 0 to break the back-link from the struct
4035         Connection (duh)
4036
4037         * ircd/ircd.c: set me's magic number correctly
4038
4039         * include/client.h: define magic numbers and accessor/verifier
4040         macros
4041
4042         * ircd/list.c: assert that dealloc_client() is called with
4043         cli_connect(cptr) == 0; set cli_connect(cptr) to 0 before calling
4044         dealloc_client(); don't mess with cli_from(cptr)
4045
4046         * ircd/s_bsd.c: only attempt to dealloc a connection if the
4047         associated client has already been destroyed, or at least delinked
4048
4049 2001-06-05  Kevin L. Mitchell  <klmitch@mit.edu>
4050
4051         * ircd/list.c (free_client): only try to delete the socket when
4052         the fd hasn't already been closed, avoiding a double-free
4053
4054         * ircd/list.c (free_connection): make sure the client is really
4055         gone before doing away with the connection
4056
4057         * ircd/s_bsd.c: record that socket has been added in con_freeflag
4058         field; queue a socket_del() as soon as the socket is close()'d;
4059         use con_freeflag & FREEFLAG_TIMER instead of con_timer; clear
4060         FREEFLAG_SOCKET on ET_DESTROY event in client_sock_callback(),
4061         then dealloc the connection if safe; mark socket as dead when
4062         there's a read error or EOF; clear FREEFLAG_TIMER flag upon entry
4063         to client_timer_callback(); dealloc connection if safe upon
4064         ET_DESTROY event in client_timer_callback()
4065
4066         * ircd/list.c: use con_freeflag instead of con_timer; only dealloc
4067         the connection if both socket and timer have been destroyed;
4068         destroy both socket and timer explicitly and carefully
4069
4070         * include/client.h: replace the con_timer field with a
4071         con_freeflag field, to indicate what still needs freeing; define
4072         the freeflags
4073
4074         * ircd/engine_select.c (engine_loop): duh...sockList[i] could
4075         become 0
4076
4077         * ircd/engine_devpoll.c (engine_loop): duh...sockList[i] could
4078         become 0
4079
4080         * ircd/s_bsd.c: add some extra assertions to try to track down a
4081         corruption problem
4082
4083         * ircd/engine_select.c (engine_loop): add an extra assert to try
4084         to track down a corruption problem
4085
4086         * ircd/engine_poll.c (engine_loop): add an extra assert to try to
4087         track down a corruption problem
4088
4089         * ircd/engine_kqueue.c (engine_loop): add an extra assert to try
4090         to track down a corruption problem
4091
4092         * ircd/engine_devpoll.c (engine_loop): skip slots that have become
4093         empty during processing; add an extra assert to try to track down
4094         a corruption problem
4095
4096         * ircd/engine_kqueue.c (engine_delete): make sure to zero deleted
4097         entries
4098
4099 2001-06-04  Kevin L. Mitchell  <klmitch@mit.edu>
4100
4101         * ircd/s_bsd.c (client_sock_callback): client is no longer
4102         blocked, so we must mark it as unblocked
4103
4104         * ircd/engine_select.c: add Debug() calls galore; add handling for
4105         SS_NOTSOCK; use a dummy sock variable to keep things from
4106         disappearing on us; correct timeout calculation; update nfds for
4107         efficiency
4108
4109         * ircd/engine_poll.c: use new debugging level (DEBUG_ENGINE);
4110         remove a spurious "if (sock)" which will always be true; update
4111         nfds for efficiency
4112
4113         * ircd/engine_kqueue.c: add Debug() calls galore; add handling for
4114         SS_NOTSOCK (just in case); correct timeout calculation
4115
4116         * ircd/engine_devpoll.c: add Debug() calls galore; add handling
4117         for SS_NOTSOCK; correct timeout calculation; add EAGAIN handling
4118
4119         * include/s_debug.h (DEBUG_ENGINE): add new debugging level;
4120         pretty-indent numbers
4121
4122         * ircd/engine_poll.c (engine_loop): break out SS_NOTSOCK
4123         case--it's not a socket; the check for writability is most likely
4124         not needed, but present for completeness
4125
4126 2001-05-24  Kevin L. Mitchell  <klmitch@mit.edu>
4127
4128         * ircd/s_bsd.c: add Debug messages; call read_packet() even if the
4129         no newline flag is set; call read_packet() when the timer expires,
4130         regardless of what's in the buffer--read_packet() should be able
4131         to deal properly
4132
4133         * ircd/IPcheck.c (ip_registry_connect_succeeded): correct a NOTICE
4134         sent to clients to include the client nickname (duh)
4135
4136         * ircd/ircd_events.c: don't destroy a timer if it's already marked
4137         for destruction; replace a missing ! in socket_del()
4138
4139         * ircd/engine_poll.c (engine_loop): reference a temporary variable
4140         so we don't have to worry about sockList[i] going away
4141
4142         * ircd/s_bsd.c (client_sock_callback): add Debug messages
4143
4144         * ircd/s_auth.c: add Debug messages all over the place
4145
4146         * ircd/ircd_events.c: add and edit some Debug messages; add a list
4147         of routines to convert some of the enums and flags from numbers
4148         into human-readable strings for the Debug messages
4149
4150         * ircd/engine_poll.c: hack some Debug messages to use the new name
4151         conversion routines in ircd_events.c; add an extra assert for a
4152         condition that shouldn't ever happen; apparently recv() can return
4153         EAGAIN when poll() returns readable--I wonder why...
4154
4155         * include/ircd_events.h: declare some helper routines under
4156         DEBUGMODE
4157
4158 2001-05-23  Kevin L. Mitchell  <klmitch@mit.edu>
4159
4160         * ircd/s_bsd.c (client_sock_callback): add an extra assertion
4161         check
4162
4163         * ircd/s_auth.c: add more Debug messages
4164
4165         * ircd/list.c (make_client): add an extra assertion check
4166
4167         * ircd/ircd_events.c (socket_events): don't call the engine events
4168         changer if we haven't actually made any changes to the event mask
4169
4170         * ircd/uping.c: add some Debug messages
4171
4172         * ircd/s_stats.c: document new /STATS e
4173
4174         * ircd/s_err.c: add RPL_STATSENGINE to report the engine name
4175
4176         * ircd/s_bsd.c: remove static client_timer variable; in
4177         read_packet(), if there's still data in the client's recvQ after
4178         parsing, add a 2 second timer (con_proc); fix the ET_DESTROY case
4179         of client_sock_callback to handle destroying the timer properly;
4180         rewrote client_timer_callback from scratch to be called on an
4181         individual client
4182
4183         * ircd/m_stats.c: add /STATS e to report the engine name
4184
4185         * ircd/list.c: deal with con_timer field in struct Connection
4186         properly; correct a core-level bug in remove_client_from_list--if
4187         the client is the only one in the list, we try to update
4188         GlobalClientList's cli_prev pointer--not good
4189
4190         * ircd/ircd.c: remove call to init_client_timer()
4191
4192         * ircd/engine_poll.c: made Debug messages more uniform by
4193         prepending "poll:" to them all; corrected an off-by-one error that
4194         caused poll_count to be 1 less than the actual count and removed
4195         my work-around; added Debug messages to indicate which socket is
4196         being checked and what the results are
4197
4198         * ircd/Makefile.in: ran a make depend
4199
4200         * include/s_bsd.h: remove init_client_timer(), since we're doing
4201         it differently now
4202
4203         * include/numeric.h (RPL_STATSENGINE): a stats reply to report the
4204         engine name
4205
4206         * include/ircd_policy.h (HEAD_IN_SAND_STATS_E): turn off /stats e
4207         reports for non-opers
4208
4209         * include/client.h: add con_timer and con_proc fields to struct
4210         Connection and define accessor macros--con_timer marks that
4211         con_proc contains a valid timer, and con_proc is used to pace user
4212         data
4213
4214         * ircd/s_bsd.c (close_connection): let free_client() destroy the
4215         socket
4216
4217         * ircd/s_auth.c (start_auth): add a Debug call to indicate when
4218         auth has begun on a client
4219
4220         * ircd/ircd_events.c: ensure that event_execute() is called with a
4221         non-NULL event; modify event_add() macro to properly zero list
4222         bits; modify gen_dequeue() to not try to clip it out of a list
4223         it's already been clipped out of; change signal socket
4224         initialization to use state SS_NOTSOCK; permit timeout values of
4225         0 in add_timer(); add many Debug calls; change socket_del() and
4226         timer_del() to always set the GEN_DESTROY flag; use GEN_MARKED in
4227         timer_run() instead of GEN_DESTROY so that event_generate() will
4228         pass on the events; remove the switch and replace with a simpler
4229         if-then-else tree in timer_run(); don't allow destroyed sockets to
4230         be destroyed again, nor their states or event masks to be changed
4231
4232         * ircd/ircd.c: initialize "running" to 1
4233
4234         * ircd/engine_poll.c: deal with SS_NOTSOCK "sockets"; add Debug
4235         messages all over the place; fix a counting problem in
4236         engine_add(); turn wait into a signed integer and set it to -1
4237         only if timer_next() returns 0; adjust wait time to be relative;
4238         don't call gen_ref_dec() if socket disappeared while we were
4239         processing it
4240
4241         * include/ircd_events.h: the pipe for signals is not a socket, so
4242         we must mark it as such--added SS_NOTSOCK for that special socket;
4243         events won't be generated if GEN_DESTROY is on, so add GEN_MARKED
4244         for the benefit of timer_run()
4245
4246         * configure.in: add --enable-pedantic and --enable-warnings to
4247         turn on (and off) -Wall -pedantic in CFLAGS
4248
4249 2001-05-21  Kevin L. Mitchell  <klmitch@mit.edu>
4250
4251         * ircd/s_conf.c: change "s_addr" element accesses to "address"
4252         element accesses
4253
4254         * include/s_conf.h: on some systems, "s_addr" is a macro; use
4255         "address" instead
4256
4257 2001-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
4258
4259         * ircd/engine_kqueue.c: include ircd_alloc.h; set_or_clear returns
4260         void in this file; add a missing semi-colon; declare errcode,
4261         codesize
4262
4263         * ircd/uping.c (uping_sender_callback): it's pptr, not uping
4264
4265         * ircd/s_user.c (register_user): comment out spurious reference to
4266         nextping
4267
4268         * ircd/s_serv.c (server_estab): comment out spurious reference to
4269         nextping
4270
4271         * ircd/s_conf.c (read_configuration_file): comment out spurious
4272         reference to nextping and nextconnect
4273
4274         * ircd/s_bsd.c: comment out some spurious references to formerly
4275         global (now non-existant) variables; correct a couple of typos
4276
4277         * ircd/s_auth.c: pre-declare some functions referenced in the
4278         callback; correct a typo
4279
4280         * ircd/res.c (start_resolver): pass errno value of ENFILE
4281
4282         * ircd/listener.c (accept_connection): you know your API is messed
4283         up when...variables that shouldn't have been global crop up in
4284         other files
4285
4286         * ircd/list.c (free_client): substitution of == for =
4287
4288         * ircd/ircd_signal.c: include assert.h for assertion checking;
4289         check ev_data() to find out what signal generated event
4290
4291         * ircd/ircd_events.c: some references to the variable "timer"
4292         should have been references to the variable "ptr"
4293
4294         * ircd/engine_select.c: it's struct fd_set, not struct fdset;
4295         ev_timer(ev) is already a timer pointer; declare codesize as a
4296         size_t to correct signedness issue; use timer_next(), not
4297         time_next()
4298
4299         * ircd/engine_poll.c: ev_timer(ev) is already a timer pointer;
4300         select fd out of struct pollfd in assertion checking; declare
4301         errcode and codesize; use timer_next(), not time_next()
4302
4303         * ircd/engine_kqueue.c: ev_timer(ev) is already a timer pointer;
4304         use function timer_next(), not time_next()
4305
4306         * ircd/engine_devpoll.c: ev_timer(ev) is already a timer pointer;
4307         use function timer_next(), not time_next()
4308
4309         * ircd/Makefile.in (IRCD_SRC): add ircd_events.c to the list of
4310         compiled sources; do make depend
4311
4312         * include/list.h: pre-declare struct Connection
4313
4314         * include/ircd_events.h (gen_ref_inc): cast to the right structure
4315         name
4316
4317         * include/s_auth.h: duh; missing */
4318
4319 2001-05-10  Kevin L. Mitchell  <klmitch@mit.edu>
4320
4321         * ircd/send.c: update write events status after sending data or
4322         accumulating data to be sent
4323
4324         * ircd/m_list.c (m_list): update write events status after
4325         canceling a running /list
4326
4327         * ircd/channel.c (list_next_channels): update write events status
4328         after listing a few channels
4329
4330         * ircd/s_bsd.c: extensive changes to update to new events model;
4331         remove on_write_unblocked() and the two implementations of
4332         read_message(), which have been deprecated by this change
4333
4334         * ircd/s_auth.c: set the socket events we're interested in for
4335         clients; simplify some logic that does the connect_nonb followed
4336         by the socket_add
4337
4338         * ircd/list.c: define free_connection() to free a connection
4339         that's become freeable once the struct Socket has been
4340         deallocated; fix up free_client() to take this new behavior into
4341         account
4342
4343         * ircd/ircd.c: call init_client_timer()
4344
4345         * include/s_bsd.h: declare new REGISTER_ERROR_MESSAGE when unable
4346         to register connect-in-progress with events system; declare
4347         init_client_timer() (HACK!) to preserve rate-limiting behavior
4348
4349         * include/list.h: declare new free_connection()
4350
4351         * include/client.h: add a struct Socket to struct Connection
4352
4353 2001-05-09  Kevin L. Mitchell  <klmitch@mit.edu>
4354
4355         * ircd/ircd_signal.c: massage the handlers for SIGHUP, SIGINT, and
4356         SIGTERM into event callbacks; perform the actions in the
4357         callbacks, since they're not called in the context of the signal;
4358         set up the signal callbacks in the event engine
4359
4360         * ircd/ircd_events.c (signal_callback): we're supposed to look for
4361         a specific signal; don't generate an event if there is no signal
4362         structure for it
4363
4364         * ircd/ircd.c: nuke nextconnect and nextping and replace them with
4365         connect_timer and ping_timer; massage try_connections() and
4366         check_pings() into timer callbacks that re-add themselves at the
4367         right time; remove ircd.c's "event_loop()"; initialize the event
4368         system and the connect_timer and ping_timer
4369
4370         * ircd/uping.c: correct a couple more typos
4371
4372         * ircd/s_auth.c: rework to use new events system
4373
4374         * ircd/os_solaris.c (os_connect_nonb): update to new interface
4375
4376         * ircd/os_openbsd.c (os_connect_nonb): update to new interface
4377
4378         * ircd/os_linux.c (os_connect_nonb): update to new interface
4379
4380         * ircd/os_generic.c (os_connect_nonb): update to new interface
4381
4382         * ircd/os_bsd.c (os_connect_nonb): update to new interface
4383
4384         * include/s_auth.h: remove deprecated members of struct
4385         AuthRequest, replacing them with struct Socket and struct Timer
4386         structures; add flags to indicate when these structures have been
4387         released by the event system; remove the deprecated
4388         timeout_auth_queries()
4389
4390         * include/ircd_osdep.h (os_connect_nonb): connect could complete
4391         immediately, so change the interface to handle that possibility
4392
4393         * ircd/uping.c (uping_server): noticed and corrected a typo
4394
4395         * ircd/listener.c: set up to use ircd_event's struct Socket by
4396         adding an socket_add() call to inetport(), replacing
4397         free_listener() with socket_del() in close_listener(), and
4398         reworking accept_connection to be called as the callback
4399
4400         * ircd/ircd.c: add a call to IPcheck_init()
4401
4402         * ircd/IPcheck.c: remove IPcheck_expire(); rework
4403         ip_registry_expire() to be called from a timer; write
4404         IPcheck_init() to set up the expiration timer (hard-coded for a
4405         60-second expiration time)
4406
4407         * include/listener.h: add a struct Socket to the struct Listener;
4408         remove accept_connection()
4409
4410         * include/IPcheck.h: add IPcheck_init(), remove IPcheck_expire()
4411
4412 2001-05-08  Kevin L. Mitchell  <klmitch@mit.edu>
4413
4414         * ircd/ircd_events.c: include config.h; use USE_KQUEUE and
4415         USE_DEVPOLL instead of HAVE_KQUEUE and HAVE_DEVPOLL_H
4416
4417         * ircd/engine_select.c: include config.h; set FD_SETSIZE to
4418         MAXCONNECTIONS, not IRCD_FD_SETSIZE...
4419
4420         * ircd/engine_poll.c: include config.h
4421
4422         * ircd/engine_kqueue.c: include config.h
4423
4424         * ircd/engine_devpoll.c: include config.h
4425
4426         * ircd/Makefile.in: include engine sources in compilation and make
4427         depend steps
4428
4429         * configure.in: add checks for enabling the /dev/poll- and
4430         kqueue-based engines
4431
4432         * acconfig.h: add lines for USE_DEVPOLL and USE_KQUEUE
4433
4434         * ircd/Makefile.in: work in the engine sources
4435
4436 2001-05-07  Kevin L. Mitchell  <klmitch@mit.edu>
4437
4438         * ircd/m_settime.c: include ircd_snprintf.h
4439
4440         * ircd/ircd_relay.c: stomp a couple of gcc warnings suggesting
4441         parens around a construct that had both || and &&
4442
4443         * ircd/chkconf.c: #include "config.h" to get some important
4444         definitions
4445
4446         * ircd/Makefile.in: revamp ircd makefile for new build system
4447
4448         * doc/Makefile.in: revamp doc makefile for new build system
4449
4450         * config/*: Removed old build system files
4451
4452         * stamp-h.in: a stamp file
4453
4454         * install-sh: install-sh for new build system
4455
4456         * configure.in: configure.in for new build system
4457
4458         * configure: configure script for new build system (built by
4459         autoconf)
4460
4461         * config.sub: config.sub for new build system
4462
4463         * config.h.in: config.h.in for new build system (built by
4464         autoheader)
4465
4466         * config.guess: config.guess for new build system
4467
4468         * aclocal.m4: aclocal.m4 for new build system (built by aclocal
4469         1.4)
4470
4471         * acinclude.m4: aclocal.m4 macros for new build system
4472
4473         * acconfig.h: config.h skeleton for new build system
4474
4475         * Makefile.in: modify for new build system
4476
4477 2001-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
4478
4479         * ircd/s_err.c: get rid of the last vestiges of TIME_T_FMT
4480
4481         * ircd/m_settime.c: get rid of the last vestiges of TIME_T_FMT
4482
4483         * ircd/m_server.c: get rid of the last vestiges of TIME_T_FMT
4484
4485 2001-05-01  Perry Lorier       <Isomer@coders.net>
4486         * doc/iauth.doc: Protocol for iauth server. (from hybrid).
4487         * doc/linux-poll.patch: Patch to make Linux under 2.2 not deadlock
4488                 when you have far far too many sockets in use.
4489         * {include,ircd}/iauth.c: A start on iauth support.
4490
4491 2001-05-01  Perry Lorier       <Isomer@coders.net>
4492         * ircd/s_err.c: Suggested wording change.
4493         * ircd/s_user.c: Users aren't target limited against +k users.
4494         * ircd/chkconf.c: Made it compile again, who knows if it works, but
4495                 now I can at least make install
4496         * various: Cleanups on m_*.c files.
4497
4498
4499 2001-04-23  Kevin L. Mitchell  <klmitch@mit.edu>
4500
4501         * ircd/s_misc.c (exit_client): make netsplit server notice say the
4502         right thing
4503
4504         * ircd/m_links.c (m_links_redirect): forward-port RPL_ENDOFLINKS
4505         change to make Khaled happy...
4506
4507         * ircd/m_whois.c (do_whois): pull-up of m_whois() fix
4508         (do_whois): duh...
4509
4510 2001-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
4511
4512         * ircd/msgq.c: finally remove the msgq_integrity() hack, as it's
4513         turned up no more bugs
4514
4515         * ircd/ircd.c: use /* */ comments instead of // comments--all the
4516         world's not gcc :(
4517
4518         * ircd/s_conf.c (conf_add_server): use /* */ comments instead of
4519         // comments--all the world's not gcc :(
4520
4521         * ircd/runmalloc.c: finally garbage-collect unused file
4522
4523         * include/runmalloc.h: finally garbage-collect unused file
4524
4525         * ircd/<multiple files>: addition of '#include "config.h"' before
4526         all other includes in most .c files
4527
4528         * include/<multiple files>: remove includes of config.h, which are
4529         now going into the raw .c files
4530
4531 2001-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
4532
4533         * ircd/m_whois.c (do_whois): display proper server name if the
4534         user is looking up himself
4535
4536         * ircd/m_who.c (m_who): disable match by servername or display of
4537         server names by non-opers
4538
4539         * include/ircd_policy.h: add define for
4540         HEAD_IN_SAND_WHO_SERVERNAME to cover full intent of sub-motion 15
4541         of CFV 165
4542
4543 2001-04-18  Kevin L. Mitchell  <klmitch@mit.edu>
4544
4545         * ircd/s_conf.c: keep the $R in memory so we can see it clearly
4546         when we do a /stats k
4547
4548         * ircd/s_user.c (set_user_mode): pull-up of changes to prevent
4549         users from turning on +s and +g
4550
4551         * ircd/s_misc.c (exit_client): pull-up of changes to turn off
4552         net.split notice
4553
4554         * ircd/parse.c: pull-up of changes to disable /trace, /links, and
4555         /map for users
4556
4557         * ircd/m_whois.c (do_whois): pull-up of server name masking for
4558         /whois
4559
4560         * ircd/m_user.c (m_user): removal of umode and snomask defaulting
4561         functions, pull-up
4562
4563         * ircd/m_stats.c (m_stats): pull-up of stats-disabling stuff
4564
4565         * ircd/m_map.c (m_map_redirect): pull-up of m_map_redirect()
4566
4567         * ircd/m_links.c (m_links_redirect): pull-up of m_links_redirect()
4568
4569         * ircd/channel.c (channel_modes): pull-up of channel key display
4570         as *
4571
4572         * include/ircd_policy.h: pull-up of ircd_policy.h
4573
4574         * include/client.h: pull-up of Set/ClearServNotice()
4575
4576         * ircd/gline.c (do_gline): report client name in G-line message
4577         (pull-up)
4578
4579         * ircd/s_user.c (register_user): pull-up--show IP address in some
4580         server notices dealing only with users; report which connection
4581         class has filled up
4582
4583         * ircd/s_stats.c (report_deny_list): use conf->flags &
4584         DENY_FLAGS_IP insteaf of conf->ip_kill
4585
4586         * ircd/m_stats.c (report_klines): use conf->flags & DENY_FLAGS_IP
4587         insteaf of conf->ip_kill
4588
4589         * ircd/s_conf.c: use flags field in struct DenyConf; pull-up of
4590         K-line by real name
4591
4592         * include/s_conf.h: use a flags field in struct DenyConf; define
4593         DENY_FLAGS_FILE, DENY_FLAGS_IP, and DENY_FLAGS_REALNAME for
4594         pull-up of K-line by real name
4595
4596         * ircd/m_trace.c: pull-up of IP show for user connections
4597
4598         * doc/example.conf: pull-up of the realname K-line documentation
4599
4600         * ircd/ircd.c: forward port of pid file advisory locking mechanism
4601
4602 2001-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
4603
4604         * ircd/send.c (sendcmdto_flag_butone): recast to just broadcast to
4605         all servers, rather than to only servers that have +w/+g/whatever
4606         users on them; among other things, this removes that atrocity
4607         known as sentalong[] from this function
4608
4609         * ircd/m_admin.c: must include ircd.h to declare "me"; must
4610         include hash.h to declare FindUser()
4611
4612         * ircd/m_wallusers.c: implementation of WALLUSERS
4613
4614         * ircd/m_desynch.c (ms_desynch): only send DESYNCHs to opers
4615
4616         * ircd/m_wallops.c: only send WALLOPS to opers
4617
4618         * ircd/parse.c: add WALLUSERS command to parser table
4619
4620         * include/handlers.h: declare wallusers handlers
4621
4622         * include/msg.h: add WALLUSERS command
4623
4624         * ircd/send.c (sendcmdto_flag_butone): if FLAGS_OPER is or'd with
4625         flag, send only to appropriate opers
4626
4627 2001-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
4628
4629         * ircd/uping.c: refit to use the new events interface
4630
4631         * ircd/res.c: refit to use the new events interface
4632
4633         * ircd/ircd_events.c: create timer_chg(), which permits a
4634         (non-periodic) timer's expire time to be modified; change the
4635         logic in timer_run() so that timers that were re-added while the
4636         event was being processed will not be destroyed prematurely
4637
4638         * include/uping.h: include the events header, declare some extra
4639         fields in struct UPing, remove timeout value, and define some
4640         flags for marking which cleanup items have yet to be done
4641
4642         * include/ircd_events.h: add a prototype for timer_chg() to change
4643         the expire time of a running timer
4644
4645 2001-03-13 Joseph Bongaarts <foxxe@wtfs.net>
4646         * ircd/os_openbsd.c: Tweaked the openbsd hack a bit.
4647         
4648 2001-03-07  Joseph Bongaarts  <foxxe@wtfs.net>
4649
4650         * config/configure.in: Add check for OpenBSD
4651
4652         * ircd/os_openbsd.c: Add seperate os dep file for openbsd which
4653         differs from generic BSD, particularly in its handling of
4654         _XOPEN_SOURCE.
4655         
4656 2001-02-12  Kevin L. Mitchell  <klmitch@mit.edu>
4657
4658         * ircd/m_gline.c (ms_gline): propagate a G-line that happened to
4659         have been added by a U-lined server, rather than going through the
4660         activate/deactivate logic; propagate G-line removals by U-lined
4661         servers as well
4662
4663         * ircd/gline.c: rename propagate_gline() to gline_propagate();
4664         make gline_propagate() return an int 0 (convenience return); only
4665         update lastmod in gline_activate() and gline_deactivate() if the
4666         current lastmod is non-zero, since 0 lastmod is our flag of a
4667         U-lined server having added a G-line
4668
4669         * include/gline.h (gline_propagate): exporting the G-line
4670         propagation function
4671
4672         * ircd/m_list.c (m_list): duh; permit explicit channel name
4673         specification only when /list gets two arguments ("Kev
4674         #wasteland") rather than when /list gets more than two
4675         arguments--nice braino
4676
4677 2001-01-29  Thomas Helvey <twhelvey1@home.com>
4678
4679         * ircd/ircd_reply.c (need_more_params): fix bug that allowed
4680         unregistered clients to spam opers with protocol violation
4681         messages. Note: the bugfix may have eliminated some useful
4682         protocol violation messages.
4683         Please send protocol violation messages explicitly from the
4684         functions they are discovered in, you have much better context
4685         for the error there and it helps to document the behavior of the
4686         server. This was also a design bug in that it violated the
4687         "A function should do one thing" heuristic. Patching this one
4688         would have resulted in a continuous spawning of other bugs over
4689         the next 3 years, so I killed it. Check around for stuff this
4690         broke and readd the calls to protocol_violation in the functions
4691         that need to send the message.
4692
4693 2001-01-29  Kevin L. Mitchell  <klmitch@mit.edu>
4694
4695         * ircd/channel.c (mode_parse_ban): stopper a tiny leak--if a ban
4696         already existed, then the logic would (attempt to) skip it, but
4697         would not free the ban string; now the ban string is free'd and
4698         the ban count is decremented, releasing the ban for use
4699
4700         * ircd/s_user.c: make send_umode_out() take a prop argument
4701         instead of testing for the PRIV_PROPAGATE privilege itself; fix
4702         set_umode() to use this new argument, calculating it before
4703         calculating the new privileges for a -o'd user
4704
4705         * ircd/m_oper.c (m_oper): pass the new prop argument to
4706         send_umode_out()
4707
4708         * ircd/channel.c (mode_parse_ban): turn off MODE_ADD bit in bans
4709         that we're not actually going to add because they already exist;
4710         test that particular bit before adding to the linked list
4711
4712         * include/s_user.h: add a prop argument to send_umode_out() to
4713         indicate whether or not to propagate the user mode
4714
4715 2001-01-24  Kevin L. Mitchell  <klmitch@mit.edu>
4716
4717         * ircd/msgq.c: ircd_vsnprintf() returns the number of bytes that
4718         it would have written; upper-bound the number to prevent overflows
4719         by proxy; also, tune buffer size given to ircd_vsnprintf() to take
4720         into account the fact that ircd_vsnprintf() already takes the
4721         terminal \0 into account
4722
4723 2001-01-22  Kevin L. Mitchell  <klmitch@mit.edu>
4724
4725         * ircd/msgq.c: add an incredibly ugly hack to attempt to track
4726         down an apparent buffer overflow; remove msgq_map(), since it's no
4727         longer used anywhere; slight tweaks to prevent off-by-one errors,
4728         but these can't explain the problems we've seen
4729
4730         * include/msgq.h: remove msgq_map(), since it's no longer used
4731         anywhere
4732
4733 2001-01-18  Kevin L. Mitchell  <klmitch@mit.edu>
4734
4735         * ircd/s_user.c (set_nick_name): call client_set_privs() after
4736         parsing user modes
4737
4738 2001-01-17  Kevin L. Mitchell  <klmitch@mit.edu>
4739
4740         * ircd/s_bsd.c (read_message): fix a typo in the select version of
4741         read_message()
4742
4743         * ircd/whowas.c (whowas_free): MyFree() is a macro that expects
4744         its argument to be an lvalue, which means we can't use
4745         whowas_clean()'s handy-dandy "return ww" feature
4746
4747         * ircd/ircd_features.c: default LOCOP_KILL to TRUE--oops...
4748
4749 2001-01-16  Kevin L. Mitchell  <klmitch@mit.edu>
4750
4751         * ircd/ircd_events.c (timer_run): it's possible that the timer got
4752         deleted during the callback processing, so don't go to the bother
4753         of requeuing it if the destroy flag is set
4754
4755         * ircd/engine_select.c: define FD_SETSIZE to be IRCD_FD_SETSIZE
4756         out of config.h if this is a *BSD; include errno.h (oops);
4757         decrement error count after an hour using a timer; use FD_SETSIZE
4758         constant instead of IRCD_FD_SETSIZE constant; fill in event
4759         processing code
4760
4761         * ircd/engine_poll.c: include errno.h (oops); decrement error
4762         count after an hour using a timer; fill in event processing code
4763
4764         * ircd/engine_kqueue.c: include errno.h (oops); decrement error
4765         count after an hour using a timer; assert events filter is either
4766         EVFILT_READ or EVFILT_WRITE; fill in event processing code
4767
4768         * ircd/engine_devpoll.c: include errno.h (oops); decrement error
4769         count after an hour using a timer; fill in event processing code
4770
4771 2001-01-15  Kevin L. Mitchell  <klmitch@mit.edu>
4772
4773         * ircd/client.c: fixed feattab; basically, when I changed features
4774         to use small integers specifying bit positions, instead of the
4775         bits themselves, I forgot to update feattab to not | these
4776         privileges together; also fixed a bug in the antiprivs masking
4777         loop in client_set_privs()--last index wouldn't get parsed
4778
4779 2001-01-11  Kevin L. Mitchell  <klmitch@mit.edu>
4780
4781         * ircd/ircd_events.c: call event_generate() with new data
4782         argument; make it set that field in struct Event; make
4783         socket_add() return the value of the eng_add callback
4784
4785         * ircd/engine_select.c: make engine_add() return a
4786         successful/unsuccessful status; add bounds-checking outside of an
4787         assert; use accessor macros; use log_write(), not the deprecated
4788         ircd_log(); add an assert to engine_loop() to double-check for
4789         data structure corruption
4790
4791         * ircd/engine_poll.c: make engine_add() return a
4792         successful/unsuccessful status; add bounds-checking outside of an
4793         assert; use accessor macros; use log_write(), not the deprecated
4794         ircd_log(); add an assert to engine_loop() to double-check for
4795         data structure corruption
4796
4797         * ircd/engine_kqueue.c: implementation of an engine for kqueue()
4798
4799         * ircd/engine_devpoll.c: implementation of an engine for /dev/poll
4800
4801         * include/ircd_events.h: define some accessor macros; add ev_data
4802         to struct Event for certain important data--errno values, for
4803         instance; make EngineAdd callback tell us if it was successful or
4804         not; add extra argument to event_generate(); make socket_add()
4805         return the status from EngineAdd
4806
4807 2001-01-10  Kevin L. Mitchell  <klmitch@mit.edu>
4808
4809         * ircd/ircd_events.c: pass initializer information about how many
4810         total _filedescriptors_ may be opened at once
4811
4812         * ircd/ircd.c: use exported "running" instead of unexported
4813         thisServer.running
4814
4815         * ircd/engine_select.c: implementation of an event engine based on
4816         select()
4817
4818         * ircd/engine_poll.c: implementation of an event engine based on
4819         poll()
4820
4821         * include/ircd_events.h: pass the engine initializer an integer
4822         specifing how many _filedescriptors_ may be opened at once
4823
4824         * include/ircd.h: running has to be exported for the engine_*
4825         event loops
4826
4827 2001-01-09  Kevin L. Mitchell  <klmitch@mit.edu>
4828
4829         * ircd/ircd_events.c: include some needed headers; add some
4830         comments; make evEngines[] const; bundle sig_sock and sig_fd into
4831         a struct named sigInfo; rework struct evInfo to have a queue of
4832         _generators_, and only when threaded; added a gen_init() function
4833         to centralize generator initialization; fix various compile-time
4834         errors; rework event_add() for new queueing scheme and checked for
4835         compile-time errors; add casts where needed; spell evEngines[]
4836         correctly; make engine_name() return const char*
4837
4838         * include/ircd_events.h: type EventCallBack depends on struct
4839         Event, so pre-declare it; put _event_ queue into generators, and
4840         only when threaded; give engine data a union to store both ints
4841         and pointers; make engine name a const; fix gen_ref_dec() macro;
4842         make engine_name() return a const char*
4843
4844         * ircd/ircd_events.c: gen_dequeue() is now exported, so move it
4845         down with the non-static functions; modify event_execute() to use
4846         the new gen_ref_dec() to simplify code; make sure event_generate()
4847         does not generate new events for generators marked for destruction
4848
4849         * include/ircd_events.h: the engines, at least, may need to modify
4850         reference counts to keep generators from going away while
4851         something still points at them, so add reference counter
4852         manipulators and export gen_dequeue() for them
4853
4854         * ircd/ircd_events.c: set up the list of engines to try; set up
4855         the signal struct Socket; rename netInfo to evInfo; move static
4856         functions near the beginning of the file; do away with
4857         signal_signal() (since we no longer keep a signal count ourselves)
4858         and call event_generate() directly from signal_callback--also
4859         renamed some functions; allow signal_callback() to read up to
4860         SIGS_PER_SOCK at once from the signal pipe; add event_init() to
4861         initialize the entire event system; add event_loop() to call the
4862         engine's event loop; initialize new struct GenHeader member,
4863         gh_engdata; remove timer_next(); add socket_add() function to add
4864         a socket; add socket_del() to mark a socket for deletion; add
4865         socket_state() to transition a socket between states; add
4866         socket_events() to set what events we're interested in on the
4867         socket; add engine_name() to retrieve event engine's name
4868
4869         * include/ircd_events.h: add engine data field to struct
4870         GenHeader; rename SOCK_ACTION_REMOVE to SOCK_ACTION_DEL; add a
4871         note about states vs s_events; remove signal count; fold union
4872         Generator back into struct Event; remove count members from struct
4873         Generators; redefine engine callbacks to not take a struct
4874         Engine*; add explanatory comments to callback definitions; add
4875         some engine callbacks to handle operations; remove struct Engine
4876         flag member--can detect single flag from eng_signal member; add
4877         event_init(), event_loop(), engine_name(), and the socket_*()
4878         functions; make timer_next() a macro to avoid a function call
4879
4880 2001-01-08  Kevin L. Mitchell  <klmitch@mit.edu>
4881
4882         * include/ircd_events.h: rename to ircd_events.h, since it handles
4883         events, not just networking stuff; add signal support; more
4884         structural rearrangement
4885
4886         * ircd/ircd_events.c: rename to ircd_events.c, since it handles
4887         events, not just networking stuff; add signal support; more
4888         structural rearrangement
4889
4890 2001-01-07  Kevin L. Mitchell  <klmitch@mit.edu>
4891
4892         * ircd/ircd_network.c: implement timer API; add reference counts
4893         appropriately
4894
4895         * include/ircd_network.h: firm up some pieces of the interface;
4896         split out members everything has into a separate structure; add
4897         reference counts; add timer API
4898
4899 2001-01-06  Kevin L. Mitchell  <klmitch@mit.edu>
4900
4901         * ircd/ircd_network.c: static data and event manipulation
4902         functions for new event processing system
4903
4904         * include/ircd_network.h: data structures for new event processing
4905         system
4906
4907 2001-01-03  Kevin L. Mitchell  <klmitch@mit.edu>
4908
4909         * ircd/whowas.c: Completely re-did the old allocation scheme by
4910         turning it into a linked list, permitting the
4911         NICKNAMEHISTORYLENGTH feature to be changed on the fly
4912
4913         * ircd/s_debug.c (count_memory): use FEAT_NICKNAMEHISTORYLENGTH
4914         feature instead of old #define
4915
4916         * ircd/ircd_features.c: add NICKNAMEHISTORYLENGTH feature as an
4917         integer feature with a notify callback (whowas_realloc)
4918
4919         * ircd/client.c (client_set_privs): second memset was supposed to
4920         be over antiprivs, not privs; thanks, Chris Behrens
4921         <cbehrens@xo.com> for pointing that out...
4922
4923         * include/whowas.h: new elements for an extra linked list in
4924         struct Whowas; a notify function for feature value changes
4925
4926         * include/ircd_features.h: new feature--FEAT_NICKNAMEHISTORYLENGTH
4927
4928         * config/config-sh.in: NICKNAMEHISTORYLENGTH is now a feature
4929
4930 2001-01-02  Kevin L. Mitchell  <klmitch@mit.edu>
4931
4932         * config/config-sh.in: get rid of DEFAULT_LIST_PARAMETER
4933         compile-time option--now in features subsystem
4934
4935         * ircd/motd.c (motd_init): rework motd_init() to be called as the
4936         notify function for MPATH and RPATH features (should probably
4937         split it up a bit, though...)
4938
4939         * ircd/m_privs.c (mo_privs): if called with no parameters, return
4940         privs of the caller, rather than an error
4941
4942         * ircd/m_list.c: pull usage message into its own function; pull
4943         list parameter processing into its own function that does not
4944         modify the contents of the parameter; add list_set_default() to
4945         set the default list parameter (uses the notify hook); rework
4946         m_list() to make use of these functions; removed dead code
4947
4948         * ircd/ircd_log.c (log_feature_mark): make sure to return 0, since
4949         we have no notify handler
4950
4951         * ircd/ircd_features.c: add notify callback for notification of
4952         value changes; give mark callback an int return value to indicate
4953         whether or not to call the notify callback; fix up feature macros
4954         for new notify callback; add DEFAULT_LIST_PARAM feature; rewrite
4955         string handling in feature_set() to deal with def_str being a null
4956         pointer; wrote feature_init() to set up all defaults appropriately
4957
4958         * ircd/ircd.c (main): call feature_init() instead of
4959         feature_mark(), to avoid calling notify functions while setting up
4960         defaults
4961
4962         * ircd/client.c: updated to deal with new privileges structure
4963
4964         * ircd/class.c: updated so init_class() can be called should one
4965         of PINGFREQUENCY, CONNECTFREQUENCY, MAXIMUM_LINKS, or
4966         DEFAULTMAXSENDQLENGTH be changed
4967
4968         * include/ircd_log.h: log_feature_mark() updated to fit with new
4969         API changes
4970
4971         * include/ircd_features.h: added DEFAULT_LIST_PARAM feature and
4972         feature_init() function (found necessary since adding the notify
4973         stuff and notifying motd.c during start-up...before we defined
4974         RPATH!)
4975
4976         * include/client.h: move privs around to enable addition of more
4977         bits if necessary; based on the FD_* macros
4978
4979         * include/channel.h: declare list_set_default (actually located in
4980         m_list.c *blanche*)
4981
4982         * ircd/s_user.c: retrieve MAXSILES and MAXSILELENGTH (now
4983         AVBANLEN*MAXSILES) from features subsystem
4984
4985         * ircd/s_debug.c (debug_serveropts): CMDLINE_CONFIG doesn't go to
4986         anything anymore
4987
4988         * ircd/s_bsd.c: retrieve HANGONGOODLINK and HANGONRETRYDELAY from
4989         the features subsystem
4990
4991         * ircd/s_auth.c (start_auth): NODNS migrated to the features
4992         subsystem
4993
4994         * ircd/random.c: created random_seed_set() function to set seed
4995         value, along with some stuff to make ircrandom() a little more
4996         random--state preserving, xor of time instead of direct usage,
4997         etc.; it's still a pseudo-random number generator, though, and
4998         hopefully I haven't broken the randomness
4999
5000         * ircd/m_version.c: FEATUREVALUES makes use of feature_int() calls
5001
5002         * ircd/m_join.c: use features interface to retrieve
5003         MAXCHANNELSPERUSER
5004
5005         * ircd/ircd_features.c: add NODISP flag for super-secret features;
5006         add a whole bunch of new features migrated over from make config
5007
5008         * ircd/ircd.c: use features interface to retrieve PINGFREQUENCY,
5009         CONNECTTIMEOUT, and TIMESEC
5010
5011         * ircd/client.c (client_get_ping): use features interface to
5012         retrieve PINGFREQUENCY
5013
5014         * ircd/class.c: use features interface to retrieve PINGFREQUENCY,
5015         CONNECTFREQUENCY, MAXIMUM_LINKS, and DEFAULTMAXSENDQLENGTH
5016
5017         * ircd/chkconf.c (DEFAULTMAXSENDQLENGTH): since it's now in the
5018         features subsystem, we have to add something explicit
5019
5020         * ircd/channel.c: use features interface to retrieve
5021         KILLCHASETIMELIMIT, MAXBANLENGTH, MAXBANS, and MAXCHANNELSPERUSER;
5022         note that MAXBANLENGTH is now calculated dynamically from MAXBANS
5023         and AVBANLEN
5024
5025         * ircd/Makefile.in: run make depend
5026
5027         * include/supported.h (FEATURESVALUES): update to reference
5028         feature settings
5029
5030         * include/random.h: add prototype for random_seed_set
5031
5032         * include/ircd_features.h: add several more features
5033
5034         * include/channel.h: move MAXBANS and MAXBANLENGTH into feature
5035         subsystem
5036
5037         * config/config-sh.in: feature-ized some more stuff
5038
5039         * include/motd.h: some new elements in motd.h for motd.c changes
5040
5041         * ircd/motd.c: motd_cache() now searches a list of already cached
5042         MOTD files; saves us from having duplicate caches in memory if
5043         there are two identical T-lines for two different sites...
5044
5045 2001-01-02  Perry Lorier <isomer@coders.net>
5046         * ircd/motd.c: don't core if the motd isn't found.  Bug found by
5047         Amarande.
5048
5049 2001-01-02  Perry Lorier <isomer@coders.net>
5050         * ircd/s_err.c: Added third param to 004 - the channel modes that tage params.  Used by hybrid/epic.
5051         * ircd/s_channels.c: Added fix for msg'ing a -n+m channel - thanks
5052                 to guppy for noticing, and hektik for providing the fix.
5053         * misc others: Minor cleanups, added more protocol_violations, ripped
5054                 out more P09 stuffs, bit more protocol neg stuff.
5055
5056 2000-12-19  Kevin L. Mitchell  <klmitch@mit.edu>
5057
5058         * ircd/m_ison.c (m_ison): Dianora says that ISON has to end with a
5059         space (*sigh* stupid clients...)
5060
5061         * ircd/s_user.c: make WALLOPS_OPER_ONLY a feature managed through
5062         ircd_features.[ch]
5063
5064         * ircd/s_err.c: get rid of GODMODE conditionals
5065
5066         * ircd/s_debug.c (debug_serveropts): switch to using appropriate
5067         calls into the features subsystem for various serveropts
5068         characters
5069
5070         * ircd/s_conf.c (find_conf_entry): get rid of USEONE conditional
5071
5072         * ircd/s_bsd.c: remove GODMODE conditional; use features subsystem
5073         to get value of VIRTUAL_HOST and CLIENT_FLOOD; remove
5074         NOFLOWCONTROL conditional
5075
5076         * ircd/s_auth.c: use features subsystem to determine value of
5077         KILL_IPMISMATCH
5078
5079         * ircd/parse.c: get rid of NOOPER and GODMODE conditionals; use
5080         features subsystem to determine the setting of IDLE_FROM_MSG
5081
5082         * ircd/numnicks.c: get rid of EXTENDED_NUMERICS conditionals
5083
5084         * ircd/motd.c: get value of NODEFAULTMOTD from features subsystem;
5085         use features subsystem to get motd file names
5086
5087         * ircd/m_settime.c: get value of RELIABLE_CLOCK from features
5088         subsystem
5089
5090         * ircd/m_server.c: get rid of CRYPT_LINK_PASSWORD, since it does
5091         us no good; use features subsystem to figure out if we need to do
5092         HUB-type stuff; make TESTNET debugging sendto_opmask_butone's use
5093         the Debug(()) macro instead; get value of RELIABLE_CLOCK from
5094         features subsystem
5095
5096         * ircd/m_privmsg.c: get IDLE_FROM_MSG from the features subsystem
5097
5098         * ircd/m_oper.c: get CRYPT_OPER_PASSWORD from the features
5099         subsystem
5100
5101         * ircd/m_connect.c: get SERVER_PORT from the features subsystem
5102
5103         * ircd/ircd_log.c (log_set_file): fix a bug that kept log files
5104         from getting marked if they were already set to something...
5105
5106         * ircd/ircd_features.c: add a flag to indicates read-only access;
5107         add several new features that used to be compile-time selected
5108
5109         * ircd/ircd.c: grab pidfile out of feature subsystem; don't check
5110         access to motd files (what the heck?); make sure to initialize the
5111         feature subsystem before trying to write the config file
5112
5113         * ircd/dbuf.c: use feature_int() to retrieve BUFFERPOOL settings;
5114         use feature_bool() to figure out if we're using the FERGUSON
5115         flusher
5116
5117         * ircd/Makefile.in: MPATH and RPATH are now done differently, so
5118         remove the clause that creates empty files of that name; also ran
5119         make depend
5120
5121         * include/sys.h: CLIENT_FLOOD is now a feature; unfortunately,
5122         there is no easy way to bounds-check it at present
5123
5124         * include/querycmds.h: make sure ircd_features.h is included; use
5125         feature_str(FEAT_DOMAINNAME) in calls to match()
5126
5127         * include/ircd_features.h: many new features that used to be
5128         compile-time selected
5129
5130         * config/config-sh.in: add * to DOMAINNAME; try also using first
5131         argument to search in /etc/resolv.conf; removed many compile-time
5132         options that now can be configured through the features system
5133
5134 2000-12-18  Kevin L. Mitchell  <klmitch@mit.edu>
5135
5136         * doc/api/log.txt: how to use the logging API
5137
5138         * doc/api/features.txt: how to use the features API
5139
5140         * doc/api/api.txt: how to write API documentation
5141
5142         * include/ircd_features.h: rearranged a couple of features for
5143         neatness purposes
5144
5145         * ircd/ircd_features.c: cleaned up the macros some; rearranged
5146         some code to all go into the switch; rearranged a couple of
5147         features for neatness purposes
5148
5149 2000-12-16  Greg Sikorski <gte@atomicrevs.demon.co.uk>
5150         * ircd/os_bsd.c: Added os_set_tos for BSD users.
5151
5152 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
5153
5154         * ircd/ircd_features.c: Isomer almost got it right; you need to
5155         use F_I(), since it's an integer value, not a boolean value.  The
5156         asserts in feature_int would catch you out...  Also made the F_*
5157         macros take flags
5158
5159         * ircd/s_err.c: define RPL_PRIVS reply
5160
5161         * ircd/parse.c: put new PRIVS command into command table
5162
5163         * ircd/m_privs.c (mo_privs): message handler to report operator
5164         privileges
5165
5166         * ircd/ircd_features.c: declare new features OPER_SET and
5167         LOCOP_SET; redo boolean testing routine to accept TRUE, YES, and
5168         ON for boolean TRUE, and FALSE, NO, and OFF for boolean FALSE
5169
5170         * ircd/client.c: simplify client_set_privs() with a table that
5171         defines what features to test for; add new client_report_privs()
5172
5173         * ircd/Makefile.in: compile new m_privs.c; run make depend
5174
5175         * include/numeric.h (RPL_PRIVS): new reply numeric for displaying
5176         an operator's privileges
5177
5178         * include/msg.h: define new command: PRIVS
5179
5180         * include/ircd_features.h: create new features OPER_SET and
5181         LOCOP_SET for controlling access to /set
5182
5183         * include/handlers.h (mo_privs): declare message handler for
5184         reporting oper privileges
5185
5186         * include/client.h (client_report_privs): declare function to
5187         report what privileges an oper has
5188
5189         * ircd/m_whois.c (do_whois): fix a bug that caused /whois to
5190         report that a user is an oper if the oper doing the /whois had
5191         PRIV_SEE_OPERS
5192
5193 2000-12-17  Isomer <Isomer@coders.net>
5194         * ircd/listener.c: added support for TOS twiddling as a 'feature'.
5195
5196 2000-12-17  Isomer <Isomer@coders.net>
5197         * ircd/os_linux.c: add TOS stuffs
5198
5199         * ircd/listener.c: add TOS stuffs
5200
5201 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
5202
5203         * ircd/whocmds.c (do_who): use HasPriv to determine whether or not
5204         to indicate a user is an oper
5205
5206         * ircd/s_user.c: clear privileges setting when deopping; don't
5207         propagate +o unless user has PRIV_PROPAGATE privilege
5208
5209         * ircd/s_debug.c (debug_serveropts): created debug_serveropts()
5210         function and replaced how the server option string is generated
5211
5212         * ircd/parse.c: remove conditional on CONFIG_OPERCMDS
5213
5214         * ircd/m_whois.c (do_whois): use HasPriv to determine whether or
5215         not to indicate the user is an operator
5216
5217         * ircd/m_who.c: use HasPriv to determine whether or not a user
5218         should be displayed in the list of opers
5219
5220         * ircd/m_version.c: call debug_serveropts() to get server option
5221         string
5222
5223         * ircd/m_userip.c (userip_formatter): use HasPriv to determine
5224         whether or not to show oper status
5225
5226         * ircd/m_userhost.c (userhost_formatter): use HasPriv to determine
5227         whether or not to show oper status
5228
5229         * ircd/m_restart.c (mo_restart): replace ugly #ifdef conditional
5230         checks with HasPriv check; remove dead code
5231
5232         * ircd/m_rehash.c (mo_rehash): replace ugly #ifdef conditional
5233         checks with HasPriv check
5234
5235         * ircd/m_opmode.c (mo_opmode): use HasPriv to check permissions;
5236         use feature_bool to check if disabled
5237
5238         * ircd/m_oper.c (m_oper): set oper priviliges
5239
5240         * ircd/m_mode.c (m_mode): replace #ifdef conditional with HasPriv
5241         check
5242
5243         * ircd/m_kill.c (mo_kill): use HasPriv checks to determine if we
5244         can kill
5245
5246         * ircd/m_kick.c (m_kick): replace #ifdef conditional with HasPriv
5247         check
5248
5249         * ircd/m_jupe.c (mo_jupe): rework permissions checking structure;
5250         use feature_bool to check if disabled
5251
5252         * ircd/m_join.c (m_join): remove BADCHAN conditional; replace
5253         #ifdef conditional with a HasPriv check
5254
5255         * ircd/m_gline.c (mo_gline): rework permissions checking
5256         structure; use feature_bool to check if any part is disabled
5257
5258         * ircd/m_die.c: replace ugly #ifdef conditionals with HasPriv
5259         check; remove dead code
5260
5261         * ircd/m_clearmode.c: use feature_bool() to detect if we're
5262         disabled; use HasPriv to figure out what we're permitted to do;
5263         only allow clearmode on moded channels
5264
5265         * ircd/ircd_features.c: define various features; use HasPriv to
5266         verify permissions to set/reset
5267
5268         * ircd/gline.c (gline_add): use HasPriv instead of #ifdef
5269         conditionals
5270
5271         * ircd/client.c (client_set_privs): function to set an oper's
5272         privileges
5273
5274         * ircd/channel.c: use HasPriv calls instead of #ifdef conditionals
5275
5276         * include/whocmds.h: deconditionalize several macros and
5277         substitute appropriate calls to HasPriv()
5278
5279         * include/s_debug.h: get rid of global serveropts[]; define new
5280         function debug_serveropts() to build that string on the fly
5281
5282         * include/ircd_features.h: define some features
5283
5284         * include/client.h: add privs member to struct Connection; define
5285         various priviledges
5286
5287         * include/channel.h: no longer using IsOperOnLocalChannel; remove
5288         conditional of MAGIC_OPER_OVERRIDE on OPER_WALK_THROUGH_LMODES
5289
5290         * doc/Configure.help: remove help information for deprecated
5291         options
5292
5293         * config/config-sh.in: remove certain deprecated options having to
5294         do with what opers can and cannot do--first stage in moving
5295         compile-time constants into the .conf
5296
5297 2000-12-16  Isomer <Isomer@coders.net>
5298         * ircd/parse.c: detect if the prefix is missing and try and recover
5299         instead of coring.
5300
5301 2000-12-15  Kevin L. Mitchell  <klmitch@mit.edu>
5302
5303         * ircd/ircd_log.c: found and fixed some bugs in the debug logging
5304         code that would sometimes result in the log file not being
5305         reopened--which meant that a user could connect and get the
5306         logging output--oops
5307
5308         * ircd/Makefile.in: run make depend...
5309
5310         * ircd/s_stats.c: get rid of report_feature_list()
5311
5312         * ircd/s_err.c: add the 'bad value' error message, shift error
5313         messages over somewhat
5314
5315         * ircd/s_debug.c (debug_init): call log_debug_init with the
5316         use_tty flag
5317
5318         * ircd/s_conf.c (read_configuration_file): unmark features before
5319         reading the config file, then reset unmarked features after
5320         reading the config file
5321
5322         * ircd/m_stats.c: use feature_report() instead of
5323         report_feature_list()
5324
5325         * ircd/ircd_log.c: fix log_debug_file (bogus assertion); add
5326         special 'mark' flags and use them; add the stuff needed by the
5327         features API
5328
5329         * ircd/ircd_features.c: rework the features API and add gobs of
5330         comments to try to explain what some of these complex functions
5331         are actually doing
5332
5333         * include/s_stats.h: get rid of report_feature_list(); use
5334         feature_report() instead
5335
5336         * include/numeric.h: added a new error message and shifted old
5337         values over some--this is, after all, an alpha
5338
5339         * include/ircd_log.h: log_debug_init now takes an integer to tell
5340         it if it should be using the tty; added a couple of functions
5341         required by the features API
5342
5343         * include/ircd_features.h: add an enum and some more functions to
5344         flesh out the feature API--it should now be possible to put all
5345         those compile-time constants in the config file!
5346
5347         * ircd/send.c: got the direction of the assert incorrect...
5348
5349         * ircd/send.c: implement the efficiency of flush_connections by
5350         creating a linked list of struct Connection's with queued data;
5351         also get rid of flush_sendq_except and make sure to yank
5352         connections out of the list when their sendQs become empty (notice
5353         the assertion in flush_connections!)
5354
5355         * ircd/s_bsd.c (close_connection): must yank the Connection out of
5356         the sendq list
5357
5358         * ircd/list.c (dealloc_connection): must yank the Connection out
5359         of the sendq list
5360
5361         * ircd/dbuf.c (dbuf_put): call flush_connections instead of the
5362         deprecated flush_sendq_except
5363
5364         * ircd/client.c: define a couple new helper functions for sendq
5365         threading--this will make the flush_connections function in send.c
5366         considerably more efficient by creating a linked list of
5367         Connections that have queued data to send
5368
5369         * include/send.h: remove flush_sendq_except, as it's not used
5370         anymore
5371
5372         * include/client.h: declare a couple new helper functions for the
5373         sendq threading system
5374
5375 2000-12-14  Kevin L. Mitchell  <klmitch@mit.edu>
5376
5377         * ircd/m_ison.c (m_ison): Apply Diane Bruce's patch to make ISON
5378         parse all arguments
5379
5380         * ircd/s_debug.c (count_memory): modify to report for clients and
5381         connections, not local clients and remote clients
5382
5383         * ircd/list.c: fiddle with the client-fiddling functions to take
5384         into account the divorce of struct Connection from struct Client
5385
5386         * ircd/ircd.c: define a struct Connection for me, initialize it,
5387         and link it into the right place (ewww, globals!)
5388
5389         * include/client.h: remove CLIENT_{LOCAL,REMOTE}_SIZE; split
5390         struct Client into struct Client and struct Connection; redefine
5391         local-portion accessor macros to go through struct Client to the
5392         struct Connection; define struct Connection accessor macros
5393
5394 2000-12-13  Kevin L. Mitchell  <klmitch@mit.edu>
5395
5396         * ircd/whowas.c: missed a couple of accesses to a struct Client
5397
5398         * ircd/uping.c: missed a couple of accesses to a struct Client
5399
5400         * ircd/send.c: missed a couple of accesses to a struct Client
5401
5402         * ircd/s_user.c: missed a couple of accesses to a struct Client
5403
5404         * ircd/s_misc.c: missed a couple of accesses to a struct Client
5405
5406         * ircd/s_conf.c: missed a couple of accesses to a struct Client
5407
5408         * ircd/s_bsd.c: missed a couple of accesses to a struct Client
5409
5410         * ircd/s_auth.c: missed a couple of accesses to a struct Client
5411
5412         * ircd/res.c: missed a couple of accesses to a struct Client
5413
5414         * ircd/parse.c: missed a couple of accesses to a struct Client
5415
5416         * ircd/m_whois.c: use new accessor macros for struct Client
5417
5418         * ircd/m_who.c: use new accessor macros for struct Client
5419
5420         * ircd/m_wallchops.c: use new accessor macros for struct Client
5421
5422         * ircd/m_version.c: use new accessor macros for struct Client
5423
5424         * ircd/m_userip.c: use new accessor macros for struct Client
5425
5426         * ircd/m_userhost.c: use new accessor macros for struct Client
5427
5428         * ircd/m_user.c: use new accessor macros for struct Client
5429
5430         * ircd/m_uping.c: use new accessor macros for struct Client
5431
5432         * ircd/m_trace.c: use new accessor macros for struct Client
5433
5434         * ircd/m_topic.c: use new accessor macros for struct Client
5435
5436         * ircd/m_time.c: use new accessor macros for struct Client
5437
5438         * ircd/m_stats.c: use new accessor macros for struct Client
5439
5440         * ircd/m_squit.c: use new accessor macros for struct Client
5441
5442         * ircd/m_silence.c: use new accessor macros for struct Client
5443
5444         * ircd/m_server.c: use new accessor macros for struct Client;
5445         remove dead code
5446
5447         * ircd/m_rpong.c: use new accessor macros for struct Client
5448
5449         * ircd/m_rping.c: use new accessor macros for struct Client
5450
5451         * ircd/m_quit.c: use new accessor macros for struct Client
5452
5453         * ircd/m_privmsg.c: use new accessor macros for struct Client
5454
5455         * ircd/m_pong.c: use new accessor macros for struct Client; remove
5456         dead code
5457
5458         * ircd/m_ping.c: use new accessor macros for struct Client
5459
5460         * ircd/m_pass.c: use new accessor macros for struct Client
5461
5462         * ircd/m_part.c: use new accessor macros for struct Client
5463
5464         * ircd/m_oper.c: use new accessor macros for struct Client
5465
5466         * ircd/m_notice.c: use new accessor macros for struct Client
5467
5468         * ircd/m_nick.c: use new accessor macros for struct Client
5469
5470         * ircd/m_names.c: use new accessor macros for struct Client
5471
5472         * ircd/m_mode.c: use new accessor macros for struct Client
5473
5474         * ircd/m_map.c: use new accessor macros for struct Client
5475
5476         * ircd/m_list.c: use new accessor macros for struct Client
5477
5478         * ircd/m_links.c: use new accessor macros for struct Client;
5479         remove some dead code
5480
5481         * ircd/m_kill.c: use new accessor macros for struct Client; remove
5482         some dead code
5483
5484         * ircd/m_kick.c: use new accessor macros for struct Client
5485
5486         * ircd/m_join.c: use new accessor macros for struct Client; remove
5487         some dead code
5488
5489         * ircd/m_ison.c: use new accessor macros for struct Client
5490
5491         * ircd/m_invite.c: use new accessor macros for struct Client
5492
5493         * ircd/m_info.c: use new accessor macros for struct Client
5494
5495         * ircd/m_gline.c: use new accessor macros for struct Client
5496
5497         * ircd/m_error.c: use new accessor macros for struct Client
5498
5499         * ircd/m_create.c: use new accessor macros for struct Client
5500
5501         * ircd/m_connect.c: use new accessor macros for struct Client;
5502         removed some dead code
5503
5504         * ircd/m_burst.c: use new accessor macros for struct Client
5505
5506         * ircd/m_away.c: use new accessor macros for struct Client
5507
5508         * ircd/m_admin.c: use new accessor macros for struct Client
5509
5510         * ircd/hash.c: missed a couple of accesses to a struct Client
5511
5512         * ircd/gline.c: missed a couple of accesses to a struct Client
5513
5514         * ircd/crule.c: missed a couple of accesses to a struct Client
5515
5516         * ircd/class.c: missed an access to a struct Client
5517
5518         * ircd/channel.c: missed a couple of accesses to a struct Client
5519
5520         * ircd/IPcheck.c: missed an access to a struct Client
5521
5522         * include/querycmds.h: fix a couple of stats macros to use
5523         structure accessor macros
5524
5525         * include/client.h: change structure member names to highlight any
5526         places in the code I've missed
5527
5528 2000-12-12  Kevin L. Mitchell  <klmitch@mit.edu>
5529
5530         * ircd/whowas.c: use new struct Client accessor macros
5531
5532         * ircd/whocmds.c: use new struct Client accessor macros
5533
5534         * ircd/send.c: use new struct Client accessor macros
5535
5536         * ircd/s_user.c: use new struct Client accessor macros; removed
5537         some dead code
5538
5539         * ircd/s_serv.c: use new struct Client accessor macros; removed
5540         some dead code
5541
5542         * ircd/s_numeric.c: use new struct Client accessor macros
5543
5544         * ircd/s_misc.c: use new struct Client accessor macros
5545
5546         * ircd/s_debug.c: use new struct Client accessor macros
5547
5548         * ircd/s_conf.c: use new struct Client accessor macros
5549
5550         * ircd/s_bsd.c: use new struct Client accessor macros
5551
5552         * ircd/s_auth.c: use new struct Client accessor macros
5553
5554         * ircd/parse.c: use new struct Client accessor macros
5555
5556         * ircd/packet.c: use new struct Client accessor macros
5557
5558         * ircd/numnicks.c: use new struct Client accessor macros
5559
5560         * ircd/motd.c: use new struct Client accessor macros
5561
5562         * ircd/listener.c: use new struct Client accessor macros
5563
5564         * ircd/list.c: use new struct Client accessor macros
5565
5566         * ircd/jupe.c: use new struct Client accessor macros
5567
5568         * ircd/ircd_snprintf.c: use new struct Client accessor macros
5569
5570         * ircd/ircd_reply.c: use new struct Client accessor macros
5571
5572         * ircd/ircd_relay.c: use new struct Client accessor macros
5573
5574         * ircd/ircd.c: use new struct Client accessor macros
5575
5576         * ircd/gline.c: catch some instances of me.<stuff> I missed
5577         previously
5578
5579         * ircd/client.c: use cli_ instead of con_
5580
5581         * ircd/class.c: use cli_ instead of con_
5582
5583         * ircd/channel.c: use cli_ instead of con_
5584
5585         * ircd/IPcheck.c: use cli_ instead of con_; catch some instances
5586         of me.<stuff> I missed previously
5587
5588         * include/client.h: use cli_ instead of con_...seemed like a good
5589         idea at the time *shrug*
5590
5591 2000-12-11  Kevin L. Mitchell  <klmitch@mit.edu>
5592
5593         * ircd/hash.c: use struct Client accessor macros
5594
5595         * ircd/gline.c: use struct Client accessor macros
5596
5597         * ircd/crule.c: use struct Client accessor macros
5598
5599         * ircd/client.c: use struct Client accessor macros; remove some
5600         dead code
5601
5602         * ircd/class.c: use struct Client accessor macros
5603
5604         * ircd/channel.c: use struct Client accessor macros; remove some
5605         dead code
5606
5607         * ircd/IPcheck.c: use struct Client accessor macros
5608
5609         * include/numnicks.h: use struct Client accessor macros
5610
5611         * include/client.h: first step to divorcing struct Client and
5612         struct Connection--define accessor macros and use them
5613
5614         * ircd/gline.c: When Uworld removed Uworld-set G-lines, only the
5615         uplink would remove them.  This is because the removal protocol
5616         message wasn't being sent to the uplinks.  This is fixed by fixing
5617         propagate_gline() to send the proper number of arguments depending
5618         on whether or not we're adding or deleting the Uworld gline, and
5619         by having gline_deactivate() make sure to turn off the active bit
5620         and call propagate_gline() if it's a Uworld gline
5621
5622 2000-12-10  Kevin L. Mitchell  <klmitch@mit.edu>
5623
5624         * ircd/os_generic.c: make sure IOV_MAX gets defined, just in case
5625
5626         * ircd/os_bsd.c: apparently BSD doesn't have IOV_MAX defined
5627         anywhere intelligent...
5628
5629 2000-12-09  Kevin L. Mitchell  <klmitch@mit.edu>
5630
5631         * ircd/send.c (send_queued): call deliver_it with appropriate
5632         arguments
5633
5634         * ircd/s_serv.c: reorder a couple of headers--cosmetic
5635
5636         * ircd/s_bsd.c (deliver_it): make deliver_it work with a struct
5637         MsgQ
5638
5639         * ircd/os_solaris.c (os_sendv_nonb): function for calling writev
5640         with appropriate iovec
5641
5642         * ircd/os_linux.c (os_sendv_nonb): function for calling writev
5643         with appropriate iovec
5644
5645         * ircd/os_generic.c (os_sendv_nonb): function for calling writev
5646         with appropriate iovec
5647
5648         * ircd/os_bsd.c (os_sendv_nonb): function for calling writev with
5649         appropriate iovec
5650
5651         * ircd/msgq.c (msgq_mapiov): add a len_p argument for totalling up
5652         exactly how much we're trying to write out to the fd
5653
5654         * include/s_bsd.h: make deliver_it take a struct MsgQ
5655
5656         * include/msgq.h: add a len_p argument to msgq_mapiov to help
5657         detect short writes that indicate possible socket blocking
5658
5659         * include/ircd_osdep.h: declare os_sendv_nonb()
5660
5661         * ircd/channel.c (modebuf_mode): don't add empty modes...
5662
5663 2000-12-08  Kevin L. Mitchell  <klmitch@mit.edu>
5664
5665         * include/send.h: add prio argument to send_buffer to select
5666         between normal and priority queues
5667
5668         * ircd/s_user.c (send_user_info): add prio argument to send_buffer
5669         call
5670
5671         * ircd/m_ison.c (m_ison): add prio argument to send_buffer call
5672
5673         * ircd/ircd_reply.c (send_reply): add prio argument to send_buffer
5674         call
5675
5676         * ircd/channel.c (send_channel_modes): add prio argument to
5677         send_buffer call
5678
5679         * ircd/send.c (send_buffer): add a prio argument to select the
5680         priority queue; update send.c functions to use it
5681
5682         * ircd/msgq.c (msgq_add): remove msgq_prio; fold msgq_link and
5683         msgq_add; add a prio argument to msgq_add to select the priority
5684         queue
5685
5686         * include/msgq.h: remove msgq_prio; add a prio argument to
5687         msgq_add
5688
5689         * ircd/send.c: remove sendbuf; remove GODMODE code; switch to
5690         using msgq functions instead of dbuf functions; remove old, dead
5691         sendto_* functions; redo send_buffer to take a struct MsgBuf;
5692         rework sendcmdto_* functions to make use of the new struct MsgBuf
5693
5694         * ircd/s_user.c: remove hunt_server; restructure send_user_info to
5695         make appropriate use of struct MsgBuf
5696
5697         * ircd/s_debug.c (count_memory): count memory used by the MsgQ
5698         system and report it
5699
5700         * ircd/s_conf.c (read_configuration_file): use
5701         sendto_opmask_butone instead of the now dead sendto_op_mask
5702
5703         * ircd/s_bsd.c: switch to using appropriate MsgQLength and other
5704         calls on sendQ
5705
5706         * ircd/parse.c (parse_server): get rid of a piece of GODMODE code
5707
5708         * ircd/msgq.c: add msgq_append and msgq_bufleft; fix a bug in
5709         msgq_clean
5710
5711         * ircd/m_version.c: fix spelling in comments marking dead code
5712
5713         * ircd/m_userip.c (userip_formatter): restructure to make use of
5714         struct MsgBuf
5715
5716         * ircd/m_userhost.c (userhost_formatter): restructure to make use
5717         of struct MsgBuf
5718
5719         * ircd/m_stats.c: use MsgQLength on a sendQ
5720
5721         * ircd/m_settime.c: use MsgQLength instead of DBufLength on a
5722         sendQ; mark a piece of dead code
5723
5724         * ircd/m_names.c: use send_reply instead of sendto_one
5725
5726         * ircd/m_mode.c: use new mode; remove old dead code
5727
5728         * ircd/m_ison.c (m_ison): restructure to make use of struct MsgBuf
5729
5730         * ircd/m_burst.c: use BUFSIZE instead of IRC_BUFSIZE; remove old
5731         dead code
5732
5733         * ircd/listener.c (accept_connection): use sendto_opmask_butone
5734         instead of sendto_op_mask
5735
5736         * ircd/list.c (free_client): use MsgQClear to clear sendQ
5737
5738         * ircd/ircd_reply.c: remove send_error_to_client; restructure
5739         send_reply to make use of struct MsgBuf
5740
5741         * ircd/dbuf.c (dbuf_put): remove argument to flush_sendq_except,
5742         since its no longer used (at least currently)
5743
5744         * ircd/channel.c: restructure send_channel_modes to make use of
5745         struct MsgBuf; remove set_mode, add_token_to_sendbuf, cancel_mode,
5746         and send_hack_notice; use BUFSIZE instead of IRC_BUFSIZE
5747
5748         * ircd/Makefile.in: add msgq.c to list of sources; run make depend
5749
5750         * ircd/IPcheck.c: use sendcmdto_one instead of sendto_one
5751
5752         * include/send.h: send_buffer now takes a struct MsgBuf * instead
5753         of a char *; flush_sendq_except now takes no arguments, as sendq
5754         flushing currently only happens in dbuf.h and sendQ is a struct
5755         MsgQ; remove prototypes for a lot of old sendto_* functions that
5756         aren't used anymore; remove sendbuf and IRC_BUFSIZE--the former is
5757         no longer needed, and the latter is identical to BUFSIZE in
5758         ircd_defs.h
5759
5760         * include/s_user.h: make InfoFormatter take a struct MsgBuf*
5761         instead of a char *; also make it return void, instead of char *
5762
5763         * include/msgq.h: add msgq_append and msgq_bufleft functions
5764
5765         * include/client.h: use a struct MsgQ instead of a struct DBuf for
5766         sendq
5767
5768         * doc/Configure.help: Remove help for compile-time options that
5769         have gone away
5770
5771         * config/config-sh.in: remove CONFIG_NEWMODE
5772
5773         * ircd/m_server.c (mr_server): don't send server IPs in any server
5774         notices
5775
5776         * ircd/msgq.c (msgq_vmake): add \r\n to messages
5777
5778 2000-12-07  Kevin L. Mitchell  <klmitch@mit.edu>
5779
5780         * include/msgq.h: declare the MsgQ API
5781
5782         * ircd/msgq.c: implementation of new MsgQ system
5783
5784 2000-12-06  Kevin L. Mitchell  <klmitch@mit.edu>
5785
5786         * ircd/ircd_features.c: #include was supposed to be for
5787           ircd_features.h, not features.h--missed when I had to do a
5788           rename because of namespace collision
5789
5790 2000-12-05  Greg Sikorski <gte@atomicrevs.demon.co.uk>
5791         * ircd/m_topic.c: Added missing braces that caused all remote
5792           topics to be ignored.
5793
5794 2000-12-04  Kevin L. Mitchell  <klmitch@mit.edu>
5795
5796         * ircd/m_create.c: I'm tired of the exit_client warning :)
5797         (ms_create): discovered that exit_client() was being called with
5798         too few arguments
5799
5800         * ircd/s_misc.c (exit_client): remove all dependance on
5801         FNAME_USERLOG, since that's now gone; log only to LS_USER
5802
5803         * ircd/s_debug.c: USE_SYSLOG no longer means anything
5804
5805         * ircd/m_oper.c (m_oper): no longer log to LS_OPERLOG--we already
5806         log to LS_OPER
5807
5808         * ircd/m_kill.c: no longer conditionalize on SYSLOG_KILL
5809
5810         * ircd/ircd_log.c: remove LS_OPERLOG, LS_USERLOG
5811
5812         * include/ircd_log.h: remove LS_OPERLOG, LS_USERLOG--they serve
5813         the same purpose as LS_USER and LS_OPER
5814
5815         * config/config-sh.in: remove no longer relevant log config
5816         variables
5817
5818         * ircd/uping.c (uping_init): use log_write instead of ircd_log
5819
5820         * ircd/s_misc.c (exit_client): use log_write instead of ircd_log
5821
5822         * ircd/s_conf.c: use log_write instead of ircd_log
5823
5824         * ircd/s_bsd.c (report_error): use log_write instead of ircd_log
5825
5826         * ircd/s_auth.c (timeout_auth_queries): use log_write instead of
5827         ircd_log
5828
5829         * ircd/res.c (send_res_msg): use log_write instead of ircd_log
5830
5831         * ircd/m_who.c: use log_write instead of write_log; no longer
5832         conditionalize on WPATH; mark dead ircd_log calls
5833
5834         * ircd/m_uping.c: mark dead ircd_log call
5835
5836         * ircd/m_server.c (mr_server): use log_write instead of ircd_log
5837
5838         * ircd/m_restart.c: use log_write instead of ircd_log; mark dead
5839         ircd_log calls
5840
5841         * ircd/m_rehash.c (mo_rehash): use log_write instead of ircd_log
5842
5843         * ircd/m_oper.c: use log_write instead of ircd_log; no longer
5844         conditionalize on FNAME_OPERLOG; mark dead ircd_log calls
5845
5846         * ircd/m_kill.c: mark dead ircd_log calls
5847
5848         * ircd/m_connect.c: use log_write instead of ircd_log; mark dead
5849         ircd_log
5850
5851         * ircd/m_clearmode.c: use log_write instead of write_log; no
5852         longer conditionalize on OPATH
5853
5854         * ircd/jupe.c: use log_write instead of write_log; no longer
5855         conditionalize on JPATH
5856
5857         * ircd/ircd_log.c: add USER subsystem; remove ircd_log() compat
5858         function; fix a couple of bugs
5859
5860         * ircd/ircd_alloc.c: fixed a comment
5861
5862         * ircd/ircd.c: use log_write instead of ircd_log; fold server
5863         notice generation in a couple of cases
5864
5865         * ircd/gline.c: use log_write instead of write_log; no longer
5866         conditionalize on GPATH
5867
5868         * ircd/channel.c (modebuf_flush_int): use log_write instead of
5869         write_log; no longer conditionalize on OPATH
5870
5871         * ircd/Makefile.in: run make depend, since dependencies have
5872         changed
5873
5874         * doc/example.conf: add system USER to documentation
5875
5876         * include/ircd_log.h: add system USER; remove old ircd_log()
5877         declarations
5878
5879 2000-12-04  Isomer <isomer@coders.net>
5880         * ircd/m_names.c: Add NAMES_EON to do_names to say add a
5881         'end_of_names' reply when done.
5882         * ircd/m_join.c: use NAMES_EON as mentioned above
5883
5884 2000-12-01  net  <simms@LUCIDA.QC.CA>
5885
5886         * ircd/motd.c: add a freelist for struct Motds
5887
5888 2000-11-30  Kevin L. Mitchell  <klmitch@mit.edu>
5889
5890         * ircd/s_stats.c (report_feature_list): report features--only
5891         local opers can see logging configuration, since it doesn't really
5892         mean anything to users
5893
5894         * ircd/s_err.c: add reply messages for new feature subsystem
5895
5896         * ircd/s_conf.c: add F lines to .conf
5897
5898         * ircd/parse.c: add the message descriptions for /set, /reset, and
5899         /get
5900
5901         * ircd/m_stats.c: add /stats f
5902
5903         * ircd/m_set.c (mo_set): implement /set
5904
5905         * ircd/m_reset.c (mo_reset): implement /reset
5906
5907         * ircd/m_rehash.c: /rehash m now flushes MOTD cache, and /rehash l
5908         reopens log files (for log file rotation)
5909
5910         * ircd/m_get.c (mo_get): implement /get
5911
5912         * ircd/ircd_log.c: use int instead of void return value; add
5913         log_report_features() and log_canon(); fix a function that
5914         disappears if DEBUGMODE not #define'd
5915
5916         * ircd/ircd_features.c: functions to manipulate feature settings
5917         either from the config file or with the new /set, /reset, and /get
5918         commands
5919
5920         * ircd/Makefile.in: add new .c files, run make depend
5921
5922         * include/s_stats.h: declare report_feature_list() (/stats f
5923         handler)
5924
5925         * include/numeric.h: add RPL_STATSFLINE, RPL_FEATURE,
5926         ERR_NOFEATURE, ERR_BADLOGTYPE, ERR_BADLOGSYS, and ERR_BADLOGVALUE
5927         reply numerics
5928
5929         * include/msg.h: add defines for SET, RESET, and GET
5930
5931         * include/ircd_log.h: add a function to canonicalize subsystem
5932         names; change some void return values to int
5933
5934         * include/ircd_features.h: new features subsystem handles all the
5935         manipulation of special features, like log files
5936
5937         * include/handlers.h: declare new mo_{s,res,g}et message handlers
5938         for fiddling with features run-time
5939
5940         * include/client.h (SNO_DEFAULT): don't set SNO_DEBUG by default;
5941         seemed like a good idea at the time...
5942
5943         * doc/example.conf: document new F lines
5944
5945 2000-11-29  Kevin L. Mitchell  <klmitch@mit.edu>
5946
5947         * ircd/s_debug.c: rewrite debug_init() and vdebug() in terms of
5948         new logging functions, which have special support for the debug
5949         log; added loop detection to vdebug(), so that I can
5950         sendto_opmask_butone() from log_vwrite() without incurring another
5951         call to vdebug()
5952
5953         * ircd/s_conf.c (rehash): call log_reopen() from rehash routine;
5954         this allows log file rotations
5955
5956         * ircd/m_kill.c: call log_write_kill() instead of ircd_log_kill()
5957
5958         * ircd/ircd_log.c: much more work fleshing out the interface;
5959         removed old interface; included backwards-compat ircd_log()
5960         function that logs to subsystem LS_OLDLOG
5961
5962         * ircd/ircd.c: switch to new log_init()/log_close()/log_reopen()
5963         functions
5964
5965         * include/ircd_log.h: include stdarg.h for va_list; move ordering
5966         warning to top of file; fill out LogSys enum; declare new
5967         log_debug_init(), log_vwrite(), log_write_kill(), and
5968         log_[sg]et_*() functions; add flags argument to log_write();
5969         defined flags to inhibit various logging actions
5970
5971         * include/client.h: added support for new SNO_DEBUG, enabled only
5972         if DEBUGMODE is defined
5973
5974 2000-11-28  Kevin L. Mitchell  <klmitch@mit.edu>
5975
5976         * ircd/ircd_log.c: make sure the various LOG_* constants are
5977         defined (probably not needed, since #include <syslog.h> isn't
5978         conditional); various static data needed for the new logging
5979         functions; definitions of new logging functions
5980
5981         * include/ircd_log.h: new LogSys enum, declarations for part of
5982         new logging API
5983
5984         * ircd/motd.c: we were setting type to MOTD_CLASS unconditionally,
5985         which was of course stupid; switched to using switch/case in
5986         initialization in motd_create(); zero the MotdList.other pointer
5987         from motd_clear()
5988
5989         * ircd/ircd.c (main): motd_init() has to come before init_conf(),
5990         or we overwrite init_conf()'s hard work with respect to T-lines
5991
5992 2000-11-27  Kevin L. Mitchell  <klmitch@mit.edu>
5993
5994         * ircd/s_stats.c: comment out report_motd_list and include a
5995         reference to motd_report()
5996
5997         * ircd/s_conf.c: rip out the old MOTD manipulation functions; call
5998         motd_add() from the conf parser; call motd_clear() from the rehash
5999         routine; remove the no longer needed memory clearing and reloading
6000         stuff from the rehash service routine
6001
6002         * ircd/motd.c: loads new API, including static internal functions
6003         to do allocation/deallocation, etc.
6004
6005         * ircd/m_stats.c: use new motd_report() instead of
6006         report_motd_list()
6007
6008         * ircd/m_motd.c: use new syntax for motd_send()
6009
6010         * ircd/ircd.c: use new motd_init() function
6011
6012         * ircd/Makefile.in (SRC): forgot to add motd.c to SRC in
6013         Makefile.(in); also ran make depend
6014
6015         * include/motd.h: don't need config.h, but now do need time.h;
6016         define new structures and constants; redefine old API and define
6017         new functions
6018
6019 2000-11-22  Kevin L. Mitchell  <klmitch@mit.edu>
6020
6021         * ircd/s_user.c (register_user): use motd_signon() instead of
6022         calling m_motd; much cleaner this way
6023
6024         * ircd/motd.c: write the new motd_* stuff to make MOTD handling
6025         less of a crock
6026
6027         * ircd/m_motd.c: rewrite m{,s}_motd to call out to new motd_*
6028         functions
6029
6030         * include/motd.h: define new MOTD API stuff
6031
6032 2000-11-20  Kevin L. Mitchell  <klmitch@mit.edu>
6033
6034         * ircd/ircd_reply.c (protocol_violation): rewrite
6035         protocol_violation so it'll actually work
6036
6037         oh, yeah, use %s -> cptr->name, instead of %c -> cptr, so we get
6038         the client's real name in there.
6039
6040         * ircd/m_motd.c (m_motd): Iso's addition of get_client_class(sptr)
6041         resulted in core dumps if NODEFAULTMOTD is defined, because m_motd
6042         gets called from register_user with a NULL sptr.  This is probably
6043         a design problem, but this bandaid will do for now...
6044
6045 2000-11-19  Isomer <isomer@coders.net>
6046         * ircd/ircd_reply.c: added 'protocol_violation', thus alerting us
6047         to problems in the server<->server protocol.
6048
6049         * ircd/m_connect.c: allow remote connects with a port of '0'
6050         meaning to use the port in the config file.
6051
6052         * ircd/m_create.c: Enable hacking protection, lets see how far we
6053         get.
6054
6055         * ircd/m_error.c: The RFC says never accept ERROR from unreg'd
6056         clients, so we don't any more.
6057
6058         * ircd/m_kill.c: The kill path is now made up of numnicks of servers,
6059         and the user@host is displayed of the victim.
6060
6061         * ircd/m_map.c: reloaded 'dump_map'.
6062
6063         * ircd/m_trace.c: allow per class T:
6064
6065         * ircd/m_stats.c: allow local opers /remote stats anywhere on the 'net.
6066
6067 2000-11-17  Isomer <isomer@coders.net>
6068
6069         * ircd/m_topic.c: Fixed bug where we'd only send to clients topics
6070         that were the *same* instead of different.  Oh the embarrasment!
6071
6072         * ircd/IPcheck.c: Merged net's fix.
6073
6074 2000-11-02  Kevin L. Mitchell  <klmitch@mit.edu>
6075
6076         * ircd/m_whois.c: remove compiler warning by adding a newline to
6077         end of file
6078
6079         * ircd/m_names.c: moved the flags up to s_user.h
6080
6081         * ircd/m_join.c: call do_names instead of m_names; restructure
6082         ms_join to never transmute a JOIN into a CREATE, but use the TS in
6083         the JOIN (if present) to timestamp the channel
6084
6085         * ircd/channel.c: send JOINs individually, instead of grouping
6086         them, so that we can send the channel's creation time
6087
6088         * include/s_user.h: declare do_names()
6089
6090 2000-10-30  Isomer <isomer@coders.net>
6091         * ircd/m_oper.c: Fixed warning
6092
6093 2000-10-30  Isomer <isomer@coders.net>
6094         * ircd/m_oper.c: Fixed over agressive cut and no paste
6095
6096 2000-10-30  Isomer <isomer@coders.net>
6097
6098         * ircd/m_topic.c: Restructured, fixed bug where topics on local
6099         channels are propergated (I forget who pointed this out to me, but
6100         thanks anyway).  Also to save bandwidth don't send the topic to
6101         users if the topic is already the same on the server (but still
6102         propergate to other servers).  X/W's "autotopic" feature must
6103         chew a lot of bandwidth, hopefully this will help reduce this.
6104
6105         * doc/rfc1459.rfc: Updated documentation on /topic.
6106
6107         * ircd/listener.c: snotice warnings about failed accept()'s
6108         potentially warning admins that they're running out of fd's.
6109
6110         * ircd/stats.c, ircd/class.c: Removed /stats v, added number of
6111         people in a class in /stats y
6112
6113         * ircd/m_create.c: Checks for timewarp hacking and squit's
6114         evil servers. (currently disabled)
6115         
6116
6117 2000-10-30  net <simms@lucida.qc.ca>
6118         
6119         * ircd/gline.c: Fixed various bugs Isomer left behind.
6120
6121 2000-10-26  Kevin L. Mitchell  <klmitch@mit.edu>
6122
6123         * ircd/m_join.c (m_join): reply on attempt to join a BADCHANed
6124         channel is now ERR_BANNEDFROMCHAN instead of ERR_BADCHANNAME
6125
6126 2000-10-24  Kevin L. Mitchell  <klmitch@mit.edu>
6127
6128         * ircd/channel.c: ok, now last mode rules; mode +ps will always
6129         result in +s (and won't send a mode if the channel is already +s);
6130         mode +sp will always result in +p; -n+n on a +n channel results in
6131         no mode change; -n+n on a -n channel results in a +n mode change;
6132         etc.
6133
6134 2000-10-23  Kevin L. Mitchell  <klmitch@mit.edu>
6135
6136         * ircd/channel.c: add "add" and "del" elements to ParseState to
6137         avoid not-too-pretty -p+s when +s is sufficient; fix a bug in
6138         mode_parse_limit that caused it to clear all channel modes
6139         prematurely; restructure mode_parse_mode to avoid calling
6140         modebuf_mode too early (ties in with first mentioned change);
6141         better logic for +p/+s mutual exclusivity; initialize "add" and
6142         "del" elements in mode_parse; send simple modes down to
6143         modebuf_mode after the loop in mode_parse
6144
6145 2000-09-28  Greg Sikorski <gte@atomicrevs.demon.co.uk>
6146         * ircd/m_names.c: Fixed a non-lethal logic error that 
6147         triggers an assert() in find_member_link while debugging.
6148         (Spotted by Maniac-).
6149 2000-09-19  Thomas Helvey <helveytw@home.com>
6150         * ircd/s_conf.c: move K:lines to their own list and data
6151         structures, add supporting code.
6152         * ircd/m_stats.c: cleanup stats processing a bit move
6153         kline listing code to a new function, haven't figured
6154         out where it goes yet tho'
6155         * ircd/s_stats.c: added K:line bulk lister
6156         * include/s_conf.h: added new DenyConf struct
6157         * *[ch]: fixeup code that depended on changes
6158
6159 2000-09-17  Thomas Helvey <helveytw@home.com>
6160         * ircd/class.c: encapsulate class list
6161         * include/class.h: clean up classes
6162         * * fixup code that depended on changes
6163
6164 2000-09-17  Thomas Helvey <helveytw@home.com>
6165         * ircd/s_conf.c: add me to local conf
6166         * include/s_conf.h: move CONF_ME macro to chkconf.c
6167         * ircd/s_bsd.c: cleanup initialization, allow virtual host
6168         to be changed by rehash
6169
6170 2000-09-17  Thomas Helvey <helveytw@home.com>
6171         * include/class.h: add missing prototype
6172         * ircd/class.c: make argument to get_conf_class const
6173
6174 2000-09-17  Thomas Helvey <helveytw@home.com>
6175         * ircd/*.c: merged in changes from 2.10.10.pl12, cleanup
6176         merge conflicts.
6177         * ircd/*.h: merged in changes from 2.10.10.pl12, cleanup
6178         merge conflicts
6179
6180 2000-09-16  Thomas Helvey <helveytw@home.com>
6181         * ircd/s_conf.c: add code for server struct
6182         * ircd/client.c: copy of class.c sort of, new file for client
6183         specific operations, will move things here as appropriate,
6184         currently only one function is exported from here.
6185         * ircd/*.c: general logic cleanups, convert negatives to
6186         positives in places.
6187
6188 2000-09-16  Thomas Helvey <helveytw@home.com>
6189         * ircd/s_conf.c: add code for new crule data structs, strip quotes
6190         * ircd/crule.c: clean up scary casting a bit, type safety stuff
6191         * include/s_conf.h: add CRuleConf struct and support, remove
6192         unused constants
6193         * include/crule.h: type safety cleanups
6194         * ircd/*.c: fixup code that depended on stuff I changed
6195
6196 2000-09-15  Thomas Helvey <helveytw@home.com>
6197         * ircd/s_conf.c: start adding code for new conf data structs, changed
6198         listeners, admin line, motd lines, class lines. Move validate_hostent
6199         to resolver. General mayhem.
6200         * include/s_conf.h: new data structs and accessors
6201         * ircd/res.c: move validate_hostent here, rewrite, use regular
6202         expression for validation.
6203         * doc/example.conf: update docs for port
6204
6205 2000-09-14  Thomas Helvey <helveytw@home.com>
6206         * ircd/s_conf.c (conf_init): rewrite conf file parser, start to break
6207         up conf_init into managable chunks.
6208         * ircd/listener.c (set_listener_mask): fix logic bug core dump.
6209         * include/s_conf.h: add new data struct for local info (unwinding the mess).
6210
6211 2000-09-13  Thomas Helvey <helveytw@home.com>
6212         * ircd/list.c: put Clients in free lists, pre-allocate MAXCONNECTIONS
6213         local clients.
6214         * ircd/list.c: put SLinks in free lists
6215         * ircd/channel.c: put Memberships in free lists
6216         * ircd/ircd.c: rearrange initializations a bit in main
6217         Note: With these changes, ircd NEVER frees Clients, SLinks or
6218         Memberships. It will also rarely need to allocate new
6219         ones during net bursts and other disruptions. This should
6220         cut down on memory fragmentation a bit as well.
6221
6222 2000-08-30  Kevin L. Mitchell  <klmitch@mit.edu>
6223
6224         * ircd/m_names.c (do_names): pull-up from do_names fix in
6225         u2.10.10.pl11
6226
6227 2000-07-15  Perry Lorier       <Isomer@coders.net>
6228         * various: IP only k:'s and G:'s now do bit tests instead of two(!) 
6229                  match()'s.  Major Major cpu savings.  Also speed up the
6230                  other case slightly.  As a side effect you can now
6231                  k/Gline *@10.0.0.0/8.  I'll do bans tomorrow, it's nearing
6232                  3am.
6233
6234 2000-07-15  Perry Lorier       <Isomer@coders.net>
6235         * various: Fixed warnings after compiling on an alpha.
6236 2000-07-09  Perry Lorier       <Isomer@coders.net>
6237         * doc/ircd.8: Applied grammitical changes by Liandrin, applied
6238                       changes suggested by various other people.
6239         * ircd/IPcheck.c: More bug fixes.  Current problem appears to be
6240                         that it gets a corrupt entry somehow.
6241 2000-07-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
6242         * ircd/m_oper.c: Clean up compiler warning.
6243
6244 2000-07-08  Perry Lorier       <Isomer@coders.net>
6245         * doc/ircd.8: Updated the documentation, it was slightly out of date
6246                       being updated around 1989.
6247         * ircd/m_whois.c: Rewrote for clarity, and probably a bit more speed.
6248                           fixed a few minor glitches.
6249         * doc/rfc1459.unet: Updated.
6250         * ircd/IPcheck.c: Fixed more bugs.
6251         * ircd/s_bsd.c: We now keep track of servers we've conected.
6252
6253 2000-07-02  Perry Lorier       <Isomer@coders.net>
6254         * ircd/s_misc.c: Fixed remote IPcheck bug.  Ok, I'm a moron, so sue
6255                         me.  Thanks to Hektik, thanks thanks thanks thanks
6256                         thanks thanks thanks thanks thank thanks thank thanks
6257
6258 2000-07-01  Perry Lorier       <Isomer@coders.net>
6259         * ircd/s_conf.c: "Fixed" the "bug" where people would "evade" K:'s.
6260         * ircd/s_conf.c, include/IPcheck.h: Fixed compile warnings.
6261
6262 2000-06-22  Perry Lorier       <Isomer@coders.net>
6263         * ircd/IPcheck.c: Large chunks redone.
6264         * ircd/s_conf.c: Changes due to IPcheck - ONE nolonger supported,
6265                         single AND double digit limits are allowed now.
6266         * misc other: Changes to IPcheck.
6267
6268 2000-06-30  Perry Lorier       <Isomer@coders.net>
6269         * ircd/ircd.c: Fix command line parameter bugs.
6270
6271 2000-06-30  Perry Lorier       <Isomer@coders.net>
6272         * ircd/m_kill.c: Fixed bug with LOCAL_KILL_ONLY
6273         * ircd/m_nick.c: Tidied things up.
6274
6275 2000-06-12 Joseph Bongaarts <foxxe@trms.com>
6276         * ircd/m_stats.c: Iso forgot mo_stats when he added /stats v
6277         
6278 2000-05-29  Perry Lorier       <Isomer@coders.net>
6279         * ircd/m_stats.c: add /stats v to do only the last part of the /trace
6280         * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
6281                         you think it'll get bored and fix itself?
6282
6283 2000-06-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
6284
6285         * ircd/m_names.c: Clean up compiler warnings.
6286
6287 2000-06-09  Kevin L. Mitchell  <klmitch@mit.edu>
6288
6289         * ircd/channel.c (mode_parse_client): don't send warning if
6290         there's not enough arguments for a +/-o/v; means the habit of
6291         doing "/mode #channel +oooooo bob" doesn't result in a bunch of
6292         error messages
6293
6294 2000-06-04  Greg Sikorski <gte@atomicrevs.demon.co.uk>
6295
6296         * ircd/m_names.c: Re-factor code to remove unneccessary
6297         GlobalChannelList iteration every time someone joins a channel.
6298
6299 2000-06-02  Kevin L. Mitchell  <klmitch@mit.edu>
6300
6301         * ircd/s_user.c: add struct Gline * argument to register_user;
6302         look up global glines and repropagate them if necessary; send
6303         acknowledgement of gline to remote servers when registering users
6304
6305         * ircd/s_serv.c (server_estab): don't send acknowledgement of
6306         local glines to remote servers; do send gline acknowledgement of
6307         bursted users
6308
6309         * ircd/m_user.c (m_user): pass new struct Gline * argument to
6310         register_user
6311
6312         * ircd/m_pong.c: pass new struct Gline * argument to register_user
6313
6314         * ircd/m_nick.c (ms_nick): document protocol change
6315
6316         * ircd/gline.c: support GLINE_LASTMOD
6317
6318         * include/s_user.h: add struct Gline * argument to register_user
6319
6320         * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
6321
6322         * ircd/s_conf.c (find_kill): add unsigned int argument to
6323         gline_lookup()
6324
6325         * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
6326         glines; add unsigned int argument to gline_lookup()
6327
6328         * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
6329         argument to gline_lookup()
6330
6331         * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
6332         parameter, or when it falls out of bounds: see comments prior to
6333         call to jupe_resend(); call server_estab with struct Jupe
6334         parameter, so that we place the appropriate %<lastmod> in the
6335         appropriate place.
6336
6337         * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
6338         server, as well as for servers when we're sending the BURST
6339
6340         * include/s_serv.h: add a struct Jupe * to the arguments for
6341         server_estab() so that we can send the appropriate lastmod
6342         parameter
6343
6344         * ircd/m_gline.c (ms_gline): actually, this should be the
6345         slightest bit more efficient...
6346
6347         * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
6348         bit more efficient...
6349
6350         * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
6351         during netburst
6352
6353         * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
6354         netburst
6355
6356         * ircd/channel.c (joinbuf_join): really remove user from local
6357         channels
6358
6359 2000-05-29  Perry Lorier       <Isomer@coders.net>
6360         * ircd/m_names.c: Removed redundant space. 
6361         * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
6362
6363 2000-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
6364
6365         * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
6366         a " "
6367
6368 2000-05-04  Kevin L. Mitchell  <klmitch@mit.edu>
6369
6370         * ircd/channel.c: replace bogus assertions with returns, which is
6371         logically correct; only wipe out limit/key if they were originally
6372         set in the first place; remove user from channel when doing a
6373         PARTALL; only send MODE +o for user CREATEing channel if user is
6374         not MyUser--CREATE will only be used if the channel did not
6375         originally exist, therefore we can assume no one local is on the
6376         channel anyway, and we don't exactly need for the user to see an
6377         explicit +o for themselves
6378
6379         * doc/readme.gline: describe the syntax of the GLINE command
6380
6381         * doc/readme.jupe: update to reflect a couple of changes to JUPE
6382
6383         * ircd/gline.c: don't propagate local changes
6384
6385         * ircd/jupe.c: don't propagate local changes
6386
6387         * ircd/m_gline.c (mo_gline): force local flag when deactivating
6388         glines with 0 lastmod
6389
6390         * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
6391         are now removed instead of being deactivated
6392
6393         * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
6394         -<mask>" be accepted
6395
6396         * ircd/channel.c (send_channel_modes): deal with one of the last
6397         vestiges of sendbuf
6398
6399         * ircd/m_burst.c (ms_burst): debugged ban processing; removed
6400         debugging hooks
6401
6402         * ircd/channel.c (modebuf_extract): remove debugging
6403         sendto_opmask_butone calls
6404
6405 2000-05-03  Kevin L. Mitchell  <klmitch@mit.edu>
6406
6407         * ircd/channel.c: support a couple of new flags to support using
6408         mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
6409         of modebuf_extract to extract added flags for use by ms_burst
6410
6411         * include/channel.h: a couple of new flags to support using
6412         mode_parse inside ms_burst
6413
6414         * ircd/m_burst.c (ms_burst): brand new implementation of BURST
6415
6416         * ircd/m_endburst.c: add loop to processing of end_of_burst to
6417         free empty channels after the BURST is over.
6418
6419         * ircd/m_server.c: convert to use new send.c functions--I wanted
6420         to rewrite it from scratch, but the logic's pretty complex; I may
6421         still rewrite it, though...
6422
6423 2000-05-02  Thomas Helvey <tomh@inxpress.net>
6424
6425         * ircd/ircd.c: fix broken header include ordering
6426
6427 2000-05-02  Thomas Helvey <tomh@inxpress.net>
6428         
6429         * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
6430         review emailed privately
6431
6432         * include/IPcheck.h: removed unneeded include
6433
6434 2000-05-02  Kevin L. Mitchell  <klmitch@mit.edu>
6435
6436         * ircd/s_user.c (hunt_server): throw in a comment so I know what
6437         the sendto_one is for
6438
6439         * include/querycmds.h (Count_unknownbecomesclient): convert to
6440         sendto_opmask_butone
6441
6442         * ircd/send.c: start removing dead code
6443
6444         * include/send.h: start removing dead code
6445
6446         * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
6447         hunt_server_cmd
6448
6449         * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
6450
6451 2000-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
6452
6453         * ircd/m_stats.c: convert to sendcmdto_one / send_reply
6454
6455         * ircd/m_kick.c: Completely reimplement m_kick
6456
6457         * ircd/channel.c: send_user_joins removed; it was dead code,
6458         anyway...
6459
6460 2000-05-01  Perry Lorier <isomer@coders.net>
6461         * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
6462         * ircd/channels.c: My fix for the part problem.  Untested, probably
6463                 won't work.  Can't be much worse than the current problem.
6464                 it'll either work or core, take your pick.
6465
6466
6467 2000-04-30  Perry Lorier <isomer@coders.net>
6468         * config/config-sh.in: Fix for CONNEXIT
6469         * ircd/s_{user,misc}.c: Fix for CONNEXIT
6470         * ircd/m_invite.c: Fix for incorrectly numnickified invite.
6471                         (Kev: Want to come talk to me about this?)
6472
6473 2000-04-30  Steven M. Doyle <steven@doyle.net>
6474         * ircd/ircd.c
6475           - general cleanups and readability enhancements
6476           - rewrite of setuid/chroot code.
6477           - server will no longer run as root
6478           - -DPROFIL compile option removed
6479           - Fixed IPcheck API calls
6480  
6481         * config/config-sh.in
6482           - Fixed up chroot compile options
6483           - Added options for debug and profile compiles
6484  
6485         * config/gen.ircd.Makefile
6486           - Support for new debug/profile options
6487  
6488         * ircd/Makefile.in
6489           - Support for new debug/profile options
6490  
6491         * ircd/ircd_signal.c
6492           - Removed -DPROFIL
6493
6494         * include/IPcheck.h
6495           - Removed old API prototypes, added new ones
6496         
6497         * ircd/IPcheck.c
6498           - Readability cleanups (well, I -think-...)
6499           - Changed IPRegistryEntry.last_connect to a time_t.  The previously
6500             used unsigned short was probably causing interesting things after
6501             a client had been connected longer than about 65,535 seconds...
6502           - Removed old API functions.
6503
6504         * ircd/whocmds.c
6505           - Removed IPcheck.h include
6506         
6507         * Additionally modified IPcheck API calls in:
6508           - ircd/m_nick.c
6509           - ircd/m_auth.c
6510           - ircd/s_bsd.c
6511           - ircd/s_conf.c
6512           - ircd/s_misc.c
6513           - ircd/s_serv.c
6514           - ircd/s_user.c
6515         
6516         
6517 2000-04-30  Perry Lorier <isomer@coders.net>
6518         * ircd/s_bsd.c: Sigh. :)
6519         * ircd/m_mode.c: fix for modeless channels by poptix.
6520
6521 2000-04-29  Kevin L. Mitchell  <klmitch@mit.edu>
6522
6523         * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
6524
6525         * ircd/channel.c (clean_channelname): make clean_channelname also
6526         truncate long channel names
6527
6528 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
6529
6530         * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
6531
6532         * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
6533         joinbuf_flush
6534
6535         * include/channel.h: definitions and declarations for the struct
6536         JoinBuf abstraction
6537
6538 2000-04-29  Perry Lorier <isomer@coders.net>
6539         * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
6540
6541 2000-04-29  Perry Lorier <isomer@coders.net>
6542         * ircd/s_bsd.c: Add debugging code to IPcheck
6543
6544 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
6545
6546         * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
6547
6548         * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
6549         RPL_EXPLICIT
6550
6551         * ircd/m_userhost.c (m_userhost): add a dead code comment
6552
6553         * ircd/m_desynch.c: forgot one...
6554
6555         * ircd/m_rehash.c (mo_rehash): er, duplicates :)
6556
6557         * ircd/m_proto.c (proto_send_supported): just change a comment so
6558         it doesn't show up in my scans
6559
6560         * ircd/ircd_reply.c (send_reply): fix a slight bug...
6561
6562         * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
6563         kinda hackish...
6564
6565         * ircd/parse.c (parse_server): argument wrangling to make
6566         processing in do_numeric a little easier to deal with
6567
6568         * ircd/s_serv.c (server_estab): SERVER should come from
6569         acptr->serv->up, not &me
6570
6571         * ircd/m_lusers.c: accidentally left out sptr for a %C
6572
6573         * ircd/send.c: hack to support doing wallchops...
6574
6575         * ircd/m_whowas.c: convert to new send functions
6576
6577         * ircd/m_whois.c: convert to new send functions
6578
6579         * ircd/m_who.c: convert to new send functions
6580
6581         * ircd/m_wallops.c: convert to new send functions
6582
6583         * ircd/m_wallchops.c: convert to new send functions
6584
6585         * ircd/m_version.c: convert to new send functions
6586
6587         * ircd/m_userip.c: convert to new send functions
6588
6589         * ircd/m_userhost.c: convert to new send functions
6590
6591         * ircd/m_uping.c: convert to new send functions
6592
6593         * ircd/m_trace.c: convert to new send functions
6594
6595         * ircd/m_topic.c: convert to new send functions
6596
6597         * ircd/m_time.c: convert to new send functions
6598
6599         * ircd/m_squit.c: convert to new send functions
6600
6601         * ircd/m_silence.c: convert to new send functions
6602
6603         * ircd/m_settime.c: convert to new send functions
6604
6605         * ircd/m_restart.c: convert to new send functions
6606
6607         * ircd/m_rehash.c: convert to new send functions
6608
6609         * ircd/m_privmsg.c: convert to new send functions
6610
6611         * ircd/m_pong.c: convert to new send functions
6612
6613         * ircd/m_ping.c: convert to new send functions
6614
6615         * ircd/m_pass.c: convert to new send functions
6616
6617         * ircd/m_opmode.c: convert to new send functions
6618
6619         * ircd/m_oper.c: convert to new send functions
6620
6621         * ircd/m_notice.c: convert to new send functions
6622
6623         * ircd/m_nick.c: convert to new send functions
6624
6625         * ircd/m_names.c: convert to new send functions
6626
6627         * ircd/m_motd.c: convert to new send functions
6628
6629         * ircd/m_mode.c: convert to new send functions
6630
6631         * ircd/m_map.c: convert to new send functions
6632
6633         * ircd/m_lusers.c: convert to new send functions
6634
6635         * ircd/m_list.c: convert to new send functions
6636
6637         * ircd/m_links.c: convert to new send functions
6638
6639         * ircd/m_kill.c: convert to new send functions
6640
6641         * ircd/m_jupe.c: convert to new send functions
6642
6643         * ircd/m_invite.c: convert to new send functions
6644
6645         * ircd/m_info.c: convert to new send functions
6646
6647         * ircd/m_help.c: convert to new send functions
6648
6649         * ircd/m_gline.c: convert to new send functions
6650
6651         * ircd/m_error.c: convert to new send functions
6652
6653         * ircd/m_endburst.c: convert to new send functions
6654
6655         * ircd/m_die.c: convert to new send functions
6656
6657         * ircd/m_destruct.c: convert to new send functions
6658
6659         * ircd/m_defaults.c: convert to new send functions
6660
6661         * ircd/m_connect.c: convert to new send functions
6662
6663 2000-04-28  Perry Lorier <isomer@coders.net>
6664         * RELEASE.NOTES: Describe a few more undocumented features.
6665         * config/config-sh.in: change the default paths for logging
6666         and the recommended number of channels.
6667         * include/supported.h: Rearrange slightly, added CHANTYPE's
6668
6669 2000-04-27  Kevin L. Mitchell  <klmitch@mit.edu>
6670
6671         * ircd/m_close.c: convert to send_reply
6672
6673         * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
6674
6675         * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
6676
6677         * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
6678
6679         * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
6680         that takes cmd and tok arguments, etc.  NOTE: THIS IMPLEMENTATION
6681         HAS A MAJOR HACK!!!  The whole hunt_server architecture should be
6682         carefully rethought...
6683
6684         * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
6685
6686         * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
6687
6688         * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
6689         numeric nick; therefore, we have to use the server name
6690
6691         * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
6692
6693         * ircd/send.c: fix minor bugs
6694
6695         * ircd/s_user.c (check_target_limit): mark dead code so I filter
6696         it when I grep
6697
6698         * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
6699         when I grep
6700
6701         * ircd/parse.c: mark dead code so I filter it when I grep
6702
6703         * ircd/map.c: mark dead code so I filter it when I grep
6704
6705         * ircd/ircd.c: mark dead code so I filter it when I grep
6706
6707         * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
6708         functions
6709
6710         * ircd/channel.c: mark dead code so I filter it when I grep
6711
6712         * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
6713         hope I'm not stepping on toes...
6714
6715         * ircd/s_conf.c: more sendto_opmask_butone / send_reply
6716         conversions; use ircd_snprintf in a couple of cases to negate the
6717         possibility of buffer overflow
6718
6719 2000-04-26  Kevin L. Mitchell  <klmitch@mit.edu>
6720
6721         * ircd/channel.c: convert as much as possible to new send
6722         semantics
6723
6724         * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
6725         test member->user->from->fd, not from->fd
6726
6727         * ircd/gline.c (gline_add): go ahead and add badchans; we just
6728         won't look for them in m_gline; this way, they always work...
6729
6730         * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
6731
6732         * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
6733         ircd_vsnprintf conversion specifiers
6734
6735         * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
6736         I have my conversion specifiers
6737
6738         * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
6739
6740         * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
6741         local users
6742
6743         * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
6744         little less brain-dead
6745
6746         * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
6747
6748         * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
6749         RPL_STATSDEBUG
6750
6751         * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
6752         RPL_STATSDEBUG
6753
6754         * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
6755         for RPL_STATSDEBUG
6756
6757         * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
6758
6759         * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
6760
6761         * ircd/s_user.c (register_user): use RPL_EXPLICIT for
6762         ERR_INVALIDUSERNAME
6763
6764         * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
6765
6766         * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
6767         a numeric as needing to use an explicit pattern, which will be the
6768         first argument in the variable argument list
6769
6770         * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
6771         non-prefixed nospoof PING
6772
6773         * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
6774         non-prefixed SERVER login
6775
6776         * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
6777         a numeric usage further up)
6778
6779         * include/send.h: declare sendrawto_one
6780
6781         * ircd/send.c (sendrawto_one): new function to use ONLY for
6782         non-prefixed commands, like PING to client, or PASS/SERVER on
6783         server registration
6784
6785 2000-04-25  Kevin L. Mitchell  <klmitch@mit.edu>
6786
6787         * ircd/ircd_snprintf.c (doprintf): implement %H for possible
6788         future expansion (channel numerics?)
6789
6790         * include/ircd_snprintf.h: added documentation to # to explain use
6791         with %C; added documentation for : to explain use with %C; added
6792         documentation for %H for channels
6793
6794         * ircd/whocmds.c: use send_reply
6795
6796         * ircd/userload.c: use sendcmdto_one
6797
6798         * ircd/uping.c: use sendcmdto_one
6799
6800         * ircd/send.c: use new flags to %C format string; ':' prefixes
6801         client name with a colon for local connects, '#' uses
6802         nick!user@host form for local connects
6803
6804         * ircd/s_user.c: use send_reply, sendto_opmask_butone,
6805         sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
6806
6807         * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
6808
6809         * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
6810         sendcmdto_one
6811
6812         * ircd/s_auth.c: use sendto_opmask_butone
6813
6814         * ircd/res.c: use sendcmdto_one
6815
6816         * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
6817         debugging assertions
6818
6819 2000-04-24  Kevin L. Mitchell  <klmitch@mit.edu>
6820
6821         * ircd/support.c: dumpcore is no longer used, so get rid of it
6822
6823         * ircd/parse.c: use send_reply, sendcmdto_one
6824
6825         * ircd/map.c: use send_reply
6826
6827         * ircd/listener.c: use send_reply
6828
6829         * ircd/jupe.c: use sendto_opmask_butone, send_reply
6830
6831         * ircd/ircd_reply.c: use send_reply
6832
6833         * ircd/ircd.c: use sendto_opmask_butone
6834
6835         * ircd/gline.c: use sendto_opmask_butone, send_reply
6836
6837         * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
6838         registered clients; make FLAG_ALT print nick!user@host; make
6839         FLAG_COLON print :blah
6840
6841         * ircd/class.c (report_classes): use send_reply instead of
6842         sendto_one
6843
6844         * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
6845
6846         * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
6847         sendto_one with sendcmdto_one
6848
6849 2000-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
6850
6851         * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
6852         MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
6853         sendcmdto_match_butone
6854
6855         * include/send.h: declare sendcmdto_match_butone
6856
6857 2000-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
6858
6859         * ircd/jupe.c: update to use send_reply()
6860
6861         * ircd/gline.c: update to use send_reply()
6862
6863         * include/ircd_reply.h: declare send_reply
6864
6865         * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
6866         replies; uses ircd_snprintf
6867
6868         * ircd/send.c: added comments to redirect searchers to appropriate
6869         sendcmdto_* function; moved new functions to end of file; added
6870         explanatory comments; reordered arguments; defined new functions
6871         mentioned below
6872
6873         * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
6874
6875         * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
6876
6877         * ircd/jupe.c: reorder arguments to sendcmdto_* functions
6878
6879         * ircd/gline.c: reorder arguments to sendcmdto_* functions
6880
6881         * include/send.h: reorder arguments, add explanatory comments,
6882         declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
6883         and vsendto_opmask_butone
6884
6885 2000-04-19  Kevin L. Mitchell  <klmitch@mit.edu>
6886
6887         * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
6888         vsendto_op_mask that uses '*' instead of the receiving client
6889         nickname
6890
6891         * include/send.h: declare sendcmdto_channel_butone; takes a skip
6892         argument that allows you to skip (or not to skip) deaf users,
6893         users behind bursting servers, and non channel operators
6894
6895 2000-04-17  Kevin L. Mitchell  <klmitch@mit.edu>
6896
6897         * ircd/send.c: new sendcmdto_channel_butserv -- note that old
6898         sendto_channel_butserv has a subtle bug; also wrote
6899         sendcmdto_common_channels.
6900
6901         * include/send.h: declare new sendcmdto_* functions
6902
6903         * ircd/jupe.c: support local deactivations of jupes
6904
6905         * ircd/gline.c: support local deactivations of glines
6906
6907         * include/jupe.h: JUPE_LDEACT allows jupes to be locally
6908         deactivated; if they aren't locally deactivated, then it slaves to
6909         the net-wide activation status; JupeIsRemActive() tests only
6910         whether the jupe is active everywhere else
6911
6912         * include/gline.h: GLINE_LDEACT allows glines to be locally
6913         deactivated; if they aren't locally deactivated, then it slaves to
6914         the net-wide activation status; GlineIsRemActive() tests only
6915         whether the gline is active everywhere else
6916
6917         * ircd/gline.c: detect overlapping G-lines; if an existing, wider
6918         gline expires after the new one will, we drop the new one,
6919         otherwise we add the G-line after that one (so the wide one will
6920         apply first); if the new one contains an existing G-line and if it
6921         will expire after the existing one, we drop the existing one to
6922         save memory
6923
6924         * ircd/m_gline.c (mo_gline): opers could issue remote local
6925         glines when CONFIG_OPERCMDS was off; fixed
6926
6927 2000-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
6928
6929         * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
6930         this is a local JUPE
6931
6932         * ircd/gline.c: add flags argument to gline_activate and
6933         gline_deactivate for future expansion
6934
6935         * ircd/m_gline.c: pass flags to gline_activate and
6936         gline_deactivate
6937
6938         * include/gline.h: add flags argument to gline_activate and
6939         gline_deactivate
6940
6941         * ircd/jupe.c: add flags argument to jupe_activate and
6942         jupe_deactivate for future expansion
6943
6944         * include/jupe.h: add flags argument to jupe_activate and
6945         jupe_deactivate
6946
6947         * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
6948         local, active; pass flags to jupe_activate and jupe_deactivate
6949
6950         * include/gline.h: remove dead code
6951
6952         * ircd/gline.c: make gline expire times relative to CurrentTime,
6953         since that should be monotonically increasing, instead of
6954         TStime(), which can be set backwards, and which can therefore
6955         cause an expire time to increase; make local glines be removed
6956         instead of just deactivated; don't let gline_find() look for
6957         user@host glines if the mask being looked up is a channel mask
6958
6959         * ircd/send.c (vsendcmdto_one): forgot to account for the case
6960         where origin is a server and destination is a user
6961
6962         * ircd/jupe.c: make jupe expire times relative to CurrentTime,
6963         since that should be monotonically increasing, instead of
6964         TStime(), which can be set backwards, and which can therefore
6965         cause an expire time to increase; make local jupes be removed
6966         instead of just deactivated
6967
6968         * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
6969         limit is fine.  any other warnings I should know about?
6970
6971 2000-04-15  Thomas Helvey <tomh@inxpress.net>
6972
6973         * ircd/*.c: const correctness and type safety cleanups to
6974         get code to compile with C++ compiler. Still has
6975         signed/unsigned comparison warnings.
6976
6977 2000-04-15  Greg Sikorski <gte@atomicrevs.demon.co.uk>
6978
6979         * ircd/userload.c: change <sys/time.h> include to <time.h> for
6980           portability.
6981
6982 2000-04-14  Kevin L. Mitchell  <klmitch@mit.edu>
6983
6984         * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
6985         and convert acptr...
6986
6987         * ircd/s_user.c: move gline_lookup function call into
6988         register_user, where it'll have a username to lookup!
6989
6990         * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
6991         functions; also stuff send_error_to_client into return clauses
6992
6993         * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
6994         functions; also use send_error_to_client where that makes sense
6995
6996         * ircd/jupe.c: modify to utilize new sendcmdto_* series of
6997         functions; also use send_error_to_client where that makes sense
6998
6999         * ircd/gline.c: modify to utilize new sendcmdto_* series of
7000         functions; also fix gline_lookup() to deal properly with remote
7001         clients--boy, do struct Client and struct User need to be cleaned
7002         up!
7003
7004         * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
7005         too...
7006
7007         * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
7008         sendcmdto_serv_butone(), all utilizing the %v conversion of
7009         ircd_snprintf()
7010
7011         * include/send.h: define IRC_BUFSIZE, max size of a message;
7012         declare sendcmdto_one(), vsendcmdto_one(), and
7013         sendcmdto_serv_butone()
7014
7015         * include/msg.h: define all the CMD_* constants needed to utilize
7016         the new sendcmdto_* series of functions
7017
7018         * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
7019
7020         * ircd/gline.c: remove old, dead code.
7021
7022         * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
7023         unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
7024         (don't advertise proxies); remove dead code
7025
7026         * ircd/parse.c: oper handler for JUPE only lists jupes unless
7027         CONFIG_OPERCMDS is enabled
7028
7029         * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
7030         CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
7031
7032         * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
7033         always return ERR_DISABLED
7034
7035         * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
7036         enabled, always return ERR_DISABLED
7037
7038         * ircd/s_err.c: add error message to indicate disabled commands
7039
7040         * include/numeric.h (ERR_DISABLED): to indicate disabled commands
7041
7042         * doc/Configure.help: add documentation for CONFIG_OPERCMDS
7043
7044         * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
7045         CONFIG_NEW_MODE to 'y' for now
7046
7047         * ircd/gline.c (gline_list): fix a minor formatting bogon
7048
7049         * BUGS: since I fixed that bug, might as well mark it fixed.
7050
7051         * ircd/m_join.c: look up badchans with GLINE_EXACT
7052
7053         * ircd/m_gline.c: fix parc count problems; look up existing
7054         G-lines with GLINE_EXACT; only set new lastmod when
7055         activating/deactivating existing glines if old lastmod was not 0
7056
7057         * ircd/gline.c: forgot to copy the gline reason over; don't
7058         propagate a gline with 0 lastmod if origin is user; add
7059         GLINE_EXACT to force exact matching of gline mask
7060
7061         * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
7062         flag properly
7063
7064         * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
7065         but gline_lookup() actually takes a client--d'oh.
7066
7067 2000-04-13  Thomas Helvey <tomh@inxpress.net>
7068         * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
7069
7070 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
7071
7072         * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
7073           "/who * x"
7074           "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
7075           (Found by Plexus).
7076
7077         * ircd/whocmds.c: Change idle time calc from socket idle to user
7078           idle.
7079
7080 2000-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
7081
7082         * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
7083         too, for ircd_snprintf.c
7084
7085         * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
7086         comments; mostly descended from the Linux manpage for printf, but
7087         also documenting the extensions.
7088
7089         * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
7090         client; make 'q' be the same as 'L'; remove __inline__; only
7091         define EXTENSION if HAVE_LONG_LONG is defined
7092
7093         * include/handlers.h: declare m_gline()
7094
7095         * ircd/parse.c: gline can be called by users, but it only lists
7096         the glines.
7097
7098         * ircd/s_user.c (set_nick_name): resend gline if a remote server
7099         introduces a glined client
7100
7101         * ircd/s_serv.c (server_estab): burst glines, too
7102
7103         * ircd/gline.c: fix up all the expire times to be offsets;
7104         simplify gline_resend()
7105
7106         * ircd/m_gline.c: begin coding replacements for ms_gline(),
7107         mo_gline(), and m_gline()
7108
7109         * ircd/gline.c (gline_add): allow *@#channel to work correctly;
7110         also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
7111
7112 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
7113
7114         * tools/Bouncer/*: Add comments/documentation/tags.
7115         * tools/Bouncer/*: Add debug defines, make task fork().
7116
7117 2000-04-12  Thomas Helvey <tomh@inxpress.net>
7118         * ircd/s_err.c: Cleanup s_err.c make one table so we
7119         don't have to do anything tricky to get an error string.
7120
7121 2000-04-12  Greg Sikorski <gte@atomicrevs.demon.co.uk>
7122         * Add port bouncer for http (x/w)
7123
7124 2000-04-12  Kevin L. Mitchell  <klmitch@mit.edu>
7125
7126         * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
7127         call to gline_find(); also used GlineReason() instead of direct
7128         reference to structure member
7129
7130         * ircd/m_join.c (m_join): replace bad_channel() calls with calls
7131         to gline_find(name, GLINE_BADCHAN), and also check to see if gline
7132         is active
7133
7134         * ircd/channel.c: nothing seems to be called anywhere...
7135
7136         * ircd/s_err.c: update a couple of replies to dovetail with new
7137         semantics
7138
7139         * ircd/gline.c: begin complete re-implementation of gline.c along
7140         the lines of the final design of jupe.c
7141
7142         * include/gline.h: begin complete re-implementation of gline.c
7143         along the lines of the final design of jupe.c
7144
7145         * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
7146         %s by %s" message...
7147
7148         * ircd/ircd_snprintf.c: my new snprintf()-like functions
7149
7150         * include/ircd_snprintf.h: my new snprintf()-like functions
7151
7152 2000-04-11  Thomas Helvey <tomh@inxpress.net>
7153         * ircd/IPcheck.c: removed old dead code
7154         * ircd/s_user.c (send_user_info): removed non-standard
7155           user not found message for userhost/userip
7156
7157 2000-04-11  Greg Sikorski <gte@atomicrevs.demon.co.uk>
7158
7159         * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
7160         * doc/p10.html: Work on chapter 4.
7161
7162 2000-04-10  Kevin L. Mitchell  <klmitch@mit.edu>
7163
7164         * ircd/channel.c (mode_parse_client): fix coredump on /mode
7165         #foobar +o nosuchnick
7166
7167 2000-04-10  Perry Lorier  <Isomer@coders.net>
7168         * BUGS: Added bug.
7169
7170 2000-04-09  Thomas Helvey <tomh@inxpress.net>
7171         * include/IPcheck.h: fix prototype
7172         * ircd/s_user.c: fix usage of IPcheck_remote_connect
7173         * ircd/IPcheck.c: removed unused args
7174
7175 2000-04-09  Thomas Helvey <tomh@inxpress.net>
7176         * include/IPcheck.h: add proto for IPcheck_expire
7177
7178         * ircd/IPcheck.c: Rewrote
7179
7180         * ircd/ircd.c: Add IPcheck_expire to main message loop
7181
7182         * ircd/s_user.c: Redo target hashing, refactor target code
7183
7184         * include/numeric.h: Cleaned up numerics, added which ones are
7185         in use by other networks and what they are in use for.
7186
7187         * ircd/channel.c: cleaned can_join(), allow anyone through anything
7188         if /invited, simplified the function.  Opers overusing OPEROVERRIDE
7189         will get a message explaining to them not to cheat.
7190
7191         * ircd/m_join.c: cleaned up the various join functions, should be
7192         a lot more efficient.  Still needs work.  Now assumes that s<->s
7193         won't send it a JOIN 0.  Service coders - note this and tread with
7194         care.
7195
7196         * ircd/m_stats.c: added Gte-'s stats doc patch.
7197
7198         * ircd/m_version.c: /version now returns the 005 numeric as well.
7199         as requested by Liandrin.
7200
7201
7202 2000-04-07  Kevin L. Mitchell  <klmitch@mit.edu>
7203
7204         * ircd/m_clearmode.c: add include for support.h for write_log()
7205
7206         * configure: move ircd/crypt/* to tools/*
7207
7208 2000-04-06  Thomas Helvey <tomh@inxpress.net>
7209         * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
7210           set client host to server alias if connection from localhost
7211
7212 2000-04-06  Perry Lorier <isomer@coders.net>
7213         * ircd/ircd.c: Fix core during pinging (oops)
7214         
7215 2000-04-06  Perry Lorier <isomer@coders.net>
7216         * ircd/send.c: fixed wrong ident being sent to channels bug.
7217         * include/numerics.h: Updated some of the numerics from other
7218         networks.  Flagged some as 'unused' by undernet.
7219
7220 2000-03-30  Perry Lorier <isomer@coders.net>
7221         * ircd/ircd.c: Lets see if this helps the ping problem at all.
7222         * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
7223         time for local clients. (as requested), extended who now returns all
7224         the flags (@+!) so you can tell the complete state of a client.
7225
7226 2000-03-30  Thomas Helvey <tomh@inxpress.net>
7227         * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
7228
7229 2000-03-30  Perry Lorier <isomer@coders.net>
7230         * ircd/parse.c: oops, missed opers.
7231
7232 2000-03-30  Perry Lorier <isomer@coders.net>
7233         * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
7234         for so long.  Remember: m_ping MUST be in the parse array. :)
7235
7236 2000-03-30  Perry Lorier <isomer@coders.net>
7237         * ircd/ircd.c: test in check_pings was wrong.  I move that we
7238         disallow cvs commit after 10pm localtime....
7239
7240 2000-03-30  Perry Lorier <isomer@coders.net>
7241         * ircd/m_pong.c: Fix it for servers too.
7242
7243 2000-03-30  Perry Lorier <isomer@coders.net>
7244         * ircd/m_pong.c: Fix ping timeout bugs
7245
7246 2000-03-30  Perry Lorier <isomer@coders.net>
7247         * ircd/channel.c: Bans had CurrentTime in their when field instead
7248         of TStime()
7249
7250 2000-03-31  Thomas Helvey <tomh@ixpress.net>
7251         * ircd/numnicks.c (SetXYYCapacity): fix for extended
7252         numerics.
7253
7254 2000-03-30  Perry Lorier <isomer@coders.net>
7255         * ircd/m_nick.c: send kills both ways so when we add nick change
7256         on collision we don't desync the network.
7257
7258         * ircd/map.c: Fixup the map a bit more.
7259
7260 2000-03-31  Kevin L. Mitchell  <klmitch@mit.edu>
7261
7262         * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
7263
7264         * ircd/m_opmode.c: Log the mode changes to OPATH
7265
7266         * ircd/channel.c (modebuf_flush_int): Log the mode changes to
7267         OPATH
7268
7269         * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
7270         OPATH
7271
7272         * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
7273
7274         * config/config-sh.in: added OPATH for opmode log file
7275
7276         * ircd/m_clearmode.c (do_clearmode): updated uses of
7277         modebuf_mode_string() for the new usage
7278
7279         * ircd/channel.c: added flag MODE_FREE and an int argument to
7280         modebuf_mode_string() to indicate that the string must be free'd;
7281         updated calls to modebuf_mode_string() for the new usage; called
7282         collapse(pretty_mask()) on the ban string and use allocated memory
7283         for it; added ban list length accounting; fixed a number of small
7284         bugs in ban processing
7285
7286         * include/channel.h: added flag MODE_FREE and an int argument to
7287         modebuf_mode_string() to indicate that the string must be free'd
7288
7289         * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
7290         keys and limits that are set
7291
7292 2000-03-30  Perry Lorier <isomer@coders.net>
7293         * ircd/ircd.c: rewrote check_pings() for maintainability
7294         and speed.  Also changed quit msg's so they don't have
7295         redundant nick[host] info in them.
7296
7297         * ircd/send.c: Changed write errors to report what error
7298         occured (if possible).
7299
7300         * ircd/gline.c: added gline comment to the quit.
7301
7302         * ircd/m_server.c: Added suggestions to server quits mentioning
7303         what went wrong so the admin can fix it earlier instead of asking
7304         questions...
7305
7306         * ircd/map.c: Changed m_map() to hide numerics, show a * beside
7307         servers that aren't fully burst yet.  And show '(--s)' for servers
7308         where its not sure.
7309
7310         * doc/example.conf: Fixed wrapped U:
7311
7312 2000-03-30  Kevin L. Mitchell  <klmitch@mit.edu>
7313
7314         * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
7315         mode_parse() (version selectable at compile time)
7316
7317         * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
7318
7319         * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
7320
7321         * config/config-sh.in: add new config option to enable new m_mode
7322         implementation
7323
7324         * doc/Configure.help: add documentation for new config option
7325         CONFIG_NEW_MODE
7326
7327         * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
7328         MODE -v : Not enough parameters
7329
7330         * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
7331         +k and +l even if they weren't set...
7332
7333         * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
7334
7335         * ircd/channel.c: make mode_process_clients() clear the DEOPPED
7336         flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
7337         for; test the 0-th member, not the i-th member, of the client
7338         change state stuff
7339
7340         * ircd/m_clearmode.c (do_clearmode): use the new
7341         mode_invite_clear() function
7342
7343         * ircd/channel.c: cleared up all the compile-time warnings and
7344         errors
7345
7346         * include/channel.h: added declarations for mode_ban_invalidate()
7347         and mode_invite_clear()
7348
7349         * ircd/channel.c: finished mode_parse(), then broke it up into a
7350         dozen or so helper functions to make the code easier to read
7351
7352 2000-03-29  Thomas Helvey <tomh@inxpress.net>
7353         * ircd/ircd.c: refactor server initialization a bit, use
7354         getopt for parsing command line, refactor init_sys, main,
7355         and other bits.
7356
7357         * ircd/s_bsd.c: add functions for initialization to clean
7358         up logic a bit and remove duplicated code.
7359
7360         * include/ircd.h: add struct for server process related
7361         variables.
7362
7363 2000-03-29  Kevin L. Mitchell  <klmitch@mit.edu>
7364
7365         * ircd/channel.c: initial definition of mode_parse(); flags to
7366         prevent doing the same thing multiple times; helper method
7367         send_notoper() to send a "Not oper"/"Not on channel" notice
7368
7369         * include/channel.h: declare mode_parse() and helper flags
7370
7371         * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
7372         sending to match the current action of set_mode() closely enough
7373         that hopefully there won't be major conflicts
7374
7375         * ircd/channel.c (modebuf_flush_int): consolidated the mode string
7376         building logic, reversed the order of the arguments to mode
7377         commands to have '-' preceed '+'
7378
7379 2000-03-29  Thomas Helvey <tomh@inxpress.net>
7380         * ircd/s_bsd.c (add_connection): don't disable socket options
7381         let OS tune itself and allow important performance tweaks to 
7382         work.
7383
7384 2000-03-28  Kevin L. Mitchell  <klmitch@mit.edu>
7385
7386         * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
7387         confused by set_mode, which is doing some really weird logic;
7388         guess what I'm going to rewrite next?  ;)
7389
7390 2000-03-28  Kevin L. Mitchell  <klmitch@emc.com>
7391
7392         * include/channel.h: added MODE_SAVE for the bounds checking stuff
7393         in modebuf_flush
7394
7395         * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
7396         make it do bounds checking on the buffer; all modes are sent only
7397         if the all parameter is 1; modebuf_flush is the exported wrapper
7398
7399         * include/channel.h: add BOUNCE, renumber flags to get a little
7400         more space
7401
7402         * ircd/channel.c (modebuf_flush): don't overload HACK2, add
7403         BOUNCE; send DESYNCH message
7404
7405 2000-03-27  Kevin L. Mitchell  <klmitch@emc.com>
7406
7407         * ircd/m_clearmode.c (do_clearmode): only mark the modes the
7408         channel actually has in effect for deletion
7409
7410         * ircd/channel.c: added explanatory comments to all added
7411         functions; made flushing take place at the correct place even if
7412         the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
7413         to bash some stupid bugs; made modebuf_flush() return if ModeBuf
7414         is empty, fixed the apparent source, removed some bogus string
7415         termination code, properly terminate the mode strings, add support
7416         for HACK2 and HACK3, made limit strings not be sent if the limit
7417         is being removed, changed where '+' and '-' come from in sent
7418         strings, added support for DEOP flag, set up bouncing code for
7419         HACK2
7420
7421         * ircd/Makefile.in: ran make depend
7422
7423         * include/channel.h: added new defines for future functionality,
7424         made modebuf_flush() return int so I can use tail recursion
7425
7426         * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
7427         to make it all compile
7428
7429         * ircd/m_opmode.c: add msg.h to includes...
7430
7431         * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
7432
7433         * ircd/channel.c (modebuf_flush): realized I forgot to
7434         nul-terminate addbuf/rembuf properly...
7435
7436         * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
7437
7438         * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
7439         sendto_serv_butone--blah^2
7440
7441         * ircd/send.c (sendto_serv_butone): stupid comments confused me
7442
7443         * ircd/channel.c (modebuf_flush): if there are no mode changes to
7444         propagate, we're done...
7445
7446         * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
7447         not sendto_all_butone
7448
7449         * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
7450
7451         * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
7452
7453         * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
7454         the list
7455
7456         * ircd/parse.c: added messages for opmode and clearmode
7457
7458         * include/handlers.h: added declarations for mo_opmode(),
7459         ms_opmode(), mo_clearmode(), and ms_clearmode()
7460
7461         * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
7462         TOK_CLEARMODE
7463
7464         * include/channel.h (MODEBUF_DEST_OPMODE): Define the
7465         MODEBUF_DEST_OPMODE flag
7466
7467         * ircd/channel.c (modebuf_flush): added new flag,
7468         MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
7469         to originate from source's server (or source itself, if
7470         IsServer(source)); also causes a server-level MODE to be sent as
7471         OPMODE instead
7472
7473         * include/channel.h: defined MODEBUF_DEST_SERVER,
7474         MODEBUF_DEST_HACK4
7475
7476         * ircd/channel.c: Add another argument to build_string() to handle
7477         numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
7478         servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
7479         to be sent out
7480
7481 2000-03-27  Perry Lorier <isomer@coders.net>
7482
7483         * ircd/s_bsd.c: fixed missing 'u' typo.
7484
7485 2000-03-26  Kevin L. Mitchell  <klmitch@emc.com>
7486
7487         * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
7488         _mode_string(), _mode_client(), _flush(); also implemented a
7489         simple build_string()
7490
7491         * include/channel.h: added definition of ModeBuf, modebuf_*
7492         manipulation functions, and a couple of helper macros
7493