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