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