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