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