Author: Kev <klmitch@mit.edu>
[ircu2.10.12-pk.git] / ChangeLog
1 2001-05-07  Kevin L. Mitchell  <klmitch@mit.edu>
2
3         * ircd/m_settime.c: include ircd_snprintf.h
4
5         * ircd/ircd_relay.c: stomp a couple of gcc warnings suggesting
6         parens around a construct that had both || and &&
7
8         * ircd/chkconf.c: #include "config.h" to get some important
9         definitions
10
11         * ircd/Makefile.in: revamp ircd makefile for new build system
12
13         * doc/Makefile.in: revamp doc makefile for new build system
14
15         * config/*: Removed old build system files
16
17         * stamp-h.in: a stamp file
18
19         * install-sh: install-sh for new build system
20
21         * configure.in: configure.in for new build system
22
23         * configure: configure script for new build system (built by
24         autoconf)
25
26         * config.sub: config.sub for new build system
27
28         * config.h.in: config.h.in for new build system (built by
29         autoheader)
30
31         * config.guess: config.guess for new build system
32
33         * aclocal.m4: aclocal.m4 for new build system (built by aclocal
34         1.4)
35
36         * acinclude.m4: aclocal.m4 macros for new build system
37
38         * acconfig.h: config.h skeleton for new build system
39
40         * Makefile.in: modify for new build system
41
42 2001-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
43
44         * ircd/s_err.c: get rid of the last vestiges of TIME_T_FMT
45
46         * ircd/m_settime.c: get rid of the last vestiges of TIME_T_FMT
47
48         * ircd/m_server.c: get rid of the last vestiges of TIME_T_FMT
49
50 2001-05-01  Perry Lorier       <Isomer@coders.net>
51         * doc/iauth.doc: Protocol for iauth server. (from hybrid).
52         * doc/linux-poll.patch: Patch to make Linux under 2.2 not deadlock
53                 when you have far far too many sockets in use.
54         * {include,ircd}/iauth.c: A start on iauth support.
55
56 2001-05-01  Perry Lorier       <Isomer@coders.net>
57         * ircd/s_err.c: Suggested wording change.
58         * ircd/s_user.c: Users aren't target limited against +k users.
59         * ircd/chkconf.c: Made it compile again, who knows if it works, but
60                 now I can at least make install
61         * various: Cleanups on m_*.c files.
62
63
64 2001-04-23  Kevin L. Mitchell  <klmitch@mit.edu>
65
66         * ircd/s_misc.c (exit_client): make netsplit server notice say the
67         right thing
68
69         * ircd/m_links.c (m_links_redirect): forward-port RPL_ENDOFLINKS
70         change to make Khaled happy...
71
72         * ircd/m_whois.c (do_whois): pull-up of m_whois() fix
73         (do_whois): duh...
74
75 2001-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
76
77         * ircd/msgq.c: finally remove the msgq_integrity() hack, as it's
78         turned up no more bugs
79
80         * ircd/ircd.c: use /* */ comments instead of // comments--all the
81         world's not gcc :(
82
83         * ircd/s_conf.c (conf_add_server): use /* */ comments instead of
84         // comments--all the world's not gcc :(
85
86         * ircd/runmalloc.c: finally garbage-collect unused file
87
88         * include/runmalloc.h: finally garbage-collect unused file
89
90         * ircd/<multiple files>: addition of '#include "config.h"' before
91         all other includes in most .c files
92
93         * include/<multiple files>: remove includes of config.h, which are
94         now going into the raw .c files
95
96 2001-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
97
98         * ircd/m_whois.c (do_whois): display proper server name if the
99         user is looking up himself
100
101         * ircd/m_who.c (m_who): disable match by servername or display of
102         server names by non-opers
103
104         * include/ircd_policy.h: add define for
105         HEAD_IN_SAND_WHO_SERVERNAME to cover full intent of sub-motion 15
106         of CFV 165
107
108 2001-04-18  Kevin L. Mitchell  <klmitch@mit.edu>
109
110         * ircd/s_conf.c: keep the $R in memory so we can see it clearly
111         when we do a /stats k
112
113         * ircd/s_user.c (set_user_mode): pull-up of changes to prevent
114         users from turning on +s and +g
115
116         * ircd/s_misc.c (exit_client): pull-up of changes to turn off
117         net.split notice
118
119         * ircd/parse.c: pull-up of changes to disable /trace, /links, and
120         /map for users
121
122         * ircd/m_whois.c (do_whois): pull-up of server name masking for
123         /whois
124
125         * ircd/m_user.c (m_user): removal of umode and snomask defaulting
126         functions, pull-up
127
128         * ircd/m_stats.c (m_stats): pull-up of stats-disabling stuff
129
130         * ircd/m_map.c (m_map_redirect): pull-up of m_map_redirect()
131
132         * ircd/m_links.c (m_links_redirect): pull-up of m_links_redirect()
133
134         * ircd/channel.c (channel_modes): pull-up of channel key display
135         as *
136
137         * include/ircd_policy.h: pull-up of ircd_policy.h
138
139         * include/client.h: pull-up of Set/ClearServNotice()
140
141         * ircd/gline.c (do_gline): report client name in G-line message
142         (pull-up)
143
144         * ircd/s_user.c (register_user): pull-up--show IP address in some
145         server notices dealing only with users; report which connection
146         class has filled up
147
148         * ircd/s_stats.c (report_deny_list): use conf->flags &
149         DENY_FLAGS_IP insteaf of conf->ip_kill
150
151         * ircd/m_stats.c (report_klines): use conf->flags & DENY_FLAGS_IP
152         insteaf of conf->ip_kill
153
154         * ircd/s_conf.c: use flags field in struct DenyConf; pull-up of
155         K-line by real name
156
157         * include/s_conf.h: use a flags field in struct DenyConf; define
158         DENY_FLAGS_FILE, DENY_FLAGS_IP, and DENY_FLAGS_REALNAME for
159         pull-up of K-line by real name
160
161         * ircd/m_trace.c: pull-up of IP show for user connections
162
163         * doc/example.conf: pull-up of the realname K-line documentation
164
165         * ircd/ircd.c: forward port of pid file advisory locking mechanism
166
167 2001-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
168
169         * ircd/send.c (sendcmdto_flag_butone): recast to just broadcast to
170         all servers, rather than to only servers that have +w/+g/whatever
171         users on them; among other things, this removes that atrocity
172         known as sentalong[] from this function
173
174         * ircd/m_admin.c: must include ircd.h to declare "me"; must
175         include hash.h to declare FindUser()
176
177         * ircd/m_wallusers.c: implementation of WALLUSERS
178
179         * ircd/m_desynch.c (ms_desynch): only send DESYNCHs to opers
180
181         * ircd/m_wallops.c: only send WALLOPS to opers
182
183         * ircd/parse.c: add WALLUSERS command to parser table
184
185         * include/handlers.h: declare wallusers handlers
186
187         * include/msg.h: add WALLUSERS command
188
189         * ircd/send.c (sendcmdto_flag_butone): if FLAGS_OPER is or'd with
190         flag, send only to appropriate opers
191
192 2001-03-13 Joseph Bongaarts <foxxe@wtfs.net>
193         * ircd/os_openbsd.c: Tweaked the openbsd hack a bit.
194         
195 2001-03-07  Joseph Bongaarts  <foxxe@wtfs.net>
196
197         * config/configure.in: Add check for OpenBSD
198
199         * ircd/os_openbsd.c: Add seperate os dep file for openbsd which
200         differs from generic BSD, particularly in its handling of
201         _XOPEN_SOURCE.
202         
203 2001-02-12  Kevin L. Mitchell  <klmitch@mit.edu>
204
205         * ircd/m_gline.c (ms_gline): propagate a G-line that happened to
206         have been added by a U-lined server, rather than going through the
207         activate/deactivate logic; propagate G-line removals by U-lined
208         servers as well
209
210         * ircd/gline.c: rename propagate_gline() to gline_propagate();
211         make gline_propagate() return an int 0 (convenience return); only
212         update lastmod in gline_activate() and gline_deactivate() if the
213         current lastmod is non-zero, since 0 lastmod is our flag of a
214         U-lined server having added a G-line
215
216         * include/gline.h (gline_propagate): exporting the G-line
217         propagation function
218
219         * ircd/m_list.c (m_list): duh; permit explicit channel name
220         specification only when /list gets two arguments ("Kev
221         #wasteland") rather than when /list gets more than two
222         arguments--nice braino
223
224 2001-01-29  Thomas Helvey <twhelvey1@home.com>
225
226         * ircd/ircd_reply.c (need_more_params): fix bug that allowed
227         unregistered clients to spam opers with protocol violation
228         messages. Note: the bugfix may have eliminated some useful
229         protocol violation messages.
230         Please send protocol violation messages explicitly from the
231         functions they are discovered in, you have much better context
232         for the error there and it helps to document the behavior of the
233         server. This was also a design bug in that it violated the
234         "A function should do one thing" heuristic. Patching this one
235         would have resulted in a continuous spawning of other bugs over
236         the next 3 years, so I killed it. Check around for stuff this
237         broke and readd the calls to protocol_violation in the functions
238         that need to send the message.
239
240 2001-01-29  Kevin L. Mitchell  <klmitch@mit.edu>
241
242         * ircd/channel.c (mode_parse_ban): stopper a tiny leak--if a ban
243         already existed, then the logic would (attempt to) skip it, but
244         would not free the ban string; now the ban string is free'd and
245         the ban count is decremented, releasing the ban for use
246
247         * ircd/s_user.c: make send_umode_out() take a prop argument
248         instead of testing for the PRIV_PROPAGATE privilege itself; fix
249         set_umode() to use this new argument, calculating it before
250         calculating the new privileges for a -o'd user
251
252         * ircd/m_oper.c (m_oper): pass the new prop argument to
253         send_umode_out()
254
255         * ircd/channel.c (mode_parse_ban): turn off MODE_ADD bit in bans
256         that we're not actually going to add because they already exist;
257         test that particular bit before adding to the linked list
258
259         * include/s_user.h: add a prop argument to send_umode_out() to
260         indicate whether or not to propagate the user mode
261
262 2001-01-24  Kevin L. Mitchell  <klmitch@mit.edu>
263
264         * ircd/msgq.c: ircd_vsnprintf() returns the number of bytes that
265         it would have written; upper-bound the number to prevent overflows
266         by proxy; also, tune buffer size given to ircd_vsnprintf() to take
267         into account the fact that ircd_vsnprintf() already takes the
268         terminal \0 into account
269
270 2001-01-22  Kevin L. Mitchell  <klmitch@mit.edu>
271
272         * ircd/msgq.c: add an incredibly ugly hack to attempt to track
273         down an apparent buffer overflow; remove msgq_map(), since it's no
274         longer used anywhere; slight tweaks to prevent off-by-one errors,
275         but these can't explain the problems we've seen
276
277         * include/msgq.h: remove msgq_map(), since it's no longer used
278         anywhere
279
280 2001-01-18  Kevin L. Mitchell  <klmitch@mit.edu>
281
282         * ircd/s_user.c (set_nick_name): call client_set_privs() after
283         parsing user modes
284
285 2001-01-17  Kevin L. Mitchell  <klmitch@mit.edu>
286
287         * ircd/s_bsd.c (read_message): fix a typo in the select version of
288         read_message()
289
290         * ircd/whowas.c (whowas_free): MyFree() is a macro that expects
291         its argument to be an lvalue, which means we can't use
292         whowas_clean()'s handy-dandy "return ww" feature
293
294         * ircd/ircd_features.c: default LOCOP_KILL to TRUE--oops...
295
296 2001-01-15  Kevin L. Mitchell  <klmitch@mit.edu>
297
298         * ircd/client.c: fixed feattab; basically, when I changed features
299         to use small integers specifying bit positions, instead of the
300         bits themselves, I forgot to update feattab to not | these
301         privileges together; also fixed a bug in the antiprivs masking
302         loop in client_set_privs()--last index wouldn't get parsed
303
304 2001-01-03  Kevin L. Mitchell  <klmitch@mit.edu>
305
306         * ircd/whowas.c: Completely re-did the old allocation scheme by
307         turning it into a linked list, permitting the
308         NICKNAMEHISTORYLENGTH feature to be changed on the fly
309
310         * ircd/s_debug.c (count_memory): use FEAT_NICKNAMEHISTORYLENGTH
311         feature instead of old #define
312
313         * ircd/ircd_features.c: add NICKNAMEHISTORYLENGTH feature as an
314         integer feature with a notify callback (whowas_realloc)
315
316         * ircd/client.c (client_set_privs): second memset was supposed to
317         be over antiprivs, not privs; thanks, Chris Behrens
318         <cbehrens@xo.com> for pointing that out...
319
320         * include/whowas.h: new elements for an extra linked list in
321         struct Whowas; a notify function for feature value changes
322
323         * include/ircd_features.h: new feature--FEAT_NICKNAMEHISTORYLENGTH
324
325         * config/config-sh.in: NICKNAMEHISTORYLENGTH is now a feature
326
327 2001-01-02  Kevin L. Mitchell  <klmitch@mit.edu>
328
329         * config/config-sh.in: get rid of DEFAULT_LIST_PARAMETER
330         compile-time option--now in features subsystem
331
332         * ircd/motd.c (motd_init): rework motd_init() to be called as the
333         notify function for MPATH and RPATH features (should probably
334         split it up a bit, though...)
335
336         * ircd/m_privs.c (mo_privs): if called with no parameters, return
337         privs of the caller, rather than an error
338
339         * ircd/m_list.c: pull usage message into its own function; pull
340         list parameter processing into its own function that does not
341         modify the contents of the parameter; add list_set_default() to
342         set the default list parameter (uses the notify hook); rework
343         m_list() to make use of these functions; removed dead code
344
345         * ircd/ircd_log.c (log_feature_mark): make sure to return 0, since
346         we have no notify handler
347
348         * ircd/ircd_features.c: add notify callback for notification of
349         value changes; give mark callback an int return value to indicate
350         whether or not to call the notify callback; fix up feature macros
351         for new notify callback; add DEFAULT_LIST_PARAM feature; rewrite
352         string handling in feature_set() to deal with def_str being a null
353         pointer; wrote feature_init() to set up all defaults appropriately
354
355         * ircd/ircd.c (main): call feature_init() instead of
356         feature_mark(), to avoid calling notify functions while setting up
357         defaults
358
359         * ircd/client.c: updated to deal with new privileges structure
360
361         * ircd/class.c: updated so init_class() can be called should one
362         of PINGFREQUENCY, CONNECTFREQUENCY, MAXIMUM_LINKS, or
363         DEFAULTMAXSENDQLENGTH be changed
364
365         * include/ircd_log.h: log_feature_mark() updated to fit with new
366         API changes
367
368         * include/ircd_features.h: added DEFAULT_LIST_PARAM feature and
369         feature_init() function (found necessary since adding the notify
370         stuff and notifying motd.c during start-up...before we defined
371         RPATH!)
372
373         * include/client.h: move privs around to enable addition of more
374         bits if necessary; based on the FD_* macros
375
376         * include/channel.h: declare list_set_default (actually located in
377         m_list.c *blanche*)
378
379         * ircd/s_user.c: retrieve MAXSILES and MAXSILELENGTH (now
380         AVBANLEN*MAXSILES) from features subsystem
381
382         * ircd/s_debug.c (debug_serveropts): CMDLINE_CONFIG doesn't go to
383         anything anymore
384
385         * ircd/s_bsd.c: retrieve HANGONGOODLINK and HANGONRETRYDELAY from
386         the features subsystem
387
388         * ircd/s_auth.c (start_auth): NODNS migrated to the features
389         subsystem
390
391         * ircd/random.c: created random_seed_set() function to set seed
392         value, along with some stuff to make ircrandom() a little more
393         random--state preserving, xor of time instead of direct usage,
394         etc.; it's still a pseudo-random number generator, though, and
395         hopefully I haven't broken the randomness
396
397         * ircd/m_version.c: FEATUREVALUES makes use of feature_int() calls
398
399         * ircd/m_join.c: use features interface to retrieve
400         MAXCHANNELSPERUSER
401
402         * ircd/ircd_features.c: add NODISP flag for super-secret features;
403         add a whole bunch of new features migrated over from make config
404
405         * ircd/ircd.c: use features interface to retrieve PINGFREQUENCY,
406         CONNECTTIMEOUT, and TIMESEC
407
408         * ircd/client.c (client_get_ping): use features interface to
409         retrieve PINGFREQUENCY
410
411         * ircd/class.c: use features interface to retrieve PINGFREQUENCY,
412         CONNECTFREQUENCY, MAXIMUM_LINKS, and DEFAULTMAXSENDQLENGTH
413
414         * ircd/chkconf.c (DEFAULTMAXSENDQLENGTH): since it's now in the
415         features subsystem, we have to add something explicit
416
417         * ircd/channel.c: use features interface to retrieve
418         KILLCHASETIMELIMIT, MAXBANLENGTH, MAXBANS, and MAXCHANNELSPERUSER;
419         note that MAXBANLENGTH is now calculated dynamically from MAXBANS
420         and AVBANLEN
421
422         * ircd/Makefile.in: run make depend
423
424         * include/supported.h (FEATURESVALUES): update to reference
425         feature settings
426
427         * include/random.h: add prototype for random_seed_set
428
429         * include/ircd_features.h: add several more features
430
431         * include/channel.h: move MAXBANS and MAXBANLENGTH into feature
432         subsystem
433
434         * config/config-sh.in: feature-ized some more stuff
435
436         * include/motd.h: some new elements in motd.h for motd.c changes
437
438         * ircd/motd.c: motd_cache() now searches a list of already cached
439         MOTD files; saves us from having duplicate caches in memory if
440         there are two identical T-lines for two different sites...
441
442 2001-01-02  Perry Lorier <isomer@coders.net>
443         * ircd/motd.c: don't core if the motd isn't found.  Bug found by
444         Amarande.
445
446 2001-01-02  Perry Lorier <isomer@coders.net>
447         * ircd/s_err.c: Added third param to 004 - the channel modes that tage params.  Used by hybrid/epic.
448         * ircd/s_channels.c: Added fix for msg'ing a -n+m channel - thanks
449                 to guppy for noticing, and hektik for providing the fix.
450         * misc others: Minor cleanups, added more protocol_violations, ripped
451                 out more P09 stuffs, bit more protocol neg stuff.
452
453 2000-12-19  Kevin L. Mitchell  <klmitch@mit.edu>
454
455         * ircd/m_ison.c (m_ison): Dianora says that ISON has to end with a
456         space (*sigh* stupid clients...)
457
458         * ircd/s_user.c: make WALLOPS_OPER_ONLY a feature managed through
459         ircd_features.[ch]
460
461         * ircd/s_err.c: get rid of GODMODE conditionals
462
463         * ircd/s_debug.c (debug_serveropts): switch to using appropriate
464         calls into the features subsystem for various serveropts
465         characters
466
467         * ircd/s_conf.c (find_conf_entry): get rid of USEONE conditional
468
469         * ircd/s_bsd.c: remove GODMODE conditional; use features subsystem
470         to get value of VIRTUAL_HOST and CLIENT_FLOOD; remove
471         NOFLOWCONTROL conditional
472
473         * ircd/s_auth.c: use features subsystem to determine value of
474         KILL_IPMISMATCH
475
476         * ircd/parse.c: get rid of NOOPER and GODMODE conditionals; use
477         features subsystem to determine the setting of IDLE_FROM_MSG
478
479         * ircd/numnicks.c: get rid of EXTENDED_NUMERICS conditionals
480
481         * ircd/motd.c: get value of NODEFAULTMOTD from features subsystem;
482         use features subsystem to get motd file names
483
484         * ircd/m_settime.c: get value of RELIABLE_CLOCK from features
485         subsystem
486
487         * ircd/m_server.c: get rid of CRYPT_LINK_PASSWORD, since it does
488         us no good; use features subsystem to figure out if we need to do
489         HUB-type stuff; make TESTNET debugging sendto_opmask_butone's use
490         the Debug(()) macro instead; get value of RELIABLE_CLOCK from
491         features subsystem
492
493         * ircd/m_privmsg.c: get IDLE_FROM_MSG from the features subsystem
494
495         * ircd/m_oper.c: get CRYPT_OPER_PASSWORD from the features
496         subsystem
497
498         * ircd/m_connect.c: get SERVER_PORT from the features subsystem
499
500         * ircd/ircd_log.c (log_set_file): fix a bug that kept log files
501         from getting marked if they were already set to something...
502
503         * ircd/ircd_features.c: add a flag to indicates read-only access;
504         add several new features that used to be compile-time selected
505
506         * ircd/ircd.c: grab pidfile out of feature subsystem; don't check
507         access to motd files (what the heck?); make sure to initialize the
508         feature subsystem before trying to write the config file
509
510         * ircd/dbuf.c: use feature_int() to retrieve BUFFERPOOL settings;
511         use feature_bool() to figure out if we're using the FERGUSON
512         flusher
513
514         * ircd/Makefile.in: MPATH and RPATH are now done differently, so
515         remove the clause that creates empty files of that name; also ran
516         make depend
517
518         * include/sys.h: CLIENT_FLOOD is now a feature; unfortunately,
519         there is no easy way to bounds-check it at present
520
521         * include/querycmds.h: make sure ircd_features.h is included; use
522         feature_str(FEAT_DOMAINNAME) in calls to match()
523
524         * include/ircd_features.h: many new features that used to be
525         compile-time selected
526
527         * config/config-sh.in: add * to DOMAINNAME; try also using first
528         argument to search in /etc/resolv.conf; removed many compile-time
529         options that now can be configured through the features system
530
531 2000-12-18  Kevin L. Mitchell  <klmitch@mit.edu>
532
533         * doc/api/log.txt: how to use the logging API
534
535         * doc/api/features.txt: how to use the features API
536
537         * doc/api/api.txt: how to write API documentation
538
539         * include/ircd_features.h: rearranged a couple of features for
540         neatness purposes
541
542         * ircd/ircd_features.c: cleaned up the macros some; rearranged
543         some code to all go into the switch; rearranged a couple of
544         features for neatness purposes
545
546 2000-12-16  Greg Sikorski <gte@atomicrevs.demon.co.uk>
547         * ircd/os_bsd.c: Added os_set_tos for BSD users.
548
549 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
550
551         * ircd/ircd_features.c: Isomer almost got it right; you need to
552         use F_I(), since it's an integer value, not a boolean value.  The
553         asserts in feature_int would catch you out...  Also made the F_*
554         macros take flags
555
556         * ircd/s_err.c: define RPL_PRIVS reply
557
558         * ircd/parse.c: put new PRIVS command into command table
559
560         * ircd/m_privs.c (mo_privs): message handler to report operator
561         privileges
562
563         * ircd/ircd_features.c: declare new features OPER_SET and
564         LOCOP_SET; redo boolean testing routine to accept TRUE, YES, and
565         ON for boolean TRUE, and FALSE, NO, and OFF for boolean FALSE
566
567         * ircd/client.c: simplify client_set_privs() with a table that
568         defines what features to test for; add new client_report_privs()
569
570         * ircd/Makefile.in: compile new m_privs.c; run make depend
571
572         * include/numeric.h (RPL_PRIVS): new reply numeric for displaying
573         an operator's privileges
574
575         * include/msg.h: define new command: PRIVS
576
577         * include/ircd_features.h: create new features OPER_SET and
578         LOCOP_SET for controlling access to /set
579
580         * include/handlers.h (mo_privs): declare message handler for
581         reporting oper privileges
582
583         * include/client.h (client_report_privs): declare function to
584         report what privileges an oper has
585
586         * ircd/m_whois.c (do_whois): fix a bug that caused /whois to
587         report that a user is an oper if the oper doing the /whois had
588         PRIV_SEE_OPERS
589
590 2000-12-17  Isomer <Isomer@coders.net>
591         * ircd/listener.c: added support for TOS twiddling as a 'feature'.
592
593 2000-12-17  Isomer <Isomer@coders.net>
594         * ircd/os_linux.c: add TOS stuffs
595
596         * ircd/listener.c: add TOS stuffs
597
598 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
599
600         * ircd/whocmds.c (do_who): use HasPriv to determine whether or not
601         to indicate a user is an oper
602
603         * ircd/s_user.c: clear privileges setting when deopping; don't
604         propagate +o unless user has PRIV_PROPAGATE privilege
605
606         * ircd/s_debug.c (debug_serveropts): created debug_serveropts()
607         function and replaced how the server option string is generated
608
609         * ircd/parse.c: remove conditional on CONFIG_OPERCMDS
610
611         * ircd/m_whois.c (do_whois): use HasPriv to determine whether or
612         not to indicate the user is an operator
613
614         * ircd/m_who.c: use HasPriv to determine whether or not a user
615         should be displayed in the list of opers
616
617         * ircd/m_version.c: call debug_serveropts() to get server option
618         string
619
620         * ircd/m_userip.c (userip_formatter): use HasPriv to determine
621         whether or not to show oper status
622
623         * ircd/m_userhost.c (userhost_formatter): use HasPriv to determine
624         whether or not to show oper status
625
626         * ircd/m_restart.c (mo_restart): replace ugly #ifdef conditional
627         checks with HasPriv check; remove dead code
628
629         * ircd/m_rehash.c (mo_rehash): replace ugly #ifdef conditional
630         checks with HasPriv check
631
632         * ircd/m_opmode.c (mo_opmode): use HasPriv to check permissions;
633         use feature_bool to check if disabled
634
635         * ircd/m_oper.c (m_oper): set oper priviliges
636
637         * ircd/m_mode.c (m_mode): replace #ifdef conditional with HasPriv
638         check
639
640         * ircd/m_kill.c (mo_kill): use HasPriv checks to determine if we
641         can kill
642
643         * ircd/m_kick.c (m_kick): replace #ifdef conditional with HasPriv
644         check
645
646         * ircd/m_jupe.c (mo_jupe): rework permissions checking structure;
647         use feature_bool to check if disabled
648
649         * ircd/m_join.c (m_join): remove BADCHAN conditional; replace
650         #ifdef conditional with a HasPriv check
651
652         * ircd/m_gline.c (mo_gline): rework permissions checking
653         structure; use feature_bool to check if any part is disabled
654
655         * ircd/m_die.c: replace ugly #ifdef conditionals with HasPriv
656         check; remove dead code
657
658         * ircd/m_clearmode.c: use feature_bool() to detect if we're
659         disabled; use HasPriv to figure out what we're permitted to do;
660         only allow clearmode on moded channels
661
662         * ircd/ircd_features.c: define various features; use HasPriv to
663         verify permissions to set/reset
664
665         * ircd/gline.c (gline_add): use HasPriv instead of #ifdef
666         conditionals
667
668         * ircd/client.c (client_set_privs): function to set an oper's
669         privileges
670
671         * ircd/channel.c: use HasPriv calls instead of #ifdef conditionals
672
673         * include/whocmds.h: deconditionalize several macros and
674         substitute appropriate calls to HasPriv()
675
676         * include/s_debug.h: get rid of global serveropts[]; define new
677         function debug_serveropts() to build that string on the fly
678
679         * include/ircd_features.h: define some features
680
681         * include/client.h: add privs member to struct Connection; define
682         various priviledges
683
684         * include/channel.h: no longer using IsOperOnLocalChannel; remove
685         conditional of MAGIC_OPER_OVERRIDE on OPER_WALK_THROUGH_LMODES
686
687         * doc/Configure.help: remove help information for deprecated
688         options
689
690         * config/config-sh.in: remove certain deprecated options having to
691         do with what opers can and cannot do--first stage in moving
692         compile-time constants into the .conf
693
694 2000-12-16  Isomer <Isomer@coders.net>
695         * ircd/parse.c: detect if the prefix is missing and try and recover
696         instead of coring.
697
698 2000-12-15  Kevin L. Mitchell  <klmitch@mit.edu>
699
700         * ircd/ircd_log.c: found and fixed some bugs in the debug logging
701         code that would sometimes result in the log file not being
702         reopened--which meant that a user could connect and get the
703         logging output--oops
704
705         * ircd/Makefile.in: run make depend...
706
707         * ircd/s_stats.c: get rid of report_feature_list()
708
709         * ircd/s_err.c: add the 'bad value' error message, shift error
710         messages over somewhat
711
712         * ircd/s_debug.c (debug_init): call log_debug_init with the
713         use_tty flag
714
715         * ircd/s_conf.c (read_configuration_file): unmark features before
716         reading the config file, then reset unmarked features after
717         reading the config file
718
719         * ircd/m_stats.c: use feature_report() instead of
720         report_feature_list()
721
722         * ircd/ircd_log.c: fix log_debug_file (bogus assertion); add
723         special 'mark' flags and use them; add the stuff needed by the
724         features API
725
726         * ircd/ircd_features.c: rework the features API and add gobs of
727         comments to try to explain what some of these complex functions
728         are actually doing
729
730         * include/s_stats.h: get rid of report_feature_list(); use
731         feature_report() instead
732
733         * include/numeric.h: added a new error message and shifted old
734         values over some--this is, after all, an alpha
735
736         * include/ircd_log.h: log_debug_init now takes an integer to tell
737         it if it should be using the tty; added a couple of functions
738         required by the features API
739
740         * include/ircd_features.h: add an enum and some more functions to
741         flesh out the feature API--it should now be possible to put all
742         those compile-time constants in the config file!
743
744         * ircd/send.c: got the direction of the assert incorrect...
745
746         * ircd/send.c: implement the efficiency of flush_connections by
747         creating a linked list of struct Connection's with queued data;
748         also get rid of flush_sendq_except and make sure to yank
749         connections out of the list when their sendQs become empty (notice
750         the assertion in flush_connections!)
751
752         * ircd/s_bsd.c (close_connection): must yank the Connection out of
753         the sendq list
754
755         * ircd/list.c (dealloc_connection): must yank the Connection out
756         of the sendq list
757
758         * ircd/dbuf.c (dbuf_put): call flush_connections instead of the
759         deprecated flush_sendq_except
760
761         * ircd/client.c: define a couple new helper functions for sendq
762         threading--this will make the flush_connections function in send.c
763         considerably more efficient by creating a linked list of
764         Connections that have queued data to send
765
766         * include/send.h: remove flush_sendq_except, as it's not used
767         anymore
768
769         * include/client.h: declare a couple new helper functions for the
770         sendq threading system
771
772 2000-12-14  Kevin L. Mitchell  <klmitch@mit.edu>
773
774         * ircd/m_ison.c (m_ison): Apply Diane Bruce's patch to make ISON
775         parse all arguments
776
777         * ircd/s_debug.c (count_memory): modify to report for clients and
778         connections, not local clients and remote clients
779
780         * ircd/list.c: fiddle with the client-fiddling functions to take
781         into account the divorce of struct Connection from struct Client
782
783         * ircd/ircd.c: define a struct Connection for me, initialize it,
784         and link it into the right place (ewww, globals!)
785
786         * include/client.h: remove CLIENT_{LOCAL,REMOTE}_SIZE; split
787         struct Client into struct Client and struct Connection; redefine
788         local-portion accessor macros to go through struct Client to the
789         struct Connection; define struct Connection accessor macros
790
791 2000-12-13  Kevin L. Mitchell  <klmitch@mit.edu>
792
793         * ircd/whowas.c: missed a couple of accesses to a struct Client
794
795         * ircd/uping.c: missed a couple of accesses to a struct Client
796
797         * ircd/send.c: missed a couple of accesses to a struct Client
798
799         * ircd/s_user.c: missed a couple of accesses to a struct Client
800
801         * ircd/s_misc.c: missed a couple of accesses to a struct Client
802
803         * ircd/s_conf.c: missed a couple of accesses to a struct Client
804
805         * ircd/s_bsd.c: missed a couple of accesses to a struct Client
806
807         * ircd/s_auth.c: missed a couple of accesses to a struct Client
808
809         * ircd/res.c: missed a couple of accesses to a struct Client
810
811         * ircd/parse.c: missed a couple of accesses to a struct Client
812
813         * ircd/m_whois.c: use new accessor macros for struct Client
814
815         * ircd/m_who.c: use new accessor macros for struct Client
816
817         * ircd/m_wallchops.c: use new accessor macros for struct Client
818
819         * ircd/m_version.c: use new accessor macros for struct Client
820
821         * ircd/m_userip.c: use new accessor macros for struct Client
822
823         * ircd/m_userhost.c: use new accessor macros for struct Client
824
825         * ircd/m_user.c: use new accessor macros for struct Client
826
827         * ircd/m_uping.c: use new accessor macros for struct Client
828
829         * ircd/m_trace.c: use new accessor macros for struct Client
830
831         * ircd/m_topic.c: use new accessor macros for struct Client
832
833         * ircd/m_time.c: use new accessor macros for struct Client
834
835         * ircd/m_stats.c: use new accessor macros for struct Client
836
837         * ircd/m_squit.c: use new accessor macros for struct Client
838
839         * ircd/m_silence.c: use new accessor macros for struct Client
840
841         * ircd/m_server.c: use new accessor macros for struct Client;
842         remove dead code
843
844         * ircd/m_rpong.c: use new accessor macros for struct Client
845
846         * ircd/m_rping.c: use new accessor macros for struct Client
847
848         * ircd/m_quit.c: use new accessor macros for struct Client
849
850         * ircd/m_privmsg.c: use new accessor macros for struct Client
851
852         * ircd/m_pong.c: use new accessor macros for struct Client; remove
853         dead code
854
855         * ircd/m_ping.c: use new accessor macros for struct Client
856
857         * ircd/m_pass.c: use new accessor macros for struct Client
858
859         * ircd/m_part.c: use new accessor macros for struct Client
860
861         * ircd/m_oper.c: use new accessor macros for struct Client
862
863         * ircd/m_notice.c: use new accessor macros for struct Client
864
865         * ircd/m_nick.c: use new accessor macros for struct Client
866
867         * ircd/m_names.c: use new accessor macros for struct Client
868
869         * ircd/m_mode.c: use new accessor macros for struct Client
870
871         * ircd/m_map.c: use new accessor macros for struct Client
872
873         * ircd/m_list.c: use new accessor macros for struct Client
874
875         * ircd/m_links.c: use new accessor macros for struct Client;
876         remove some dead code
877
878         * ircd/m_kill.c: use new accessor macros for struct Client; remove
879         some dead code
880
881         * ircd/m_kick.c: use new accessor macros for struct Client
882
883         * ircd/m_join.c: use new accessor macros for struct Client; remove
884         some dead code
885
886         * ircd/m_ison.c: use new accessor macros for struct Client
887
888         * ircd/m_invite.c: use new accessor macros for struct Client
889
890         * ircd/m_info.c: use new accessor macros for struct Client
891
892         * ircd/m_gline.c: use new accessor macros for struct Client
893
894         * ircd/m_error.c: use new accessor macros for struct Client
895
896         * ircd/m_create.c: use new accessor macros for struct Client
897
898         * ircd/m_connect.c: use new accessor macros for struct Client;
899         removed some dead code
900
901         * ircd/m_burst.c: use new accessor macros for struct Client
902
903         * ircd/m_away.c: use new accessor macros for struct Client
904
905         * ircd/m_admin.c: use new accessor macros for struct Client
906
907         * ircd/hash.c: missed a couple of accesses to a struct Client
908
909         * ircd/gline.c: missed a couple of accesses to a struct Client
910
911         * ircd/crule.c: missed a couple of accesses to a struct Client
912
913         * ircd/class.c: missed an access to a struct Client
914
915         * ircd/channel.c: missed a couple of accesses to a struct Client
916
917         * ircd/IPcheck.c: missed an access to a struct Client
918
919         * include/querycmds.h: fix a couple of stats macros to use
920         structure accessor macros
921
922         * include/client.h: change structure member names to highlight any
923         places in the code I've missed
924
925 2000-12-12  Kevin L. Mitchell  <klmitch@mit.edu>
926
927         * ircd/whowas.c: use new struct Client accessor macros
928
929         * ircd/whocmds.c: use new struct Client accessor macros
930
931         * ircd/send.c: use new struct Client accessor macros
932
933         * ircd/s_user.c: use new struct Client accessor macros; removed
934         some dead code
935
936         * ircd/s_serv.c: use new struct Client accessor macros; removed
937         some dead code
938
939         * ircd/s_numeric.c: use new struct Client accessor macros
940
941         * ircd/s_misc.c: use new struct Client accessor macros
942
943         * ircd/s_debug.c: use new struct Client accessor macros
944
945         * ircd/s_conf.c: use new struct Client accessor macros
946
947         * ircd/s_bsd.c: use new struct Client accessor macros
948
949         * ircd/s_auth.c: use new struct Client accessor macros
950
951         * ircd/parse.c: use new struct Client accessor macros
952
953         * ircd/packet.c: use new struct Client accessor macros
954
955         * ircd/numnicks.c: use new struct Client accessor macros
956
957         * ircd/motd.c: use new struct Client accessor macros
958
959         * ircd/listener.c: use new struct Client accessor macros
960
961         * ircd/list.c: use new struct Client accessor macros
962
963         * ircd/jupe.c: use new struct Client accessor macros
964
965         * ircd/ircd_snprintf.c: use new struct Client accessor macros
966
967         * ircd/ircd_reply.c: use new struct Client accessor macros
968
969         * ircd/ircd_relay.c: use new struct Client accessor macros
970
971         * ircd/ircd.c: use new struct Client accessor macros
972
973         * ircd/gline.c: catch some instances of me.<stuff> I missed
974         previously
975
976         * ircd/client.c: use cli_ instead of con_
977
978         * ircd/class.c: use cli_ instead of con_
979
980         * ircd/channel.c: use cli_ instead of con_
981
982         * ircd/IPcheck.c: use cli_ instead of con_; catch some instances
983         of me.<stuff> I missed previously
984
985         * include/client.h: use cli_ instead of con_...seemed like a good
986         idea at the time *shrug*
987
988 2000-12-11  Kevin L. Mitchell  <klmitch@mit.edu>
989
990         * ircd/hash.c: use struct Client accessor macros
991
992         * ircd/gline.c: use struct Client accessor macros
993
994         * ircd/crule.c: use struct Client accessor macros
995
996         * ircd/client.c: use struct Client accessor macros; remove some
997         dead code
998
999         * ircd/class.c: use struct Client accessor macros
1000
1001         * ircd/channel.c: use struct Client accessor macros; remove some
1002         dead code
1003
1004         * ircd/IPcheck.c: use struct Client accessor macros
1005
1006         * include/numnicks.h: use struct Client accessor macros
1007
1008         * include/client.h: first step to divorcing struct Client and
1009         struct Connection--define accessor macros and use them
1010
1011         * ircd/gline.c: When Uworld removed Uworld-set G-lines, only the
1012         uplink would remove them.  This is because the removal protocol
1013         message wasn't being sent to the uplinks.  This is fixed by fixing
1014         propagate_gline() to send the proper number of arguments depending
1015         on whether or not we're adding or deleting the Uworld gline, and
1016         by having gline_deactivate() make sure to turn off the active bit
1017         and call propagate_gline() if it's a Uworld gline
1018
1019 2000-12-10  Kevin L. Mitchell  <klmitch@mit.edu>
1020
1021         * ircd/os_generic.c: make sure IOV_MAX gets defined, just in case
1022
1023         * ircd/os_bsd.c: apparently BSD doesn't have IOV_MAX defined
1024         anywhere intelligent...
1025
1026 2000-12-09  Kevin L. Mitchell  <klmitch@mit.edu>
1027
1028         * ircd/send.c (send_queued): call deliver_it with appropriate
1029         arguments
1030
1031         * ircd/s_serv.c: reorder a couple of headers--cosmetic
1032
1033         * ircd/s_bsd.c (deliver_it): make deliver_it work with a struct
1034         MsgQ
1035
1036         * ircd/os_solaris.c (os_sendv_nonb): function for calling writev
1037         with appropriate iovec
1038
1039         * ircd/os_linux.c (os_sendv_nonb): function for calling writev
1040         with appropriate iovec
1041
1042         * ircd/os_generic.c (os_sendv_nonb): function for calling writev
1043         with appropriate iovec
1044
1045         * ircd/os_bsd.c (os_sendv_nonb): function for calling writev with
1046         appropriate iovec
1047
1048         * ircd/msgq.c (msgq_mapiov): add a len_p argument for totalling up
1049         exactly how much we're trying to write out to the fd
1050
1051         * include/s_bsd.h: make deliver_it take a struct MsgQ
1052
1053         * include/msgq.h: add a len_p argument to msgq_mapiov to help
1054         detect short writes that indicate possible socket blocking
1055
1056         * include/ircd_osdep.h: declare os_sendv_nonb()
1057
1058         * ircd/channel.c (modebuf_mode): don't add empty modes...
1059
1060 2000-12-08  Kevin L. Mitchell  <klmitch@mit.edu>
1061
1062         * include/send.h: add prio argument to send_buffer to select
1063         between normal and priority queues
1064
1065         * ircd/s_user.c (send_user_info): add prio argument to send_buffer
1066         call
1067
1068         * ircd/m_ison.c (m_ison): add prio argument to send_buffer call
1069
1070         * ircd/ircd_reply.c (send_reply): add prio argument to send_buffer
1071         call
1072
1073         * ircd/channel.c (send_channel_modes): add prio argument to
1074         send_buffer call
1075
1076         * ircd/send.c (send_buffer): add a prio argument to select the
1077         priority queue; update send.c functions to use it
1078
1079         * ircd/msgq.c (msgq_add): remove msgq_prio; fold msgq_link and
1080         msgq_add; add a prio argument to msgq_add to select the priority
1081         queue
1082
1083         * include/msgq.h: remove msgq_prio; add a prio argument to
1084         msgq_add
1085
1086         * ircd/send.c: remove sendbuf; remove GODMODE code; switch to
1087         using msgq functions instead of dbuf functions; remove old, dead
1088         sendto_* functions; redo send_buffer to take a struct MsgBuf;
1089         rework sendcmdto_* functions to make use of the new struct MsgBuf
1090
1091         * ircd/s_user.c: remove hunt_server; restructure send_user_info to
1092         make appropriate use of struct MsgBuf
1093
1094         * ircd/s_debug.c (count_memory): count memory used by the MsgQ
1095         system and report it
1096
1097         * ircd/s_conf.c (read_configuration_file): use
1098         sendto_opmask_butone instead of the now dead sendto_op_mask
1099
1100         * ircd/s_bsd.c: switch to using appropriate MsgQLength and other
1101         calls on sendQ
1102
1103         * ircd/parse.c (parse_server): get rid of a piece of GODMODE code
1104
1105         * ircd/msgq.c: add msgq_append and msgq_bufleft; fix a bug in
1106         msgq_clean
1107
1108         * ircd/m_version.c: fix spelling in comments marking dead code
1109
1110         * ircd/m_userip.c (userip_formatter): restructure to make use of
1111         struct MsgBuf
1112
1113         * ircd/m_userhost.c (userhost_formatter): restructure to make use
1114         of struct MsgBuf
1115
1116         * ircd/m_stats.c: use MsgQLength on a sendQ
1117
1118         * ircd/m_settime.c: use MsgQLength instead of DBufLength on a
1119         sendQ; mark a piece of dead code
1120
1121         * ircd/m_names.c: use send_reply instead of sendto_one
1122
1123         * ircd/m_mode.c: use new mode; remove old dead code
1124
1125         * ircd/m_ison.c (m_ison): restructure to make use of struct MsgBuf
1126
1127         * ircd/m_burst.c: use BUFSIZE instead of IRC_BUFSIZE; remove old
1128         dead code
1129
1130         * ircd/listener.c (accept_connection): use sendto_opmask_butone
1131         instead of sendto_op_mask
1132
1133         * ircd/list.c (free_client): use MsgQClear to clear sendQ
1134
1135         * ircd/ircd_reply.c: remove send_error_to_client; restructure
1136         send_reply to make use of struct MsgBuf
1137
1138         * ircd/dbuf.c (dbuf_put): remove argument to flush_sendq_except,
1139         since its no longer used (at least currently)
1140
1141         * ircd/channel.c: restructure send_channel_modes to make use of
1142         struct MsgBuf; remove set_mode, add_token_to_sendbuf, cancel_mode,
1143         and send_hack_notice; use BUFSIZE instead of IRC_BUFSIZE
1144
1145         * ircd/Makefile.in: add msgq.c to list of sources; run make depend
1146
1147         * ircd/IPcheck.c: use sendcmdto_one instead of sendto_one
1148
1149         * include/send.h: send_buffer now takes a struct MsgBuf * instead
1150         of a char *; flush_sendq_except now takes no arguments, as sendq
1151         flushing currently only happens in dbuf.h and sendQ is a struct
1152         MsgQ; remove prototypes for a lot of old sendto_* functions that
1153         aren't used anymore; remove sendbuf and IRC_BUFSIZE--the former is
1154         no longer needed, and the latter is identical to BUFSIZE in
1155         ircd_defs.h
1156
1157         * include/s_user.h: make InfoFormatter take a struct MsgBuf*
1158         instead of a char *; also make it return void, instead of char *
1159
1160         * include/msgq.h: add msgq_append and msgq_bufleft functions
1161
1162         * include/client.h: use a struct MsgQ instead of a struct DBuf for
1163         sendq
1164
1165         * doc/Configure.help: Remove help for compile-time options that
1166         have gone away
1167
1168         * config/config-sh.in: remove CONFIG_NEWMODE
1169
1170         * ircd/m_server.c (mr_server): don't send server IPs in any server
1171         notices
1172
1173         * ircd/msgq.c (msgq_vmake): add \r\n to messages
1174
1175 2000-12-07  Kevin L. Mitchell  <klmitch@mit.edu>
1176
1177         * include/msgq.h: declare the MsgQ API
1178
1179         * ircd/msgq.c: implementation of new MsgQ system
1180
1181 2000-12-06  Kevin L. Mitchell  <klmitch@mit.edu>
1182
1183         * ircd/ircd_features.c: #include was supposed to be for
1184           ircd_features.h, not features.h--missed when I had to do a
1185           rename because of namespace collision
1186
1187 2000-12-05  Greg Sikorski <gte@atomicrevs.demon.co.uk>
1188         * ircd/m_topic.c: Added missing braces that caused all remote
1189           topics to be ignored.
1190
1191 2000-12-04  Kevin L. Mitchell  <klmitch@mit.edu>
1192
1193         * ircd/m_create.c: I'm tired of the exit_client warning :)
1194         (ms_create): discovered that exit_client() was being called with
1195         too few arguments
1196
1197         * ircd/s_misc.c (exit_client): remove all dependance on
1198         FNAME_USERLOG, since that's now gone; log only to LS_USER
1199
1200         * ircd/s_debug.c: USE_SYSLOG no longer means anything
1201
1202         * ircd/m_oper.c (m_oper): no longer log to LS_OPERLOG--we already
1203         log to LS_OPER
1204
1205         * ircd/m_kill.c: no longer conditionalize on SYSLOG_KILL
1206
1207         * ircd/ircd_log.c: remove LS_OPERLOG, LS_USERLOG
1208
1209         * include/ircd_log.h: remove LS_OPERLOG, LS_USERLOG--they serve
1210         the same purpose as LS_USER and LS_OPER
1211
1212         * config/config-sh.in: remove no longer relevant log config
1213         variables
1214
1215         * ircd/uping.c (uping_init): use log_write instead of ircd_log
1216
1217         * ircd/s_misc.c (exit_client): use log_write instead of ircd_log
1218
1219         * ircd/s_conf.c: use log_write instead of ircd_log
1220
1221         * ircd/s_bsd.c (report_error): use log_write instead of ircd_log
1222
1223         * ircd/s_auth.c (timeout_auth_queries): use log_write instead of
1224         ircd_log
1225
1226         * ircd/res.c (send_res_msg): use log_write instead of ircd_log
1227
1228         * ircd/m_who.c: use log_write instead of write_log; no longer
1229         conditionalize on WPATH; mark dead ircd_log calls
1230
1231         * ircd/m_uping.c: mark dead ircd_log call
1232
1233         * ircd/m_server.c (mr_server): use log_write instead of ircd_log
1234
1235         * ircd/m_restart.c: use log_write instead of ircd_log; mark dead
1236         ircd_log calls
1237
1238         * ircd/m_rehash.c (mo_rehash): use log_write instead of ircd_log
1239
1240         * ircd/m_oper.c: use log_write instead of ircd_log; no longer
1241         conditionalize on FNAME_OPERLOG; mark dead ircd_log calls
1242
1243         * ircd/m_kill.c: mark dead ircd_log calls
1244
1245         * ircd/m_connect.c: use log_write instead of ircd_log; mark dead
1246         ircd_log
1247
1248         * ircd/m_clearmode.c: use log_write instead of write_log; no
1249         longer conditionalize on OPATH
1250
1251         * ircd/jupe.c: use log_write instead of write_log; no longer
1252         conditionalize on JPATH
1253
1254         * ircd/ircd_log.c: add USER subsystem; remove ircd_log() compat
1255         function; fix a couple of bugs
1256
1257         * ircd/ircd_alloc.c: fixed a comment
1258
1259         * ircd/ircd.c: use log_write instead of ircd_log; fold server
1260         notice generation in a couple of cases
1261
1262         * ircd/gline.c: use log_write instead of write_log; no longer
1263         conditionalize on GPATH
1264
1265         * ircd/channel.c (modebuf_flush_int): use log_write instead of
1266         write_log; no longer conditionalize on OPATH
1267
1268         * ircd/Makefile.in: run make depend, since dependencies have
1269         changed
1270
1271         * doc/example.conf: add system USER to documentation
1272
1273         * include/ircd_log.h: add system USER; remove old ircd_log()
1274         declarations
1275
1276 2000-12-04  Isomer <isomer@coders.net>
1277         * ircd/m_names.c: Add NAMES_EON to do_names to say add a
1278         'end_of_names' reply when done.
1279         * ircd/m_join.c: use NAMES_EON as mentioned above
1280
1281 2000-12-01  net  <simms@LUCIDA.QC.CA>
1282
1283         * ircd/motd.c: add a freelist for struct Motds
1284
1285 2000-11-30  Kevin L. Mitchell  <klmitch@mit.edu>
1286
1287         * ircd/s_stats.c (report_feature_list): report features--only
1288         local opers can see logging configuration, since it doesn't really
1289         mean anything to users
1290
1291         * ircd/s_err.c: add reply messages for new feature subsystem
1292
1293         * ircd/s_conf.c: add F lines to .conf
1294
1295         * ircd/parse.c: add the message descriptions for /set, /reset, and
1296         /get
1297
1298         * ircd/m_stats.c: add /stats f
1299
1300         * ircd/m_set.c (mo_set): implement /set
1301
1302         * ircd/m_reset.c (mo_reset): implement /reset
1303
1304         * ircd/m_rehash.c: /rehash m now flushes MOTD cache, and /rehash l
1305         reopens log files (for log file rotation)
1306
1307         * ircd/m_get.c (mo_get): implement /get
1308
1309         * ircd/ircd_log.c: use int instead of void return value; add
1310         log_report_features() and log_canon(); fix a function that
1311         disappears if DEBUGMODE not #define'd
1312
1313         * ircd/ircd_features.c: functions to manipulate feature settings
1314         either from the config file or with the new /set, /reset, and /get
1315         commands
1316
1317         * ircd/Makefile.in: add new .c files, run make depend
1318
1319         * include/s_stats.h: declare report_feature_list() (/stats f
1320         handler)
1321
1322         * include/numeric.h: add RPL_STATSFLINE, RPL_FEATURE,
1323         ERR_NOFEATURE, ERR_BADLOGTYPE, ERR_BADLOGSYS, and ERR_BADLOGVALUE
1324         reply numerics
1325
1326         * include/msg.h: add defines for SET, RESET, and GET
1327
1328         * include/ircd_log.h: add a function to canonicalize subsystem
1329         names; change some void return values to int
1330
1331         * include/ircd_features.h: new features subsystem handles all the
1332         manipulation of special features, like log files
1333
1334         * include/handlers.h: declare new mo_{s,res,g}et message handlers
1335         for fiddling with features run-time
1336
1337         * include/client.h (SNO_DEFAULT): don't set SNO_DEBUG by default;
1338         seemed like a good idea at the time...
1339
1340         * doc/example.conf: document new F lines
1341
1342 2000-11-29  Kevin L. Mitchell  <klmitch@mit.edu>
1343
1344         * ircd/s_debug.c: rewrite debug_init() and vdebug() in terms of
1345         new logging functions, which have special support for the debug
1346         log; added loop detection to vdebug(), so that I can
1347         sendto_opmask_butone() from log_vwrite() without incurring another
1348         call to vdebug()
1349
1350         * ircd/s_conf.c (rehash): call log_reopen() from rehash routine;
1351         this allows log file rotations
1352
1353         * ircd/m_kill.c: call log_write_kill() instead of ircd_log_kill()
1354
1355         * ircd/ircd_log.c: much more work fleshing out the interface;
1356         removed old interface; included backwards-compat ircd_log()
1357         function that logs to subsystem LS_OLDLOG
1358
1359         * ircd/ircd.c: switch to new log_init()/log_close()/log_reopen()
1360         functions
1361
1362         * include/ircd_log.h: include stdarg.h for va_list; move ordering
1363         warning to top of file; fill out LogSys enum; declare new
1364         log_debug_init(), log_vwrite(), log_write_kill(), and
1365         log_[sg]et_*() functions; add flags argument to log_write();
1366         defined flags to inhibit various logging actions
1367
1368         * include/client.h: added support for new SNO_DEBUG, enabled only
1369         if DEBUGMODE is defined
1370
1371 2000-11-28  Kevin L. Mitchell  <klmitch@mit.edu>
1372
1373         * ircd/ircd_log.c: make sure the various LOG_* constants are
1374         defined (probably not needed, since #include <syslog.h> isn't
1375         conditional); various static data needed for the new logging
1376         functions; definitions of new logging functions
1377
1378         * include/ircd_log.h: new LogSys enum, declarations for part of
1379         new logging API
1380
1381         * ircd/motd.c: we were setting type to MOTD_CLASS unconditionally,
1382         which was of course stupid; switched to using switch/case in
1383         initialization in motd_create(); zero the MotdList.other pointer
1384         from motd_clear()
1385
1386         * ircd/ircd.c (main): motd_init() has to come before init_conf(),
1387         or we overwrite init_conf()'s hard work with respect to T-lines
1388
1389 2000-11-27  Kevin L. Mitchell  <klmitch@mit.edu>
1390
1391         * ircd/s_stats.c: comment out report_motd_list and include a
1392         reference to motd_report()
1393
1394         * ircd/s_conf.c: rip out the old MOTD manipulation functions; call
1395         motd_add() from the conf parser; call motd_clear() from the rehash
1396         routine; remove the no longer needed memory clearing and reloading
1397         stuff from the rehash service routine
1398
1399         * ircd/motd.c: loads new API, including static internal functions
1400         to do allocation/deallocation, etc.
1401
1402         * ircd/m_stats.c: use new motd_report() instead of
1403         report_motd_list()
1404
1405         * ircd/m_motd.c: use new syntax for motd_send()
1406
1407         * ircd/ircd.c: use new motd_init() function
1408
1409         * ircd/Makefile.in (SRC): forgot to add motd.c to SRC in
1410         Makefile.(in); also ran make depend
1411
1412         * include/motd.h: don't need config.h, but now do need time.h;
1413         define new structures and constants; redefine old API and define
1414         new functions
1415
1416 2000-11-22  Kevin L. Mitchell  <klmitch@mit.edu>
1417
1418         * ircd/s_user.c (register_user): use motd_signon() instead of
1419         calling m_motd; much cleaner this way
1420
1421         * ircd/motd.c: write the new motd_* stuff to make MOTD handling
1422         less of a crock
1423
1424         * ircd/m_motd.c: rewrite m{,s}_motd to call out to new motd_*
1425         functions
1426
1427         * include/motd.h: define new MOTD API stuff
1428
1429 2000-11-20  Kevin L. Mitchell  <klmitch@mit.edu>
1430
1431         * ircd/ircd_reply.c (protocol_violation): rewrite
1432         protocol_violation so it'll actually work
1433
1434         oh, yeah, use %s -> cptr->name, instead of %c -> cptr, so we get
1435         the client's real name in there.
1436
1437         * ircd/m_motd.c (m_motd): Iso's addition of get_client_class(sptr)
1438         resulted in core dumps if NODEFAULTMOTD is defined, because m_motd
1439         gets called from register_user with a NULL sptr.  This is probably
1440         a design problem, but this bandaid will do for now...
1441
1442 2000-11-19  Isomer <isomer@coders.net>
1443         * ircd/ircd_reply.c: added 'protocol_violation', thus alerting us
1444         to problems in the server<->server protocol.
1445
1446         * ircd/m_connect.c: allow remote connects with a port of '0'
1447         meaning to use the port in the config file.
1448
1449         * ircd/m_create.c: Enable hacking protection, lets see how far we
1450         get.
1451
1452         * ircd/m_error.c: The RFC says never accept ERROR from unreg'd
1453         clients, so we don't any more.
1454
1455         * ircd/m_kill.c: The kill path is now made up of numnicks of servers,
1456         and the user@host is displayed of the victim.
1457
1458         * ircd/m_map.c: reloaded 'dump_map'.
1459
1460         * ircd/m_trace.c: allow per class T:
1461
1462         * ircd/m_stats.c: allow local opers /remote stats anywhere on the 'net.
1463
1464 2000-11-17  Isomer <isomer@coders.net>
1465
1466         * ircd/m_topic.c: Fixed bug where we'd only send to clients topics
1467         that were the *same* instead of different.  Oh the embarrasment!
1468
1469         * ircd/IPcheck.c: Merged net's fix.
1470
1471 2000-11-02  Kevin L. Mitchell  <klmitch@mit.edu>
1472
1473         * ircd/m_whois.c: remove compiler warning by adding a newline to
1474         end of file
1475
1476         * ircd/m_names.c: moved the flags up to s_user.h
1477
1478         * ircd/m_join.c: call do_names instead of m_names; restructure
1479         ms_join to never transmute a JOIN into a CREATE, but use the TS in
1480         the JOIN (if present) to timestamp the channel
1481
1482         * ircd/channel.c: send JOINs individually, instead of grouping
1483         them, so that we can send the channel's creation time
1484
1485         * include/s_user.h: declare do_names()
1486
1487 2000-10-30  Isomer <isomer@coders.net>
1488         * ircd/m_oper.c: Fixed warning
1489
1490 2000-10-30  Isomer <isomer@coders.net>
1491         * ircd/m_oper.c: Fixed over agressive cut and no paste
1492
1493 2000-10-30  Isomer <isomer@coders.net>
1494
1495         * ircd/m_topic.c: Restructured, fixed bug where topics on local
1496         channels are propergated (I forget who pointed this out to me, but
1497         thanks anyway).  Also to save bandwidth don't send the topic to
1498         users if the topic is already the same on the server (but still
1499         propergate to other servers).  X/W's "autotopic" feature must
1500         chew a lot of bandwidth, hopefully this will help reduce this.
1501
1502         * doc/rfc1459.rfc: Updated documentation on /topic.
1503
1504         * ircd/listener.c: snotice warnings about failed accept()'s
1505         potentially warning admins that they're running out of fd's.
1506
1507         * ircd/stats.c, ircd/class.c: Removed /stats v, added number of
1508         people in a class in /stats y
1509
1510         * ircd/m_create.c: Checks for timewarp hacking and squit's
1511         evil servers. (currently disabled)
1512         
1513
1514 2000-10-30  net <simms@lucida.qc.ca>
1515         
1516         * ircd/gline.c: Fixed various bugs Isomer left behind.
1517
1518 2000-10-26  Kevin L. Mitchell  <klmitch@mit.edu>
1519
1520         * ircd/m_join.c (m_join): reply on attempt to join a BADCHANed
1521         channel is now ERR_BANNEDFROMCHAN instead of ERR_BADCHANNAME
1522
1523 2000-10-24  Kevin L. Mitchell  <klmitch@mit.edu>
1524
1525         * ircd/channel.c: ok, now last mode rules; mode +ps will always
1526         result in +s (and won't send a mode if the channel is already +s);
1527         mode +sp will always result in +p; -n+n on a +n channel results in
1528         no mode change; -n+n on a -n channel results in a +n mode change;
1529         etc.
1530
1531 2000-10-23  Kevin L. Mitchell  <klmitch@mit.edu>
1532
1533         * ircd/channel.c: add "add" and "del" elements to ParseState to
1534         avoid not-too-pretty -p+s when +s is sufficient; fix a bug in
1535         mode_parse_limit that caused it to clear all channel modes
1536         prematurely; restructure mode_parse_mode to avoid calling
1537         modebuf_mode too early (ties in with first mentioned change);
1538         better logic for +p/+s mutual exclusivity; initialize "add" and
1539         "del" elements in mode_parse; send simple modes down to
1540         modebuf_mode after the loop in mode_parse
1541
1542 2000-09-28  Greg Sikorski <gte@atomicrevs.demon.co.uk>
1543         * ircd/m_names.c: Fixed a non-lethal logic error that 
1544         triggers an assert() in find_member_link while debugging.
1545         (Spotted by Maniac-).
1546 2000-09-19  Thomas Helvey <helveytw@home.com>
1547         * ircd/s_conf.c: move K:lines to their own list and data
1548         structures, add supporting code.
1549         * ircd/m_stats.c: cleanup stats processing a bit move
1550         kline listing code to a new function, haven't figured
1551         out where it goes yet tho'
1552         * ircd/s_stats.c: added K:line bulk lister
1553         * include/s_conf.h: added new DenyConf struct
1554         * *[ch]: fixeup code that depended on changes
1555
1556 2000-09-17  Thomas Helvey <helveytw@home.com>
1557         * ircd/class.c: encapsulate class list
1558         * include/class.h: clean up classes
1559         * * fixup code that depended on changes
1560
1561 2000-09-17  Thomas Helvey <helveytw@home.com>
1562         * ircd/s_conf.c: add me to local conf
1563         * include/s_conf.h: move CONF_ME macro to chkconf.c
1564         * ircd/s_bsd.c: cleanup initialization, allow virtual host
1565         to be changed by rehash
1566
1567 2000-09-17  Thomas Helvey <helveytw@home.com>
1568         * include/class.h: add missing prototype
1569         * ircd/class.c: make argument to get_conf_class const
1570
1571 2000-09-17  Thomas Helvey <helveytw@home.com>
1572         * ircd/*.c: merged in changes from 2.10.10.pl12, cleanup
1573         merge conflicts.
1574         * ircd/*.h: merged in changes from 2.10.10.pl12, cleanup
1575         merge conflicts
1576
1577 2000-09-16  Thomas Helvey <helveytw@home.com>
1578         * ircd/s_conf.c: add code for server struct
1579         * ircd/client.c: copy of class.c sort of, new file for client
1580         specific operations, will move things here as appropriate,
1581         currently only one function is exported from here.
1582         * ircd/*.c: general logic cleanups, convert negatives to
1583         positives in places.
1584
1585 2000-09-16  Thomas Helvey <helveytw@home.com>
1586         * ircd/s_conf.c: add code for new crule data structs, strip quotes
1587         * ircd/crule.c: clean up scary casting a bit, type safety stuff
1588         * include/s_conf.h: add CRuleConf struct and support, remove
1589         unused constants
1590         * include/crule.h: type safety cleanups
1591         * ircd/*.c: fixup code that depended on stuff I changed
1592
1593 2000-09-15  Thomas Helvey <helveytw@home.com>
1594         * ircd/s_conf.c: start adding code for new conf data structs, changed
1595         listeners, admin line, motd lines, class lines. Move validate_hostent
1596         to resolver. General mayhem.
1597         * include/s_conf.h: new data structs and accessors
1598         * ircd/res.c: move validate_hostent here, rewrite, use regular
1599         expression for validation.
1600         * doc/example.conf: update docs for port
1601
1602 2000-09-14  Thomas Helvey <helveytw@home.com>
1603         * ircd/s_conf.c (conf_init): rewrite conf file parser, start to break
1604         up conf_init into managable chunks.
1605         * ircd/listener.c (set_listener_mask): fix logic bug core dump.
1606         * include/s_conf.h: add new data struct for local info (unwinding the mess).
1607
1608 2000-09-13  Thomas Helvey <helveytw@home.com>
1609         * ircd/list.c: put Clients in free lists, pre-allocate MAXCONNECTIONS
1610         local clients.
1611         * ircd/list.c: put SLinks in free lists
1612         * ircd/channel.c: put Memberships in free lists
1613         * ircd/ircd.c: rearrange initializations a bit in main
1614         Note: With these changes, ircd NEVER frees Clients, SLinks or
1615         Memberships. It will also rarely need to allocate new
1616         ones during net bursts and other disruptions. This should
1617         cut down on memory fragmentation a bit as well.
1618
1619 2000-08-30  Kevin L. Mitchell  <klmitch@mit.edu>
1620
1621         * ircd/m_names.c (do_names): pull-up from do_names fix in
1622         u2.10.10.pl11
1623
1624 2000-07-15  Perry Lorier       <Isomer@coders.net>
1625         * various: IP only k:'s and G:'s now do bit tests instead of two(!) 
1626                  match()'s.  Major Major cpu savings.  Also speed up the
1627                  other case slightly.  As a side effect you can now
1628                  k/Gline *@10.0.0.0/8.  I'll do bans tomorrow, it's nearing
1629                  3am.
1630
1631 2000-07-15  Perry Lorier       <Isomer@coders.net>
1632         * various: Fixed warnings after compiling on an alpha.
1633 2000-07-09  Perry Lorier       <Isomer@coders.net>
1634         * doc/ircd.8: Applied grammitical changes by Liandrin, applied
1635                       changes suggested by various other people.
1636         * ircd/IPcheck.c: More bug fixes.  Current problem appears to be
1637                         that it gets a corrupt entry somehow.
1638 2000-07-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
1639         * ircd/m_oper.c: Clean up compiler warning.
1640
1641 2000-07-08  Perry Lorier       <Isomer@coders.net>
1642         * doc/ircd.8: Updated the documentation, it was slightly out of date
1643                       being updated around 1989.
1644         * ircd/m_whois.c: Rewrote for clarity, and probably a bit more speed.
1645                           fixed a few minor glitches.
1646         * doc/rfc1459.unet: Updated.
1647         * ircd/IPcheck.c: Fixed more bugs.
1648         * ircd/s_bsd.c: We now keep track of servers we've conected.
1649
1650 2000-07-02  Perry Lorier       <Isomer@coders.net>
1651         * ircd/s_misc.c: Fixed remote IPcheck bug.  Ok, I'm a moron, so sue
1652                         me.  Thanks to Hektik, thanks thanks thanks thanks
1653                         thanks thanks thanks thanks thank thanks thank thanks
1654
1655 2000-07-01  Perry Lorier       <Isomer@coders.net>
1656         * ircd/s_conf.c: "Fixed" the "bug" where people would "evade" K:'s.
1657         * ircd/s_conf.c, include/IPcheck.h: Fixed compile warnings.
1658
1659 2000-06-22  Perry Lorier       <Isomer@coders.net>
1660         * ircd/IPcheck.c: Large chunks redone.
1661         * ircd/s_conf.c: Changes due to IPcheck - ONE nolonger supported,
1662                         single AND double digit limits are allowed now.
1663         * misc other: Changes to IPcheck.
1664
1665 2000-06-30  Perry Lorier       <Isomer@coders.net>
1666         * ircd/ircd.c: Fix command line parameter bugs.
1667
1668 2000-06-30  Perry Lorier       <Isomer@coders.net>
1669         * ircd/m_kill.c: Fixed bug with LOCAL_KILL_ONLY
1670         * ircd/m_nick.c: Tidied things up.
1671
1672 2000-06-12 Joseph Bongaarts <foxxe@trms.com>
1673         * ircd/m_stats.c: Iso forgot mo_stats when he added /stats v
1674         
1675 2000-05-29  Perry Lorier       <Isomer@coders.net>
1676         * ircd/m_stats.c: add /stats v to do only the last part of the /trace
1677         * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
1678                         you think it'll get bored and fix itself?
1679
1680 2000-06-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
1681
1682         * ircd/m_names.c: Clean up compiler warnings.
1683
1684 2000-06-09  Kevin L. Mitchell  <klmitch@mit.edu>
1685
1686         * ircd/channel.c (mode_parse_client): don't send warning if
1687         there's not enough arguments for a +/-o/v; means the habit of
1688         doing "/mode #channel +oooooo bob" doesn't result in a bunch of
1689         error messages
1690
1691 2000-06-04  Greg Sikorski <gte@atomicrevs.demon.co.uk>
1692
1693         * ircd/m_names.c: Re-factor code to remove unneccessary
1694         GlobalChannelList iteration every time someone joins a channel.
1695
1696 2000-06-02  Kevin L. Mitchell  <klmitch@mit.edu>
1697
1698         * ircd/s_user.c: add struct Gline * argument to register_user;
1699         look up global glines and repropagate them if necessary; send
1700         acknowledgement of gline to remote servers when registering users
1701
1702         * ircd/s_serv.c (server_estab): don't send acknowledgement of
1703         local glines to remote servers; do send gline acknowledgement of
1704         bursted users
1705
1706         * ircd/m_user.c (m_user): pass new struct Gline * argument to
1707         register_user
1708
1709         * ircd/m_pong.c: pass new struct Gline * argument to register_user
1710
1711         * ircd/m_nick.c (ms_nick): document protocol change
1712
1713         * ircd/gline.c: support GLINE_LASTMOD
1714
1715         * include/s_user.h: add struct Gline * argument to register_user
1716
1717         * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
1718
1719         * ircd/s_conf.c (find_kill): add unsigned int argument to
1720         gline_lookup()
1721
1722         * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
1723         glines; add unsigned int argument to gline_lookup()
1724
1725         * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
1726         argument to gline_lookup()
1727
1728         * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
1729         parameter, or when it falls out of bounds: see comments prior to
1730         call to jupe_resend(); call server_estab with struct Jupe
1731         parameter, so that we place the appropriate %<lastmod> in the
1732         appropriate place.
1733
1734         * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
1735         server, as well as for servers when we're sending the BURST
1736
1737         * include/s_serv.h: add a struct Jupe * to the arguments for
1738         server_estab() so that we can send the appropriate lastmod
1739         parameter
1740
1741         * ircd/m_gline.c (ms_gline): actually, this should be the
1742         slightest bit more efficient...
1743
1744         * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
1745         bit more efficient...
1746
1747         * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
1748         during netburst
1749
1750         * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
1751         netburst
1752
1753         * ircd/channel.c (joinbuf_join): really remove user from local
1754         channels
1755
1756 2000-05-29  Perry Lorier       <Isomer@coders.net>
1757         * ircd/m_names.c: Removed redundant space. 
1758         * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
1759
1760 2000-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
1761
1762         * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
1763         a " "
1764
1765 2000-05-04  Kevin L. Mitchell  <klmitch@mit.edu>
1766
1767         * ircd/channel.c: replace bogus assertions with returns, which is
1768         logically correct; only wipe out limit/key if they were originally
1769         set in the first place; remove user from channel when doing a
1770         PARTALL; only send MODE +o for user CREATEing channel if user is
1771         not MyUser--CREATE will only be used if the channel did not
1772         originally exist, therefore we can assume no one local is on the
1773         channel anyway, and we don't exactly need for the user to see an
1774         explicit +o for themselves
1775
1776         * doc/readme.gline: describe the syntax of the GLINE command
1777
1778         * doc/readme.jupe: update to reflect a couple of changes to JUPE
1779
1780         * ircd/gline.c: don't propagate local changes
1781
1782         * ircd/jupe.c: don't propagate local changes
1783
1784         * ircd/m_gline.c (mo_gline): force local flag when deactivating
1785         glines with 0 lastmod
1786
1787         * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
1788         are now removed instead of being deactivated
1789
1790         * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
1791         -<mask>" be accepted
1792
1793         * ircd/channel.c (send_channel_modes): deal with one of the last
1794         vestiges of sendbuf
1795
1796         * ircd/m_burst.c (ms_burst): debugged ban processing; removed
1797         debugging hooks
1798
1799         * ircd/channel.c (modebuf_extract): remove debugging
1800         sendto_opmask_butone calls
1801
1802 2000-05-03  Kevin L. Mitchell  <klmitch@mit.edu>
1803
1804         * ircd/channel.c: support a couple of new flags to support using
1805         mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
1806         of modebuf_extract to extract added flags for use by ms_burst
1807
1808         * include/channel.h: a couple of new flags to support using
1809         mode_parse inside ms_burst
1810
1811         * ircd/m_burst.c (ms_burst): brand new implementation of BURST
1812
1813         * ircd/m_endburst.c: add loop to processing of end_of_burst to
1814         free empty channels after the BURST is over.
1815
1816         * ircd/m_server.c: convert to use new send.c functions--I wanted
1817         to rewrite it from scratch, but the logic's pretty complex; I may
1818         still rewrite it, though...
1819
1820 2000-05-02  Thomas Helvey <tomh@inxpress.net>
1821
1822         * ircd/ircd.c: fix broken header include ordering
1823
1824 2000-05-02  Thomas Helvey <tomh@inxpress.net>
1825         
1826         * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
1827         review emailed privately
1828
1829         * include/IPcheck.h: removed unneeded include
1830
1831 2000-05-02  Kevin L. Mitchell  <klmitch@mit.edu>
1832
1833         * ircd/s_user.c (hunt_server): throw in a comment so I know what
1834         the sendto_one is for
1835
1836         * include/querycmds.h (Count_unknownbecomesclient): convert to
1837         sendto_opmask_butone
1838
1839         * ircd/send.c: start removing dead code
1840
1841         * include/send.h: start removing dead code
1842
1843         * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
1844         hunt_server_cmd
1845
1846         * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
1847
1848 2000-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
1849
1850         * ircd/m_stats.c: convert to sendcmdto_one / send_reply
1851
1852         * ircd/m_kick.c: Completely reimplement m_kick
1853
1854         * ircd/channel.c: send_user_joins removed; it was dead code,
1855         anyway...
1856
1857 2000-05-01  Perry Lorier <isomer@coders.net>
1858         * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
1859         * ircd/channels.c: My fix for the part problem.  Untested, probably
1860                 won't work.  Can't be much worse than the current problem.
1861                 it'll either work or core, take your pick.
1862
1863
1864 2000-04-30  Perry Lorier <isomer@coders.net>
1865         * config/config-sh.in: Fix for CONNEXIT
1866         * ircd/s_{user,misc}.c: Fix for CONNEXIT
1867         * ircd/m_invite.c: Fix for incorrectly numnickified invite.
1868                         (Kev: Want to come talk to me about this?)
1869
1870 2000-04-30  Steven M. Doyle <steven@doyle.net>
1871         * ircd/ircd.c
1872           - general cleanups and readability enhancements
1873           - rewrite of setuid/chroot code.
1874           - server will no longer run as root
1875           - -DPROFIL compile option removed
1876           - Fixed IPcheck API calls
1877  
1878         * config/config-sh.in
1879           - Fixed up chroot compile options
1880           - Added options for debug and profile compiles
1881  
1882         * config/gen.ircd.Makefile
1883           - Support for new debug/profile options
1884  
1885         * ircd/Makefile.in
1886           - Support for new debug/profile options
1887  
1888         * ircd/ircd_signal.c
1889           - Removed -DPROFIL
1890
1891         * include/IPcheck.h
1892           - Removed old API prototypes, added new ones
1893         
1894         * ircd/IPcheck.c
1895           - Readability cleanups (well, I -think-...)
1896           - Changed IPRegistryEntry.last_connect to a time_t.  The previously
1897             used unsigned short was probably causing interesting things after
1898             a client had been connected longer than about 65,535 seconds...
1899           - Removed old API functions.
1900
1901         * ircd/whocmds.c
1902           - Removed IPcheck.h include
1903         
1904         * Additionally modified IPcheck API calls in:
1905           - ircd/m_nick.c
1906           - ircd/m_auth.c
1907           - ircd/s_bsd.c
1908           - ircd/s_conf.c
1909           - ircd/s_misc.c
1910           - ircd/s_serv.c
1911           - ircd/s_user.c
1912         
1913         
1914 2000-04-30  Perry Lorier <isomer@coders.net>
1915         * ircd/s_bsd.c: Sigh. :)
1916         * ircd/m_mode.c: fix for modeless channels by poptix.
1917
1918 2000-04-29  Kevin L. Mitchell  <klmitch@mit.edu>
1919
1920         * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
1921
1922         * ircd/channel.c (clean_channelname): make clean_channelname also
1923         truncate long channel names
1924
1925 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
1926
1927         * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
1928
1929         * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
1930         joinbuf_flush
1931
1932         * include/channel.h: definitions and declarations for the struct
1933         JoinBuf abstraction
1934
1935 2000-04-29  Perry Lorier <isomer@coders.net>
1936         * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
1937
1938 2000-04-29  Perry Lorier <isomer@coders.net>
1939         * ircd/s_bsd.c: Add debugging code to IPcheck
1940
1941 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
1942
1943         * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
1944
1945         * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
1946         RPL_EXPLICIT
1947
1948         * ircd/m_userhost.c (m_userhost): add a dead code comment
1949
1950         * ircd/m_desynch.c: forgot one...
1951
1952         * ircd/m_rehash.c (mo_rehash): er, duplicates :)
1953
1954         * ircd/m_proto.c (proto_send_supported): just change a comment so
1955         it doesn't show up in my scans
1956
1957         * ircd/ircd_reply.c (send_reply): fix a slight bug...
1958
1959         * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
1960         kinda hackish...
1961
1962         * ircd/parse.c (parse_server): argument wrangling to make
1963         processing in do_numeric a little easier to deal with
1964
1965         * ircd/s_serv.c (server_estab): SERVER should come from
1966         acptr->serv->up, not &me
1967
1968         * ircd/m_lusers.c: accidentally left out sptr for a %C
1969
1970         * ircd/send.c: hack to support doing wallchops...
1971
1972         * ircd/m_whowas.c: convert to new send functions
1973
1974         * ircd/m_whois.c: convert to new send functions
1975
1976         * ircd/m_who.c: convert to new send functions
1977
1978         * ircd/m_wallops.c: convert to new send functions
1979
1980         * ircd/m_wallchops.c: convert to new send functions
1981
1982         * ircd/m_version.c: convert to new send functions
1983
1984         * ircd/m_userip.c: convert to new send functions
1985
1986         * ircd/m_userhost.c: convert to new send functions
1987
1988         * ircd/m_uping.c: convert to new send functions
1989
1990         * ircd/m_trace.c: convert to new send functions
1991
1992         * ircd/m_topic.c: convert to new send functions
1993
1994         * ircd/m_time.c: convert to new send functions
1995
1996         * ircd/m_squit.c: convert to new send functions
1997
1998         * ircd/m_silence.c: convert to new send functions
1999
2000         * ircd/m_settime.c: convert to new send functions
2001
2002         * ircd/m_restart.c: convert to new send functions
2003
2004         * ircd/m_rehash.c: convert to new send functions
2005
2006         * ircd/m_privmsg.c: convert to new send functions
2007
2008         * ircd/m_pong.c: convert to new send functions
2009
2010         * ircd/m_ping.c: convert to new send functions
2011
2012         * ircd/m_pass.c: convert to new send functions
2013
2014         * ircd/m_opmode.c: convert to new send functions
2015
2016         * ircd/m_oper.c: convert to new send functions
2017
2018         * ircd/m_notice.c: convert to new send functions
2019
2020         * ircd/m_nick.c: convert to new send functions
2021
2022         * ircd/m_names.c: convert to new send functions
2023
2024         * ircd/m_motd.c: convert to new send functions
2025
2026         * ircd/m_mode.c: convert to new send functions
2027
2028         * ircd/m_map.c: convert to new send functions
2029
2030         * ircd/m_lusers.c: convert to new send functions
2031
2032         * ircd/m_list.c: convert to new send functions
2033
2034         * ircd/m_links.c: convert to new send functions
2035
2036         * ircd/m_kill.c: convert to new send functions
2037
2038         * ircd/m_jupe.c: convert to new send functions
2039
2040         * ircd/m_invite.c: convert to new send functions
2041
2042         * ircd/m_info.c: convert to new send functions
2043
2044         * ircd/m_help.c: convert to new send functions
2045
2046         * ircd/m_gline.c: convert to new send functions
2047
2048         * ircd/m_error.c: convert to new send functions
2049
2050         * ircd/m_endburst.c: convert to new send functions
2051
2052         * ircd/m_die.c: convert to new send functions
2053
2054         * ircd/m_destruct.c: convert to new send functions
2055
2056         * ircd/m_defaults.c: convert to new send functions
2057
2058         * ircd/m_connect.c: convert to new send functions
2059
2060 2000-04-28  Perry Lorier <isomer@coders.net>
2061         * RELEASE.NOTES: Describe a few more undocumented features.
2062         * config/config-sh.in: change the default paths for logging
2063         and the recommended number of channels.
2064         * include/supported.h: Rearrange slightly, added CHANTYPE's
2065
2066 2000-04-27  Kevin L. Mitchell  <klmitch@mit.edu>
2067
2068         * ircd/m_close.c: convert to send_reply
2069
2070         * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
2071
2072         * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
2073
2074         * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
2075
2076         * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
2077         that takes cmd and tok arguments, etc.  NOTE: THIS IMPLEMENTATION
2078         HAS A MAJOR HACK!!!  The whole hunt_server architecture should be
2079         carefully rethought...
2080
2081         * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
2082
2083         * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
2084
2085         * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
2086         numeric nick; therefore, we have to use the server name
2087
2088         * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
2089
2090         * ircd/send.c: fix minor bugs
2091
2092         * ircd/s_user.c (check_target_limit): mark dead code so I filter
2093         it when I grep
2094
2095         * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
2096         when I grep
2097
2098         * ircd/parse.c: mark dead code so I filter it when I grep
2099
2100         * ircd/map.c: mark dead code so I filter it when I grep
2101
2102         * ircd/ircd.c: mark dead code so I filter it when I grep
2103
2104         * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
2105         functions
2106
2107         * ircd/channel.c: mark dead code so I filter it when I grep
2108
2109         * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
2110         hope I'm not stepping on toes...
2111
2112         * ircd/s_conf.c: more sendto_opmask_butone / send_reply
2113         conversions; use ircd_snprintf in a couple of cases to negate the
2114         possibility of buffer overflow
2115
2116 2000-04-26  Kevin L. Mitchell  <klmitch@mit.edu>
2117
2118         * ircd/channel.c: convert as much as possible to new send
2119         semantics
2120
2121         * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
2122         test member->user->from->fd, not from->fd
2123
2124         * ircd/gline.c (gline_add): go ahead and add badchans; we just
2125         won't look for them in m_gline; this way, they always work...
2126
2127         * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
2128
2129         * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
2130         ircd_vsnprintf conversion specifiers
2131
2132         * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
2133         I have my conversion specifiers
2134
2135         * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
2136
2137         * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
2138         local users
2139
2140         * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
2141         little less brain-dead
2142
2143         * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
2144
2145         * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
2146         RPL_STATSDEBUG
2147
2148         * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
2149         RPL_STATSDEBUG
2150
2151         * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
2152         for RPL_STATSDEBUG
2153
2154         * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
2155
2156         * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
2157
2158         * ircd/s_user.c (register_user): use RPL_EXPLICIT for
2159         ERR_INVALIDUSERNAME
2160
2161         * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
2162
2163         * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
2164         a numeric as needing to use an explicit pattern, which will be the
2165         first argument in the variable argument list
2166
2167         * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
2168         non-prefixed nospoof PING
2169
2170         * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
2171         non-prefixed SERVER login
2172
2173         * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
2174         a numeric usage further up)
2175
2176         * include/send.h: declare sendrawto_one
2177
2178         * ircd/send.c (sendrawto_one): new function to use ONLY for
2179         non-prefixed commands, like PING to client, or PASS/SERVER on
2180         server registration
2181
2182 2000-04-25  Kevin L. Mitchell  <klmitch@mit.edu>
2183
2184         * ircd/ircd_snprintf.c (doprintf): implement %H for possible
2185         future expansion (channel numerics?)
2186
2187         * include/ircd_snprintf.h: added documentation to # to explain use
2188         with %C; added documentation for : to explain use with %C; added
2189         documentation for %H for channels
2190
2191         * ircd/whocmds.c: use send_reply
2192
2193         * ircd/userload.c: use sendcmdto_one
2194
2195         * ircd/uping.c: use sendcmdto_one
2196
2197         * ircd/send.c: use new flags to %C format string; ':' prefixes
2198         client name with a colon for local connects, '#' uses
2199         nick!user@host form for local connects
2200
2201         * ircd/s_user.c: use send_reply, sendto_opmask_butone,
2202         sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
2203
2204         * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
2205
2206         * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
2207         sendcmdto_one
2208
2209         * ircd/s_auth.c: use sendto_opmask_butone
2210
2211         * ircd/res.c: use sendcmdto_one
2212
2213         * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
2214         debugging assertions
2215
2216 2000-04-24  Kevin L. Mitchell  <klmitch@mit.edu>
2217
2218         * ircd/support.c: dumpcore is no longer used, so get rid of it
2219
2220         * ircd/parse.c: use send_reply, sendcmdto_one
2221
2222         * ircd/map.c: use send_reply
2223
2224         * ircd/listener.c: use send_reply
2225
2226         * ircd/jupe.c: use sendto_opmask_butone, send_reply
2227
2228         * ircd/ircd_reply.c: use send_reply
2229
2230         * ircd/ircd.c: use sendto_opmask_butone
2231
2232         * ircd/gline.c: use sendto_opmask_butone, send_reply
2233
2234         * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
2235         registered clients; make FLAG_ALT print nick!user@host; make
2236         FLAG_COLON print :blah
2237
2238         * ircd/class.c (report_classes): use send_reply instead of
2239         sendto_one
2240
2241         * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
2242
2243         * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
2244         sendto_one with sendcmdto_one
2245
2246 2000-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
2247
2248         * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
2249         MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
2250         sendcmdto_match_butone
2251
2252         * include/send.h: declare sendcmdto_match_butone
2253
2254 2000-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
2255
2256         * ircd/jupe.c: update to use send_reply()
2257
2258         * ircd/gline.c: update to use send_reply()
2259
2260         * include/ircd_reply.h: declare send_reply
2261
2262         * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
2263         replies; uses ircd_snprintf
2264
2265         * ircd/send.c: added comments to redirect searchers to appropriate
2266         sendcmdto_* function; moved new functions to end of file; added
2267         explanatory comments; reordered arguments; defined new functions
2268         mentioned below
2269
2270         * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
2271
2272         * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
2273
2274         * ircd/jupe.c: reorder arguments to sendcmdto_* functions
2275
2276         * ircd/gline.c: reorder arguments to sendcmdto_* functions
2277
2278         * include/send.h: reorder arguments, add explanatory comments,
2279         declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
2280         and vsendto_opmask_butone
2281
2282 2000-04-19  Kevin L. Mitchell  <klmitch@mit.edu>
2283
2284         * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
2285         vsendto_op_mask that uses '*' instead of the receiving client
2286         nickname
2287
2288         * include/send.h: declare sendcmdto_channel_butone; takes a skip
2289         argument that allows you to skip (or not to skip) deaf users,
2290         users behind bursting servers, and non channel operators
2291
2292 2000-04-17  Kevin L. Mitchell  <klmitch@mit.edu>
2293
2294         * ircd/send.c: new sendcmdto_channel_butserv -- note that old
2295         sendto_channel_butserv has a subtle bug; also wrote
2296         sendcmdto_common_channels.
2297
2298         * include/send.h: declare new sendcmdto_* functions
2299
2300         * ircd/jupe.c: support local deactivations of jupes
2301
2302         * ircd/gline.c: support local deactivations of glines
2303
2304         * include/jupe.h: JUPE_LDEACT allows jupes to be locally
2305         deactivated; if they aren't locally deactivated, then it slaves to
2306         the net-wide activation status; JupeIsRemActive() tests only
2307         whether the jupe is active everywhere else
2308
2309         * include/gline.h: GLINE_LDEACT allows glines to be locally
2310         deactivated; if they aren't locally deactivated, then it slaves to
2311         the net-wide activation status; GlineIsRemActive() tests only
2312         whether the gline is active everywhere else
2313
2314         * ircd/gline.c: detect overlapping G-lines; if an existing, wider
2315         gline expires after the new one will, we drop the new one,
2316         otherwise we add the G-line after that one (so the wide one will
2317         apply first); if the new one contains an existing G-line and if it
2318         will expire after the existing one, we drop the existing one to
2319         save memory
2320
2321         * ircd/m_gline.c (mo_gline): opers could issue remote local
2322         glines when CONFIG_OPERCMDS was off; fixed
2323
2324 2000-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
2325
2326         * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
2327         this is a local JUPE
2328
2329         * ircd/gline.c: add flags argument to gline_activate and
2330         gline_deactivate for future expansion
2331
2332         * ircd/m_gline.c: pass flags to gline_activate and
2333         gline_deactivate
2334
2335         * include/gline.h: add flags argument to gline_activate and
2336         gline_deactivate
2337
2338         * ircd/jupe.c: add flags argument to jupe_activate and
2339         jupe_deactivate for future expansion
2340
2341         * include/jupe.h: add flags argument to jupe_activate and
2342         jupe_deactivate
2343
2344         * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
2345         local, active; pass flags to jupe_activate and jupe_deactivate
2346
2347         * include/gline.h: remove dead code
2348
2349         * ircd/gline.c: make gline expire times relative to CurrentTime,
2350         since that should be monotonically increasing, instead of
2351         TStime(), which can be set backwards, and which can therefore
2352         cause an expire time to increase; make local glines be removed
2353         instead of just deactivated; don't let gline_find() look for
2354         user@host glines if the mask being looked up is a channel mask
2355
2356         * ircd/send.c (vsendcmdto_one): forgot to account for the case
2357         where origin is a server and destination is a user
2358
2359         * ircd/jupe.c: make jupe expire times relative to CurrentTime,
2360         since that should be monotonically increasing, instead of
2361         TStime(), which can be set backwards, and which can therefore
2362         cause an expire time to increase; make local jupes be removed
2363         instead of just deactivated
2364
2365         * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
2366         limit is fine.  any other warnings I should know about?
2367
2368 2000-04-15  Thomas Helvey <tomh@inxpress.net>
2369
2370         * ircd/*.c: const correctness and type safety cleanups to
2371         get code to compile with C++ compiler. Still has
2372         signed/unsigned comparison warnings.
2373
2374 2000-04-15  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2375
2376         * ircd/userload.c: change <sys/time.h> include to <time.h> for
2377           portability.
2378
2379 2000-04-14  Kevin L. Mitchell  <klmitch@mit.edu>
2380
2381         * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
2382         and convert acptr...
2383
2384         * ircd/s_user.c: move gline_lookup function call into
2385         register_user, where it'll have a username to lookup!
2386
2387         * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
2388         functions; also stuff send_error_to_client into return clauses
2389
2390         * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
2391         functions; also use send_error_to_client where that makes sense
2392
2393         * ircd/jupe.c: modify to utilize new sendcmdto_* series of
2394         functions; also use send_error_to_client where that makes sense
2395
2396         * ircd/gline.c: modify to utilize new sendcmdto_* series of
2397         functions; also fix gline_lookup() to deal properly with remote
2398         clients--boy, do struct Client and struct User need to be cleaned
2399         up!
2400
2401         * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
2402         too...
2403
2404         * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
2405         sendcmdto_serv_butone(), all utilizing the %v conversion of
2406         ircd_snprintf()
2407
2408         * include/send.h: define IRC_BUFSIZE, max size of a message;
2409         declare sendcmdto_one(), vsendcmdto_one(), and
2410         sendcmdto_serv_butone()
2411
2412         * include/msg.h: define all the CMD_* constants needed to utilize
2413         the new sendcmdto_* series of functions
2414
2415         * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
2416
2417         * ircd/gline.c: remove old, dead code.
2418
2419         * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
2420         unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
2421         (don't advertise proxies); remove dead code
2422
2423         * ircd/parse.c: oper handler for JUPE only lists jupes unless
2424         CONFIG_OPERCMDS is enabled
2425
2426         * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
2427         CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
2428
2429         * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
2430         always return ERR_DISABLED
2431
2432         * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
2433         enabled, always return ERR_DISABLED
2434
2435         * ircd/s_err.c: add error message to indicate disabled commands
2436
2437         * include/numeric.h (ERR_DISABLED): to indicate disabled commands
2438
2439         * doc/Configure.help: add documentation for CONFIG_OPERCMDS
2440
2441         * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
2442         CONFIG_NEW_MODE to 'y' for now
2443
2444         * ircd/gline.c (gline_list): fix a minor formatting bogon
2445
2446         * BUGS: since I fixed that bug, might as well mark it fixed.
2447
2448         * ircd/m_join.c: look up badchans with GLINE_EXACT
2449
2450         * ircd/m_gline.c: fix parc count problems; look up existing
2451         G-lines with GLINE_EXACT; only set new lastmod when
2452         activating/deactivating existing glines if old lastmod was not 0
2453
2454         * ircd/gline.c: forgot to copy the gline reason over; don't
2455         propagate a gline with 0 lastmod if origin is user; add
2456         GLINE_EXACT to force exact matching of gline mask
2457
2458         * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
2459         flag properly
2460
2461         * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
2462         but gline_lookup() actually takes a client--d'oh.
2463
2464 2000-04-13  Thomas Helvey <tomh@inxpress.net>
2465         * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
2466
2467 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2468
2469         * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
2470           "/who * x"
2471           "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
2472           (Found by Plexus).
2473
2474         * ircd/whocmds.c: Change idle time calc from socket idle to user
2475           idle.
2476
2477 2000-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
2478
2479         * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
2480         too, for ircd_snprintf.c
2481
2482         * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
2483         comments; mostly descended from the Linux manpage for printf, but
2484         also documenting the extensions.
2485
2486         * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
2487         client; make 'q' be the same as 'L'; remove __inline__; only
2488         define EXTENSION if HAVE_LONG_LONG is defined
2489
2490         * include/handlers.h: declare m_gline()
2491
2492         * ircd/parse.c: gline can be called by users, but it only lists
2493         the glines.
2494
2495         * ircd/s_user.c (set_nick_name): resend gline if a remote server
2496         introduces a glined client
2497
2498         * ircd/s_serv.c (server_estab): burst glines, too
2499
2500         * ircd/gline.c: fix up all the expire times to be offsets;
2501         simplify gline_resend()
2502
2503         * ircd/m_gline.c: begin coding replacements for ms_gline(),
2504         mo_gline(), and m_gline()
2505
2506         * ircd/gline.c (gline_add): allow *@#channel to work correctly;
2507         also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
2508
2509 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2510
2511         * tools/Bouncer/*: Add comments/documentation/tags.
2512         * tools/Bouncer/*: Add debug defines, make task fork().
2513
2514 2000-04-12  Thomas Helvey <tomh@inxpress.net>
2515         * ircd/s_err.c: Cleanup s_err.c make one table so we
2516         don't have to do anything tricky to get an error string.
2517
2518 2000-04-12  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2519         * Add port bouncer for http (x/w)
2520
2521 2000-04-12  Kevin L. Mitchell  <klmitch@mit.edu>
2522
2523         * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
2524         call to gline_find(); also used GlineReason() instead of direct
2525         reference to structure member
2526
2527         * ircd/m_join.c (m_join): replace bad_channel() calls with calls
2528         to gline_find(name, GLINE_BADCHAN), and also check to see if gline
2529         is active
2530
2531         * ircd/channel.c: nothing seems to be called anywhere...
2532
2533         * ircd/s_err.c: update a couple of replies to dovetail with new
2534         semantics
2535
2536         * ircd/gline.c: begin complete re-implementation of gline.c along
2537         the lines of the final design of jupe.c
2538
2539         * include/gline.h: begin complete re-implementation of gline.c
2540         along the lines of the final design of jupe.c
2541
2542         * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
2543         %s by %s" message...
2544
2545         * ircd/ircd_snprintf.c: my new snprintf()-like functions
2546
2547         * include/ircd_snprintf.h: my new snprintf()-like functions
2548
2549 2000-04-11  Thomas Helvey <tomh@inxpress.net>
2550         * ircd/IPcheck.c: removed old dead code
2551         * ircd/s_user.c (send_user_info): removed non-standard
2552           user not found message for userhost/userip
2553
2554 2000-04-11  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2555
2556         * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
2557         * doc/p10.html: Work on chapter 4.
2558
2559 2000-04-10  Kevin L. Mitchell  <klmitch@mit.edu>
2560
2561         * ircd/channel.c (mode_parse_client): fix coredump on /mode
2562         #foobar +o nosuchnick
2563
2564 2000-04-10  Perry Lorier  <Isomer@coders.net>
2565         * BUGS: Added bug.
2566
2567 2000-04-09  Thomas Helvey <tomh@inxpress.net>
2568         * include/IPcheck.h: fix prototype
2569         * ircd/s_user.c: fix usage of IPcheck_remote_connect
2570         * ircd/IPcheck.c: removed unused args
2571
2572 2000-04-09  Thomas Helvey <tomh@inxpress.net>
2573         * include/IPcheck.h: add proto for IPcheck_expire
2574
2575         * ircd/IPcheck.c: Rewrote
2576
2577         * ircd/ircd.c: Add IPcheck_expire to main message loop
2578
2579         * ircd/s_user.c: Redo target hashing, refactor target code
2580
2581         * include/numeric.h: Cleaned up numerics, added which ones are
2582         in use by other networks and what they are in use for.
2583
2584         * ircd/channel.c: cleaned can_join(), allow anyone through anything
2585         if /invited, simplified the function.  Opers overusing OPEROVERRIDE
2586         will get a message explaining to them not to cheat.
2587
2588         * ircd/m_join.c: cleaned up the various join functions, should be
2589         a lot more efficient.  Still needs work.  Now assumes that s<->s
2590         won't send it a JOIN 0.  Service coders - note this and tread with
2591         care.
2592
2593         * ircd/m_stats.c: added Gte-'s stats doc patch.
2594
2595         * ircd/m_version.c: /version now returns the 005 numeric as well.
2596         as requested by Liandrin.
2597
2598
2599 2000-04-07  Kevin L. Mitchell  <klmitch@mit.edu>
2600
2601         * ircd/m_clearmode.c: add include for support.h for write_log()
2602
2603         * configure: move ircd/crypt/* to tools/*
2604
2605 2000-04-06  Thomas Helvey <tomh@inxpress.net>
2606         * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
2607           set client host to server alias if connection from localhost
2608
2609 2000-04-06  Perry Lorier <isomer@coders.net>
2610         * ircd/ircd.c: Fix core during pinging (oops)
2611         
2612 2000-04-06  Perry Lorier <isomer@coders.net>
2613         * ircd/send.c: fixed wrong ident being sent to channels bug.
2614         * include/numerics.h: Updated some of the numerics from other
2615         networks.  Flagged some as 'unused' by undernet.
2616
2617 2000-03-30  Perry Lorier <isomer@coders.net>
2618         * ircd/ircd.c: Lets see if this helps the ping problem at all.
2619         * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
2620         time for local clients. (as requested), extended who now returns all
2621         the flags (@+!) so you can tell the complete state of a client.
2622
2623 2000-03-30  Thomas Helvey <tomh@inxpress.net>
2624         * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
2625
2626 2000-03-30  Perry Lorier <isomer@coders.net>
2627         * ircd/parse.c: oops, missed opers.
2628
2629 2000-03-30  Perry Lorier <isomer@coders.net>
2630         * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
2631         for so long.  Remember: m_ping MUST be in the parse array. :)
2632
2633 2000-03-30  Perry Lorier <isomer@coders.net>
2634         * ircd/ircd.c: test in check_pings was wrong.  I move that we
2635         disallow cvs commit after 10pm localtime....
2636
2637 2000-03-30  Perry Lorier <isomer@coders.net>
2638         * ircd/m_pong.c: Fix it for servers too.
2639
2640 2000-03-30  Perry Lorier <isomer@coders.net>
2641         * ircd/m_pong.c: Fix ping timeout bugs
2642
2643 2000-03-30  Perry Lorier <isomer@coders.net>
2644         * ircd/channel.c: Bans had CurrentTime in their when field instead
2645         of TStime()
2646
2647 2000-03-31  Thomas Helvey <tomh@ixpress.net>
2648         * ircd/numnicks.c (SetXYYCapacity): fix for extended
2649         numerics.
2650
2651 2000-03-30  Perry Lorier <isomer@coders.net>
2652         * ircd/m_nick.c: send kills both ways so when we add nick change
2653         on collision we don't desync the network.
2654
2655         * ircd/map.c: Fixup the map a bit more.
2656
2657 2000-03-31  Kevin L. Mitchell  <klmitch@mit.edu>
2658
2659         * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
2660
2661         * ircd/m_opmode.c: Log the mode changes to OPATH
2662
2663         * ircd/channel.c (modebuf_flush_int): Log the mode changes to
2664         OPATH
2665
2666         * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
2667         OPATH
2668
2669         * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
2670
2671         * config/config-sh.in: added OPATH for opmode log file
2672
2673         * ircd/m_clearmode.c (do_clearmode): updated uses of
2674         modebuf_mode_string() for the new usage
2675
2676         * ircd/channel.c: added flag MODE_FREE and an int argument to
2677         modebuf_mode_string() to indicate that the string must be free'd;
2678         updated calls to modebuf_mode_string() for the new usage; called
2679         collapse(pretty_mask()) on the ban string and use allocated memory
2680         for it; added ban list length accounting; fixed a number of small
2681         bugs in ban processing
2682
2683         * include/channel.h: added flag MODE_FREE and an int argument to
2684         modebuf_mode_string() to indicate that the string must be free'd
2685
2686         * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
2687         keys and limits that are set
2688
2689 2000-03-30  Perry Lorier <isomer@coders.net>
2690         * ircd/ircd.c: rewrote check_pings() for maintainability
2691         and speed.  Also changed quit msg's so they don't have
2692         redundant nick[host] info in them.
2693
2694         * ircd/send.c: Changed write errors to report what error
2695         occured (if possible).
2696
2697         * ircd/gline.c: added gline comment to the quit.
2698
2699         * ircd/m_server.c: Added suggestions to server quits mentioning
2700         what went wrong so the admin can fix it earlier instead of asking
2701         questions...
2702
2703         * ircd/map.c: Changed m_map() to hide numerics, show a * beside
2704         servers that aren't fully burst yet.  And show '(--s)' for servers
2705         where its not sure.
2706
2707         * doc/example.conf: Fixed wrapped U:
2708
2709 2000-03-30  Kevin L. Mitchell  <klmitch@mit.edu>
2710
2711         * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
2712         mode_parse() (version selectable at compile time)
2713
2714         * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
2715
2716         * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
2717
2718         * config/config-sh.in: add new config option to enable new m_mode
2719         implementation
2720
2721         * doc/Configure.help: add documentation for new config option
2722         CONFIG_NEW_MODE
2723
2724         * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
2725         MODE -v : Not enough parameters
2726
2727         * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
2728         +k and +l even if they weren't set...
2729
2730         * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
2731
2732         * ircd/channel.c: make mode_process_clients() clear the DEOPPED
2733         flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
2734         for; test the 0-th member, not the i-th member, of the client
2735         change state stuff
2736
2737         * ircd/m_clearmode.c (do_clearmode): use the new
2738         mode_invite_clear() function
2739
2740         * ircd/channel.c: cleared up all the compile-time warnings and
2741         errors
2742
2743         * include/channel.h: added declarations for mode_ban_invalidate()
2744         and mode_invite_clear()
2745
2746         * ircd/channel.c: finished mode_parse(), then broke it up into a
2747         dozen or so helper functions to make the code easier to read
2748
2749 2000-03-29  Thomas Helvey <tomh@inxpress.net>
2750         * ircd/ircd.c: refactor server initialization a bit, use
2751         getopt for parsing command line, refactor init_sys, main,
2752         and other bits.
2753
2754         * ircd/s_bsd.c: add functions for initialization to clean
2755         up logic a bit and remove duplicated code.
2756
2757         * include/ircd.h: add struct for server process related
2758         variables.
2759
2760 2000-03-29  Kevin L. Mitchell  <klmitch@mit.edu>
2761
2762         * ircd/channel.c: initial definition of mode_parse(); flags to
2763         prevent doing the same thing multiple times; helper method
2764         send_notoper() to send a "Not oper"/"Not on channel" notice
2765
2766         * include/channel.h: declare mode_parse() and helper flags
2767
2768         * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
2769         sending to match the current action of set_mode() closely enough
2770         that hopefully there won't be major conflicts
2771
2772         * ircd/channel.c (modebuf_flush_int): consolidated the mode string
2773         building logic, reversed the order of the arguments to mode
2774         commands to have '-' preceed '+'
2775
2776 2000-03-29  Thomas Helvey <tomh@inxpress.net>
2777         * ircd/s_bsd.c (add_connection): don't disable socket options
2778         let OS tune itself and allow important performance tweaks to 
2779         work.
2780
2781 2000-03-28  Kevin L. Mitchell  <klmitch@mit.edu>
2782
2783         * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
2784         confused by set_mode, which is doing some really weird logic;
2785         guess what I'm going to rewrite next?  ;)
2786
2787 2000-03-28  Kevin L. Mitchell  <klmitch@emc.com>
2788
2789         * include/channel.h: added MODE_SAVE for the bounds checking stuff
2790         in modebuf_flush
2791
2792         * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
2793         make it do bounds checking on the buffer; all modes are sent only
2794         if the all parameter is 1; modebuf_flush is the exported wrapper
2795
2796         * include/channel.h: add BOUNCE, renumber flags to get a little
2797         more space
2798
2799         * ircd/channel.c (modebuf_flush): don't overload HACK2, add
2800         BOUNCE; send DESYNCH message
2801
2802 2000-03-27  Kevin L. Mitchell  <klmitch@emc.com>
2803
2804         * ircd/m_clearmode.c (do_clearmode): only mark the modes the
2805         channel actually has in effect for deletion
2806
2807         * ircd/channel.c: added explanatory comments to all added
2808         functions; made flushing take place at the correct place even if
2809         the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
2810         to bash some stupid bugs; made modebuf_flush() return if ModeBuf
2811         is empty, fixed the apparent source, removed some bogus string
2812         termination code, properly terminate the mode strings, add support
2813         for HACK2 and HACK3, made limit strings not be sent if the limit
2814         is being removed, changed where '+' and '-' come from in sent
2815         strings, added support for DEOP flag, set up bouncing code for
2816         HACK2
2817
2818         * ircd/Makefile.in: ran make depend
2819
2820         * include/channel.h: added new defines for future functionality,
2821         made modebuf_flush() return int so I can use tail recursion
2822
2823         * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
2824         to make it all compile
2825
2826         * ircd/m_opmode.c: add msg.h to includes...
2827
2828         * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
2829
2830         * ircd/channel.c (modebuf_flush): realized I forgot to
2831         nul-terminate addbuf/rembuf properly...
2832
2833         * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
2834
2835         * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
2836         sendto_serv_butone--blah^2
2837
2838         * ircd/send.c (sendto_serv_butone): stupid comments confused me
2839
2840         * ircd/channel.c (modebuf_flush): if there are no mode changes to
2841         propagate, we're done...
2842
2843         * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
2844         not sendto_all_butone
2845
2846         * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
2847
2848         * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
2849
2850         * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
2851         the list
2852
2853         * ircd/parse.c: added messages for opmode and clearmode
2854
2855         * include/handlers.h: added declarations for mo_opmode(),
2856         ms_opmode(), mo_clearmode(), and ms_clearmode()
2857
2858         * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
2859         TOK_CLEARMODE
2860
2861         * include/channel.h (MODEBUF_DEST_OPMODE): Define the
2862         MODEBUF_DEST_OPMODE flag
2863
2864         * ircd/channel.c (modebuf_flush): added new flag,
2865         MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
2866         to originate from source's server (or source itself, if
2867         IsServer(source)); also causes a server-level MODE to be sent as
2868         OPMODE instead
2869
2870         * include/channel.h: defined MODEBUF_DEST_SERVER,
2871         MODEBUF_DEST_HACK4
2872
2873         * ircd/channel.c: Add another argument to build_string() to handle
2874         numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
2875         servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
2876         to be sent out
2877
2878 2000-03-27  Perry Lorier <isomer@coders.net>
2879
2880         * ircd/s_bsd.c: fixed missing 'u' typo.
2881
2882 2000-03-26  Kevin L. Mitchell  <klmitch@emc.com>
2883
2884         * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
2885         _mode_string(), _mode_client(), _flush(); also implemented a
2886         simple build_string()
2887
2888         * include/channel.h: added definition of ModeBuf, modebuf_*
2889         manipulation functions, and a couple of helper macros
2890
2891 2000-03-24 Thomas Helvey <tomh@inxpress.net>
2892   * numicks.c: convert extended numerics to use original mask version
2893   * numnicks.h: ""
2894   * s_user.c:
2895 2000-03-23 Thomas Helvey <tomh@inxpress.net>
2896   * Merge in changes from production
2897 2000-03-22 Thomas Helvey <tomh@inxpress.net>
2898   * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
2899   * rfc1459.unet: Add Maniac's documentation for /names 0
2900 * Fix misc. jupe bugs that somehow made it into the tree
2901 * Escape /names 0 to mean /names --Maniac
2902 * Don't core when server asks for info --Maniac 
2903 * Add Kev's jupe patch --Bleep
2904 * Add Maniacs squit patch --Bleep
2905 * Merge in u2_10_10_beta07 changes --Bleep
2906 * Merge in u2_10_10_beta06 changes --Bleep
2907 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
2908 #-----------------------------------------------------------------------------