Author: Kev <klmitch@mit.edu>
[ircu2.10.12-pk.git] / ChangeLog
1 2001-08-17  Kevin L Mitchell  <klmitch@mit.edu>
2
3         * ircd/s_stats.c: remove description of /stats v, since it's gone
4
5         * ircd/m_wallops.c (mo_wallops): add "*" to the beginning of
6         /wallops to distinguish wallops from wallusers
7
8         * ircd/m_error.c (mr_error): ignore ERROR from clients that aren't
9         in the "handshake" or "connecting" states--I think the latter will
10         never happen, but...
11
12         * doc/Authors: apply delete's Authors patch
13
14         * RELEASE.NOTES: rewrite RELEASE.NOTES, basing it a little on
15         Braden's version
16
17         * README: rewrite README
18
19 2001-07-31  Kevin L. Mitchell  <klmitch@mit.edu>
20
21         * ircd/s_serv.c (server_estab): remove unused variable split
22
23         * ircd/parse.c: add mr_error to the parse table
24
25         * ircd/m_error.c (mr_error): add mr_error() to handle ERRORs from
26         unregistered connections--if IsUserPort() is true, the ERROR is
27         ignored, otherwise, the message is saved
28
29 2001-07-28  Kevin L. Mitchell  <klmitch@mit.edu>
30
31         * ircd/m_kill.c (ms_kill): another minor typo *sigh*
32
33         * ircd/s_user.c (send_supported): oops, minor typo...
34
35         * ircd/s_user.c: implement send_supported() to send two ISUPPORT
36         messages containing our feature buffers; make register_user() use
37         send_supported()
38
39         * ircd/s_misc.c (exit_client): make sure not to give away a remote
40         server in the ERROR message sent to the client; if the killer is a
41         server, we substitute our name in its place
42
43         * ircd/m_version.c (m_version): use send_supported() to send the
44         ISUPPORT values to the user
45
46         * ircd/m_nick.c: shave nick collision kills here a bit, too, for
47         the same reasons as for m_kill.c
48
49         * ircd/m_kill.c: shave kills a bit so that the results look
50         exactly the same no matter where you are; if we didn't do this, it
51         would be possible to map the network by looking at the differences
52         between kills originating under various circumstances
53
54         * include/supported.h: split the features into two, so as to not
55         bust the parameter count when sending the features list
56
57         * include/s_user.h: declare new send_supported() function to send
58         the ISUPPORT information
59
60 2001-07-27  Kevin L. Mitchell  <klmitch@mit.edu>
61
62         * ircd/s_bsd.c: disable IP (*not* TCP) options to prevent
63         source-routed spoofing attacks; this is only available under
64         u2.10.11, so don't even bother, since no one but testers are using
65         the source base
66
67 2001-07-25  Kevin L. Mitchell  <klmitch@mit.edu>
68
69         * include/ircd_policy.h: enable HEAD_IN_SAND_REMOTE by default
70
71         * ircd/s_err.c: put in a . for reporting link version on /trace,
72         to match what /version does
73
74 2001-07-21  Kevin L. Mitchell  <klmitch@mit.edu>
75
76         * ircd/s_misc.c (exit_client): servers don't understand what the
77         numeric nick ERROR is supposed to mean, so they ignore error
78         messages, resulting in not knowing why we were rejected; use
79         sendcmdto_one for servers and sendrawto_one for clients
80
81 2001-07-17  Kevin L. Mitchell  <klmitch@mit.edu>
82
83         * ircd/m_burst.c (ms_burst): in the case of a modeless channel and
84         a nick collide, a bare BURST may be propagated; adjust the
85         enforced parameter count to accept the bare BURST
86
87 2001-07-12  Kevin L. Mitchell  <klmitch@mit.edu>
88
89         * ircd/s_bsd.c: mark a client as having been IP checked
90
91         * ircd/IPcheck.c (ip_registry_check_remote): remove unneeded
92         second call to SetIPChecked()
93
94 2001-07-11  Kevin L. Mitchell  <klmitch@mit.edu>
95
96         * ircd/engine_poll.c: deal with POLLHUP properly (hopefully)
97
98         * ircd/engine_devpoll.c: deal with POLLHUP properly (hopefully)
99
100 2001-07-09  Kevin L. Mitchell  <klmitch@mit.edu>
101
102         * ircd/os_bsd.c (os_get_rusage): move buf into the two ifdef'd
103         sections so that if neither is used, the declaration of buf will
104         not elicit an "unused variable" warning under NetBSD
105
106         * ircd/m_map.c: include string.h to declare strcpy (fix warnings
107         on alpha)
108
109         * ircd/m_away.c: include string.h to declare strcpy/strlen (fix
110         warnings on alpha)
111
112         * ircd/ircd_log.c: include string.h to declare strcpy/strlen (fix
113         warnings on alpha)
114
115         * ircd/client.c: include string.h to declare memset (fix warnings
116         on alpha)
117
118         * ircd/channel.c: remove unused functions next_overlapped_ban,
119         del_banid, and is_deopped (fix warnings under -O1)
120
121         * ircd/IPcheck.c: include string.h to declare memset/memcpy (fix
122         warnings on alpha)
123
124 2001-06-29  Kevin L. Mitchell  <klmitch@mit.edu>
125
126         * ircd/s_user.c (set_user_mode): clear the snomask if the user
127         isn't supposed to receive server notices anymore
128
129         * ircd/ircd_features.c: change CONFIG_OPERCMDS to default to FALSE
130
131         * configure.in: use AC_MSG_CHECKING/AC_MSG_RESULT when checking
132         installation prefix; default devpoll and kqueue to on (they get
133         turned off if the required headers aren't present)
134
135         * ircd/whocmds.c (do_who): use ircd_snprintf() instead of
136         sprintf_irc(); it's a bit hackish, but it'll do for now
137
138         * ircd/support.c: remove unused #include
139
140         * ircd/send.c: remove unused #include
141
142         * ircd/s_user.c: use ircd_snprintf() instead of sprintf_irc()
143
144         * ircd/s_serv.c: remove unused #include
145
146         * ircd/s_misc.c: use ircd_snprintf() and friends instead of
147         sprintf_irc() and friends
148
149         * ircd/s_err.c: moved atoi_tab[] from ircd/sprintf_irc.c to
150         ircd/s_err.c, which is the only other file to refer to it
151
152         * ircd/s_conf.c (conf_add_deny): use ircd_snprintf() instead of
153         sprintf_irc()
154
155         * ircd/s_bsd.c (connect_server): use ircd_snprintf() instead of
156         sprintf_irc()
157
158         * ircd/s_auth.c: use ircd_snprintf() instead of sprintf_irc()
159
160         * ircd/res.c: use ircd_snprintf() instead of sprintf_irc()
161
162         * ircd/m_version.c: use ircd_snprintf() instead of sprintf_irc()
163
164         * ircd/m_kill.c: use ircd_snprintf() instead of sprintf_irc()
165
166         * ircd/listener.c: use ircd_snprintf() instead of sprintf_irc()
167
168         * ircd/gline.c: use ircd_snprintf() instead of sprintf_irc()
169
170         * ircd/channel.c: don't include sprintf_irc.h; use ircd_snprintf()
171         instead of sprintf_irc()
172
173         * ircd/Makefile.in: remove sprintf_irc.c from sources list; run
174         make depend
175
176         * include/ircd_string.h: remove declaration of sprintf_irc() (what
177         was it doing here anyway?)
178
179         * include/sprintf_irc.h: removed unneeded source file
180
181         * ircd/sprintf_irc.c: removed unneeded source file
182
183         * ircd/s_debug.c (count_memory): remove some dead code
184
185         * ircd/s_auth.c: remove some dead code
186
187         * ircd/res.c (update_list): remove some dead code
188
189         * ircd/m_whowas.c: remove some dead code
190
191         * ircd/m_whois.c: remove some dead code
192
193         * ircd/m_who.c: remove some dead code
194
195         * ircd/m_wallusers.c: remove some dead code
196
197         * ircd/m_wallops.c: remove some dead code
198
199         * ircd/m_wallchops.c: remove some dead code
200
201         * ircd/m_version.c: remove some dead code
202
203         * ircd/m_userip.c: remove some dead code
204
205         * ircd/m_userhost.c: remove some dead code
206
207         * ircd/m_uping.c: remove some dead code
208
209         * ircd/m_trace.c: remove some dead code
210
211         * ircd/m_topic.c: remove some dead code
212
213         * ircd/m_tmpl.c: remove some dead code
214
215         * ircd/m_time.c: remove some dead code
216
217         * ircd/m_squit.c: remove some dead code
218
219         * ircd/m_silence.c: remove some dead code
220
221         * ircd/m_settime.c: remove some dead code
222
223         * ircd/m_set.c: remove some dead code
224
225         * ircd/m_server.c: remove some dead code
226
227         * ircd/m_rpong.c: remove some dead code
228
229         * ircd/m_rping.c: remove some dead code
230
231         * ircd/m_restart.c: remove some dead code
232
233         * ircd/m_reset.c: remove some dead code
234
235         * ircd/m_rehash.c: remove some dead code
236
237         * ircd/m_quit.c: remove some dead code
238
239         * ircd/m_proto.c: remove some dead code
240
241         * ircd/m_privs.c: remove some dead code
242
243         * ircd/m_privmsg.c: remove some dead code
244
245         * ircd/m_pong.c: remove some dead code
246
247         * ircd/m_ping.c: remove some dead code
248
249         * ircd/m_pass.c: remove some dead code
250
251         * ircd/m_part.c: remove some dead code
252
253         * ircd/m_opmode.c: remove some dead code
254
255         * ircd/m_oper.c: remove some dead code
256
257         * ircd/m_notice.c: remove some dead code
258
259         * ircd/m_nick.c: remove some dead code
260
261         * ircd/m_map.c: remove some dead code
262
263         * ircd/m_lusers.c: remove some dead code
264
265         * ircd/m_list.c: remove some dead code
266
267         * ircd/m_links.c: remove some dead code
268
269         * ircd/m_kill.c: remove some dead code
270
271         * ircd/m_kick.c: remove some dead code
272
273         * ircd/m_jupe.c: remove some dead code
274
275         * ircd/m_join.c: remove some dead code
276
277         * ircd/m_ison.c: remove some dead code
278
279         * ircd/m_invite.c: remove some dead code
280
281         * ircd/m_info.c: remove some dead code
282
283         * ircd/m_help.c: remove some dead code
284
285         * ircd/m_gline.c: remove some dead code
286
287         * ircd/m_get.c: remove some dead code
288
289         * ircd/m_error.c: remove some dead code
290
291         * ircd/m_endburst.c: remove some dead code
292
293         * ircd/m_die.c: remove some dead code
294
295         * ircd/m_desynch.c: remove some dead code
296
297         * ircd/m_destruct.c: remove some dead code
298
299         * ircd/m_defaults.c: remove some dead code
300
301         * ircd/m_create.c: remove some dead code, along with an #if 1
302
303         * ircd/m_cprivmsg.c: remove some dead code
304
305         * ircd/m_connect.c: remove some dead code
306
307         * ircd/m_close.c: remove some dead code
308
309         * ircd/m_clearmode.c: remove some dead code
310
311         * ircd/m_burst.c: remove some dead code
312
313         * ircd/m_away.c: remove some dead code
314
315         * ircd/m_admin.c: remove some dead code
316
317         * ircd/listener.c (accept_connection): remove some dead code
318
319         * ircd/ircd_reply.c (need_more_params): remove some dead code
320
321         * ircd/channel.c (add_banid): remove some dead code
322
323         * include/support.h: remove some dead code
324
325         * include/querycmds.h: remove some dead code
326
327         * doc/readme.chroot: document how to do chroot operation
328
329 2001-06-28  Kevin L. Mitchell  <klmitch@mit.edu>
330
331         * ircd/Makefile.in: tune for VPATH builds/installs; add a rule to
332         force bin directory to be created if necessary prior to
333         installation; run make depend
334
335         * doc/Makefile.in (install): tune for VPATH installs by cd'ing to
336         the ${srcdir}
337
338         * Makefile.in: tune to detect Makefile.in changes in
339         subdirectories and to create installation directory indicated by
340         ${prefix}
341
342         * ircd/whocmds.c (count_users): routine to count the number of
343         users matching a given user@host mask
344
345         * ircd/s_err.c: add error messages for ERR_LONGMASK,
346         ERR_TOOMANYUSERS, and ERR_MASKTOOWIDE
347
348         * ircd/m_gline.c: look for and advance past '!' flag on G-lines
349         from operators; only set GLINE_OPERFORCE flag if oper has the
350         PRIV_WIDE_GLINE privilege
351
352         * ircd/ircd_features.c: add GLINEMAXUSERCOUNT, which is the
353         maximum number of users a G-line can impact before it has to be
354         forced; OPER_WIDE_GLINE, to allow operators to use ! to force a
355         wide G-line to be set; and LOCOP_WIDE_GLINE, to allow local
356         operators to use ! to force a wide G-line to be set
357
358         * ircd/gline.c: make make_gline() be called with separate user and
359         host arguments, and not call canon_userhost() directly; implement
360         gline_checkmask() to verify that a host mask is acceptable; move
361         BADCHAN check up in gline_add(), and check passed-in mask under
362         certain circumstances for acceptability; fix call to
363         sendto_opmask_butone() to handle separation of userhost into user
364         and host in gline_add(); update call to make_gline()
365
366         * ircd/client.c: use FEAT_OPER_WIDE_GLINE and
367         FEAT_LOCOP_WIDE_GLINE to set PRIV_WIDE_GLINE for an operator; add
368         PRIV_WIDE_GLINE to privtab[] for client_report_privs()
369
370         * include/whocmds.h (count_users): declare routine to count users
371         matching a given user@host mask
372
373         * include/numeric.h: added three new error returns: ERR_LONGMASK
374         -- mask can't be formatted into a buffer; ERR_TOOMANYUSERS -- too
375         many users would be impacted by the mask; ERR_MASKTOOWIDE -- mask
376         contains wildcards in the wrong places
377
378         * include/ircd_features.h: add FEAT_GLINEMAXUSERCOUNT,
379         FEAT_OPER_WIDE_GLINE, and FEAT_LOCOP_WIDE_GLINE
380
381         * include/gline.h (GLINE_OPERFORCE): provides a way for m_gline()
382         to signal to gline_add() that the operator attempted to force the
383         G-line to be set
384
385         * include/client.h (PRIV_WIDE_GLINE): new privilege for operators
386
387         * doc/readme.gline: update to document new "!" prefix to a G-line
388         user@host mask
389
390         * doc/readme.features: document GLINEMAXUSERCOUNT,
391         OPER_WIDE_GLINE, and LOCOP_WIDE_GLINE
392
393         * doc/example.conf: update to mention new features along with
394         their defaults
395
396 2001-06-27  Kevin L. Mitchell  <klmitch@mit.edu>
397
398         * doc/example.conf: updated example.conf from Braden
399         <dbtem@yahoo.com>
400
401         * include/supported.h: forward-port from pl15
402
403 2001-06-25  Kevin L. Mitchell  <klmitch@mit.edu>
404
405         * ircd/whocmds.c: include ircd_policy.h and implement
406         HEAD_IN_SAND_WHO_OPCOUNT--forward-port from pl15
407
408         * ircd/m_whois.c: forward-port of the idle-time hiding code from
409         pl15; this also required passing parc into do_whois(), which also
410         meant passing parc into do_wilds()--*sigh*
411
412         * include/ircd_policy.h: add a couple more HEAD_IN_SAND
413         #define's--WHOIS_IDLETIME and WHO_HOPCOUNT
414
415 2001-06-22  Kevin L. Mitchell  <klmitch@mit.edu>
416
417         * tools/wrapper.c: add a wrapper program that can be used to
418         adjust file descriptor limits and root directories; program must
419         be run as root--NOT SETUID!--and given appropriate -u arguments
420
421         * doc/readme.log: documentation of how to configure logging
422
423         * doc/readme.features: documentation of each feature (except for
424         logging)
425
426 2001-06-21  Kevin L. Mitchell  <klmitch@mit.edu>
427
428         * Makefile.in (config): add a deprecation notice with a pointer to
429         tools/transition
430
431         * tools/transition: shell script to convert old compile-time
432         options into new compile-time options and appropriate F-lines
433
434         * tools/mkchroot: shell-script to prepare the chroot area by
435         copying over all the necessary libraries so they can be found
436
437 2001-06-20  Kevin L. Mitchell  <klmitch@mit.edu>
438
439         * INSTALL: partial update of INSTALL for u2.10.11 release...
440
441 2001-06-14  Kevin L. Mitchell  <klmitch@mit.edu>
442
443         * ircd/table_gen.c (makeTables): finally got tired of the
444         "overflow in implicit conversion" warning, so just got rid of it
445         by explicitly casting UCHAR_MAX to a (default) char; diffs show no
446         differences in the tables generated
447
448 2001-06-11  Kevin L. Mitchell  <klmitch@mit.edu>
449
450         * ircd/send.c (sendcmdto_match_butone): don't let the server crash
451         if a client is in the STAT_CONNECTING status
452
453 2001-06-10  Kevin L. Mitchell  <klmitch@mit.edu>
454
455         * ircd/send.c: remove unused vsendcmdto_one(), consolidating it
456         into sendcmdto_one(); define new sendcmdto_prio_one(), which
457         places the message into the priority queue
458
459         * ircd/s_user.c (hunt_server_prio_cmd): definition of
460         hunt_server_prio_cmd(), which simply calls sendcmdto_prio_one()
461         instead of sendcmdto_one()
462
463         * ircd/m_settime.c: use sendcmdto_prio_one() and
464         hunt_server_prio_cmd() to send SETTIME
465
466         * ircd/m_server.c: use sendcmdto_prio_one() to send SETTIME
467
468         * include/send.h: removed declaration for unused vsendcmdto_one();
469         added a declaration for sendcmdto_prio_one()
470
471         * include/s_user.h: declare hunt_server_prio_cmd(), which calls
472         sendcmdto_prio_one()
473
474         * ircd/send.c (sendcmdto_flag_butone): oops; /wallops should be
475         put in the server's priority queue, too...
476
477         * ircd/ircd.c: don't check LPATH for accessibility at all
478
479 2001-06-08  Kevin L. Mitchell  <klmitch@mit.edu>
480
481         * ircd/s_serv.c (server_estab): send a +h flag in our SERVER
482         command if we're configured as a hub; send individual server flags
483         in SERVER commands
484
485         * ircd/s_bsd.c (completed_connection): send a +h flag in our
486         SERVER command if we're configured as a hub
487
488         * ircd/m_server.c: implement parv[7] as a mode-like string; +h
489         sets the FLAGS_HUB flag for a server; +s sets the FLAGS_SERVICE
490         flag for a server; +hs sets both flags; also modify CMD_SERVER
491         format string to send the flags
492
493         * include/client.h: define two new flags, FLAGS_HUB and
494         FLAGS_SERVICE to mark services and hubs as such; define testing
495         macros, setting macros
496
497         * ircd/s_user.c: remove deprecated struct Gline* argument to
498         register_user(); remove GLINE rebroadcast; do not send GLINE
499         acknowledgement parameter to NICK; do not look for GLINE
500         acknowledgement parameter to NICK while parsing
501
502         * ircd/s_serv.c (server_estab): remove deprecated struct Jupe*
503         argument to server_estab(); do not send JUPE/GLINE acknowledgement
504         parameters for SERVER or NICK
505
506         * ircd/m_user.c (m_user): remove deprecated argument to
507         register_user()
508
509         * ircd/m_server.c: remove deprecated argument to server_estab();
510         remove documentation comment regarding JUPE acknowledgement
511         parameter to SERVER; remove JUPE rebroadcast
512
513         * ircd/m_pong.c (mr_pong): remove deprecated argument to
514         register_user()
515
516         * ircd/m_nick.c: remove documentation comment regarding GLINE
517         acknowledgement parameter to NICK
518
519         * ircd/jupe.c: use user's real name in JUPE server notices if
520         HEAD_IN_SAND_SNOTICES is defined
521
522         * ircd/ircd.c: remove deprecated chroot() code; remove deprecated
523         setuid code; correct ancient DEBUG vs DEBUGMODE typo
524
525         * ircd/gline.c: use user's real name in GLINE server notices if
526         HEAD_IN_SAND_SNOTICES is defined
527
528         * ircd/channel.c (modebuf_flush_int): make apparent source be
529         local server, not oper's server; use user's real name in hack
530         notices and DESYNC notices if HEAD_IN_SAND_SNOTICES is defined
531
532         * include/s_user.h: remove struct Gline pre-declaration; remove
533         deprecated struct Gline argument from register_user()
534
535         * include/s_serv.h: remove struct Jupe pre-declaration; remove
536         deprecated struct Jupe argument from server_estab()
537
538 2001-06-07  Kevin L. Mitchell  <klmitch@mit.edu>
539
540         * ircd/s_stats.c (hunt_stats): forward-port from pl15 of all the
541         changes required to control remote stats
542
543         * ircd/s_numeric.c (do_numeric): rewrite numeric origins if
544         recipient is not an operator and HEAD_IN_SAND_REWRITE is defined
545         [forward-port from pl15]
546
547         * ircd/m_whowas.c (m_whowas): report server name only if requester
548         is an operator [forward-port from pl15]
549
550         * ircd/m_whois.c (do_whois): /whois <mynick> now correctly reports
551         my server; if HEAD_IN_SAND_REMOTE is 1, ignore the middle argument
552         and obtain the report from the user's server [forward-port from
553         pl15]
554
555         * ircd/m_who.c: add missing include for ircd_policy.h
556         [forward-port from pl15]
557
558         * ircd/m_version.c (m_version): require oper access for remote
559         /version if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
560
561         * ircd/m_time.c (m_time): require oper access for remote /time if
562         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
563
564         * ircd/m_stats.c: pass extra argument to hunt_stats(); correct
565         missing semicolon [forward-port from pl15]
566
567         * ircd/m_nick.c (ms_nick): hide the origin of certain collision
568         kills [forward-port from pl15]
569
570         * ircd/m_motd.c (m_motd): require oper access for remote /motd if
571         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
572
573         * ircd/m_lusers.c (m_lusers): require oper access for remote
574         /lusers if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
575
576         * ircd/m_burst.c (ms_burst): server-added bans are stored using
577         local server name, to hide remote server names; modes also are to
578         originate from the local server [forward-port from pl15]
579
580         * ircd/m_admin.c (m_admin): require oper access for remote /admin
581         if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
582
583         * ircd/channel.c (add_banid): if a server is adding a ban, use my
584         server name to hide the remote server's name [forward-port from
585         pl15]
586
587         * ircd/Makefile.in: ran make depend
588
589         * include/s_stats.h: hunt_stats() has to have an extra argument to
590         support the forward-port from pl15
591
592         * include/ircd_policy.h: #define HEAD_IN_SAND_STATS_P; add
593         HEAD_IN_SAND_{BANWHO,REWRITE,REMOTE} [forward-port from pl15]
594
595         * ircd/engine_poll.c (engine_loop): remove bogus assert that I
596         forgot to check in the events branch
597
598 2001-06-06  Kevin L. Mitchell  <klmitch@mit.edu>
599
600         * ircd/res.c (init_resolver): don't start DNS expires with a 0
601         relative timeout--if the server starts slow, timeouts could be
602         messy...there's probably a better solution, but this'll do for now
603
604         * ircd/os_solaris.c: _XOPEN_SOURCE doesn't get along with Solaris
605         headers very well; include stropts.h; define an os_set_tos()
606
607         * ircd/os_generic.c (os_set_tos): added an os_set_tos() for
608         os_generic.c
609
610         * ircd/ircd.c: if there are no C-lines, we don't want to have a
611         timer that expires at the absolute time of 0--it kinda blocks all
612         the other timers!
613
614         * ircd/engine_devpoll.c: some includes for open(); declare errcode
615         and codesize in engine_loop()
616
617         * ircd/list.c (free_client): remove bogus check on timer active
618         flag
619
620         * ircd/s_auth.c: pull out destruction code in
621         auth_timeout_request() into an externally-visible
622         destroy_auth_request(); manage cli_auth pointer in client
623         structure; use it for an extra assertion check
624
625         * ircd/list.c: include s_auth.h for destroy_auth_request(); add
626         debugging notices to show flow when deallocating
627         connections/clients; call destroy_auth_request() when free'ing a
628         client that has an auth outstanding; don't free the connection if
629         the process timer is unmarked but still active
630
631         * ircd/ircd_events.c: set GEN_ACTIVE when initializing a generator
632         and reset it before calling the event handler for an ET_DESTROY
633         event
634
635         * include/s_auth.h (destroy_auth_request): declare
636         destroy_auth_request(), which can be used to destroy an
637         outstanding auth request if a client socket goes away before the
638         auth exchange is completed
639
640         * include/ircd_events.h: add an active flag to keep track of
641         whether or not particular generators are active, for the
642         convenience of functions using the API
643
644         * include/client.h: add a pointer for auth requests to struct
645         Connection so we can kill outstanding auth requests if a client
646         socket closes unexpectedly
647
648         * ircd/s_bsd.c: cli_connect() could become 0 during the course of
649         the sock or timer callback; take that into account in the assert
650
651         * ircd/list.c: add magic number checking and setting--magic
652         numbers are zero'd on frees to detect double-frees; add back
653         setting of cli_from() to 0 to break the back-link from the struct
654         Connection (duh)
655
656         * ircd/ircd.c: set me's magic number correctly
657
658         * include/client.h: define magic numbers and accessor/verifier
659         macros
660
661         * ircd/list.c: assert that dealloc_client() is called with
662         cli_connect(cptr) == 0; set cli_connect(cptr) to 0 before calling
663         dealloc_client(); don't mess with cli_from(cptr)
664
665         * ircd/s_bsd.c: only attempt to dealloc a connection if the
666         associated client has already been destroyed, or at least delinked
667
668 2001-06-05  Kevin L. Mitchell  <klmitch@mit.edu>
669
670         * ircd/list.c (free_client): only try to delete the socket when
671         the fd hasn't already been closed, avoiding a double-free
672
673         * ircd/list.c (free_connection): make sure the client is really
674         gone before doing away with the connection
675
676         * ircd/s_bsd.c: record that socket has been added in con_freeflag
677         field; queue a socket_del() as soon as the socket is close()'d;
678         use con_freeflag & FREEFLAG_TIMER instead of con_timer; clear
679         FREEFLAG_SOCKET on ET_DESTROY event in client_sock_callback(),
680         then dealloc the connection if safe; mark socket as dead when
681         there's a read error or EOF; clear FREEFLAG_TIMER flag upon entry
682         to client_timer_callback(); dealloc connection if safe upon
683         ET_DESTROY event in client_timer_callback()
684
685         * ircd/list.c: use con_freeflag instead of con_timer; only dealloc
686         the connection if both socket and timer have been destroyed;
687         destroy both socket and timer explicitly and carefully
688
689         * include/client.h: replace the con_timer field with a
690         con_freeflag field, to indicate what still needs freeing; define
691         the freeflags
692
693         * ircd/engine_select.c (engine_loop): duh...sockList[i] could
694         become 0
695
696         * ircd/engine_devpoll.c (engine_loop): duh...sockList[i] could
697         become 0
698
699         * ircd/s_bsd.c: add some extra assertions to try to track down a
700         corruption problem
701
702         * ircd/engine_select.c (engine_loop): add an extra assert to try
703         to track down a corruption problem
704
705         * ircd/engine_poll.c (engine_loop): add an extra assert to try to
706         track down a corruption problem
707
708         * ircd/engine_kqueue.c (engine_loop): add an extra assert to try
709         to track down a corruption problem
710
711         * ircd/engine_devpoll.c (engine_loop): skip slots that have become
712         empty during processing; add an extra assert to try to track down
713         a corruption problem
714
715         * ircd/engine_kqueue.c (engine_delete): make sure to zero deleted
716         entries
717
718 2001-06-04  Kevin L. Mitchell  <klmitch@mit.edu>
719
720         * ircd/s_bsd.c (client_sock_callback): client is no longer
721         blocked, so we must mark it as unblocked
722
723         * ircd/engine_select.c: add Debug() calls galore; add handling for
724         SS_NOTSOCK; use a dummy sock variable to keep things from
725         disappearing on us; correct timeout calculation; update nfds for
726         efficiency
727
728         * ircd/engine_poll.c: use new debugging level (DEBUG_ENGINE);
729         remove a spurious "if (sock)" which will always be true; update
730         nfds for efficiency
731
732         * ircd/engine_kqueue.c: add Debug() calls galore; add handling for
733         SS_NOTSOCK (just in case); correct timeout calculation
734
735         * ircd/engine_devpoll.c: add Debug() calls galore; add handling
736         for SS_NOTSOCK; correct timeout calculation; add EAGAIN handling
737
738         * include/s_debug.h (DEBUG_ENGINE): add new debugging level;
739         pretty-indent numbers
740
741         * ircd/engine_poll.c (engine_loop): break out SS_NOTSOCK
742         case--it's not a socket; the check for writability is most likely
743         not needed, but present for completeness
744
745 2001-05-24  Kevin L. Mitchell  <klmitch@mit.edu>
746
747         * ircd/s_bsd.c: add Debug messages; call read_packet() even if the
748         no newline flag is set; call read_packet() when the timer expires,
749         regardless of what's in the buffer--read_packet() should be able
750         to deal properly
751
752         * ircd/IPcheck.c (ip_registry_connect_succeeded): correct a NOTICE
753         sent to clients to include the client nickname (duh)
754
755         * ircd/ircd_events.c: don't destroy a timer if it's already marked
756         for destruction; replace a missing ! in socket_del()
757
758         * ircd/engine_poll.c (engine_loop): reference a temporary variable
759         so we don't have to worry about sockList[i] going away
760
761         * ircd/s_bsd.c (client_sock_callback): add Debug messages
762
763         * ircd/s_auth.c: add Debug messages all over the place
764
765         * ircd/ircd_events.c: add and edit some Debug messages; add a list
766         of routines to convert some of the enums and flags from numbers
767         into human-readable strings for the Debug messages
768
769         * ircd/engine_poll.c: hack some Debug messages to use the new name
770         conversion routines in ircd_events.c; add an extra assert for a
771         condition that shouldn't ever happen; apparently recv() can return
772         EAGAIN when poll() returns readable--I wonder why...
773
774         * include/ircd_events.h: declare some helper routines under
775         DEBUGMODE
776
777 2001-05-23  Kevin L. Mitchell  <klmitch@mit.edu>
778
779         * ircd/s_bsd.c (client_sock_callback): add an extra assertion
780         check
781
782         * ircd/s_auth.c: add more Debug messages
783
784         * ircd/list.c (make_client): add an extra assertion check
785
786         * ircd/ircd_events.c (socket_events): don't call the engine events
787         changer if we haven't actually made any changes to the event mask
788
789         * ircd/uping.c: add some Debug messages
790
791         * ircd/s_stats.c: document new /STATS e
792
793         * ircd/s_err.c: add RPL_STATSENGINE to report the engine name
794
795         * ircd/s_bsd.c: remove static client_timer variable; in
796         read_packet(), if there's still data in the client's recvQ after
797         parsing, add a 2 second timer (con_proc); fix the ET_DESTROY case
798         of client_sock_callback to handle destroying the timer properly;
799         rewrote client_timer_callback from scratch to be called on an
800         individual client
801
802         * ircd/m_stats.c: add /STATS e to report the engine name
803
804         * ircd/list.c: deal with con_timer field in struct Connection
805         properly; correct a core-level bug in remove_client_from_list--if
806         the client is the only one in the list, we try to update
807         GlobalClientList's cli_prev pointer--not good
808
809         * ircd/ircd.c: remove call to init_client_timer()
810
811         * ircd/engine_poll.c: made Debug messages more uniform by
812         prepending "poll:" to them all; corrected an off-by-one error that
813         caused poll_count to be 1 less than the actual count and removed
814         my work-around; added Debug messages to indicate which socket is
815         being checked and what the results are
816
817         * ircd/Makefile.in: ran a make depend
818
819         * include/s_bsd.h: remove init_client_timer(), since we're doing
820         it differently now
821
822         * include/numeric.h (RPL_STATSENGINE): a stats reply to report the
823         engine name
824
825         * include/ircd_policy.h (HEAD_IN_SAND_STATS_E): turn off /stats e
826         reports for non-opers
827
828         * include/client.h: add con_timer and con_proc fields to struct
829         Connection and define accessor macros--con_timer marks that
830         con_proc contains a valid timer, and con_proc is used to pace user
831         data
832
833         * ircd/s_bsd.c (close_connection): let free_client() destroy the
834         socket
835
836         * ircd/s_auth.c (start_auth): add a Debug call to indicate when
837         auth has begun on a client
838
839         * ircd/ircd_events.c: ensure that event_execute() is called with a
840         non-NULL event; modify event_add() macro to properly zero list
841         bits; modify gen_dequeue() to not try to clip it out of a list
842         it's already been clipped out of; change signal socket
843         initialization to use state SS_NOTSOCK; permit timeout values of
844         0 in add_timer(); add many Debug calls; change socket_del() and
845         timer_del() to always set the GEN_DESTROY flag; use GEN_MARKED in
846         timer_run() instead of GEN_DESTROY so that event_generate() will
847         pass on the events; remove the switch and replace with a simpler
848         if-then-else tree in timer_run(); don't allow destroyed sockets to
849         be destroyed again, nor their states or event masks to be changed
850
851         * ircd/ircd.c: initialize "running" to 1
852
853         * ircd/engine_poll.c: deal with SS_NOTSOCK "sockets"; add Debug
854         messages all over the place; fix a counting problem in
855         engine_add(); turn wait into a signed integer and set it to -1
856         only if timer_next() returns 0; adjust wait time to be relative;
857         don't call gen_ref_dec() if socket disappeared while we were
858         processing it
859
860         * include/ircd_events.h: the pipe for signals is not a socket, so
861         we must mark it as such--added SS_NOTSOCK for that special socket;
862         events won't be generated if GEN_DESTROY is on, so add GEN_MARKED
863         for the benefit of timer_run()
864
865         * configure.in: add --enable-pedantic and --enable-warnings to
866         turn on (and off) -Wall -pedantic in CFLAGS
867
868 2001-05-21  Kevin L. Mitchell  <klmitch@mit.edu>
869
870         * ircd/s_conf.c: change "s_addr" element accesses to "address"
871         element accesses
872
873         * include/s_conf.h: on some systems, "s_addr" is a macro; use
874         "address" instead
875
876 2001-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
877
878         * ircd/engine_kqueue.c: include ircd_alloc.h; set_or_clear returns
879         void in this file; add a missing semi-colon; declare errcode,
880         codesize
881
882         * ircd/uping.c (uping_sender_callback): it's pptr, not uping
883
884         * ircd/s_user.c (register_user): comment out spurious reference to
885         nextping
886
887         * ircd/s_serv.c (server_estab): comment out spurious reference to
888         nextping
889
890         * ircd/s_conf.c (read_configuration_file): comment out spurious
891         reference to nextping and nextconnect
892
893         * ircd/s_bsd.c: comment out some spurious references to formerly
894         global (now non-existant) variables; correct a couple of typos
895
896         * ircd/s_auth.c: pre-declare some functions referenced in the
897         callback; correct a typo
898
899         * ircd/res.c (start_resolver): pass errno value of ENFILE
900
901         * ircd/listener.c (accept_connection): you know your API is messed
902         up when...variables that shouldn't have been global crop up in
903         other files
904
905         * ircd/list.c (free_client): substitution of == for =
906
907         * ircd/ircd_signal.c: include assert.h for assertion checking;
908         check ev_data() to find out what signal generated event
909
910         * ircd/ircd_events.c: some references to the variable "timer"
911         should have been references to the variable "ptr"
912
913         * ircd/engine_select.c: it's struct fd_set, not struct fdset;
914         ev_timer(ev) is already a timer pointer; declare codesize as a
915         size_t to correct signedness issue; use timer_next(), not
916         time_next()
917
918         * ircd/engine_poll.c: ev_timer(ev) is already a timer pointer;
919         select fd out of struct pollfd in assertion checking; declare
920         errcode and codesize; use timer_next(), not time_next()
921
922         * ircd/engine_kqueue.c: ev_timer(ev) is already a timer pointer;
923         use function timer_next(), not time_next()
924
925         * ircd/engine_devpoll.c: ev_timer(ev) is already a timer pointer;
926         use function timer_next(), not time_next()
927
928         * ircd/Makefile.in (IRCD_SRC): add ircd_events.c to the list of
929         compiled sources; do make depend
930
931         * include/list.h: pre-declare struct Connection
932
933         * include/ircd_events.h (gen_ref_inc): cast to the right structure
934         name
935
936         * include/s_auth.h: duh; missing */
937
938 2001-05-10  Kevin L. Mitchell  <klmitch@mit.edu>
939
940         * ircd/send.c: update write events status after sending data or
941         accumulating data to be sent
942
943         * ircd/m_list.c (m_list): update write events status after
944         canceling a running /list
945
946         * ircd/channel.c (list_next_channels): update write events status
947         after listing a few channels
948
949         * ircd/s_bsd.c: extensive changes to update to new events model;
950         remove on_write_unblocked() and the two implementations of
951         read_message(), which have been deprecated by this change
952
953         * ircd/s_auth.c: set the socket events we're interested in for
954         clients; simplify some logic that does the connect_nonb followed
955         by the socket_add
956
957         * ircd/list.c: define free_connection() to free a connection
958         that's become freeable once the struct Socket has been
959         deallocated; fix up free_client() to take this new behavior into
960         account
961
962         * ircd/ircd.c: call init_client_timer()
963
964         * include/s_bsd.h: declare new REGISTER_ERROR_MESSAGE when unable
965         to register connect-in-progress with events system; declare
966         init_client_timer() (HACK!) to preserve rate-limiting behavior
967
968         * include/list.h: declare new free_connection()
969
970         * include/client.h: add a struct Socket to struct Connection
971
972 2001-05-09  Kevin L. Mitchell  <klmitch@mit.edu>
973
974         * ircd/ircd_signal.c: massage the handlers for SIGHUP, SIGINT, and
975         SIGTERM into event callbacks; perform the actions in the
976         callbacks, since they're not called in the context of the signal;
977         set up the signal callbacks in the event engine
978
979         * ircd/ircd_events.c (signal_callback): we're supposed to look for
980         a specific signal; don't generate an event if there is no signal
981         structure for it
982
983         * ircd/ircd.c: nuke nextconnect and nextping and replace them with
984         connect_timer and ping_timer; massage try_connections() and
985         check_pings() into timer callbacks that re-add themselves at the
986         right time; remove ircd.c's "event_loop()"; initialize the event
987         system and the connect_timer and ping_timer
988
989         * ircd/uping.c: correct a couple more typos
990
991         * ircd/s_auth.c: rework to use new events system
992
993         * ircd/os_solaris.c (os_connect_nonb): update to new interface
994
995         * ircd/os_openbsd.c (os_connect_nonb): update to new interface
996
997         * ircd/os_linux.c (os_connect_nonb): update to new interface
998
999         * ircd/os_generic.c (os_connect_nonb): update to new interface
1000
1001         * ircd/os_bsd.c (os_connect_nonb): update to new interface
1002
1003         * include/s_auth.h: remove deprecated members of struct
1004         AuthRequest, replacing them with struct Socket and struct Timer
1005         structures; add flags to indicate when these structures have been
1006         released by the event system; remove the deprecated
1007         timeout_auth_queries()
1008
1009         * include/ircd_osdep.h (os_connect_nonb): connect could complete
1010         immediately, so change the interface to handle that possibility
1011
1012         * ircd/uping.c (uping_server): noticed and corrected a typo
1013
1014         * ircd/listener.c: set up to use ircd_event's struct Socket by
1015         adding an socket_add() call to inetport(), replacing
1016         free_listener() with socket_del() in close_listener(), and
1017         reworking accept_connection to be called as the callback
1018
1019         * ircd/ircd.c: add a call to IPcheck_init()
1020
1021         * ircd/IPcheck.c: remove IPcheck_expire(); rework
1022         ip_registry_expire() to be called from a timer; write
1023         IPcheck_init() to set up the expiration timer (hard-coded for a
1024         60-second expiration time)
1025
1026         * include/listener.h: add a struct Socket to the struct Listener;
1027         remove accept_connection()
1028
1029         * include/IPcheck.h: add IPcheck_init(), remove IPcheck_expire()
1030
1031 2001-05-08  Kevin L. Mitchell  <klmitch@mit.edu>
1032
1033         * ircd/ircd_events.c: include config.h; use USE_KQUEUE and
1034         USE_DEVPOLL instead of HAVE_KQUEUE and HAVE_DEVPOLL_H
1035
1036         * ircd/engine_select.c: include config.h; set FD_SETSIZE to
1037         MAXCONNECTIONS, not IRCD_FD_SETSIZE...
1038
1039         * ircd/engine_poll.c: include config.h
1040
1041         * ircd/engine_kqueue.c: include config.h
1042
1043         * ircd/engine_devpoll.c: include config.h
1044
1045         * ircd/Makefile.in: include engine sources in compilation and make
1046         depend steps
1047
1048         * configure.in: add checks for enabling the /dev/poll- and
1049         kqueue-based engines
1050
1051         * acconfig.h: add lines for USE_DEVPOLL and USE_KQUEUE
1052
1053         * ircd/Makefile.in: work in the engine sources
1054
1055 2001-05-07  Kevin L. Mitchell  <klmitch@mit.edu>
1056
1057         * ircd/m_settime.c: include ircd_snprintf.h
1058
1059         * ircd/ircd_relay.c: stomp a couple of gcc warnings suggesting
1060         parens around a construct that had both || and &&
1061
1062         * ircd/chkconf.c: #include "config.h" to get some important
1063         definitions
1064
1065         * ircd/Makefile.in: revamp ircd makefile for new build system
1066
1067         * doc/Makefile.in: revamp doc makefile for new build system
1068
1069         * config/*: Removed old build system files
1070
1071         * stamp-h.in: a stamp file
1072
1073         * install-sh: install-sh for new build system
1074
1075         * configure.in: configure.in for new build system
1076
1077         * configure: configure script for new build system (built by
1078         autoconf)
1079
1080         * config.sub: config.sub for new build system
1081
1082         * config.h.in: config.h.in for new build system (built by
1083         autoheader)
1084
1085         * config.guess: config.guess for new build system
1086
1087         * aclocal.m4: aclocal.m4 for new build system (built by aclocal
1088         1.4)
1089
1090         * acinclude.m4: aclocal.m4 macros for new build system
1091
1092         * acconfig.h: config.h skeleton for new build system
1093
1094         * Makefile.in: modify for new build system
1095
1096 2001-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
1097
1098         * ircd/s_err.c: get rid of the last vestiges of TIME_T_FMT
1099
1100         * ircd/m_settime.c: get rid of the last vestiges of TIME_T_FMT
1101
1102         * ircd/m_server.c: get rid of the last vestiges of TIME_T_FMT
1103
1104 2001-05-01  Perry Lorier       <Isomer@coders.net>
1105         * doc/iauth.doc: Protocol for iauth server. (from hybrid).
1106         * doc/linux-poll.patch: Patch to make Linux under 2.2 not deadlock
1107                 when you have far far too many sockets in use.
1108         * {include,ircd}/iauth.c: A start on iauth support.
1109
1110 2001-05-01  Perry Lorier       <Isomer@coders.net>
1111         * ircd/s_err.c: Suggested wording change.
1112         * ircd/s_user.c: Users aren't target limited against +k users.
1113         * ircd/chkconf.c: Made it compile again, who knows if it works, but
1114                 now I can at least make install
1115         * various: Cleanups on m_*.c files.
1116
1117
1118 2001-04-23  Kevin L. Mitchell  <klmitch@mit.edu>
1119
1120         * ircd/s_misc.c (exit_client): make netsplit server notice say the
1121         right thing
1122
1123         * ircd/m_links.c (m_links_redirect): forward-port RPL_ENDOFLINKS
1124         change to make Khaled happy...
1125
1126         * ircd/m_whois.c (do_whois): pull-up of m_whois() fix
1127         (do_whois): duh...
1128
1129 2001-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
1130
1131         * ircd/msgq.c: finally remove the msgq_integrity() hack, as it's
1132         turned up no more bugs
1133
1134         * ircd/ircd.c: use /* */ comments instead of // comments--all the
1135         world's not gcc :(
1136
1137         * ircd/s_conf.c (conf_add_server): use /* */ comments instead of
1138         // comments--all the world's not gcc :(
1139
1140         * ircd/runmalloc.c: finally garbage-collect unused file
1141
1142         * include/runmalloc.h: finally garbage-collect unused file
1143
1144         * ircd/<multiple files>: addition of '#include "config.h"' before
1145         all other includes in most .c files
1146
1147         * include/<multiple files>: remove includes of config.h, which are
1148         now going into the raw .c files
1149
1150 2001-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
1151
1152         * ircd/m_whois.c (do_whois): display proper server name if the
1153         user is looking up himself
1154
1155         * ircd/m_who.c (m_who): disable match by servername or display of
1156         server names by non-opers
1157
1158         * include/ircd_policy.h: add define for
1159         HEAD_IN_SAND_WHO_SERVERNAME to cover full intent of sub-motion 15
1160         of CFV 165
1161
1162 2001-04-18  Kevin L. Mitchell  <klmitch@mit.edu>
1163
1164         * ircd/s_conf.c: keep the $R in memory so we can see it clearly
1165         when we do a /stats k
1166
1167         * ircd/s_user.c (set_user_mode): pull-up of changes to prevent
1168         users from turning on +s and +g
1169
1170         * ircd/s_misc.c (exit_client): pull-up of changes to turn off
1171         net.split notice
1172
1173         * ircd/parse.c: pull-up of changes to disable /trace, /links, and
1174         /map for users
1175
1176         * ircd/m_whois.c (do_whois): pull-up of server name masking for
1177         /whois
1178
1179         * ircd/m_user.c (m_user): removal of umode and snomask defaulting
1180         functions, pull-up
1181
1182         * ircd/m_stats.c (m_stats): pull-up of stats-disabling stuff
1183
1184         * ircd/m_map.c (m_map_redirect): pull-up of m_map_redirect()
1185
1186         * ircd/m_links.c (m_links_redirect): pull-up of m_links_redirect()
1187
1188         * ircd/channel.c (channel_modes): pull-up of channel key display
1189         as *
1190
1191         * include/ircd_policy.h: pull-up of ircd_policy.h
1192
1193         * include/client.h: pull-up of Set/ClearServNotice()
1194
1195         * ircd/gline.c (do_gline): report client name in G-line message
1196         (pull-up)
1197
1198         * ircd/s_user.c (register_user): pull-up--show IP address in some
1199         server notices dealing only with users; report which connection
1200         class has filled up
1201
1202         * ircd/s_stats.c (report_deny_list): use conf->flags &
1203         DENY_FLAGS_IP insteaf of conf->ip_kill
1204
1205         * ircd/m_stats.c (report_klines): use conf->flags & DENY_FLAGS_IP
1206         insteaf of conf->ip_kill
1207
1208         * ircd/s_conf.c: use flags field in struct DenyConf; pull-up of
1209         K-line by real name
1210
1211         * include/s_conf.h: use a flags field in struct DenyConf; define
1212         DENY_FLAGS_FILE, DENY_FLAGS_IP, and DENY_FLAGS_REALNAME for
1213         pull-up of K-line by real name
1214
1215         * ircd/m_trace.c: pull-up of IP show for user connections
1216
1217         * doc/example.conf: pull-up of the realname K-line documentation
1218
1219         * ircd/ircd.c: forward port of pid file advisory locking mechanism
1220
1221 2001-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
1222
1223         * ircd/send.c (sendcmdto_flag_butone): recast to just broadcast to
1224         all servers, rather than to only servers that have +w/+g/whatever
1225         users on them; among other things, this removes that atrocity
1226         known as sentalong[] from this function
1227
1228         * ircd/m_admin.c: must include ircd.h to declare "me"; must
1229         include hash.h to declare FindUser()
1230
1231         * ircd/m_wallusers.c: implementation of WALLUSERS
1232
1233         * ircd/m_desynch.c (ms_desynch): only send DESYNCHs to opers
1234
1235         * ircd/m_wallops.c: only send WALLOPS to opers
1236
1237         * ircd/parse.c: add WALLUSERS command to parser table
1238
1239         * include/handlers.h: declare wallusers handlers
1240
1241         * include/msg.h: add WALLUSERS command
1242
1243         * ircd/send.c (sendcmdto_flag_butone): if FLAGS_OPER is or'd with
1244         flag, send only to appropriate opers
1245
1246 2001-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
1247
1248         * ircd/uping.c: refit to use the new events interface
1249
1250         * ircd/res.c: refit to use the new events interface
1251
1252         * ircd/ircd_events.c: create timer_chg(), which permits a
1253         (non-periodic) timer's expire time to be modified; change the
1254         logic in timer_run() so that timers that were re-added while the
1255         event was being processed will not be destroyed prematurely
1256
1257         * include/uping.h: include the events header, declare some extra
1258         fields in struct UPing, remove timeout value, and define some
1259         flags for marking which cleanup items have yet to be done
1260
1261         * include/ircd_events.h: add a prototype for timer_chg() to change
1262         the expire time of a running timer
1263
1264 2001-03-13 Joseph Bongaarts <foxxe@wtfs.net>
1265         * ircd/os_openbsd.c: Tweaked the openbsd hack a bit.
1266         
1267 2001-03-07  Joseph Bongaarts  <foxxe@wtfs.net>
1268
1269         * config/configure.in: Add check for OpenBSD
1270
1271         * ircd/os_openbsd.c: Add seperate os dep file for openbsd which
1272         differs from generic BSD, particularly in its handling of
1273         _XOPEN_SOURCE.
1274         
1275 2001-02-12  Kevin L. Mitchell  <klmitch@mit.edu>
1276
1277         * ircd/m_gline.c (ms_gline): propagate a G-line that happened to
1278         have been added by a U-lined server, rather than going through the
1279         activate/deactivate logic; propagate G-line removals by U-lined
1280         servers as well
1281
1282         * ircd/gline.c: rename propagate_gline() to gline_propagate();
1283         make gline_propagate() return an int 0 (convenience return); only
1284         update lastmod in gline_activate() and gline_deactivate() if the
1285         current lastmod is non-zero, since 0 lastmod is our flag of a
1286         U-lined server having added a G-line
1287
1288         * include/gline.h (gline_propagate): exporting the G-line
1289         propagation function
1290
1291         * ircd/m_list.c (m_list): duh; permit explicit channel name
1292         specification only when /list gets two arguments ("Kev
1293         #wasteland") rather than when /list gets more than two
1294         arguments--nice braino
1295
1296 2001-01-29  Thomas Helvey <twhelvey1@home.com>
1297
1298         * ircd/ircd_reply.c (need_more_params): fix bug that allowed
1299         unregistered clients to spam opers with protocol violation
1300         messages. Note: the bugfix may have eliminated some useful
1301         protocol violation messages.
1302         Please send protocol violation messages explicitly from the
1303         functions they are discovered in, you have much better context
1304         for the error there and it helps to document the behavior of the
1305         server. This was also a design bug in that it violated the
1306         "A function should do one thing" heuristic. Patching this one
1307         would have resulted in a continuous spawning of other bugs over
1308         the next 3 years, so I killed it. Check around for stuff this
1309         broke and readd the calls to protocol_violation in the functions
1310         that need to send the message.
1311
1312 2001-01-29  Kevin L. Mitchell  <klmitch@mit.edu>
1313
1314         * ircd/channel.c (mode_parse_ban): stopper a tiny leak--if a ban
1315         already existed, then the logic would (attempt to) skip it, but
1316         would not free the ban string; now the ban string is free'd and
1317         the ban count is decremented, releasing the ban for use
1318
1319         * ircd/s_user.c: make send_umode_out() take a prop argument
1320         instead of testing for the PRIV_PROPAGATE privilege itself; fix
1321         set_umode() to use this new argument, calculating it before
1322         calculating the new privileges for a -o'd user
1323
1324         * ircd/m_oper.c (m_oper): pass the new prop argument to
1325         send_umode_out()
1326
1327         * ircd/channel.c (mode_parse_ban): turn off MODE_ADD bit in bans
1328         that we're not actually going to add because they already exist;
1329         test that particular bit before adding to the linked list
1330
1331         * include/s_user.h: add a prop argument to send_umode_out() to
1332         indicate whether or not to propagate the user mode
1333
1334 2001-01-24  Kevin L. Mitchell  <klmitch@mit.edu>
1335
1336         * ircd/msgq.c: ircd_vsnprintf() returns the number of bytes that
1337         it would have written; upper-bound the number to prevent overflows
1338         by proxy; also, tune buffer size given to ircd_vsnprintf() to take
1339         into account the fact that ircd_vsnprintf() already takes the
1340         terminal \0 into account
1341
1342 2001-01-22  Kevin L. Mitchell  <klmitch@mit.edu>
1343
1344         * ircd/msgq.c: add an incredibly ugly hack to attempt to track
1345         down an apparent buffer overflow; remove msgq_map(), since it's no
1346         longer used anywhere; slight tweaks to prevent off-by-one errors,
1347         but these can't explain the problems we've seen
1348
1349         * include/msgq.h: remove msgq_map(), since it's no longer used
1350         anywhere
1351
1352 2001-01-18  Kevin L. Mitchell  <klmitch@mit.edu>
1353
1354         * ircd/s_user.c (set_nick_name): call client_set_privs() after
1355         parsing user modes
1356
1357 2001-01-17  Kevin L. Mitchell  <klmitch@mit.edu>
1358
1359         * ircd/s_bsd.c (read_message): fix a typo in the select version of
1360         read_message()
1361
1362         * ircd/whowas.c (whowas_free): MyFree() is a macro that expects
1363         its argument to be an lvalue, which means we can't use
1364         whowas_clean()'s handy-dandy "return ww" feature
1365
1366         * ircd/ircd_features.c: default LOCOP_KILL to TRUE--oops...
1367
1368 2001-01-16  Kevin L. Mitchell  <klmitch@mit.edu>
1369
1370         * ircd/ircd_events.c (timer_run): it's possible that the timer got
1371         deleted during the callback processing, so don't go to the bother
1372         of requeuing it if the destroy flag is set
1373
1374         * ircd/engine_select.c: define FD_SETSIZE to be IRCD_FD_SETSIZE
1375         out of config.h if this is a *BSD; include errno.h (oops);
1376         decrement error count after an hour using a timer; use FD_SETSIZE
1377         constant instead of IRCD_FD_SETSIZE constant; fill in event
1378         processing code
1379
1380         * ircd/engine_poll.c: include errno.h (oops); decrement error
1381         count after an hour using a timer; fill in event processing code
1382
1383         * ircd/engine_kqueue.c: include errno.h (oops); decrement error
1384         count after an hour using a timer; assert events filter is either
1385         EVFILT_READ or EVFILT_WRITE; fill in event processing code
1386
1387         * ircd/engine_devpoll.c: include errno.h (oops); decrement error
1388         count after an hour using a timer; fill in event processing code
1389
1390 2001-01-15  Kevin L. Mitchell  <klmitch@mit.edu>
1391
1392         * ircd/client.c: fixed feattab; basically, when I changed features
1393         to use small integers specifying bit positions, instead of the
1394         bits themselves, I forgot to update feattab to not | these
1395         privileges together; also fixed a bug in the antiprivs masking
1396         loop in client_set_privs()--last index wouldn't get parsed
1397
1398 2001-01-11  Kevin L. Mitchell  <klmitch@mit.edu>
1399
1400         * ircd/ircd_events.c: call event_generate() with new data
1401         argument; make it set that field in struct Event; make
1402         socket_add() return the value of the eng_add callback
1403
1404         * ircd/engine_select.c: make engine_add() return a
1405         successful/unsuccessful status; add bounds-checking outside of an
1406         assert; use accessor macros; use log_write(), not the deprecated
1407         ircd_log(); add an assert to engine_loop() to double-check for
1408         data structure corruption
1409
1410         * ircd/engine_poll.c: make engine_add() return a
1411         successful/unsuccessful status; add bounds-checking outside of an
1412         assert; use accessor macros; use log_write(), not the deprecated
1413         ircd_log(); add an assert to engine_loop() to double-check for
1414         data structure corruption
1415
1416         * ircd/engine_kqueue.c: implementation of an engine for kqueue()
1417
1418         * ircd/engine_devpoll.c: implementation of an engine for /dev/poll
1419
1420         * include/ircd_events.h: define some accessor macros; add ev_data
1421         to struct Event for certain important data--errno values, for
1422         instance; make EngineAdd callback tell us if it was successful or
1423         not; add extra argument to event_generate(); make socket_add()
1424         return the status from EngineAdd
1425
1426 2001-01-10  Kevin L. Mitchell  <klmitch@mit.edu>
1427
1428         * ircd/ircd_events.c: pass initializer information about how many
1429         total _filedescriptors_ may be opened at once
1430
1431         * ircd/ircd.c: use exported "running" instead of unexported
1432         thisServer.running
1433
1434         * ircd/engine_select.c: implementation of an event engine based on
1435         select()
1436
1437         * ircd/engine_poll.c: implementation of an event engine based on
1438         poll()
1439
1440         * include/ircd_events.h: pass the engine initializer an integer
1441         specifing how many _filedescriptors_ may be opened at once
1442
1443         * include/ircd.h: running has to be exported for the engine_*
1444         event loops
1445
1446 2001-01-09  Kevin L. Mitchell  <klmitch@mit.edu>
1447
1448         * ircd/ircd_events.c: include some needed headers; add some
1449         comments; make evEngines[] const; bundle sig_sock and sig_fd into
1450         a struct named sigInfo; rework struct evInfo to have a queue of
1451         _generators_, and only when threaded; added a gen_init() function
1452         to centralize generator initialization; fix various compile-time
1453         errors; rework event_add() for new queueing scheme and checked for
1454         compile-time errors; add casts where needed; spell evEngines[]
1455         correctly; make engine_name() return const char*
1456
1457         * include/ircd_events.h: type EventCallBack depends on struct
1458         Event, so pre-declare it; put _event_ queue into generators, and
1459         only when threaded; give engine data a union to store both ints
1460         and pointers; make engine name a const; fix gen_ref_dec() macro;
1461         make engine_name() return a const char*
1462
1463         * ircd/ircd_events.c: gen_dequeue() is now exported, so move it
1464         down with the non-static functions; modify event_execute() to use
1465         the new gen_ref_dec() to simplify code; make sure event_generate()
1466         does not generate new events for generators marked for destruction
1467
1468         * include/ircd_events.h: the engines, at least, may need to modify
1469         reference counts to keep generators from going away while
1470         something still points at them, so add reference counter
1471         manipulators and export gen_dequeue() for them
1472
1473         * ircd/ircd_events.c: set up the list of engines to try; set up
1474         the signal struct Socket; rename netInfo to evInfo; move static
1475         functions near the beginning of the file; do away with
1476         signal_signal() (since we no longer keep a signal count ourselves)
1477         and call event_generate() directly from signal_callback--also
1478         renamed some functions; allow signal_callback() to read up to
1479         SIGS_PER_SOCK at once from the signal pipe; add event_init() to
1480         initialize the entire event system; add event_loop() to call the
1481         engine's event loop; initialize new struct GenHeader member,
1482         gh_engdata; remove timer_next(); add socket_add() function to add
1483         a socket; add socket_del() to mark a socket for deletion; add
1484         socket_state() to transition a socket between states; add
1485         socket_events() to set what events we're interested in on the
1486         socket; add engine_name() to retrieve event engine's name
1487
1488         * include/ircd_events.h: add engine data field to struct
1489         GenHeader; rename SOCK_ACTION_REMOVE to SOCK_ACTION_DEL; add a
1490         note about states vs s_events; remove signal count; fold union
1491         Generator back into struct Event; remove count members from struct
1492         Generators; redefine engine callbacks to not take a struct
1493         Engine*; add explanatory comments to callback definitions; add
1494         some engine callbacks to handle operations; remove struct Engine
1495         flag member--can detect single flag from eng_signal member; add
1496         event_init(), event_loop(), engine_name(), and the socket_*()
1497         functions; make timer_next() a macro to avoid a function call
1498
1499 2001-01-08  Kevin L. Mitchell  <klmitch@mit.edu>
1500
1501         * include/ircd_events.h: rename to ircd_events.h, since it handles
1502         events, not just networking stuff; add signal support; more
1503         structural rearrangement
1504
1505         * ircd/ircd_events.c: rename to ircd_events.c, since it handles
1506         events, not just networking stuff; add signal support; more
1507         structural rearrangement
1508
1509 2001-01-07  Kevin L. Mitchell  <klmitch@mit.edu>
1510
1511         * ircd/ircd_network.c: implement timer API; add reference counts
1512         appropriately
1513
1514         * include/ircd_network.h: firm up some pieces of the interface;
1515         split out members everything has into a separate structure; add
1516         reference counts; add timer API
1517
1518 2001-01-06  Kevin L. Mitchell  <klmitch@mit.edu>
1519
1520         * ircd/ircd_network.c: static data and event manipulation
1521         functions for new event processing system
1522
1523         * include/ircd_network.h: data structures for new event processing
1524         system
1525
1526 2001-01-03  Kevin L. Mitchell  <klmitch@mit.edu>
1527
1528         * ircd/whowas.c: Completely re-did the old allocation scheme by
1529         turning it into a linked list, permitting the
1530         NICKNAMEHISTORYLENGTH feature to be changed on the fly
1531
1532         * ircd/s_debug.c (count_memory): use FEAT_NICKNAMEHISTORYLENGTH
1533         feature instead of old #define
1534
1535         * ircd/ircd_features.c: add NICKNAMEHISTORYLENGTH feature as an
1536         integer feature with a notify callback (whowas_realloc)
1537
1538         * ircd/client.c (client_set_privs): second memset was supposed to
1539         be over antiprivs, not privs; thanks, Chris Behrens
1540         <cbehrens@xo.com> for pointing that out...
1541
1542         * include/whowas.h: new elements for an extra linked list in
1543         struct Whowas; a notify function for feature value changes
1544
1545         * include/ircd_features.h: new feature--FEAT_NICKNAMEHISTORYLENGTH
1546
1547         * config/config-sh.in: NICKNAMEHISTORYLENGTH is now a feature
1548
1549 2001-01-02  Kevin L. Mitchell  <klmitch@mit.edu>
1550
1551         * config/config-sh.in: get rid of DEFAULT_LIST_PARAMETER
1552         compile-time option--now in features subsystem
1553
1554         * ircd/motd.c (motd_init): rework motd_init() to be called as the
1555         notify function for MPATH and RPATH features (should probably
1556         split it up a bit, though...)
1557
1558         * ircd/m_privs.c (mo_privs): if called with no parameters, return
1559         privs of the caller, rather than an error
1560
1561         * ircd/m_list.c: pull usage message into its own function; pull
1562         list parameter processing into its own function that does not
1563         modify the contents of the parameter; add list_set_default() to
1564         set the default list parameter (uses the notify hook); rework
1565         m_list() to make use of these functions; removed dead code
1566
1567         * ircd/ircd_log.c (log_feature_mark): make sure to return 0, since
1568         we have no notify handler
1569
1570         * ircd/ircd_features.c: add notify callback for notification of
1571         value changes; give mark callback an int return value to indicate
1572         whether or not to call the notify callback; fix up feature macros
1573         for new notify callback; add DEFAULT_LIST_PARAM feature; rewrite
1574         string handling in feature_set() to deal with def_str being a null
1575         pointer; wrote feature_init() to set up all defaults appropriately
1576
1577         * ircd/ircd.c (main): call feature_init() instead of
1578         feature_mark(), to avoid calling notify functions while setting up
1579         defaults
1580
1581         * ircd/client.c: updated to deal with new privileges structure
1582
1583         * ircd/class.c: updated so init_class() can be called should one
1584         of PINGFREQUENCY, CONNECTFREQUENCY, MAXIMUM_LINKS, or
1585         DEFAULTMAXSENDQLENGTH be changed
1586
1587         * include/ircd_log.h: log_feature_mark() updated to fit with new
1588         API changes
1589
1590         * include/ircd_features.h: added DEFAULT_LIST_PARAM feature and
1591         feature_init() function (found necessary since adding the notify
1592         stuff and notifying motd.c during start-up...before we defined
1593         RPATH!)
1594
1595         * include/client.h: move privs around to enable addition of more
1596         bits if necessary; based on the FD_* macros
1597
1598         * include/channel.h: declare list_set_default (actually located in
1599         m_list.c *blanche*)
1600
1601         * ircd/s_user.c: retrieve MAXSILES and MAXSILELENGTH (now
1602         AVBANLEN*MAXSILES) from features subsystem
1603
1604         * ircd/s_debug.c (debug_serveropts): CMDLINE_CONFIG doesn't go to
1605         anything anymore
1606
1607         * ircd/s_bsd.c: retrieve HANGONGOODLINK and HANGONRETRYDELAY from
1608         the features subsystem
1609
1610         * ircd/s_auth.c (start_auth): NODNS migrated to the features
1611         subsystem
1612
1613         * ircd/random.c: created random_seed_set() function to set seed
1614         value, along with some stuff to make ircrandom() a little more
1615         random--state preserving, xor of time instead of direct usage,
1616         etc.; it's still a pseudo-random number generator, though, and
1617         hopefully I haven't broken the randomness
1618
1619         * ircd/m_version.c: FEATUREVALUES makes use of feature_int() calls
1620
1621         * ircd/m_join.c: use features interface to retrieve
1622         MAXCHANNELSPERUSER
1623
1624         * ircd/ircd_features.c: add NODISP flag for super-secret features;
1625         add a whole bunch of new features migrated over from make config
1626
1627         * ircd/ircd.c: use features interface to retrieve PINGFREQUENCY,
1628         CONNECTTIMEOUT, and TIMESEC
1629
1630         * ircd/client.c (client_get_ping): use features interface to
1631         retrieve PINGFREQUENCY
1632
1633         * ircd/class.c: use features interface to retrieve PINGFREQUENCY,
1634         CONNECTFREQUENCY, MAXIMUM_LINKS, and DEFAULTMAXSENDQLENGTH
1635
1636         * ircd/chkconf.c (DEFAULTMAXSENDQLENGTH): since it's now in the
1637         features subsystem, we have to add something explicit
1638
1639         * ircd/channel.c: use features interface to retrieve
1640         KILLCHASETIMELIMIT, MAXBANLENGTH, MAXBANS, and MAXCHANNELSPERUSER;
1641         note that MAXBANLENGTH is now calculated dynamically from MAXBANS
1642         and AVBANLEN
1643
1644         * ircd/Makefile.in: run make depend
1645
1646         * include/supported.h (FEATURESVALUES): update to reference
1647         feature settings
1648
1649         * include/random.h: add prototype for random_seed_set
1650
1651         * include/ircd_features.h: add several more features
1652
1653         * include/channel.h: move MAXBANS and MAXBANLENGTH into feature
1654         subsystem
1655
1656         * config/config-sh.in: feature-ized some more stuff
1657
1658         * include/motd.h: some new elements in motd.h for motd.c changes
1659
1660         * ircd/motd.c: motd_cache() now searches a list of already cached
1661         MOTD files; saves us from having duplicate caches in memory if
1662         there are two identical T-lines for two different sites...
1663
1664 2001-01-02  Perry Lorier <isomer@coders.net>
1665         * ircd/motd.c: don't core if the motd isn't found.  Bug found by
1666         Amarande.
1667
1668 2001-01-02  Perry Lorier <isomer@coders.net>
1669         * ircd/s_err.c: Added third param to 004 - the channel modes that tage params.  Used by hybrid/epic.
1670         * ircd/s_channels.c: Added fix for msg'ing a -n+m channel - thanks
1671                 to guppy for noticing, and hektik for providing the fix.
1672         * misc others: Minor cleanups, added more protocol_violations, ripped
1673                 out more P09 stuffs, bit more protocol neg stuff.
1674
1675 2000-12-19  Kevin L. Mitchell  <klmitch@mit.edu>
1676
1677         * ircd/m_ison.c (m_ison): Dianora says that ISON has to end with a
1678         space (*sigh* stupid clients...)
1679
1680         * ircd/s_user.c: make WALLOPS_OPER_ONLY a feature managed through
1681         ircd_features.[ch]
1682
1683         * ircd/s_err.c: get rid of GODMODE conditionals
1684
1685         * ircd/s_debug.c (debug_serveropts): switch to using appropriate
1686         calls into the features subsystem for various serveropts
1687         characters
1688
1689         * ircd/s_conf.c (find_conf_entry): get rid of USEONE conditional
1690
1691         * ircd/s_bsd.c: remove GODMODE conditional; use features subsystem
1692         to get value of VIRTUAL_HOST and CLIENT_FLOOD; remove
1693         NOFLOWCONTROL conditional
1694
1695         * ircd/s_auth.c: use features subsystem to determine value of
1696         KILL_IPMISMATCH
1697
1698         * ircd/parse.c: get rid of NOOPER and GODMODE conditionals; use
1699         features subsystem to determine the setting of IDLE_FROM_MSG
1700
1701         * ircd/numnicks.c: get rid of EXTENDED_NUMERICS conditionals
1702
1703         * ircd/motd.c: get value of NODEFAULTMOTD from features subsystem;
1704         use features subsystem to get motd file names
1705
1706         * ircd/m_settime.c: get value of RELIABLE_CLOCK from features
1707         subsystem
1708
1709         * ircd/m_server.c: get rid of CRYPT_LINK_PASSWORD, since it does
1710         us no good; use features subsystem to figure out if we need to do
1711         HUB-type stuff; make TESTNET debugging sendto_opmask_butone's use
1712         the Debug(()) macro instead; get value of RELIABLE_CLOCK from
1713         features subsystem
1714
1715         * ircd/m_privmsg.c: get IDLE_FROM_MSG from the features subsystem
1716
1717         * ircd/m_oper.c: get CRYPT_OPER_PASSWORD from the features
1718         subsystem
1719
1720         * ircd/m_connect.c: get SERVER_PORT from the features subsystem
1721
1722         * ircd/ircd_log.c (log_set_file): fix a bug that kept log files
1723         from getting marked if they were already set to something...
1724
1725         * ircd/ircd_features.c: add a flag to indicates read-only access;
1726         add several new features that used to be compile-time selected
1727
1728         * ircd/ircd.c: grab pidfile out of feature subsystem; don't check
1729         access to motd files (what the heck?); make sure to initialize the
1730         feature subsystem before trying to write the config file
1731
1732         * ircd/dbuf.c: use feature_int() to retrieve BUFFERPOOL settings;
1733         use feature_bool() to figure out if we're using the FERGUSON
1734         flusher
1735
1736         * ircd/Makefile.in: MPATH and RPATH are now done differently, so
1737         remove the clause that creates empty files of that name; also ran
1738         make depend
1739
1740         * include/sys.h: CLIENT_FLOOD is now a feature; unfortunately,
1741         there is no easy way to bounds-check it at present
1742
1743         * include/querycmds.h: make sure ircd_features.h is included; use
1744         feature_str(FEAT_DOMAINNAME) in calls to match()
1745
1746         * include/ircd_features.h: many new features that used to be
1747         compile-time selected
1748
1749         * config/config-sh.in: add * to DOMAINNAME; try also using first
1750         argument to search in /etc/resolv.conf; removed many compile-time
1751         options that now can be configured through the features system
1752
1753 2000-12-18  Kevin L. Mitchell  <klmitch@mit.edu>
1754
1755         * doc/api/log.txt: how to use the logging API
1756
1757         * doc/api/features.txt: how to use the features API
1758
1759         * doc/api/api.txt: how to write API documentation
1760
1761         * include/ircd_features.h: rearranged a couple of features for
1762         neatness purposes
1763
1764         * ircd/ircd_features.c: cleaned up the macros some; rearranged
1765         some code to all go into the switch; rearranged a couple of
1766         features for neatness purposes
1767
1768 2000-12-16  Greg Sikorski <gte@atomicrevs.demon.co.uk>
1769         * ircd/os_bsd.c: Added os_set_tos for BSD users.
1770
1771 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
1772
1773         * ircd/ircd_features.c: Isomer almost got it right; you need to
1774         use F_I(), since it's an integer value, not a boolean value.  The
1775         asserts in feature_int would catch you out...  Also made the F_*
1776         macros take flags
1777
1778         * ircd/s_err.c: define RPL_PRIVS reply
1779
1780         * ircd/parse.c: put new PRIVS command into command table
1781
1782         * ircd/m_privs.c (mo_privs): message handler to report operator
1783         privileges
1784
1785         * ircd/ircd_features.c: declare new features OPER_SET and
1786         LOCOP_SET; redo boolean testing routine to accept TRUE, YES, and
1787         ON for boolean TRUE, and FALSE, NO, and OFF for boolean FALSE
1788
1789         * ircd/client.c: simplify client_set_privs() with a table that
1790         defines what features to test for; add new client_report_privs()
1791
1792         * ircd/Makefile.in: compile new m_privs.c; run make depend
1793
1794         * include/numeric.h (RPL_PRIVS): new reply numeric for displaying
1795         an operator's privileges
1796
1797         * include/msg.h: define new command: PRIVS
1798
1799         * include/ircd_features.h: create new features OPER_SET and
1800         LOCOP_SET for controlling access to /set
1801
1802         * include/handlers.h (mo_privs): declare message handler for
1803         reporting oper privileges
1804
1805         * include/client.h (client_report_privs): declare function to
1806         report what privileges an oper has
1807
1808         * ircd/m_whois.c (do_whois): fix a bug that caused /whois to
1809         report that a user is an oper if the oper doing the /whois had
1810         PRIV_SEE_OPERS
1811
1812 2000-12-17  Isomer <Isomer@coders.net>
1813         * ircd/listener.c: added support for TOS twiddling as a 'feature'.
1814
1815 2000-12-17  Isomer <Isomer@coders.net>
1816         * ircd/os_linux.c: add TOS stuffs
1817
1818         * ircd/listener.c: add TOS stuffs
1819
1820 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
1821
1822         * ircd/whocmds.c (do_who): use HasPriv to determine whether or not
1823         to indicate a user is an oper
1824
1825         * ircd/s_user.c: clear privileges setting when deopping; don't
1826         propagate +o unless user has PRIV_PROPAGATE privilege
1827
1828         * ircd/s_debug.c (debug_serveropts): created debug_serveropts()
1829         function and replaced how the server option string is generated
1830
1831         * ircd/parse.c: remove conditional on CONFIG_OPERCMDS
1832
1833         * ircd/m_whois.c (do_whois): use HasPriv to determine whether or
1834         not to indicate the user is an operator
1835
1836         * ircd/m_who.c: use HasPriv to determine whether or not a user
1837         should be displayed in the list of opers
1838
1839         * ircd/m_version.c: call debug_serveropts() to get server option
1840         string
1841
1842         * ircd/m_userip.c (userip_formatter): use HasPriv to determine
1843         whether or not to show oper status
1844
1845         * ircd/m_userhost.c (userhost_formatter): use HasPriv to determine
1846         whether or not to show oper status
1847
1848         * ircd/m_restart.c (mo_restart): replace ugly #ifdef conditional
1849         checks with HasPriv check; remove dead code
1850
1851         * ircd/m_rehash.c (mo_rehash): replace ugly #ifdef conditional
1852         checks with HasPriv check
1853
1854         * ircd/m_opmode.c (mo_opmode): use HasPriv to check permissions;
1855         use feature_bool to check if disabled
1856
1857         * ircd/m_oper.c (m_oper): set oper priviliges
1858
1859         * ircd/m_mode.c (m_mode): replace #ifdef conditional with HasPriv
1860         check
1861
1862         * ircd/m_kill.c (mo_kill): use HasPriv checks to determine if we
1863         can kill
1864
1865         * ircd/m_kick.c (m_kick): replace #ifdef conditional with HasPriv
1866         check
1867
1868         * ircd/m_jupe.c (mo_jupe): rework permissions checking structure;
1869         use feature_bool to check if disabled
1870
1871         * ircd/m_join.c (m_join): remove BADCHAN conditional; replace
1872         #ifdef conditional with a HasPriv check
1873
1874         * ircd/m_gline.c (mo_gline): rework permissions checking
1875         structure; use feature_bool to check if any part is disabled
1876
1877         * ircd/m_die.c: replace ugly #ifdef conditionals with HasPriv
1878         check; remove dead code
1879
1880         * ircd/m_clearmode.c: use feature_bool() to detect if we're
1881         disabled; use HasPriv to figure out what we're permitted to do;
1882         only allow clearmode on moded channels
1883
1884         * ircd/ircd_features.c: define various features; use HasPriv to
1885         verify permissions to set/reset
1886
1887         * ircd/gline.c (gline_add): use HasPriv instead of #ifdef
1888         conditionals
1889
1890         * ircd/client.c (client_set_privs): function to set an oper's
1891         privileges
1892
1893         * ircd/channel.c: use HasPriv calls instead of #ifdef conditionals
1894
1895         * include/whocmds.h: deconditionalize several macros and
1896         substitute appropriate calls to HasPriv()
1897
1898         * include/s_debug.h: get rid of global serveropts[]; define new
1899         function debug_serveropts() to build that string on the fly
1900
1901         * include/ircd_features.h: define some features
1902
1903         * include/client.h: add privs member to struct Connection; define
1904         various priviledges
1905
1906         * include/channel.h: no longer using IsOperOnLocalChannel; remove
1907         conditional of MAGIC_OPER_OVERRIDE on OPER_WALK_THROUGH_LMODES
1908
1909         * doc/Configure.help: remove help information for deprecated
1910         options
1911
1912         * config/config-sh.in: remove certain deprecated options having to
1913         do with what opers can and cannot do--first stage in moving
1914         compile-time constants into the .conf
1915
1916 2000-12-16  Isomer <Isomer@coders.net>
1917         * ircd/parse.c: detect if the prefix is missing and try and recover
1918         instead of coring.
1919
1920 2000-12-15  Kevin L. Mitchell  <klmitch@mit.edu>
1921
1922         * ircd/ircd_log.c: found and fixed some bugs in the debug logging
1923         code that would sometimes result in the log file not being
1924         reopened--which meant that a user could connect and get the
1925         logging output--oops
1926
1927         * ircd/Makefile.in: run make depend...
1928
1929         * ircd/s_stats.c: get rid of report_feature_list()
1930
1931         * ircd/s_err.c: add the 'bad value' error message, shift error
1932         messages over somewhat
1933
1934         * ircd/s_debug.c (debug_init): call log_debug_init with the
1935         use_tty flag
1936
1937         * ircd/s_conf.c (read_configuration_file): unmark features before
1938         reading the config file, then reset unmarked features after
1939         reading the config file
1940
1941         * ircd/m_stats.c: use feature_report() instead of
1942         report_feature_list()
1943
1944         * ircd/ircd_log.c: fix log_debug_file (bogus assertion); add
1945         special 'mark' flags and use them; add the stuff needed by the
1946         features API
1947
1948         * ircd/ircd_features.c: rework the features API and add gobs of
1949         comments to try to explain what some of these complex functions
1950         are actually doing
1951
1952         * include/s_stats.h: get rid of report_feature_list(); use
1953         feature_report() instead
1954
1955         * include/numeric.h: added a new error message and shifted old
1956         values over some--this is, after all, an alpha
1957
1958         * include/ircd_log.h: log_debug_init now takes an integer to tell
1959         it if it should be using the tty; added a couple of functions
1960         required by the features API
1961
1962         * include/ircd_features.h: add an enum and some more functions to
1963         flesh out the feature API--it should now be possible to put all
1964         those compile-time constants in the config file!
1965
1966         * ircd/send.c: got the direction of the assert incorrect...
1967
1968         * ircd/send.c: implement the efficiency of flush_connections by
1969         creating a linked list of struct Connection's with queued data;
1970         also get rid of flush_sendq_except and make sure to yank
1971         connections out of the list when their sendQs become empty (notice
1972         the assertion in flush_connections!)
1973
1974         * ircd/s_bsd.c (close_connection): must yank the Connection out of
1975         the sendq list
1976
1977         * ircd/list.c (dealloc_connection): must yank the Connection out
1978         of the sendq list
1979
1980         * ircd/dbuf.c (dbuf_put): call flush_connections instead of the
1981         deprecated flush_sendq_except
1982
1983         * ircd/client.c: define a couple new helper functions for sendq
1984         threading--this will make the flush_connections function in send.c
1985         considerably more efficient by creating a linked list of
1986         Connections that have queued data to send
1987
1988         * include/send.h: remove flush_sendq_except, as it's not used
1989         anymore
1990
1991         * include/client.h: declare a couple new helper functions for the
1992         sendq threading system
1993
1994 2000-12-14  Kevin L. Mitchell  <klmitch@mit.edu>
1995
1996         * ircd/m_ison.c (m_ison): Apply Diane Bruce's patch to make ISON
1997         parse all arguments
1998
1999         * ircd/s_debug.c (count_memory): modify to report for clients and
2000         connections, not local clients and remote clients
2001
2002         * ircd/list.c: fiddle with the client-fiddling functions to take
2003         into account the divorce of struct Connection from struct Client
2004
2005         * ircd/ircd.c: define a struct Connection for me, initialize it,
2006         and link it into the right place (ewww, globals!)
2007
2008         * include/client.h: remove CLIENT_{LOCAL,REMOTE}_SIZE; split
2009         struct Client into struct Client and struct Connection; redefine
2010         local-portion accessor macros to go through struct Client to the
2011         struct Connection; define struct Connection accessor macros
2012
2013 2000-12-13  Kevin L. Mitchell  <klmitch@mit.edu>
2014
2015         * ircd/whowas.c: missed a couple of accesses to a struct Client
2016
2017         * ircd/uping.c: missed a couple of accesses to a struct Client
2018
2019         * ircd/send.c: missed a couple of accesses to a struct Client
2020
2021         * ircd/s_user.c: missed a couple of accesses to a struct Client
2022
2023         * ircd/s_misc.c: missed a couple of accesses to a struct Client
2024
2025         * ircd/s_conf.c: missed a couple of accesses to a struct Client
2026
2027         * ircd/s_bsd.c: missed a couple of accesses to a struct Client
2028
2029         * ircd/s_auth.c: missed a couple of accesses to a struct Client
2030
2031         * ircd/res.c: missed a couple of accesses to a struct Client
2032
2033         * ircd/parse.c: missed a couple of accesses to a struct Client
2034
2035         * ircd/m_whois.c: use new accessor macros for struct Client
2036
2037         * ircd/m_who.c: use new accessor macros for struct Client
2038
2039         * ircd/m_wallchops.c: use new accessor macros for struct Client
2040
2041         * ircd/m_version.c: use new accessor macros for struct Client
2042
2043         * ircd/m_userip.c: use new accessor macros for struct Client
2044
2045         * ircd/m_userhost.c: use new accessor macros for struct Client
2046
2047         * ircd/m_user.c: use new accessor macros for struct Client
2048
2049         * ircd/m_uping.c: use new accessor macros for struct Client
2050
2051         * ircd/m_trace.c: use new accessor macros for struct Client
2052
2053         * ircd/m_topic.c: use new accessor macros for struct Client
2054
2055         * ircd/m_time.c: use new accessor macros for struct Client
2056
2057         * ircd/m_stats.c: use new accessor macros for struct Client
2058
2059         * ircd/m_squit.c: use new accessor macros for struct Client
2060
2061         * ircd/m_silence.c: use new accessor macros for struct Client
2062
2063         * ircd/m_server.c: use new accessor macros for struct Client;
2064         remove dead code
2065
2066         * ircd/m_rpong.c: use new accessor macros for struct Client
2067
2068         * ircd/m_rping.c: use new accessor macros for struct Client
2069
2070         * ircd/m_quit.c: use new accessor macros for struct Client
2071
2072         * ircd/m_privmsg.c: use new accessor macros for struct Client
2073
2074         * ircd/m_pong.c: use new accessor macros for struct Client; remove
2075         dead code
2076
2077         * ircd/m_ping.c: use new accessor macros for struct Client
2078
2079         * ircd/m_pass.c: use new accessor macros for struct Client
2080
2081         * ircd/m_part.c: use new accessor macros for struct Client
2082
2083         * ircd/m_oper.c: use new accessor macros for struct Client
2084
2085         * ircd/m_notice.c: use new accessor macros for struct Client
2086
2087         * ircd/m_nick.c: use new accessor macros for struct Client
2088
2089         * ircd/m_names.c: use new accessor macros for struct Client
2090
2091         * ircd/m_mode.c: use new accessor macros for struct Client
2092
2093         * ircd/m_map.c: use new accessor macros for struct Client
2094
2095         * ircd/m_list.c: use new accessor macros for struct Client
2096
2097         * ircd/m_links.c: use new accessor macros for struct Client;
2098         remove some dead code
2099
2100         * ircd/m_kill.c: use new accessor macros for struct Client; remove
2101         some dead code
2102
2103         * ircd/m_kick.c: use new accessor macros for struct Client
2104
2105         * ircd/m_join.c: use new accessor macros for struct Client; remove
2106         some dead code
2107
2108         * ircd/m_ison.c: use new accessor macros for struct Client
2109
2110         * ircd/m_invite.c: use new accessor macros for struct Client
2111
2112         * ircd/m_info.c: use new accessor macros for struct Client
2113
2114         * ircd/m_gline.c: use new accessor macros for struct Client
2115
2116         * ircd/m_error.c: use new accessor macros for struct Client
2117
2118         * ircd/m_create.c: use new accessor macros for struct Client
2119
2120         * ircd/m_connect.c: use new accessor macros for struct Client;
2121         removed some dead code
2122
2123         * ircd/m_burst.c: use new accessor macros for struct Client
2124
2125         * ircd/m_away.c: use new accessor macros for struct Client
2126
2127         * ircd/m_admin.c: use new accessor macros for struct Client
2128
2129         * ircd/hash.c: missed a couple of accesses to a struct Client
2130
2131         * ircd/gline.c: missed a couple of accesses to a struct Client
2132
2133         * ircd/crule.c: missed a couple of accesses to a struct Client
2134
2135         * ircd/class.c: missed an access to a struct Client
2136
2137         * ircd/channel.c: missed a couple of accesses to a struct Client
2138
2139         * ircd/IPcheck.c: missed an access to a struct Client
2140
2141         * include/querycmds.h: fix a couple of stats macros to use
2142         structure accessor macros
2143
2144         * include/client.h: change structure member names to highlight any
2145         places in the code I've missed
2146
2147 2000-12-12  Kevin L. Mitchell  <klmitch@mit.edu>
2148
2149         * ircd/whowas.c: use new struct Client accessor macros
2150
2151         * ircd/whocmds.c: use new struct Client accessor macros
2152
2153         * ircd/send.c: use new struct Client accessor macros
2154
2155         * ircd/s_user.c: use new struct Client accessor macros; removed
2156         some dead code
2157
2158         * ircd/s_serv.c: use new struct Client accessor macros; removed
2159         some dead code
2160
2161         * ircd/s_numeric.c: use new struct Client accessor macros
2162
2163         * ircd/s_misc.c: use new struct Client accessor macros
2164
2165         * ircd/s_debug.c: use new struct Client accessor macros
2166
2167         * ircd/s_conf.c: use new struct Client accessor macros
2168
2169         * ircd/s_bsd.c: use new struct Client accessor macros
2170
2171         * ircd/s_auth.c: use new struct Client accessor macros
2172
2173         * ircd/parse.c: use new struct Client accessor macros
2174
2175         * ircd/packet.c: use new struct Client accessor macros
2176
2177         * ircd/numnicks.c: use new struct Client accessor macros
2178
2179         * ircd/motd.c: use new struct Client accessor macros
2180
2181         * ircd/listener.c: use new struct Client accessor macros
2182
2183         * ircd/list.c: use new struct Client accessor macros
2184
2185         * ircd/jupe.c: use new struct Client accessor macros
2186
2187         * ircd/ircd_snprintf.c: use new struct Client accessor macros
2188
2189         * ircd/ircd_reply.c: use new struct Client accessor macros
2190
2191         * ircd/ircd_relay.c: use new struct Client accessor macros
2192
2193         * ircd/ircd.c: use new struct Client accessor macros
2194
2195         * ircd/gline.c: catch some instances of me.<stuff> I missed
2196         previously
2197
2198         * ircd/client.c: use cli_ instead of con_
2199
2200         * ircd/class.c: use cli_ instead of con_
2201
2202         * ircd/channel.c: use cli_ instead of con_
2203
2204         * ircd/IPcheck.c: use cli_ instead of con_; catch some instances
2205         of me.<stuff> I missed previously
2206
2207         * include/client.h: use cli_ instead of con_...seemed like a good
2208         idea at the time *shrug*
2209
2210 2000-12-11  Kevin L. Mitchell  <klmitch@mit.edu>
2211
2212         * ircd/hash.c: use struct Client accessor macros
2213
2214         * ircd/gline.c: use struct Client accessor macros
2215
2216         * ircd/crule.c: use struct Client accessor macros
2217
2218         * ircd/client.c: use struct Client accessor macros; remove some
2219         dead code
2220
2221         * ircd/class.c: use struct Client accessor macros
2222
2223         * ircd/channel.c: use struct Client accessor macros; remove some
2224         dead code
2225
2226         * ircd/IPcheck.c: use struct Client accessor macros
2227
2228         * include/numnicks.h: use struct Client accessor macros
2229
2230         * include/client.h: first step to divorcing struct Client and
2231         struct Connection--define accessor macros and use them
2232
2233         * ircd/gline.c: When Uworld removed Uworld-set G-lines, only the
2234         uplink would remove them.  This is because the removal protocol
2235         message wasn't being sent to the uplinks.  This is fixed by fixing
2236         propagate_gline() to send the proper number of arguments depending
2237         on whether or not we're adding or deleting the Uworld gline, and
2238         by having gline_deactivate() make sure to turn off the active bit
2239         and call propagate_gline() if it's a Uworld gline
2240
2241 2000-12-10  Kevin L. Mitchell  <klmitch@mit.edu>
2242
2243         * ircd/os_generic.c: make sure IOV_MAX gets defined, just in case
2244
2245         * ircd/os_bsd.c: apparently BSD doesn't have IOV_MAX defined
2246         anywhere intelligent...
2247
2248 2000-12-09  Kevin L. Mitchell  <klmitch@mit.edu>
2249
2250         * ircd/send.c (send_queued): call deliver_it with appropriate
2251         arguments
2252
2253         * ircd/s_serv.c: reorder a couple of headers--cosmetic
2254
2255         * ircd/s_bsd.c (deliver_it): make deliver_it work with a struct
2256         MsgQ
2257
2258         * ircd/os_solaris.c (os_sendv_nonb): function for calling writev
2259         with appropriate iovec
2260
2261         * ircd/os_linux.c (os_sendv_nonb): function for calling writev
2262         with appropriate iovec
2263
2264         * ircd/os_generic.c (os_sendv_nonb): function for calling writev
2265         with appropriate iovec
2266
2267         * ircd/os_bsd.c (os_sendv_nonb): function for calling writev with
2268         appropriate iovec
2269
2270         * ircd/msgq.c (msgq_mapiov): add a len_p argument for totalling up
2271         exactly how much we're trying to write out to the fd
2272
2273         * include/s_bsd.h: make deliver_it take a struct MsgQ
2274
2275         * include/msgq.h: add a len_p argument to msgq_mapiov to help
2276         detect short writes that indicate possible socket blocking
2277
2278         * include/ircd_osdep.h: declare os_sendv_nonb()
2279
2280         * ircd/channel.c (modebuf_mode): don't add empty modes...
2281
2282 2000-12-08  Kevin L. Mitchell  <klmitch@mit.edu>
2283
2284         * include/send.h: add prio argument to send_buffer to select
2285         between normal and priority queues
2286
2287         * ircd/s_user.c (send_user_info): add prio argument to send_buffer
2288         call
2289
2290         * ircd/m_ison.c (m_ison): add prio argument to send_buffer call
2291
2292         * ircd/ircd_reply.c (send_reply): add prio argument to send_buffer
2293         call
2294
2295         * ircd/channel.c (send_channel_modes): add prio argument to
2296         send_buffer call
2297
2298         * ircd/send.c (send_buffer): add a prio argument to select the
2299         priority queue; update send.c functions to use it
2300
2301         * ircd/msgq.c (msgq_add): remove msgq_prio; fold msgq_link and
2302         msgq_add; add a prio argument to msgq_add to select the priority
2303         queue
2304
2305         * include/msgq.h: remove msgq_prio; add a prio argument to
2306         msgq_add
2307
2308         * ircd/send.c: remove sendbuf; remove GODMODE code; switch to
2309         using msgq functions instead of dbuf functions; remove old, dead
2310         sendto_* functions; redo send_buffer to take a struct MsgBuf;
2311         rework sendcmdto_* functions to make use of the new struct MsgBuf
2312
2313         * ircd/s_user.c: remove hunt_server; restructure send_user_info to
2314         make appropriate use of struct MsgBuf
2315
2316         * ircd/s_debug.c (count_memory): count memory used by the MsgQ
2317         system and report it
2318
2319         * ircd/s_conf.c (read_configuration_file): use
2320         sendto_opmask_butone instead of the now dead sendto_op_mask
2321
2322         * ircd/s_bsd.c: switch to using appropriate MsgQLength and other
2323         calls on sendQ
2324
2325         * ircd/parse.c (parse_server): get rid of a piece of GODMODE code
2326
2327         * ircd/msgq.c: add msgq_append and msgq_bufleft; fix a bug in
2328         msgq_clean
2329
2330         * ircd/m_version.c: fix spelling in comments marking dead code
2331
2332         * ircd/m_userip.c (userip_formatter): restructure to make use of
2333         struct MsgBuf
2334
2335         * ircd/m_userhost.c (userhost_formatter): restructure to make use
2336         of struct MsgBuf
2337
2338         * ircd/m_stats.c: use MsgQLength on a sendQ
2339
2340         * ircd/m_settime.c: use MsgQLength instead of DBufLength on a
2341         sendQ; mark a piece of dead code
2342
2343         * ircd/m_names.c: use send_reply instead of sendto_one
2344
2345         * ircd/m_mode.c: use new mode; remove old dead code
2346
2347         * ircd/m_ison.c (m_ison): restructure to make use of struct MsgBuf
2348
2349         * ircd/m_burst.c: use BUFSIZE instead of IRC_BUFSIZE; remove old
2350         dead code
2351
2352         * ircd/listener.c (accept_connection): use sendto_opmask_butone
2353         instead of sendto_op_mask
2354
2355         * ircd/list.c (free_client): use MsgQClear to clear sendQ
2356
2357         * ircd/ircd_reply.c: remove send_error_to_client; restructure
2358         send_reply to make use of struct MsgBuf
2359
2360         * ircd/dbuf.c (dbuf_put): remove argument to flush_sendq_except,
2361         since its no longer used (at least currently)
2362
2363         * ircd/channel.c: restructure send_channel_modes to make use of
2364         struct MsgBuf; remove set_mode, add_token_to_sendbuf, cancel_mode,
2365         and send_hack_notice; use BUFSIZE instead of IRC_BUFSIZE
2366
2367         * ircd/Makefile.in: add msgq.c to list of sources; run make depend
2368
2369         * ircd/IPcheck.c: use sendcmdto_one instead of sendto_one
2370
2371         * include/send.h: send_buffer now takes a struct MsgBuf * instead
2372         of a char *; flush_sendq_except now takes no arguments, as sendq
2373         flushing currently only happens in dbuf.h and sendQ is a struct
2374         MsgQ; remove prototypes for a lot of old sendto_* functions that
2375         aren't used anymore; remove sendbuf and IRC_BUFSIZE--the former is
2376         no longer needed, and the latter is identical to BUFSIZE in
2377         ircd_defs.h
2378
2379         * include/s_user.h: make InfoFormatter take a struct MsgBuf*
2380         instead of a char *; also make it return void, instead of char *
2381
2382         * include/msgq.h: add msgq_append and msgq_bufleft functions
2383
2384         * include/client.h: use a struct MsgQ instead of a struct DBuf for
2385         sendq
2386
2387         * doc/Configure.help: Remove help for compile-time options that
2388         have gone away
2389
2390         * config/config-sh.in: remove CONFIG_NEWMODE
2391
2392         * ircd/m_server.c (mr_server): don't send server IPs in any server
2393         notices
2394
2395         * ircd/msgq.c (msgq_vmake): add \r\n to messages
2396
2397 2000-12-07  Kevin L. Mitchell  <klmitch@mit.edu>
2398
2399         * include/msgq.h: declare the MsgQ API
2400
2401         * ircd/msgq.c: implementation of new MsgQ system
2402
2403 2000-12-06  Kevin L. Mitchell  <klmitch@mit.edu>
2404
2405         * ircd/ircd_features.c: #include was supposed to be for
2406           ircd_features.h, not features.h--missed when I had to do a
2407           rename because of namespace collision
2408
2409 2000-12-05  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2410         * ircd/m_topic.c: Added missing braces that caused all remote
2411           topics to be ignored.
2412
2413 2000-12-04  Kevin L. Mitchell  <klmitch@mit.edu>
2414
2415         * ircd/m_create.c: I'm tired of the exit_client warning :)
2416         (ms_create): discovered that exit_client() was being called with
2417         too few arguments
2418
2419         * ircd/s_misc.c (exit_client): remove all dependance on
2420         FNAME_USERLOG, since that's now gone; log only to LS_USER
2421
2422         * ircd/s_debug.c: USE_SYSLOG no longer means anything
2423
2424         * ircd/m_oper.c (m_oper): no longer log to LS_OPERLOG--we already
2425         log to LS_OPER
2426
2427         * ircd/m_kill.c: no longer conditionalize on SYSLOG_KILL
2428
2429         * ircd/ircd_log.c: remove LS_OPERLOG, LS_USERLOG
2430
2431         * include/ircd_log.h: remove LS_OPERLOG, LS_USERLOG--they serve
2432         the same purpose as LS_USER and LS_OPER
2433
2434         * config/config-sh.in: remove no longer relevant log config
2435         variables
2436
2437         * ircd/uping.c (uping_init): use log_write instead of ircd_log
2438
2439         * ircd/s_misc.c (exit_client): use log_write instead of ircd_log
2440
2441         * ircd/s_conf.c: use log_write instead of ircd_log
2442
2443         * ircd/s_bsd.c (report_error): use log_write instead of ircd_log
2444
2445         * ircd/s_auth.c (timeout_auth_queries): use log_write instead of
2446         ircd_log
2447
2448         * ircd/res.c (send_res_msg): use log_write instead of ircd_log
2449
2450         * ircd/m_who.c: use log_write instead of write_log; no longer
2451         conditionalize on WPATH; mark dead ircd_log calls
2452
2453         * ircd/m_uping.c: mark dead ircd_log call
2454
2455         * ircd/m_server.c (mr_server): use log_write instead of ircd_log
2456
2457         * ircd/m_restart.c: use log_write instead of ircd_log; mark dead
2458         ircd_log calls
2459
2460         * ircd/m_rehash.c (mo_rehash): use log_write instead of ircd_log
2461
2462         * ircd/m_oper.c: use log_write instead of ircd_log; no longer
2463         conditionalize on FNAME_OPERLOG; mark dead ircd_log calls
2464
2465         * ircd/m_kill.c: mark dead ircd_log calls
2466
2467         * ircd/m_connect.c: use log_write instead of ircd_log; mark dead
2468         ircd_log
2469
2470         * ircd/m_clearmode.c: use log_write instead of write_log; no
2471         longer conditionalize on OPATH
2472
2473         * ircd/jupe.c: use log_write instead of write_log; no longer
2474         conditionalize on JPATH
2475
2476         * ircd/ircd_log.c: add USER subsystem; remove ircd_log() compat
2477         function; fix a couple of bugs
2478
2479         * ircd/ircd_alloc.c: fixed a comment
2480
2481         * ircd/ircd.c: use log_write instead of ircd_log; fold server
2482         notice generation in a couple of cases
2483
2484         * ircd/gline.c: use log_write instead of write_log; no longer
2485         conditionalize on GPATH
2486
2487         * ircd/channel.c (modebuf_flush_int): use log_write instead of
2488         write_log; no longer conditionalize on OPATH
2489
2490         * ircd/Makefile.in: run make depend, since dependencies have
2491         changed
2492
2493         * doc/example.conf: add system USER to documentation
2494
2495         * include/ircd_log.h: add system USER; remove old ircd_log()
2496         declarations
2497
2498 2000-12-04  Isomer <isomer@coders.net>
2499         * ircd/m_names.c: Add NAMES_EON to do_names to say add a
2500         'end_of_names' reply when done.
2501         * ircd/m_join.c: use NAMES_EON as mentioned above
2502
2503 2000-12-01  net  <simms@LUCIDA.QC.CA>
2504
2505         * ircd/motd.c: add a freelist for struct Motds
2506
2507 2000-11-30  Kevin L. Mitchell  <klmitch@mit.edu>
2508
2509         * ircd/s_stats.c (report_feature_list): report features--only
2510         local opers can see logging configuration, since it doesn't really
2511         mean anything to users
2512
2513         * ircd/s_err.c: add reply messages for new feature subsystem
2514
2515         * ircd/s_conf.c: add F lines to .conf
2516
2517         * ircd/parse.c: add the message descriptions for /set, /reset, and
2518         /get
2519
2520         * ircd/m_stats.c: add /stats f
2521
2522         * ircd/m_set.c (mo_set): implement /set
2523
2524         * ircd/m_reset.c (mo_reset): implement /reset
2525
2526         * ircd/m_rehash.c: /rehash m now flushes MOTD cache, and /rehash l
2527         reopens log files (for log file rotation)
2528
2529         * ircd/m_get.c (mo_get): implement /get
2530
2531         * ircd/ircd_log.c: use int instead of void return value; add
2532         log_report_features() and log_canon(); fix a function that
2533         disappears if DEBUGMODE not #define'd
2534
2535         * ircd/ircd_features.c: functions to manipulate feature settings
2536         either from the config file or with the new /set, /reset, and /get
2537         commands
2538
2539         * ircd/Makefile.in: add new .c files, run make depend
2540
2541         * include/s_stats.h: declare report_feature_list() (/stats f
2542         handler)
2543
2544         * include/numeric.h: add RPL_STATSFLINE, RPL_FEATURE,
2545         ERR_NOFEATURE, ERR_BADLOGTYPE, ERR_BADLOGSYS, and ERR_BADLOGVALUE
2546         reply numerics
2547
2548         * include/msg.h: add defines for SET, RESET, and GET
2549
2550         * include/ircd_log.h: add a function to canonicalize subsystem
2551         names; change some void return values to int
2552
2553         * include/ircd_features.h: new features subsystem handles all the
2554         manipulation of special features, like log files
2555
2556         * include/handlers.h: declare new mo_{s,res,g}et message handlers
2557         for fiddling with features run-time
2558
2559         * include/client.h (SNO_DEFAULT): don't set SNO_DEBUG by default;
2560         seemed like a good idea at the time...
2561
2562         * doc/example.conf: document new F lines
2563
2564 2000-11-29  Kevin L. Mitchell  <klmitch@mit.edu>
2565
2566         * ircd/s_debug.c: rewrite debug_init() and vdebug() in terms of
2567         new logging functions, which have special support for the debug
2568         log; added loop detection to vdebug(), so that I can
2569         sendto_opmask_butone() from log_vwrite() without incurring another
2570         call to vdebug()
2571
2572         * ircd/s_conf.c (rehash): call log_reopen() from rehash routine;
2573         this allows log file rotations
2574
2575         * ircd/m_kill.c: call log_write_kill() instead of ircd_log_kill()
2576
2577         * ircd/ircd_log.c: much more work fleshing out the interface;
2578         removed old interface; included backwards-compat ircd_log()
2579         function that logs to subsystem LS_OLDLOG
2580
2581         * ircd/ircd.c: switch to new log_init()/log_close()/log_reopen()
2582         functions
2583
2584         * include/ircd_log.h: include stdarg.h for va_list; move ordering
2585         warning to top of file; fill out LogSys enum; declare new
2586         log_debug_init(), log_vwrite(), log_write_kill(), and
2587         log_[sg]et_*() functions; add flags argument to log_write();
2588         defined flags to inhibit various logging actions
2589
2590         * include/client.h: added support for new SNO_DEBUG, enabled only
2591         if DEBUGMODE is defined
2592
2593 2000-11-28  Kevin L. Mitchell  <klmitch@mit.edu>
2594
2595         * ircd/ircd_log.c: make sure the various LOG_* constants are
2596         defined (probably not needed, since #include <syslog.h> isn't
2597         conditional); various static data needed for the new logging
2598         functions; definitions of new logging functions
2599
2600         * include/ircd_log.h: new LogSys enum, declarations for part of
2601         new logging API
2602
2603         * ircd/motd.c: we were setting type to MOTD_CLASS unconditionally,
2604         which was of course stupid; switched to using switch/case in
2605         initialization in motd_create(); zero the MotdList.other pointer
2606         from motd_clear()
2607
2608         * ircd/ircd.c (main): motd_init() has to come before init_conf(),
2609         or we overwrite init_conf()'s hard work with respect to T-lines
2610
2611 2000-11-27  Kevin L. Mitchell  <klmitch@mit.edu>
2612
2613         * ircd/s_stats.c: comment out report_motd_list and include a
2614         reference to motd_report()
2615
2616         * ircd/s_conf.c: rip out the old MOTD manipulation functions; call
2617         motd_add() from the conf parser; call motd_clear() from the rehash
2618         routine; remove the no longer needed memory clearing and reloading
2619         stuff from the rehash service routine
2620
2621         * ircd/motd.c: loads new API, including static internal functions
2622         to do allocation/deallocation, etc.
2623
2624         * ircd/m_stats.c: use new motd_report() instead of
2625         report_motd_list()
2626
2627         * ircd/m_motd.c: use new syntax for motd_send()
2628
2629         * ircd/ircd.c: use new motd_init() function
2630
2631         * ircd/Makefile.in (SRC): forgot to add motd.c to SRC in
2632         Makefile.(in); also ran make depend
2633
2634         * include/motd.h: don't need config.h, but now do need time.h;
2635         define new structures and constants; redefine old API and define
2636         new functions
2637
2638 2000-11-22  Kevin L. Mitchell  <klmitch@mit.edu>
2639
2640         * ircd/s_user.c (register_user): use motd_signon() instead of
2641         calling m_motd; much cleaner this way
2642
2643         * ircd/motd.c: write the new motd_* stuff to make MOTD handling
2644         less of a crock
2645
2646         * ircd/m_motd.c: rewrite m{,s}_motd to call out to new motd_*
2647         functions
2648
2649         * include/motd.h: define new MOTD API stuff
2650
2651 2000-11-20  Kevin L. Mitchell  <klmitch@mit.edu>
2652
2653         * ircd/ircd_reply.c (protocol_violation): rewrite
2654         protocol_violation so it'll actually work
2655
2656         oh, yeah, use %s -> cptr->name, instead of %c -> cptr, so we get
2657         the client's real name in there.
2658
2659         * ircd/m_motd.c (m_motd): Iso's addition of get_client_class(sptr)
2660         resulted in core dumps if NODEFAULTMOTD is defined, because m_motd
2661         gets called from register_user with a NULL sptr.  This is probably
2662         a design problem, but this bandaid will do for now...
2663
2664 2000-11-19  Isomer <isomer@coders.net>
2665         * ircd/ircd_reply.c: added 'protocol_violation', thus alerting us
2666         to problems in the server<->server protocol.
2667
2668         * ircd/m_connect.c: allow remote connects with a port of '0'
2669         meaning to use the port in the config file.
2670
2671         * ircd/m_create.c: Enable hacking protection, lets see how far we
2672         get.
2673
2674         * ircd/m_error.c: The RFC says never accept ERROR from unreg'd
2675         clients, so we don't any more.
2676
2677         * ircd/m_kill.c: The kill path is now made up of numnicks of servers,
2678         and the user@host is displayed of the victim.
2679
2680         * ircd/m_map.c: reloaded 'dump_map'.
2681
2682         * ircd/m_trace.c: allow per class T:
2683
2684         * ircd/m_stats.c: allow local opers /remote stats anywhere on the 'net.
2685
2686 2000-11-17  Isomer <isomer@coders.net>
2687
2688         * ircd/m_topic.c: Fixed bug where we'd only send to clients topics
2689         that were the *same* instead of different.  Oh the embarrasment!
2690
2691         * ircd/IPcheck.c: Merged net's fix.
2692
2693 2000-11-02  Kevin L. Mitchell  <klmitch@mit.edu>
2694
2695         * ircd/m_whois.c: remove compiler warning by adding a newline to
2696         end of file
2697
2698         * ircd/m_names.c: moved the flags up to s_user.h
2699
2700         * ircd/m_join.c: call do_names instead of m_names; restructure
2701         ms_join to never transmute a JOIN into a CREATE, but use the TS in
2702         the JOIN (if present) to timestamp the channel
2703
2704         * ircd/channel.c: send JOINs individually, instead of grouping
2705         them, so that we can send the channel's creation time
2706
2707         * include/s_user.h: declare do_names()
2708
2709 2000-10-30  Isomer <isomer@coders.net>
2710         * ircd/m_oper.c: Fixed warning
2711
2712 2000-10-30  Isomer <isomer@coders.net>
2713         * ircd/m_oper.c: Fixed over agressive cut and no paste
2714
2715 2000-10-30  Isomer <isomer@coders.net>
2716
2717         * ircd/m_topic.c: Restructured, fixed bug where topics on local
2718         channels are propergated (I forget who pointed this out to me, but
2719         thanks anyway).  Also to save bandwidth don't send the topic to
2720         users if the topic is already the same on the server (but still
2721         propergate to other servers).  X/W's "autotopic" feature must
2722         chew a lot of bandwidth, hopefully this will help reduce this.
2723
2724         * doc/rfc1459.rfc: Updated documentation on /topic.
2725
2726         * ircd/listener.c: snotice warnings about failed accept()'s
2727         potentially warning admins that they're running out of fd's.
2728
2729         * ircd/stats.c, ircd/class.c: Removed /stats v, added number of
2730         people in a class in /stats y
2731
2732         * ircd/m_create.c: Checks for timewarp hacking and squit's
2733         evil servers. (currently disabled)
2734         
2735
2736 2000-10-30  net <simms@lucida.qc.ca>
2737         
2738         * ircd/gline.c: Fixed various bugs Isomer left behind.
2739
2740 2000-10-26  Kevin L. Mitchell  <klmitch@mit.edu>
2741
2742         * ircd/m_join.c (m_join): reply on attempt to join a BADCHANed
2743         channel is now ERR_BANNEDFROMCHAN instead of ERR_BADCHANNAME
2744
2745 2000-10-24  Kevin L. Mitchell  <klmitch@mit.edu>
2746
2747         * ircd/channel.c: ok, now last mode rules; mode +ps will always
2748         result in +s (and won't send a mode if the channel is already +s);
2749         mode +sp will always result in +p; -n+n on a +n channel results in
2750         no mode change; -n+n on a -n channel results in a +n mode change;
2751         etc.
2752
2753 2000-10-23  Kevin L. Mitchell  <klmitch@mit.edu>
2754
2755         * ircd/channel.c: add "add" and "del" elements to ParseState to
2756         avoid not-too-pretty -p+s when +s is sufficient; fix a bug in
2757         mode_parse_limit that caused it to clear all channel modes
2758         prematurely; restructure mode_parse_mode to avoid calling
2759         modebuf_mode too early (ties in with first mentioned change);
2760         better logic for +p/+s mutual exclusivity; initialize "add" and
2761         "del" elements in mode_parse; send simple modes down to
2762         modebuf_mode after the loop in mode_parse
2763
2764 2000-09-28  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2765         * ircd/m_names.c: Fixed a non-lethal logic error that 
2766         triggers an assert() in find_member_link while debugging.
2767         (Spotted by Maniac-).
2768 2000-09-19  Thomas Helvey <helveytw@home.com>
2769         * ircd/s_conf.c: move K:lines to their own list and data
2770         structures, add supporting code.
2771         * ircd/m_stats.c: cleanup stats processing a bit move
2772         kline listing code to a new function, haven't figured
2773         out where it goes yet tho'
2774         * ircd/s_stats.c: added K:line bulk lister
2775         * include/s_conf.h: added new DenyConf struct
2776         * *[ch]: fixeup code that depended on changes
2777
2778 2000-09-17  Thomas Helvey <helveytw@home.com>
2779         * ircd/class.c: encapsulate class list
2780         * include/class.h: clean up classes
2781         * * fixup code that depended on changes
2782
2783 2000-09-17  Thomas Helvey <helveytw@home.com>
2784         * ircd/s_conf.c: add me to local conf
2785         * include/s_conf.h: move CONF_ME macro to chkconf.c
2786         * ircd/s_bsd.c: cleanup initialization, allow virtual host
2787         to be changed by rehash
2788
2789 2000-09-17  Thomas Helvey <helveytw@home.com>
2790         * include/class.h: add missing prototype
2791         * ircd/class.c: make argument to get_conf_class const
2792
2793 2000-09-17  Thomas Helvey <helveytw@home.com>
2794         * ircd/*.c: merged in changes from 2.10.10.pl12, cleanup
2795         merge conflicts.
2796         * ircd/*.h: merged in changes from 2.10.10.pl12, cleanup
2797         merge conflicts
2798
2799 2000-09-16  Thomas Helvey <helveytw@home.com>
2800         * ircd/s_conf.c: add code for server struct
2801         * ircd/client.c: copy of class.c sort of, new file for client
2802         specific operations, will move things here as appropriate,
2803         currently only one function is exported from here.
2804         * ircd/*.c: general logic cleanups, convert negatives to
2805         positives in places.
2806
2807 2000-09-16  Thomas Helvey <helveytw@home.com>
2808         * ircd/s_conf.c: add code for new crule data structs, strip quotes
2809         * ircd/crule.c: clean up scary casting a bit, type safety stuff
2810         * include/s_conf.h: add CRuleConf struct and support, remove
2811         unused constants
2812         * include/crule.h: type safety cleanups
2813         * ircd/*.c: fixup code that depended on stuff I changed
2814
2815 2000-09-15  Thomas Helvey <helveytw@home.com>
2816         * ircd/s_conf.c: start adding code for new conf data structs, changed
2817         listeners, admin line, motd lines, class lines. Move validate_hostent
2818         to resolver. General mayhem.
2819         * include/s_conf.h: new data structs and accessors
2820         * ircd/res.c: move validate_hostent here, rewrite, use regular
2821         expression for validation.
2822         * doc/example.conf: update docs for port
2823
2824 2000-09-14  Thomas Helvey <helveytw@home.com>
2825         * ircd/s_conf.c (conf_init): rewrite conf file parser, start to break
2826         up conf_init into managable chunks.
2827         * ircd/listener.c (set_listener_mask): fix logic bug core dump.
2828         * include/s_conf.h: add new data struct for local info (unwinding the mess).
2829
2830 2000-09-13  Thomas Helvey <helveytw@home.com>
2831         * ircd/list.c: put Clients in free lists, pre-allocate MAXCONNECTIONS
2832         local clients.
2833         * ircd/list.c: put SLinks in free lists
2834         * ircd/channel.c: put Memberships in free lists
2835         * ircd/ircd.c: rearrange initializations a bit in main
2836         Note: With these changes, ircd NEVER frees Clients, SLinks or
2837         Memberships. It will also rarely need to allocate new
2838         ones during net bursts and other disruptions. This should
2839         cut down on memory fragmentation a bit as well.
2840
2841 2000-08-30  Kevin L. Mitchell  <klmitch@mit.edu>
2842
2843         * ircd/m_names.c (do_names): pull-up from do_names fix in
2844         u2.10.10.pl11
2845
2846 2000-07-15  Perry Lorier       <Isomer@coders.net>
2847         * various: IP only k:'s and G:'s now do bit tests instead of two(!) 
2848                  match()'s.  Major Major cpu savings.  Also speed up the
2849                  other case slightly.  As a side effect you can now
2850                  k/Gline *@10.0.0.0/8.  I'll do bans tomorrow, it's nearing
2851                  3am.
2852
2853 2000-07-15  Perry Lorier       <Isomer@coders.net>
2854         * various: Fixed warnings after compiling on an alpha.
2855 2000-07-09  Perry Lorier       <Isomer@coders.net>
2856         * doc/ircd.8: Applied grammitical changes by Liandrin, applied
2857                       changes suggested by various other people.
2858         * ircd/IPcheck.c: More bug fixes.  Current problem appears to be
2859                         that it gets a corrupt entry somehow.
2860 2000-07-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2861         * ircd/m_oper.c: Clean up compiler warning.
2862
2863 2000-07-08  Perry Lorier       <Isomer@coders.net>
2864         * doc/ircd.8: Updated the documentation, it was slightly out of date
2865                       being updated around 1989.
2866         * ircd/m_whois.c: Rewrote for clarity, and probably a bit more speed.
2867                           fixed a few minor glitches.
2868         * doc/rfc1459.unet: Updated.
2869         * ircd/IPcheck.c: Fixed more bugs.
2870         * ircd/s_bsd.c: We now keep track of servers we've conected.
2871
2872 2000-07-02  Perry Lorier       <Isomer@coders.net>
2873         * ircd/s_misc.c: Fixed remote IPcheck bug.  Ok, I'm a moron, so sue
2874                         me.  Thanks to Hektik, thanks thanks thanks thanks
2875                         thanks thanks thanks thanks thank thanks thank thanks
2876
2877 2000-07-01  Perry Lorier       <Isomer@coders.net>
2878         * ircd/s_conf.c: "Fixed" the "bug" where people would "evade" K:'s.
2879         * ircd/s_conf.c, include/IPcheck.h: Fixed compile warnings.
2880
2881 2000-06-22  Perry Lorier       <Isomer@coders.net>
2882         * ircd/IPcheck.c: Large chunks redone.
2883         * ircd/s_conf.c: Changes due to IPcheck - ONE nolonger supported,
2884                         single AND double digit limits are allowed now.
2885         * misc other: Changes to IPcheck.
2886
2887 2000-06-30  Perry Lorier       <Isomer@coders.net>
2888         * ircd/ircd.c: Fix command line parameter bugs.
2889
2890 2000-06-30  Perry Lorier       <Isomer@coders.net>
2891         * ircd/m_kill.c: Fixed bug with LOCAL_KILL_ONLY
2892         * ircd/m_nick.c: Tidied things up.
2893
2894 2000-06-12 Joseph Bongaarts <foxxe@trms.com>
2895         * ircd/m_stats.c: Iso forgot mo_stats when he added /stats v
2896         
2897 2000-05-29  Perry Lorier       <Isomer@coders.net>
2898         * ircd/m_stats.c: add /stats v to do only the last part of the /trace
2899         * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
2900                         you think it'll get bored and fix itself?
2901
2902 2000-06-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2903
2904         * ircd/m_names.c: Clean up compiler warnings.
2905
2906 2000-06-09  Kevin L. Mitchell  <klmitch@mit.edu>
2907
2908         * ircd/channel.c (mode_parse_client): don't send warning if
2909         there's not enough arguments for a +/-o/v; means the habit of
2910         doing "/mode #channel +oooooo bob" doesn't result in a bunch of
2911         error messages
2912
2913 2000-06-04  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2914
2915         * ircd/m_names.c: Re-factor code to remove unneccessary
2916         GlobalChannelList iteration every time someone joins a channel.
2917
2918 2000-06-02  Kevin L. Mitchell  <klmitch@mit.edu>
2919
2920         * ircd/s_user.c: add struct Gline * argument to register_user;
2921         look up global glines and repropagate them if necessary; send
2922         acknowledgement of gline to remote servers when registering users
2923
2924         * ircd/s_serv.c (server_estab): don't send acknowledgement of
2925         local glines to remote servers; do send gline acknowledgement of
2926         bursted users
2927
2928         * ircd/m_user.c (m_user): pass new struct Gline * argument to
2929         register_user
2930
2931         * ircd/m_pong.c: pass new struct Gline * argument to register_user
2932
2933         * ircd/m_nick.c (ms_nick): document protocol change
2934
2935         * ircd/gline.c: support GLINE_LASTMOD
2936
2937         * include/s_user.h: add struct Gline * argument to register_user
2938
2939         * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
2940
2941         * ircd/s_conf.c (find_kill): add unsigned int argument to
2942         gline_lookup()
2943
2944         * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
2945         glines; add unsigned int argument to gline_lookup()
2946
2947         * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
2948         argument to gline_lookup()
2949
2950         * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
2951         parameter, or when it falls out of bounds: see comments prior to
2952         call to jupe_resend(); call server_estab with struct Jupe
2953         parameter, so that we place the appropriate %<lastmod> in the
2954         appropriate place.
2955
2956         * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
2957         server, as well as for servers when we're sending the BURST
2958
2959         * include/s_serv.h: add a struct Jupe * to the arguments for
2960         server_estab() so that we can send the appropriate lastmod
2961         parameter
2962
2963         * ircd/m_gline.c (ms_gline): actually, this should be the
2964         slightest bit more efficient...
2965
2966         * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
2967         bit more efficient...
2968
2969         * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
2970         during netburst
2971
2972         * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
2973         netburst
2974
2975         * ircd/channel.c (joinbuf_join): really remove user from local
2976         channels
2977
2978 2000-05-29  Perry Lorier       <Isomer@coders.net>
2979         * ircd/m_names.c: Removed redundant space. 
2980         * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
2981
2982 2000-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
2983
2984         * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
2985         a " "
2986
2987 2000-05-04  Kevin L. Mitchell  <klmitch@mit.edu>
2988
2989         * ircd/channel.c: replace bogus assertions with returns, which is
2990         logically correct; only wipe out limit/key if they were originally
2991         set in the first place; remove user from channel when doing a
2992         PARTALL; only send MODE +o for user CREATEing channel if user is
2993         not MyUser--CREATE will only be used if the channel did not
2994         originally exist, therefore we can assume no one local is on the
2995         channel anyway, and we don't exactly need for the user to see an
2996         explicit +o for themselves
2997
2998         * doc/readme.gline: describe the syntax of the GLINE command
2999
3000         * doc/readme.jupe: update to reflect a couple of changes to JUPE
3001
3002         * ircd/gline.c: don't propagate local changes
3003
3004         * ircd/jupe.c: don't propagate local changes
3005
3006         * ircd/m_gline.c (mo_gline): force local flag when deactivating
3007         glines with 0 lastmod
3008
3009         * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
3010         are now removed instead of being deactivated
3011
3012         * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
3013         -<mask>" be accepted
3014
3015         * ircd/channel.c (send_channel_modes): deal with one of the last
3016         vestiges of sendbuf
3017
3018         * ircd/m_burst.c (ms_burst): debugged ban processing; removed
3019         debugging hooks
3020
3021         * ircd/channel.c (modebuf_extract): remove debugging
3022         sendto_opmask_butone calls
3023
3024 2000-05-03  Kevin L. Mitchell  <klmitch@mit.edu>
3025
3026         * ircd/channel.c: support a couple of new flags to support using
3027         mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
3028         of modebuf_extract to extract added flags for use by ms_burst
3029
3030         * include/channel.h: a couple of new flags to support using
3031         mode_parse inside ms_burst
3032
3033         * ircd/m_burst.c (ms_burst): brand new implementation of BURST
3034
3035         * ircd/m_endburst.c: add loop to processing of end_of_burst to
3036         free empty channels after the BURST is over.
3037
3038         * ircd/m_server.c: convert to use new send.c functions--I wanted
3039         to rewrite it from scratch, but the logic's pretty complex; I may
3040         still rewrite it, though...
3041
3042 2000-05-02  Thomas Helvey <tomh@inxpress.net>
3043
3044         * ircd/ircd.c: fix broken header include ordering
3045
3046 2000-05-02  Thomas Helvey <tomh@inxpress.net>
3047         
3048         * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
3049         review emailed privately
3050
3051         * include/IPcheck.h: removed unneeded include
3052
3053 2000-05-02  Kevin L. Mitchell  <klmitch@mit.edu>
3054
3055         * ircd/s_user.c (hunt_server): throw in a comment so I know what
3056         the sendto_one is for
3057
3058         * include/querycmds.h (Count_unknownbecomesclient): convert to
3059         sendto_opmask_butone
3060
3061         * ircd/send.c: start removing dead code
3062
3063         * include/send.h: start removing dead code
3064
3065         * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
3066         hunt_server_cmd
3067
3068         * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
3069
3070 2000-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
3071
3072         * ircd/m_stats.c: convert to sendcmdto_one / send_reply
3073
3074         * ircd/m_kick.c: Completely reimplement m_kick
3075
3076         * ircd/channel.c: send_user_joins removed; it was dead code,
3077         anyway...
3078
3079 2000-05-01  Perry Lorier <isomer@coders.net>
3080         * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
3081         * ircd/channels.c: My fix for the part problem.  Untested, probably
3082                 won't work.  Can't be much worse than the current problem.
3083                 it'll either work or core, take your pick.
3084
3085
3086 2000-04-30  Perry Lorier <isomer@coders.net>
3087         * config/config-sh.in: Fix for CONNEXIT
3088         * ircd/s_{user,misc}.c: Fix for CONNEXIT
3089         * ircd/m_invite.c: Fix for incorrectly numnickified invite.
3090                         (Kev: Want to come talk to me about this?)
3091
3092 2000-04-30  Steven M. Doyle <steven@doyle.net>
3093         * ircd/ircd.c
3094           - general cleanups and readability enhancements
3095           - rewrite of setuid/chroot code.
3096           - server will no longer run as root
3097           - -DPROFIL compile option removed
3098           - Fixed IPcheck API calls
3099  
3100         * config/config-sh.in
3101           - Fixed up chroot compile options
3102           - Added options for debug and profile compiles
3103  
3104         * config/gen.ircd.Makefile
3105           - Support for new debug/profile options
3106  
3107         * ircd/Makefile.in
3108           - Support for new debug/profile options
3109  
3110         * ircd/ircd_signal.c
3111           - Removed -DPROFIL
3112
3113         * include/IPcheck.h
3114           - Removed old API prototypes, added new ones
3115         
3116         * ircd/IPcheck.c
3117           - Readability cleanups (well, I -think-...)
3118           - Changed IPRegistryEntry.last_connect to a time_t.  The previously
3119             used unsigned short was probably causing interesting things after
3120             a client had been connected longer than about 65,535 seconds...
3121           - Removed old API functions.
3122
3123         * ircd/whocmds.c
3124           - Removed IPcheck.h include
3125         
3126         * Additionally modified IPcheck API calls in:
3127           - ircd/m_nick.c
3128           - ircd/m_auth.c
3129           - ircd/s_bsd.c
3130           - ircd/s_conf.c
3131           - ircd/s_misc.c
3132           - ircd/s_serv.c
3133           - ircd/s_user.c
3134         
3135         
3136 2000-04-30  Perry Lorier <isomer@coders.net>
3137         * ircd/s_bsd.c: Sigh. :)
3138         * ircd/m_mode.c: fix for modeless channels by poptix.
3139
3140 2000-04-29  Kevin L. Mitchell  <klmitch@mit.edu>
3141
3142         * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
3143
3144         * ircd/channel.c (clean_channelname): make clean_channelname also
3145         truncate long channel names
3146
3147 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
3148
3149         * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
3150
3151         * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
3152         joinbuf_flush
3153
3154         * include/channel.h: definitions and declarations for the struct
3155         JoinBuf abstraction
3156
3157 2000-04-29  Perry Lorier <isomer@coders.net>
3158         * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
3159
3160 2000-04-29  Perry Lorier <isomer@coders.net>
3161         * ircd/s_bsd.c: Add debugging code to IPcheck
3162
3163 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
3164
3165         * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
3166
3167         * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
3168         RPL_EXPLICIT
3169
3170         * ircd/m_userhost.c (m_userhost): add a dead code comment
3171
3172         * ircd/m_desynch.c: forgot one...
3173
3174         * ircd/m_rehash.c (mo_rehash): er, duplicates :)
3175
3176         * ircd/m_proto.c (proto_send_supported): just change a comment so
3177         it doesn't show up in my scans
3178
3179         * ircd/ircd_reply.c (send_reply): fix a slight bug...
3180
3181         * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
3182         kinda hackish...
3183
3184         * ircd/parse.c (parse_server): argument wrangling to make
3185         processing in do_numeric a little easier to deal with
3186
3187         * ircd/s_serv.c (server_estab): SERVER should come from
3188         acptr->serv->up, not &me
3189
3190         * ircd/m_lusers.c: accidentally left out sptr for a %C
3191
3192         * ircd/send.c: hack to support doing wallchops...
3193
3194         * ircd/m_whowas.c: convert to new send functions
3195
3196         * ircd/m_whois.c: convert to new send functions
3197
3198         * ircd/m_who.c: convert to new send functions
3199
3200         * ircd/m_wallops.c: convert to new send functions
3201
3202         * ircd/m_wallchops.c: convert to new send functions
3203
3204         * ircd/m_version.c: convert to new send functions
3205
3206         * ircd/m_userip.c: convert to new send functions
3207
3208         * ircd/m_userhost.c: convert to new send functions
3209
3210         * ircd/m_uping.c: convert to new send functions
3211
3212         * ircd/m_trace.c: convert to new send functions
3213
3214         * ircd/m_topic.c: convert to new send functions
3215
3216         * ircd/m_time.c: convert to new send functions
3217
3218         * ircd/m_squit.c: convert to new send functions
3219
3220         * ircd/m_silence.c: convert to new send functions
3221
3222         * ircd/m_settime.c: convert to new send functions
3223
3224         * ircd/m_restart.c: convert to new send functions
3225
3226         * ircd/m_rehash.c: convert to new send functions
3227
3228         * ircd/m_privmsg.c: convert to new send functions
3229
3230         * ircd/m_pong.c: convert to new send functions
3231
3232         * ircd/m_ping.c: convert to new send functions
3233
3234         * ircd/m_pass.c: convert to new send functions
3235
3236         * ircd/m_opmode.c: convert to new send functions
3237
3238         * ircd/m_oper.c: convert to new send functions
3239
3240         * ircd/m_notice.c: convert to new send functions
3241
3242         * ircd/m_nick.c: convert to new send functions
3243
3244         * ircd/m_names.c: convert to new send functions
3245
3246         * ircd/m_motd.c: convert to new send functions
3247
3248         * ircd/m_mode.c: convert to new send functions
3249
3250         * ircd/m_map.c: convert to new send functions
3251
3252         * ircd/m_lusers.c: convert to new send functions
3253
3254         * ircd/m_list.c: convert to new send functions
3255
3256         * ircd/m_links.c: convert to new send functions
3257
3258         * ircd/m_kill.c: convert to new send functions
3259
3260         * ircd/m_jupe.c: convert to new send functions
3261
3262         * ircd/m_invite.c: convert to new send functions
3263
3264         * ircd/m_info.c: convert to new send functions
3265
3266         * ircd/m_help.c: convert to new send functions
3267
3268         * ircd/m_gline.c: convert to new send functions
3269
3270         * ircd/m_error.c: convert to new send functions
3271
3272         * ircd/m_endburst.c: convert to new send functions
3273
3274         * ircd/m_die.c: convert to new send functions
3275
3276         * ircd/m_destruct.c: convert to new send functions
3277
3278         * ircd/m_defaults.c: convert to new send functions
3279
3280         * ircd/m_connect.c: convert to new send functions
3281
3282 2000-04-28  Perry Lorier <isomer@coders.net>
3283         * RELEASE.NOTES: Describe a few more undocumented features.
3284         * config/config-sh.in: change the default paths for logging
3285         and the recommended number of channels.
3286         * include/supported.h: Rearrange slightly, added CHANTYPE's
3287
3288 2000-04-27  Kevin L. Mitchell  <klmitch@mit.edu>
3289
3290         * ircd/m_close.c: convert to send_reply
3291
3292         * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
3293
3294         * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
3295
3296         * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
3297
3298         * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
3299         that takes cmd and tok arguments, etc.  NOTE: THIS IMPLEMENTATION
3300         HAS A MAJOR HACK!!!  The whole hunt_server architecture should be
3301         carefully rethought...
3302
3303         * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
3304
3305         * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
3306
3307         * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
3308         numeric nick; therefore, we have to use the server name
3309
3310         * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
3311
3312         * ircd/send.c: fix minor bugs
3313
3314         * ircd/s_user.c (check_target_limit): mark dead code so I filter
3315         it when I grep
3316
3317         * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
3318         when I grep
3319
3320         * ircd/parse.c: mark dead code so I filter it when I grep
3321
3322         * ircd/map.c: mark dead code so I filter it when I grep
3323
3324         * ircd/ircd.c: mark dead code so I filter it when I grep
3325
3326         * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
3327         functions
3328
3329         * ircd/channel.c: mark dead code so I filter it when I grep
3330
3331         * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
3332         hope I'm not stepping on toes...
3333
3334         * ircd/s_conf.c: more sendto_opmask_butone / send_reply
3335         conversions; use ircd_snprintf in a couple of cases to negate the
3336         possibility of buffer overflow
3337
3338 2000-04-26  Kevin L. Mitchell  <klmitch@mit.edu>
3339
3340         * ircd/channel.c: convert as much as possible to new send
3341         semantics
3342
3343         * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
3344         test member->user->from->fd, not from->fd
3345
3346         * ircd/gline.c (gline_add): go ahead and add badchans; we just
3347         won't look for them in m_gline; this way, they always work...
3348
3349         * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
3350
3351         * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
3352         ircd_vsnprintf conversion specifiers
3353
3354         * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
3355         I have my conversion specifiers
3356
3357         * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
3358
3359         * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
3360         local users
3361
3362         * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
3363         little less brain-dead
3364
3365         * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
3366
3367         * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
3368         RPL_STATSDEBUG
3369
3370         * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
3371         RPL_STATSDEBUG
3372
3373         * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
3374         for RPL_STATSDEBUG
3375
3376         * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
3377
3378         * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
3379
3380         * ircd/s_user.c (register_user): use RPL_EXPLICIT for
3381         ERR_INVALIDUSERNAME
3382
3383         * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
3384
3385         * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
3386         a numeric as needing to use an explicit pattern, which will be the
3387         first argument in the variable argument list
3388
3389         * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
3390         non-prefixed nospoof PING
3391
3392         * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
3393         non-prefixed SERVER login
3394
3395         * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
3396         a numeric usage further up)
3397
3398         * include/send.h: declare sendrawto_one
3399
3400         * ircd/send.c (sendrawto_one): new function to use ONLY for
3401         non-prefixed commands, like PING to client, or PASS/SERVER on
3402         server registration
3403
3404 2000-04-25  Kevin L. Mitchell  <klmitch@mit.edu>
3405
3406         * ircd/ircd_snprintf.c (doprintf): implement %H for possible
3407         future expansion (channel numerics?)
3408
3409         * include/ircd_snprintf.h: added documentation to # to explain use
3410         with %C; added documentation for : to explain use with %C; added
3411         documentation for %H for channels
3412
3413         * ircd/whocmds.c: use send_reply
3414
3415         * ircd/userload.c: use sendcmdto_one
3416
3417         * ircd/uping.c: use sendcmdto_one
3418
3419         * ircd/send.c: use new flags to %C format string; ':' prefixes
3420         client name with a colon for local connects, '#' uses
3421         nick!user@host form for local connects
3422
3423         * ircd/s_user.c: use send_reply, sendto_opmask_butone,
3424         sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
3425
3426         * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
3427
3428         * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
3429         sendcmdto_one
3430
3431         * ircd/s_auth.c: use sendto_opmask_butone
3432
3433         * ircd/res.c: use sendcmdto_one
3434
3435         * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
3436         debugging assertions
3437
3438 2000-04-24  Kevin L. Mitchell  <klmitch@mit.edu>
3439
3440         * ircd/support.c: dumpcore is no longer used, so get rid of it
3441
3442         * ircd/parse.c: use send_reply, sendcmdto_one
3443
3444         * ircd/map.c: use send_reply
3445
3446         * ircd/listener.c: use send_reply
3447
3448         * ircd/jupe.c: use sendto_opmask_butone, send_reply
3449
3450         * ircd/ircd_reply.c: use send_reply
3451
3452         * ircd/ircd.c: use sendto_opmask_butone
3453
3454         * ircd/gline.c: use sendto_opmask_butone, send_reply
3455
3456         * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
3457         registered clients; make FLAG_ALT print nick!user@host; make
3458         FLAG_COLON print :blah
3459
3460         * ircd/class.c (report_classes): use send_reply instead of
3461         sendto_one
3462
3463         * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
3464
3465         * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
3466         sendto_one with sendcmdto_one
3467
3468 2000-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
3469
3470         * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
3471         MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
3472         sendcmdto_match_butone
3473
3474         * include/send.h: declare sendcmdto_match_butone
3475
3476 2000-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
3477
3478         * ircd/jupe.c: update to use send_reply()
3479
3480         * ircd/gline.c: update to use send_reply()
3481
3482         * include/ircd_reply.h: declare send_reply
3483
3484         * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
3485         replies; uses ircd_snprintf
3486
3487         * ircd/send.c: added comments to redirect searchers to appropriate
3488         sendcmdto_* function; moved new functions to end of file; added
3489         explanatory comments; reordered arguments; defined new functions
3490         mentioned below
3491
3492         * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
3493
3494         * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
3495
3496         * ircd/jupe.c: reorder arguments to sendcmdto_* functions
3497
3498         * ircd/gline.c: reorder arguments to sendcmdto_* functions
3499
3500         * include/send.h: reorder arguments, add explanatory comments,
3501         declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
3502         and vsendto_opmask_butone
3503
3504 2000-04-19  Kevin L. Mitchell  <klmitch@mit.edu>
3505
3506         * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
3507         vsendto_op_mask that uses '*' instead of the receiving client
3508         nickname
3509
3510         * include/send.h: declare sendcmdto_channel_butone; takes a skip
3511         argument that allows you to skip (or not to skip) deaf users,
3512         users behind bursting servers, and non channel operators
3513
3514 2000-04-17  Kevin L. Mitchell  <klmitch@mit.edu>
3515
3516         * ircd/send.c: new sendcmdto_channel_butserv -- note that old
3517         sendto_channel_butserv has a subtle bug; also wrote
3518         sendcmdto_common_channels.
3519
3520         * include/send.h: declare new sendcmdto_* functions
3521
3522         * ircd/jupe.c: support local deactivations of jupes
3523
3524         * ircd/gline.c: support local deactivations of glines
3525
3526         * include/jupe.h: JUPE_LDEACT allows jupes to be locally
3527         deactivated; if they aren't locally deactivated, then it slaves to
3528         the net-wide activation status; JupeIsRemActive() tests only
3529         whether the jupe is active everywhere else
3530
3531         * include/gline.h: GLINE_LDEACT allows glines to be locally
3532         deactivated; if they aren't locally deactivated, then it slaves to
3533         the net-wide activation status; GlineIsRemActive() tests only
3534         whether the gline is active everywhere else
3535
3536         * ircd/gline.c: detect overlapping G-lines; if an existing, wider
3537         gline expires after the new one will, we drop the new one,
3538         otherwise we add the G-line after that one (so the wide one will
3539         apply first); if the new one contains an existing G-line and if it
3540         will expire after the existing one, we drop the existing one to
3541         save memory
3542
3543         * ircd/m_gline.c (mo_gline): opers could issue remote local
3544         glines when CONFIG_OPERCMDS was off; fixed
3545
3546 2000-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
3547
3548         * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
3549         this is a local JUPE
3550
3551         * ircd/gline.c: add flags argument to gline_activate and
3552         gline_deactivate for future expansion
3553
3554         * ircd/m_gline.c: pass flags to gline_activate and
3555         gline_deactivate
3556
3557         * include/gline.h: add flags argument to gline_activate and
3558         gline_deactivate
3559
3560         * ircd/jupe.c: add flags argument to jupe_activate and
3561         jupe_deactivate for future expansion
3562
3563         * include/jupe.h: add flags argument to jupe_activate and
3564         jupe_deactivate
3565
3566         * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
3567         local, active; pass flags to jupe_activate and jupe_deactivate
3568
3569         * include/gline.h: remove dead code
3570
3571         * ircd/gline.c: make gline expire times relative to CurrentTime,
3572         since that should be monotonically increasing, instead of
3573         TStime(), which can be set backwards, and which can therefore
3574         cause an expire time to increase; make local glines be removed
3575         instead of just deactivated; don't let gline_find() look for
3576         user@host glines if the mask being looked up is a channel mask
3577
3578         * ircd/send.c (vsendcmdto_one): forgot to account for the case
3579         where origin is a server and destination is a user
3580
3581         * ircd/jupe.c: make jupe expire times relative to CurrentTime,
3582         since that should be monotonically increasing, instead of
3583         TStime(), which can be set backwards, and which can therefore
3584         cause an expire time to increase; make local jupes be removed
3585         instead of just deactivated
3586
3587         * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
3588         limit is fine.  any other warnings I should know about?
3589
3590 2000-04-15  Thomas Helvey <tomh@inxpress.net>
3591
3592         * ircd/*.c: const correctness and type safety cleanups to
3593         get code to compile with C++ compiler. Still has
3594         signed/unsigned comparison warnings.
3595
3596 2000-04-15  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3597
3598         * ircd/userload.c: change <sys/time.h> include to <time.h> for
3599           portability.
3600
3601 2000-04-14  Kevin L. Mitchell  <klmitch@mit.edu>
3602
3603         * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
3604         and convert acptr...
3605
3606         * ircd/s_user.c: move gline_lookup function call into
3607         register_user, where it'll have a username to lookup!
3608
3609         * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
3610         functions; also stuff send_error_to_client into return clauses
3611
3612         * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
3613         functions; also use send_error_to_client where that makes sense
3614
3615         * ircd/jupe.c: modify to utilize new sendcmdto_* series of
3616         functions; also use send_error_to_client where that makes sense
3617
3618         * ircd/gline.c: modify to utilize new sendcmdto_* series of
3619         functions; also fix gline_lookup() to deal properly with remote
3620         clients--boy, do struct Client and struct User need to be cleaned
3621         up!
3622
3623         * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
3624         too...
3625
3626         * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
3627         sendcmdto_serv_butone(), all utilizing the %v conversion of
3628         ircd_snprintf()
3629
3630         * include/send.h: define IRC_BUFSIZE, max size of a message;
3631         declare sendcmdto_one(), vsendcmdto_one(), and
3632         sendcmdto_serv_butone()
3633
3634         * include/msg.h: define all the CMD_* constants needed to utilize
3635         the new sendcmdto_* series of functions
3636
3637         * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
3638
3639         * ircd/gline.c: remove old, dead code.
3640
3641         * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
3642         unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
3643         (don't advertise proxies); remove dead code
3644
3645         * ircd/parse.c: oper handler for JUPE only lists jupes unless
3646         CONFIG_OPERCMDS is enabled
3647
3648         * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
3649         CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
3650
3651         * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
3652         always return ERR_DISABLED
3653
3654         * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
3655         enabled, always return ERR_DISABLED
3656
3657         * ircd/s_err.c: add error message to indicate disabled commands
3658
3659         * include/numeric.h (ERR_DISABLED): to indicate disabled commands
3660
3661         * doc/Configure.help: add documentation for CONFIG_OPERCMDS
3662
3663         * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
3664         CONFIG_NEW_MODE to 'y' for now
3665
3666         * ircd/gline.c (gline_list): fix a minor formatting bogon
3667
3668         * BUGS: since I fixed that bug, might as well mark it fixed.
3669
3670         * ircd/m_join.c: look up badchans with GLINE_EXACT
3671
3672         * ircd/m_gline.c: fix parc count problems; look up existing
3673         G-lines with GLINE_EXACT; only set new lastmod when
3674         activating/deactivating existing glines if old lastmod was not 0
3675
3676         * ircd/gline.c: forgot to copy the gline reason over; don't
3677         propagate a gline with 0 lastmod if origin is user; add
3678         GLINE_EXACT to force exact matching of gline mask
3679
3680         * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
3681         flag properly
3682
3683         * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
3684         but gline_lookup() actually takes a client--d'oh.
3685
3686 2000-04-13  Thomas Helvey <tomh@inxpress.net>
3687         * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
3688
3689 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3690
3691         * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
3692           "/who * x"
3693           "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
3694           (Found by Plexus).
3695
3696         * ircd/whocmds.c: Change idle time calc from socket idle to user
3697           idle.
3698
3699 2000-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
3700
3701         * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
3702         too, for ircd_snprintf.c
3703
3704         * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
3705         comments; mostly descended from the Linux manpage for printf, but
3706         also documenting the extensions.
3707
3708         * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
3709         client; make 'q' be the same as 'L'; remove __inline__; only
3710         define EXTENSION if HAVE_LONG_LONG is defined
3711
3712         * include/handlers.h: declare m_gline()
3713
3714         * ircd/parse.c: gline can be called by users, but it only lists
3715         the glines.
3716
3717         * ircd/s_user.c (set_nick_name): resend gline if a remote server
3718         introduces a glined client
3719
3720         * ircd/s_serv.c (server_estab): burst glines, too
3721
3722         * ircd/gline.c: fix up all the expire times to be offsets;
3723         simplify gline_resend()
3724
3725         * ircd/m_gline.c: begin coding replacements for ms_gline(),
3726         mo_gline(), and m_gline()
3727
3728         * ircd/gline.c (gline_add): allow *@#channel to work correctly;
3729         also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
3730
3731 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3732
3733         * tools/Bouncer/*: Add comments/documentation/tags.
3734         * tools/Bouncer/*: Add debug defines, make task fork().
3735
3736 2000-04-12  Thomas Helvey <tomh@inxpress.net>
3737         * ircd/s_err.c: Cleanup s_err.c make one table so we
3738         don't have to do anything tricky to get an error string.
3739
3740 2000-04-12  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3741         * Add port bouncer for http (x/w)
3742
3743 2000-04-12  Kevin L. Mitchell  <klmitch@mit.edu>
3744
3745         * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
3746         call to gline_find(); also used GlineReason() instead of direct
3747         reference to structure member
3748
3749         * ircd/m_join.c (m_join): replace bad_channel() calls with calls
3750         to gline_find(name, GLINE_BADCHAN), and also check to see if gline
3751         is active
3752
3753         * ircd/channel.c: nothing seems to be called anywhere...
3754
3755         * ircd/s_err.c: update a couple of replies to dovetail with new
3756         semantics
3757
3758         * ircd/gline.c: begin complete re-implementation of gline.c along
3759         the lines of the final design of jupe.c
3760
3761         * include/gline.h: begin complete re-implementation of gline.c
3762         along the lines of the final design of jupe.c
3763
3764         * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
3765         %s by %s" message...
3766
3767         * ircd/ircd_snprintf.c: my new snprintf()-like functions
3768
3769         * include/ircd_snprintf.h: my new snprintf()-like functions
3770
3771 2000-04-11  Thomas Helvey <tomh@inxpress.net>
3772         * ircd/IPcheck.c: removed old dead code
3773         * ircd/s_user.c (send_user_info): removed non-standard
3774           user not found message for userhost/userip
3775
3776 2000-04-11  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3777
3778         * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
3779         * doc/p10.html: Work on chapter 4.
3780
3781 2000-04-10  Kevin L. Mitchell  <klmitch@mit.edu>
3782
3783         * ircd/channel.c (mode_parse_client): fix coredump on /mode
3784         #foobar +o nosuchnick
3785
3786 2000-04-10  Perry Lorier  <Isomer@coders.net>
3787         * BUGS: Added bug.
3788
3789 2000-04-09  Thomas Helvey <tomh@inxpress.net>
3790         * include/IPcheck.h: fix prototype
3791         * ircd/s_user.c: fix usage of IPcheck_remote_connect
3792         * ircd/IPcheck.c: removed unused args
3793
3794 2000-04-09  Thomas Helvey <tomh@inxpress.net>
3795         * include/IPcheck.h: add proto for IPcheck_expire
3796
3797         * ircd/IPcheck.c: Rewrote
3798
3799         * ircd/ircd.c: Add IPcheck_expire to main message loop
3800
3801         * ircd/s_user.c: Redo target hashing, refactor target code
3802
3803         * include/numeric.h: Cleaned up numerics, added which ones are
3804         in use by other networks and what they are in use for.
3805
3806         * ircd/channel.c: cleaned can_join(), allow anyone through anything
3807         if /invited, simplified the function.  Opers overusing OPEROVERRIDE
3808         will get a message explaining to them not to cheat.
3809
3810         * ircd/m_join.c: cleaned up the various join functions, should be
3811         a lot more efficient.  Still needs work.  Now assumes that s<->s
3812         won't send it a JOIN 0.  Service coders - note this and tread with
3813         care.
3814
3815         * ircd/m_stats.c: added Gte-'s stats doc patch.
3816
3817         * ircd/m_version.c: /version now returns the 005 numeric as well.
3818         as requested by Liandrin.
3819
3820
3821 2000-04-07  Kevin L. Mitchell  <klmitch@mit.edu>
3822
3823         * ircd/m_clearmode.c: add include for support.h for write_log()
3824
3825         * configure: move ircd/crypt/* to tools/*
3826
3827 2000-04-06  Thomas Helvey <tomh@inxpress.net>
3828         * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
3829           set client host to server alias if connection from localhost
3830
3831 2000-04-06  Perry Lorier <isomer@coders.net>
3832         * ircd/ircd.c: Fix core during pinging (oops)
3833         
3834 2000-04-06  Perry Lorier <isomer@coders.net>
3835         * ircd/send.c: fixed wrong ident being sent to channels bug.
3836         * include/numerics.h: Updated some of the numerics from other
3837         networks.  Flagged some as 'unused' by undernet.
3838
3839 2000-03-30  Perry Lorier <isomer@coders.net>
3840         * ircd/ircd.c: Lets see if this helps the ping problem at all.
3841         * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
3842         time for local clients. (as requested), extended who now returns all
3843         the flags (@+!) so you can tell the complete state of a client.
3844
3845 2000-03-30  Thomas Helvey <tomh@inxpress.net>
3846         * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
3847
3848 2000-03-30  Perry Lorier <isomer@coders.net>
3849         * ircd/parse.c: oops, missed opers.
3850
3851 2000-03-30  Perry Lorier <isomer@coders.net>
3852         * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
3853         for so long.  Remember: m_ping MUST be in the parse array. :)
3854
3855 2000-03-30  Perry Lorier <isomer@coders.net>
3856         * ircd/ircd.c: test in check_pings was wrong.  I move that we
3857         disallow cvs commit after 10pm localtime....
3858
3859 2000-03-30  Perry Lorier <isomer@coders.net>
3860         * ircd/m_pong.c: Fix it for servers too.
3861
3862 2000-03-30  Perry Lorier <isomer@coders.net>
3863         * ircd/m_pong.c: Fix ping timeout bugs
3864
3865 2000-03-30  Perry Lorier <isomer@coders.net>
3866         * ircd/channel.c: Bans had CurrentTime in their when field instead
3867         of TStime()
3868
3869 2000-03-31  Thomas Helvey <tomh@ixpress.net>
3870         * ircd/numnicks.c (SetXYYCapacity): fix for extended
3871         numerics.
3872
3873 2000-03-30  Perry Lorier <isomer@coders.net>
3874         * ircd/m_nick.c: send kills both ways so when we add nick change
3875         on collision we don't desync the network.
3876
3877         * ircd/map.c: Fixup the map a bit more.
3878
3879 2000-03-31  Kevin L. Mitchell  <klmitch@mit.edu>
3880
3881         * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
3882
3883         * ircd/m_opmode.c: Log the mode changes to OPATH
3884
3885         * ircd/channel.c (modebuf_flush_int): Log the mode changes to
3886         OPATH
3887
3888         * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
3889         OPATH
3890
3891         * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
3892
3893         * config/config-sh.in: added OPATH for opmode log file
3894
3895         * ircd/m_clearmode.c (do_clearmode): updated uses of
3896         modebuf_mode_string() for the new usage
3897
3898         * ircd/channel.c: added flag MODE_FREE and an int argument to
3899         modebuf_mode_string() to indicate that the string must be free'd;
3900         updated calls to modebuf_mode_string() for the new usage; called
3901         collapse(pretty_mask()) on the ban string and use allocated memory
3902         for it; added ban list length accounting; fixed a number of small
3903         bugs in ban processing
3904
3905         * include/channel.h: added flag MODE_FREE and an int argument to
3906         modebuf_mode_string() to indicate that the string must be free'd
3907
3908         * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
3909         keys and limits that are set
3910
3911 2000-03-30  Perry Lorier <isomer@coders.net>
3912         * ircd/ircd.c: rewrote check_pings() for maintainability
3913         and speed.  Also changed quit msg's so they don't have
3914         redundant nick[host] info in them.
3915
3916         * ircd/send.c: Changed write errors to report what error
3917         occured (if possible).
3918
3919         * ircd/gline.c: added gline comment to the quit.
3920
3921         * ircd/m_server.c: Added suggestions to server quits mentioning
3922         what went wrong so the admin can fix it earlier instead of asking
3923         questions...
3924
3925         * ircd/map.c: Changed m_map() to hide numerics, show a * beside
3926         servers that aren't fully burst yet.  And show '(--s)' for servers
3927         where its not sure.
3928
3929         * doc/example.conf: Fixed wrapped U:
3930
3931 2000-03-30  Kevin L. Mitchell  <klmitch@mit.edu>
3932
3933         * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
3934         mode_parse() (version selectable at compile time)
3935
3936         * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
3937
3938         * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
3939
3940         * config/config-sh.in: add new config option to enable new m_mode
3941         implementation
3942
3943         * doc/Configure.help: add documentation for new config option
3944         CONFIG_NEW_MODE
3945
3946         * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
3947         MODE -v : Not enough parameters
3948
3949         * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
3950         +k and +l even if they weren't set...
3951
3952         * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
3953
3954         * ircd/channel.c: make mode_process_clients() clear the DEOPPED
3955         flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
3956         for; test the 0-th member, not the i-th member, of the client
3957         change state stuff
3958
3959         * ircd/m_clearmode.c (do_clearmode): use the new
3960         mode_invite_clear() function
3961
3962         * ircd/channel.c: cleared up all the compile-time warnings and
3963         errors
3964
3965         * include/channel.h: added declarations for mode_ban_invalidate()
3966         and mode_invite_clear()
3967
3968         * ircd/channel.c: finished mode_parse(), then broke it up into a
3969         dozen or so helper functions to make the code easier to read
3970
3971 2000-03-29  Thomas Helvey <tomh@inxpress.net>
3972         * ircd/ircd.c: refactor server initialization a bit, use
3973         getopt for parsing command line, refactor init_sys, main,
3974         and other bits.
3975
3976         * ircd/s_bsd.c: add functions for initialization to clean
3977         up logic a bit and remove duplicated code.
3978
3979         * include/ircd.h: add struct for server process related
3980         variables.
3981
3982 2000-03-29  Kevin L. Mitchell  <klmitch@mit.edu>
3983
3984         * ircd/channel.c: initial definition of mode_parse(); flags to
3985         prevent doing the same thing multiple times; helper method
3986         send_notoper() to send a "Not oper"/"Not on channel" notice
3987
3988         * include/channel.h: declare mode_parse() and helper flags
3989
3990         * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
3991         sending to match the current action of set_mode() closely enough
3992         that hopefully there won't be major conflicts
3993
3994         * ircd/channel.c (modebuf_flush_int): consolidated the mode string
3995         building logic, reversed the order of the arguments to mode
3996         commands to have '-' preceed '+'
3997
3998 2000-03-29  Thomas Helvey <tomh@inxpress.net>
3999         * ircd/s_bsd.c (add_connection): don't disable socket options
4000         let OS tune itself and allow important performance tweaks to 
4001         work.
4002
4003 2000-03-28  Kevin L. Mitchell  <klmitch@mit.edu>
4004
4005         * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
4006         confused by set_mode, which is doing some really weird logic;
4007         guess what I'm going to rewrite next?  ;)
4008
4009 2000-03-28  Kevin L. Mitchell  <klmitch@emc.com>
4010
4011         * include/channel.h: added MODE_SAVE for the bounds checking stuff
4012         in modebuf_flush
4013
4014         * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
4015         make it do bounds checking on the buffer; all modes are sent only
4016         if the all parameter is 1; modebuf_flush is the exported wrapper
4017
4018         * include/channel.h: add BOUNCE, renumber flags to get a little
4019         more space
4020
4021         * ircd/channel.c (modebuf_flush): don't overload HACK2, add
4022         BOUNCE; send DESYNCH message
4023
4024 2000-03-27  Kevin L. Mitchell  <klmitch@emc.com>
4025
4026         * ircd/m_clearmode.c (do_clearmode): only mark the modes the
4027         channel actually has in effect for deletion
4028
4029         * ircd/channel.c: added explanatory comments to all added
4030         functions; made flushing take place at the correct place even if
4031         the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
4032         to bash some stupid bugs; made modebuf_flush() return if ModeBuf
4033         is empty, fixed the apparent source, removed some bogus string
4034         termination code, properly terminate the mode strings, add support
4035         for HACK2 and HACK3, made limit strings not be sent if the limit
4036         is being removed, changed where '+' and '-' come from in sent
4037         strings, added support for DEOP flag, set up bouncing code for
4038         HACK2
4039
4040         * ircd/Makefile.in: ran make depend
4041
4042         * include/channel.h: added new defines for future functionality,
4043         made modebuf_flush() return int so I can use tail recursion
4044
4045         * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
4046         to make it all compile
4047
4048         * ircd/m_opmode.c: add msg.h to includes...
4049
4050         * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
4051
4052         * ircd/channel.c (modebuf_flush): realized I forgot to
4053         nul-terminate addbuf/rembuf properly...
4054
4055         * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
4056
4057         * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
4058         sendto_serv_butone--blah^2
4059
4060         * ircd/send.c (sendto_serv_butone): stupid comments confused me
4061
4062         * ircd/channel.c (modebuf_flush): if there are no mode changes to
4063         propagate, we're done...
4064
4065         * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
4066         not sendto_all_butone
4067
4068         * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
4069
4070         * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
4071
4072         * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
4073         the list
4074
4075         * ircd/parse.c: added messages for opmode and clearmode
4076
4077         * include/handlers.h: added declarations for mo_opmode(),
4078         ms_opmode(), mo_clearmode(), and ms_clearmode()
4079
4080         * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
4081         TOK_CLEARMODE
4082
4083         * include/channel.h (MODEBUF_DEST_OPMODE): Define the
4084         MODEBUF_DEST_OPMODE flag
4085
4086         * ircd/channel.c (modebuf_flush): added new flag,
4087         MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
4088         to originate from source's server (or source itself, if
4089         IsServer(source)); also causes a server-level MODE to be sent as
4090         OPMODE instead
4091
4092         * include/channel.h: defined MODEBUF_DEST_SERVER,
4093         MODEBUF_DEST_HACK4
4094
4095         * ircd/channel.c: Add another argument to build_string() to handle
4096         numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
4097         servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
4098         to be sent out
4099
4100 2000-03-27  Perry Lorier <isomer@coders.net>
4101
4102         * ircd/s_bsd.c: fixed missing 'u' typo.
4103
4104 2000-03-26  Kevin L. Mitchell  <klmitch@emc.com>
4105
4106         * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
4107         _mode_string(), _mode_client(), _flush(); also implemented a
4108         simple build_string()
4109
4110         * include/channel.h: added definition of ModeBuf, modebuf_*
4111         manipulation functions, and a couple of helper macros
4112
4113 2000-03-24 Thomas Helvey <tomh@inxpress.net>
4114   * numicks.c: convert extended numerics to use original mask version
4115   * numnicks.h: ""
4116   * s_user.c:
4117 2000-03-23 Thomas Helvey <tomh@inxpress.net>
4118   * Merge in changes from production
4119 2000-03-22 Thomas Helvey <tomh@inxpress.net>
4120   * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
4121   * rfc1459.unet: Add Maniac's documentation for /names 0
4122 * Fix misc. jupe bugs that somehow made it into the tree
4123 * Escape /names 0 to mean /names --Maniac
4124 * Don't core when server asks for info --Maniac 
4125 * Add Kev's jupe patch --Bleep
4126 * Add Maniacs squit patch --Bleep
4127 * Merge in u2_10_10_beta07 changes --Bleep
4128 * Merge in u2_10_10_beta06 changes --Bleep
4129 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
4130 #-----------------------------------------------------------------------------