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