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