Author: Perry Lorier <isomer@coders.net>
[ircu2.10.12-pk.git] / ChangeLog
1 2000-04-29  Perry Lorier <isomer@coders.net>
2         * include/s_bsd.c: Ok, so I thought I compiled and tested this...
3
4 2000-04-29  Perry Lorier <isomer@coders.net>
5         * include/s_bsd.c: Add debugging code to IPcheck
6
7 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
8
9         * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
10
11         * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
12         RPL_EXPLICIT
13
14         * ircd/m_userhost.c (m_userhost): add a dead code comment
15
16         * ircd/m_desynch.c: forgot one...
17
18         * ircd/m_rehash.c (mo_rehash): er, duplicates :)
19
20         * ircd/m_proto.c (proto_send_supported): just change a comment so
21         it doesn't show up in my scans
22
23         * ircd/ircd_reply.c (send_reply): fix a slight bug...
24
25         * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
26         kinda hackish...
27
28         * ircd/parse.c (parse_server): argument wrangling to make
29         processing in do_numeric a little easier to deal with
30
31         * ircd/s_serv.c (server_estab): SERVER should come from
32         acptr->serv->up, not &me
33
34         * ircd/m_lusers.c: accidentally left out sptr for a %C
35
36         * ircd/send.c: hack to support doing wallchops...
37
38         * ircd/m_whowas.c: convert to new send functions
39
40         * ircd/m_whois.c: convert to new send functions
41
42         * ircd/m_who.c: convert to new send functions
43
44         * ircd/m_wallops.c: convert to new send functions
45
46         * ircd/m_wallchops.c: convert to new send functions
47
48         * ircd/m_version.c: convert to new send functions
49
50         * ircd/m_userip.c: convert to new send functions
51
52         * ircd/m_userhost.c: convert to new send functions
53
54         * ircd/m_uping.c: convert to new send functions
55
56         * ircd/m_trace.c: convert to new send functions
57
58         * ircd/m_topic.c: convert to new send functions
59
60         * ircd/m_time.c: convert to new send functions
61
62         * ircd/m_squit.c: convert to new send functions
63
64         * ircd/m_silence.c: convert to new send functions
65
66         * ircd/m_settime.c: convert to new send functions
67
68         * ircd/m_restart.c: convert to new send functions
69
70         * ircd/m_rehash.c: convert to new send functions
71
72         * ircd/m_privmsg.c: convert to new send functions
73
74         * ircd/m_pong.c: convert to new send functions
75
76         * ircd/m_ping.c: convert to new send functions
77
78         * ircd/m_pass.c: convert to new send functions
79
80         * ircd/m_opmode.c: convert to new send functions
81
82         * ircd/m_oper.c: convert to new send functions
83
84         * ircd/m_notice.c: convert to new send functions
85
86         * ircd/m_nick.c: convert to new send functions
87
88         * ircd/m_names.c: convert to new send functions
89
90         * ircd/m_motd.c: convert to new send functions
91
92         * ircd/m_mode.c: convert to new send functions
93
94         * ircd/m_map.c: convert to new send functions
95
96         * ircd/m_lusers.c: convert to new send functions
97
98         * ircd/m_list.c: convert to new send functions
99
100         * ircd/m_links.c: convert to new send functions
101
102         * ircd/m_kill.c: convert to new send functions
103
104         * ircd/m_jupe.c: convert to new send functions
105
106         * ircd/m_invite.c: convert to new send functions
107
108         * ircd/m_info.c: convert to new send functions
109
110         * ircd/m_help.c: convert to new send functions
111
112         * ircd/m_gline.c: convert to new send functions
113
114         * ircd/m_error.c: convert to new send functions
115
116         * ircd/m_endburst.c: convert to new send functions
117
118         * ircd/m_die.c: convert to new send functions
119
120         * ircd/m_destruct.c: convert to new send functions
121
122         * ircd/m_defaults.c: convert to new send functions
123
124         * ircd/m_connect.c: convert to new send functions
125
126 2000-04-28  Perry Lorier <isomer@coders.net>
127         * RELEASE.NOTES: Describe a few more undocumented features.
128         * config/config-sh.in: change the default paths for logging
129         and the recommended number of channels.
130         * include/supported.h: Rearrange slightly, added CHANTYPE's
131
132 2000-04-27  Kevin L. Mitchell  <klmitch@mit.edu>
133
134         * ircd/m_close.c: convert to send_reply
135
136         * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
137
138         * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
139
140         * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
141
142         * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
143         that takes cmd and tok arguments, etc.  NOTE: THIS IMPLEMENTATION
144         HAS A MAJOR HACK!!!  The whole hunt_server architecture should be
145         carefully rethought...
146
147         * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
148
149         * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
150
151         * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
152         numeric nick; therefore, we have to use the server name
153
154         * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
155
156         * ircd/send.c: fix minor bugs
157
158         * ircd/s_user.c (check_target_limit): mark dead code so I filter
159         it when I grep
160
161         * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
162         when I grep
163
164         * ircd/parse.c: mark dead code so I filter it when I grep
165
166         * ircd/map.c: mark dead code so I filter it when I grep
167
168         * ircd/ircd.c: mark dead code so I filter it when I grep
169
170         * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
171         functions
172
173         * ircd/channel.c: mark dead code so I filter it when I grep
174
175         * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
176         hope I'm not stepping on toes...
177
178         * ircd/s_conf.c: more sendto_opmask_butone / send_reply
179         conversions; use ircd_snprintf in a couple of cases to negate the
180         possibility of buffer overflow
181
182 2000-04-26  Kevin L. Mitchell  <klmitch@mit.edu>
183
184         * ircd/channel.c: convert as much as possible to new send
185         semantics
186
187         * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
188         test member->user->from->fd, not from->fd
189
190         * ircd/gline.c (gline_add): go ahead and add badchans; we just
191         won't look for them in m_gline; this way, they always work...
192
193         * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
194
195         * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
196         ircd_vsnprintf conversion specifiers
197
198         * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
199         I have my conversion specifiers
200
201         * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
202
203         * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
204         local users
205
206         * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
207         little less brain-dead
208
209         * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
210
211         * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
212         RPL_STATSDEBUG
213
214         * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
215         RPL_STATSDEBUG
216
217         * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
218         for RPL_STATSDEBUG
219
220         * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
221
222         * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
223
224         * ircd/s_user.c (register_user): use RPL_EXPLICIT for
225         ERR_INVALIDUSERNAME
226
227         * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
228
229         * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
230         a numeric as needing to use an explicit pattern, which will be the
231         first argument in the variable argument list
232
233         * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
234         non-prefixed nospoof PING
235
236         * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
237         non-prefixed SERVER login
238
239         * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
240         a numeric usage further up)
241
242         * include/send.h: declare sendrawto_one
243
244         * ircd/send.c (sendrawto_one): new function to use ONLY for
245         non-prefixed commands, like PING to client, or PASS/SERVER on
246         server registration
247
248 2000-04-25  Kevin L. Mitchell  <klmitch@mit.edu>
249
250         * ircd/ircd_snprintf.c (doprintf): implement %H for possible
251         future expansion (channel numerics?)
252
253         * include/ircd_snprintf.h: added documentation to # to explain use
254         with %C; added documentation for : to explain use with %C; added
255         documentation for %H for channels
256
257         * ircd/whocmds.c: use send_reply
258
259         * ircd/userload.c: use sendcmdto_one
260
261         * ircd/uping.c: use sendcmdto_one
262
263         * ircd/send.c: use new flags to %C format string; ':' prefixes
264         client name with a colon for local connects, '#' uses
265         nick!user@host form for local connects
266
267         * ircd/s_user.c: use send_reply, sendto_opmask_butone,
268         sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
269
270         * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
271
272         * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
273         sendcmdto_one
274
275         * ircd/s_auth.c: use sendto_opmask_butone
276
277         * ircd/res.c: use sendcmdto_one
278
279         * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
280         debugging assertions
281
282 2000-04-24  Kevin L. Mitchell  <klmitch@mit.edu>
283
284         * ircd/support.c: dumpcore is no longer used, so get rid of it
285
286         * ircd/parse.c: use send_reply, sendcmdto_one
287
288         * ircd/map.c: use send_reply
289
290         * ircd/listener.c: use send_reply
291
292         * ircd/jupe.c: use sendto_opmask_butone, send_reply
293
294         * ircd/ircd_reply.c: use send_reply
295
296         * ircd/ircd.c: use sendto_opmask_butone
297
298         * ircd/gline.c: use sendto_opmask_butone, send_reply
299
300         * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
301         registered clients; make FLAG_ALT print nick!user@host; make
302         FLAG_COLON print :blah
303
304         * ircd/class.c (report_classes): use send_reply instead of
305         sendto_one
306
307         * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
308
309         * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
310         sendto_one with sendcmdto_one
311
312 2000-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
313
314         * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
315         MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
316         sendcmdto_match_butone
317
318         * include/send.h: declare sendcmdto_match_butone
319
320 2000-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
321
322         * ircd/jupe.c: update to use send_reply()
323
324         * ircd/gline.c: update to use send_reply()
325
326         * include/ircd_reply.h: declare send_reply
327
328         * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
329         replies; uses ircd_snprintf
330
331         * ircd/send.c: added comments to redirect searchers to appropriate
332         sendcmdto_* function; moved new functions to end of file; added
333         explanatory comments; reordered arguments; defined new functions
334         mentioned below
335
336         * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
337
338         * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
339
340         * ircd/jupe.c: reorder arguments to sendcmdto_* functions
341
342         * ircd/gline.c: reorder arguments to sendcmdto_* functions
343
344         * include/send.h: reorder arguments, add explanatory comments,
345         declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
346         and vsendto_opmask_butone
347
348 2000-04-19  Kevin L. Mitchell  <klmitch@mit.edu>
349
350         * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
351         vsendto_op_mask that uses '*' instead of the receiving client
352         nickname
353
354         * include/send.h: declare sendcmdto_channel_butone; takes a skip
355         argument that allows you to skip (or not to skip) deaf users,
356         users behind bursting servers, and non channel operators
357
358 2000-04-17  Kevin L. Mitchell  <klmitch@mit.edu>
359
360         * ircd/send.c: new sendcmdto_channel_butserv -- note that old
361         sendto_channel_butserv has a subtle bug; also wrote
362         sendcmdto_common_channels.
363
364         * include/send.h: declare new sendcmdto_* functions
365
366         * ircd/jupe.c: support local deactivations of jupes
367
368         * ircd/gline.c: support local deactivations of glines
369
370         * include/jupe.h: JUPE_LDEACT allows jupes to be locally
371         deactivated; if they aren't locally deactivated, then it slaves to
372         the net-wide activation status; JupeIsRemActive() tests only
373         whether the jupe is active everywhere else
374
375         * include/gline.h: GLINE_LDEACT allows glines to be locally
376         deactivated; if they aren't locally deactivated, then it slaves to
377         the net-wide activation status; GlineIsRemActive() tests only
378         whether the gline is active everywhere else
379
380         * ircd/gline.c: detect overlapping G-lines; if an existing, wider
381         gline expires after the new one will, we drop the new one,
382         otherwise we add the G-line after that one (so the wide one will
383         apply first); if the new one contains an existing G-line and if it
384         will expire after the existing one, we drop the existing one to
385         save memory
386
387         * ircd/m_gline.c (mo_gline): opers could issue remote local
388         glines when CONFIG_OPERCMDS was off; fixed
389
390 2000-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
391
392         * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
393         this is a local JUPE
394
395         * ircd/gline.c: add flags argument to gline_activate and
396         gline_deactivate for future expansion
397
398         * ircd/m_gline.c: pass flags to gline_activate and
399         gline_deactivate
400
401         * include/gline.h: add flags argument to gline_activate and
402         gline_deactivate
403
404         * ircd/jupe.c: add flags argument to jupe_activate and
405         jupe_deactivate for future expansion
406
407         * include/jupe.h: add flags argument to jupe_activate and
408         jupe_deactivate
409
410         * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
411         local, active; pass flags to jupe_activate and jupe_deactivate
412
413         * include/gline.h: remove dead code
414
415         * ircd/gline.c: make gline expire times relative to CurrentTime,
416         since that should be monotonically increasing, instead of
417         TStime(), which can be set backwards, and which can therefore
418         cause an expire time to increase; make local glines be removed
419         instead of just deactivated; don't let gline_find() look for
420         user@host glines if the mask being looked up is a channel mask
421
422         * ircd/send.c (vsendcmdto_one): forgot to account for the case
423         where origin is a server and destination is a user
424
425         * ircd/jupe.c: make jupe expire times relative to CurrentTime,
426         since that should be monotonically increasing, instead of
427         TStime(), which can be set backwards, and which can therefore
428         cause an expire time to increase; make local jupes be removed
429         instead of just deactivated
430
431         * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
432         limit is fine.  any other warnings I should know about?
433
434 2000-04-15  Thomas Helvey <tomh@inxpress.net>
435
436         * ircd/*.c: const correctness and type safety cleanups to
437         get code to compile with C++ compiler. Still has
438         signed/unsigned comparison warnings.
439
440 2000-04-15  Greg Sikorski <gte@atomicrevs.demon.co.uk>
441
442         * ircd/userload.c: change <sys/time.h> include to <time.h> for
443           portability.
444
445 2000-04-14  Kevin L. Mitchell  <klmitch@mit.edu>
446
447         * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
448         and convert acptr...
449
450         * ircd/s_user.c: move gline_lookup function call into
451         register_user, where it'll have a username to lookup!
452
453         * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
454         functions; also stuff send_error_to_client into return clauses
455
456         * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
457         functions; also use send_error_to_client where that makes sense
458
459         * ircd/jupe.c: modify to utilize new sendcmdto_* series of
460         functions; also use send_error_to_client where that makes sense
461
462         * ircd/gline.c: modify to utilize new sendcmdto_* series of
463         functions; also fix gline_lookup() to deal properly with remote
464         clients--boy, do struct Client and struct User need to be cleaned
465         up!
466
467         * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
468         too...
469
470         * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
471         sendcmdto_serv_butone(), all utilizing the %v conversion of
472         ircd_snprintf()
473
474         * include/send.h: define IRC_BUFSIZE, max size of a message;
475         declare sendcmdto_one(), vsendcmdto_one(), and
476         sendcmdto_serv_butone()
477
478         * include/msg.h: define all the CMD_* constants needed to utilize
479         the new sendcmdto_* series of functions
480
481         * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
482
483         * ircd/gline.c: remove old, dead code.
484
485         * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
486         unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
487         (don't advertise proxies); remove dead code
488
489         * ircd/parse.c: oper handler for JUPE only lists jupes unless
490         CONFIG_OPERCMDS is enabled
491
492         * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
493         CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
494
495         * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
496         always return ERR_DISABLED
497
498         * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
499         enabled, always return ERR_DISABLED
500
501         * ircd/s_err.c: add error message to indicate disabled commands
502
503         * include/numeric.h (ERR_DISABLED): to indicate disabled commands
504
505         * doc/Configure.help: add documentation for CONFIG_OPERCMDS
506
507         * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
508         CONFIG_NEW_MODE to 'y' for now
509
510         * ircd/gline.c (gline_list): fix a minor formatting bogon
511
512         * BUGS: since I fixed that bug, might as well mark it fixed.
513
514         * ircd/m_join.c: look up badchans with GLINE_EXACT
515
516         * ircd/m_gline.c: fix parc count problems; look up existing
517         G-lines with GLINE_EXACT; only set new lastmod when
518         activating/deactivating existing glines if old lastmod was not 0
519
520         * ircd/gline.c: forgot to copy the gline reason over; don't
521         propagate a gline with 0 lastmod if origin is user; add
522         GLINE_EXACT to force exact matching of gline mask
523
524         * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
525         flag properly
526
527         * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
528         but gline_lookup() actually takes a client--d'oh.
529
530 2000-04-13  Thomas Helvey <tomh@inxpress.net>
531         * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
532
533 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
534
535         * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
536           "/who * x"
537           "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
538           (Found by Plexus).
539
540         * ircd/whocmds.c: Change idle time calc from socket idle to user
541           idle.
542
543 2000-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
544
545         * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
546         too, for ircd_snprintf.c
547
548         * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
549         comments; mostly descended from the Linux manpage for printf, but
550         also documenting the extensions.
551
552         * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
553         client; make 'q' be the same as 'L'; remove __inline__; only
554         define EXTENSION if HAVE_LONG_LONG is defined
555
556         * include/handlers.h: declare m_gline()
557
558         * ircd/parse.c: gline can be called by users, but it only lists
559         the glines.
560
561         * ircd/s_user.c (set_nick_name): resend gline if a remote server
562         introduces a glined client
563
564         * ircd/s_serv.c (server_estab): burst glines, too
565
566         * ircd/gline.c: fix up all the expire times to be offsets;
567         simplify gline_resend()
568
569         * ircd/m_gline.c: begin coding replacements for ms_gline(),
570         mo_gline(), and m_gline()
571
572         * ircd/gline.c (gline_add): allow *@#channel to work correctly;
573         also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
574
575 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
576
577         * tools/Bouncer/*: Add comments/documentation/tags.
578         * tools/Bouncer/*: Add debug defines, make task fork().
579
580 2000-04-12  Thomas Helvey <tomh@inxpress.net>
581         * ircd/s_err.c: Cleanup s_err.c make one table so we
582         don't have to do anything tricky to get an error string.
583
584 2000-04-12  Greg Sikorski <gte@atomicrevs.demon.co.uk>
585         * Add port bouncer for http (x/w)
586
587 2000-04-12  Kevin L. Mitchell  <klmitch@mit.edu>
588
589         * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
590         call to gline_find(); also used GlineReason() instead of direct
591         reference to structure member
592
593         * ircd/m_join.c (m_join): replace bad_channel() calls with calls
594         to gline_find(name, GLINE_BADCHAN), and also check to see if gline
595         is active
596
597         * ircd/channel.c: nothing seems to be called anywhere...
598
599         * ircd/s_err.c: update a couple of replies to dovetail with new
600         semantics
601
602         * ircd/gline.c: begin complete re-implementation of gline.c along
603         the lines of the final design of jupe.c
604
605         * include/gline.h: begin complete re-implementation of gline.c
606         along the lines of the final design of jupe.c
607
608         * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
609         %s by %s" message...
610
611         * ircd/ircd_snprintf.c: my new snprintf()-like functions
612
613         * include/ircd_snprintf.h: my new snprintf()-like functions
614
615 2000-04-11  Thomas Helvey <tomh@inxpress.net>
616         * ircd/IPcheck.c: removed old dead code
617         * ircd/s_user.c (send_user_info): removed non-standard
618           user not found message for userhost/userip
619
620 2000-04-11  Greg Sikorski <gte@atomicrevs.demon.co.uk>
621
622         * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
623         * doc/p10.html: Work on chapter 4.
624
625 2000-04-10  Kevin L. Mitchell  <klmitch@mit.edu>
626
627         * ircd/channel.c (mode_parse_client): fix coredump on /mode
628         #foobar +o nosuchnick
629
630 2000-04-10  Perry Lorier  <Isomer@coders.net>
631         * BUGS: Added bug.
632
633 2000-04-09  Thomas Helvey <tomh@inxpress.net>
634         * include/IPcheck.h: fix prototype
635         * ircd/s_user.c: fix usage of IPcheck_remote_connect
636         * ircd/IPcheck.c: removed unused args
637
638 2000-04-09  Thomas Helvey <tomh@inxpress.net>
639         * include/IPcheck.h: add proto for IPcheck_expire
640
641         * ircd/IPcheck.c: Rewrote
642
643         * ircd/ircd.c: Add IPcheck_expire to main message loop
644
645         * ircd/s_user.c: Redo target hashing, refactor target code
646
647         * include/numeric.h: Cleaned up numerics, added which ones are
648         in use by other networks and what they are in use for.
649
650         * ircd/channel.c: cleaned can_join(), allow anyone through anything
651         if /invited, simplified the function.  Opers overusing OPEROVERRIDE
652         will get a message explaining to them not to cheat.
653
654         * ircd/m_join.c: cleaned up the various join functions, should be
655         a lot more efficient.  Still needs work.  Now assumes that s<->s
656         won't send it a JOIN 0.  Service coders - note this and tread with
657         care.
658
659         * ircd/m_stats.c: added Gte-'s stats doc patch.
660
661         * ircd/m_version.c: /version now returns the 005 numeric as well.
662         as requested by Liandrin.
663
664
665 2000-04-07  Kevin L. Mitchell  <klmitch@mit.edu>
666
667         * ircd/m_clearmode.c: add include for support.h for write_log()
668
669         * configure: move ircd/crypt/* to tools/*
670
671 2000-04-06  Thomas Helvey <tomh@inxpress.net>
672         * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
673           set client host to server alias if connection from localhost
674
675 2000-04-06  Perry Lorier <isomer@coders.net>
676         * ircd/ircd.c: Fix core during pinging (oops)
677         
678 2000-04-06  Perry Lorier <isomer@coders.net>
679         * ircd/send.c: fixed wrong ident being sent to channels bug.
680         * include/numerics.h: Updated some of the numerics from other
681         networks.  Flagged some as 'unused' by undernet.
682
683 2000-03-30  Perry Lorier <isomer@coders.net>
684         * ircd/ircd.c: Lets see if this helps the ping problem at all.
685         * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
686         time for local clients. (as requested), extended who now returns all
687         the flags (@+!) so you can tell the complete state of a client.
688
689 2000-03-30  Thomas Helvey <tomh@inxpress.net>
690         * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
691
692 2000-03-30  Perry Lorier <isomer@coders.net>
693         * ircd/parse.c: oops, missed opers.
694
695 2000-03-30  Perry Lorier <isomer@coders.net>
696         * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
697         for so long.  Remember: m_ping MUST be in the parse array. :)
698
699 2000-03-30  Perry Lorier <isomer@coders.net>
700         * ircd/ircd.c: test in check_pings was wrong.  I move that we
701         disallow cvs commit after 10pm localtime....
702
703 2000-03-30  Perry Lorier <isomer@coders.net>
704         * ircd/m_pong.c: Fix it for servers too.
705
706 2000-03-30  Perry Lorier <isomer@coders.net>
707         * ircd/m_pong.c: Fix ping timeout bugs
708
709 2000-03-30  Perry Lorier <isomer@coders.net>
710         * ircd/channel.c: Bans had CurrentTime in their when field instead
711         of TStime()
712
713 2000-03-31  Thomas Helvey <tomh@ixpress.net>
714         * ircd/numnicks.c (SetXYYCapacity): fix for extended
715         numerics.
716
717 2000-03-30  Perry Lorier <isomer@coders.net>
718         * ircd/m_nick.c: send kills both ways so when we add nick change
719         on collision we don't desync the network.
720
721         * ircd/map.c: Fixup the map a bit more.
722
723 2000-03-31  Kevin L. Mitchell  <klmitch@mit.edu>
724
725         * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
726
727         * ircd/m_opmode.c: Log the mode changes to OPATH
728
729         * ircd/channel.c (modebuf_flush_int): Log the mode changes to
730         OPATH
731
732         * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
733         OPATH
734
735         * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
736
737         * config/config-sh.in: added OPATH for opmode log file
738
739         * ircd/m_clearmode.c (do_clearmode): updated uses of
740         modebuf_mode_string() for the new usage
741
742         * ircd/channel.c: added flag MODE_FREE and an int argument to
743         modebuf_mode_string() to indicate that the string must be free'd;
744         updated calls to modebuf_mode_string() for the new usage; called
745         collapse(pretty_mask()) on the ban string and use allocated memory
746         for it; added ban list length accounting; fixed a number of small
747         bugs in ban processing
748
749         * include/channel.h: added flag MODE_FREE and an int argument to
750         modebuf_mode_string() to indicate that the string must be free'd
751
752         * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
753         keys and limits that are set
754
755 2000-03-30  Perry Lorier <isomer@coders.net>
756         * ircd/ircd.c: rewrote check_pings() for maintainability
757         and speed.  Also changed quit msg's so they don't have
758         redundant nick[host] info in them.
759
760         * ircd/send.c: Changed write errors to report what error
761         occured (if possible).
762
763         * ircd/gline.c: added gline comment to the quit.
764
765         * ircd/m_server.c: Added suggestions to server quits mentioning
766         what went wrong so the admin can fix it earlier instead of asking
767         questions...
768
769         * ircd/map.c: Changed m_map() to hide numerics, show a * beside
770         servers that aren't fully burst yet.  And show '(--s)' for servers
771         where its not sure.
772
773         * doc/example.conf: Fixed wrapped U:
774
775 2000-03-30  Kevin L. Mitchell  <klmitch@mit.edu>
776
777         * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
778         mode_parse() (version selectable at compile time)
779
780         * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
781
782         * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
783
784         * config/config-sh.in: add new config option to enable new m_mode
785         implementation
786
787         * doc/Configure.help: add documentation for new config option
788         CONFIG_NEW_MODE
789
790         * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
791         MODE -v : Not enough parameters
792
793         * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
794         +k and +l even if they weren't set...
795
796         * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
797
798         * ircd/channel.c: make mode_process_clients() clear the DEOPPED
799         flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
800         for; test the 0-th member, not the i-th member, of the client
801         change state stuff
802
803         * ircd/m_clearmode.c (do_clearmode): use the new
804         mode_invite_clear() function
805
806         * ircd/channel.c: cleared up all the compile-time warnings and
807         errors
808
809         * include/channel.h: added declarations for mode_ban_invalidate()
810         and mode_invite_clear()
811
812         * ircd/channel.c: finished mode_parse(), then broke it up into a
813         dozen or so helper functions to make the code easier to read
814
815 2000-03-29  Thomas Helvey <tomh@inxpress.net>
816         * ircd/ircd.c: refactor server initialization a bit, use
817         getopt for parsing command line, refactor init_sys, main,
818         and other bits.
819
820         * ircd/s_bsd.c: add functions for initialization to clean
821         up logic a bit and remove duplicated code.
822
823         * include/ircd.h: add struct for server process related
824         variables.
825
826 2000-03-29  Kevin L. Mitchell  <klmitch@mit.edu>
827
828         * ircd/channel.c: initial definition of mode_parse(); flags to
829         prevent doing the same thing multiple times; helper method
830         send_notoper() to send a "Not oper"/"Not on channel" notice
831
832         * include/channel.h: declare mode_parse() and helper flags
833
834         * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
835         sending to match the current action of set_mode() closely enough
836         that hopefully there won't be major conflicts
837
838         * ircd/channel.c (modebuf_flush_int): consolidated the mode string
839         building logic, reversed the order of the arguments to mode
840         commands to have '-' preceed '+'
841
842 2000-03-29  Thomas Helvey <tomh@inxpress.net>
843         * ircd/s_bsd.c (add_connection): don't disable socket options
844         let OS tune itself and allow important performance tweaks to 
845         work.
846
847 2000-03-28  Kevin L. Mitchell  <klmitch@mit.edu>
848
849         * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
850         confused by set_mode, which is doing some really weird logic;
851         guess what I'm going to rewrite next?  ;)
852
853 2000-03-28  Kevin L. Mitchell  <klmitch@emc.com>
854
855         * include/channel.h: added MODE_SAVE for the bounds checking stuff
856         in modebuf_flush
857
858         * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
859         make it do bounds checking on the buffer; all modes are sent only
860         if the all parameter is 1; modebuf_flush is the exported wrapper
861
862         * include/channel.h: add BOUNCE, renumber flags to get a little
863         more space
864
865         * ircd/channel.c (modebuf_flush): don't overload HACK2, add
866         BOUNCE; send DESYNCH message
867
868 2000-03-27  Kevin L. Mitchell  <klmitch@emc.com>
869
870         * ircd/m_clearmode.c (do_clearmode): only mark the modes the
871         channel actually has in effect for deletion
872
873         * ircd/channel.c: added explanatory comments to all added
874         functions; made flushing take place at the correct place even if
875         the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
876         to bash some stupid bugs; made modebuf_flush() return if ModeBuf
877         is empty, fixed the apparent source, removed some bogus string
878         termination code, properly terminate the mode strings, add support
879         for HACK2 and HACK3, made limit strings not be sent if the limit
880         is being removed, changed where '+' and '-' come from in sent
881         strings, added support for DEOP flag, set up bouncing code for
882         HACK2
883
884         * ircd/Makefile.in: ran make depend
885
886         * include/channel.h: added new defines for future functionality,
887         made modebuf_flush() return int so I can use tail recursion
888
889         * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
890         to make it all compile
891
892         * ircd/m_opmode.c: add msg.h to includes...
893
894         * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
895
896         * ircd/channel.c (modebuf_flush): realized I forgot to
897         nul-terminate addbuf/rembuf properly...
898
899         * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
900
901         * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
902         sendto_serv_butone--blah^2
903
904         * ircd/send.c (sendto_serv_butone): stupid comments confused me
905
906         * ircd/channel.c (modebuf_flush): if there are no mode changes to
907         propagate, we're done...
908
909         * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
910         not sendto_all_butone
911
912         * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
913
914         * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
915
916         * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
917         the list
918
919         * ircd/parse.c: added messages for opmode and clearmode
920
921         * include/handlers.h: added declarations for mo_opmode(),
922         ms_opmode(), mo_clearmode(), and ms_clearmode()
923
924         * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
925         TOK_CLEARMODE
926
927         * include/channel.h (MODEBUF_DEST_OPMODE): Define the
928         MODEBUF_DEST_OPMODE flag
929
930         * ircd/channel.c (modebuf_flush): added new flag,
931         MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
932         to originate from source's server (or source itself, if
933         IsServer(source)); also causes a server-level MODE to be sent as
934         OPMODE instead
935
936         * include/channel.h: defined MODEBUF_DEST_SERVER,
937         MODEBUF_DEST_HACK4
938
939         * ircd/channel.c: Add another argument to build_string() to handle
940         numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
941         servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
942         to be sent out
943
944 2000-03-27  Perry Lorier <isomer@coders.net>
945
946         * ircd/s_bsd.c: fixed missing 'u' typo.
947
948 2000-03-26  Kevin L. Mitchell  <klmitch@emc.com>
949
950         * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
951         _mode_string(), _mode_client(), _flush(); also implemented a
952         simple build_string()
953
954         * include/channel.h: added definition of ModeBuf, modebuf_*
955         manipulation functions, and a couple of helper macros
956
957 2000-03-24 Thomas Helvey <tomh@inxpress.net>
958   * numicks.c: convert extended numerics to use original mask version
959   * numnicks.h: ""
960   * s_user.c:
961 2000-03-23 Thomas Helvey <tomh@inxpress.net>
962   * Merge in changes from production
963 2000-03-22 Thomas Helvey <tomh@inxpress.net>
964   * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
965   * rfc1459.unet: Add Maniac's documentation for /names 0
966 * Fix misc. jupe bugs that somehow made it into the tree
967 * Escape /names 0 to mean /names --Maniac
968 * Don't core when server asks for info --Maniac 
969 * Add Kev's jupe patch --Bleep
970 * Add Maniacs squit patch --Bleep
971 * Merge in u2_10_10_beta07 changes --Bleep
972 * Merge in u2_10_10_beta06 changes --Bleep
973 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
974 #-----------------------------------------------------------------------------
975 #
976 # ChangeLog for ircu2.10.11
977 #
978 # $Id: ChangeLog,v 1.114 2000-04-29 05:30:05 isomer Exp $
979 #
980 # Insert new changes at beginning of the change list.
981 #