1 2000-05-04 Kevin L. Mitchell <klmitch@mit.edu>
3 * ircd/channel.c (send_channel_modes): deal with one of the last
6 * ircd/m_burst.c (ms_burst): debugged ban processing; removed
9 * ircd/channel.c (modebuf_extract): remove debugging
10 sendto_opmask_butone calls
12 2000-05-03 Kevin L. Mitchell <klmitch@mit.edu>
14 * ircd/channel.c: support a couple of new flags to support using
15 mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
16 of modebuf_extract to extract added flags for use by ms_burst
18 * include/channel.h: a couple of new flags to support using
19 mode_parse inside ms_burst
21 * ircd/m_burst.c (ms_burst): brand new implementation of BURST
23 * ircd/m_endburst.c: add loop to processing of end_of_burst to
24 free empty channels after the BURST is over.
26 * ircd/m_server.c: convert to use new send.c functions--I wanted
27 to rewrite it from scratch, but the logic's pretty complex; I may
28 still rewrite it, though...
30 2000-05-02 Thomas Helvey <tomh@inxpress.net>
32 * ircd/ircd.c: fix broken header include ordering
34 2000-05-02 Thomas Helvey <tomh@inxpress.net>
36 * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
37 review emailed privately
39 * include/IPcheck.h: removed unneeded include
41 2000-05-02 Kevin L. Mitchell <klmitch@mit.edu>
43 * ircd/s_user.c (hunt_server): throw in a comment so I know what
46 * include/querycmds.h (Count_unknownbecomesclient): convert to
49 * ircd/send.c: start removing dead code
51 * include/send.h: start removing dead code
53 * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
56 * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
58 2000-05-01 Kevin L. Mitchell <klmitch@mit.edu>
60 * ircd/m_stats.c: convert to sendcmdto_one / send_reply
62 * ircd/m_kick.c: Completely reimplement m_kick
64 * ircd/channel.c: send_user_joins removed; it was dead code,
67 2000-05-01 Perry Lorier <isomer@coders.net>
68 * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
69 * ircd/channels.c: My fix for the part problem. Untested, probably
70 won't work. Can't be much worse than the current problem.
71 it'll either work or core, take your pick.
74 2000-04-30 Perry Lorier <isomer@coders.net>
75 * config/config-sh.in: Fix for CONNEXIT
76 * ircd/s_{user,misc}.c: Fix for CONNEXIT
77 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
78 (Kev: Want to come talk to me about this?)
80 2000-04-30 Steven M. Doyle <steven@doyle.net>
82 - general cleanups and readability enhancements
83 - rewrite of setuid/chroot code.
84 - server will no longer run as root
85 - -DPROFIL compile option removed
86 - Fixed IPcheck API calls
89 - Fixed up chroot compile options
90 - Added options for debug and profile compiles
92 * config/gen.ircd.Makefile
93 - Support for new debug/profile options
96 - Support for new debug/profile options
102 - Removed old API prototypes, added new ones
105 - Readability cleanups (well, I -think-...)
106 - Changed IPRegistryEntry.last_connect to a time_t. The previously
107 used unsigned short was probably causing interesting things after
108 a client had been connected longer than about 65,535 seconds...
109 - Removed old API functions.
112 - Removed IPcheck.h include
114 * Additionally modified IPcheck API calls in:
124 2000-04-30 Perry Lorier <isomer@coders.net>
125 * ircd/s_bsd.c: Sigh. :)
126 * ircd/m_mode.c: fix for modeless channels by poptix.
128 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
130 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
132 * ircd/channel.c (clean_channelname): make clean_channelname also
133 truncate long channel names
135 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
137 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
139 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
142 * include/channel.h: definitions and declarations for the struct
145 2000-04-29 Perry Lorier <isomer@coders.net>
146 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
148 2000-04-29 Perry Lorier <isomer@coders.net>
149 * ircd/s_bsd.c: Add debugging code to IPcheck
151 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
153 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
155 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
158 * ircd/m_userhost.c (m_userhost): add a dead code comment
160 * ircd/m_desynch.c: forgot one...
162 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
164 * ircd/m_proto.c (proto_send_supported): just change a comment so
165 it doesn't show up in my scans
167 * ircd/ircd_reply.c (send_reply): fix a slight bug...
169 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
172 * ircd/parse.c (parse_server): argument wrangling to make
173 processing in do_numeric a little easier to deal with
175 * ircd/s_serv.c (server_estab): SERVER should come from
176 acptr->serv->up, not &me
178 * ircd/m_lusers.c: accidentally left out sptr for a %C
180 * ircd/send.c: hack to support doing wallchops...
182 * ircd/m_whowas.c: convert to new send functions
184 * ircd/m_whois.c: convert to new send functions
186 * ircd/m_who.c: convert to new send functions
188 * ircd/m_wallops.c: convert to new send functions
190 * ircd/m_wallchops.c: convert to new send functions
192 * ircd/m_version.c: convert to new send functions
194 * ircd/m_userip.c: convert to new send functions
196 * ircd/m_userhost.c: convert to new send functions
198 * ircd/m_uping.c: convert to new send functions
200 * ircd/m_trace.c: convert to new send functions
202 * ircd/m_topic.c: convert to new send functions
204 * ircd/m_time.c: convert to new send functions
206 * ircd/m_squit.c: convert to new send functions
208 * ircd/m_silence.c: convert to new send functions
210 * ircd/m_settime.c: convert to new send functions
212 * ircd/m_restart.c: convert to new send functions
214 * ircd/m_rehash.c: convert to new send functions
216 * ircd/m_privmsg.c: convert to new send functions
218 * ircd/m_pong.c: convert to new send functions
220 * ircd/m_ping.c: convert to new send functions
222 * ircd/m_pass.c: convert to new send functions
224 * ircd/m_opmode.c: convert to new send functions
226 * ircd/m_oper.c: convert to new send functions
228 * ircd/m_notice.c: convert to new send functions
230 * ircd/m_nick.c: convert to new send functions
232 * ircd/m_names.c: convert to new send functions
234 * ircd/m_motd.c: convert to new send functions
236 * ircd/m_mode.c: convert to new send functions
238 * ircd/m_map.c: convert to new send functions
240 * ircd/m_lusers.c: convert to new send functions
242 * ircd/m_list.c: convert to new send functions
244 * ircd/m_links.c: convert to new send functions
246 * ircd/m_kill.c: convert to new send functions
248 * ircd/m_jupe.c: convert to new send functions
250 * ircd/m_invite.c: convert to new send functions
252 * ircd/m_info.c: convert to new send functions
254 * ircd/m_help.c: convert to new send functions
256 * ircd/m_gline.c: convert to new send functions
258 * ircd/m_error.c: convert to new send functions
260 * ircd/m_endburst.c: convert to new send functions
262 * ircd/m_die.c: convert to new send functions
264 * ircd/m_destruct.c: convert to new send functions
266 * ircd/m_defaults.c: convert to new send functions
268 * ircd/m_connect.c: convert to new send functions
270 2000-04-28 Perry Lorier <isomer@coders.net>
271 * RELEASE.NOTES: Describe a few more undocumented features.
272 * config/config-sh.in: change the default paths for logging
273 and the recommended number of channels.
274 * include/supported.h: Rearrange slightly, added CHANTYPE's
276 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
278 * ircd/m_close.c: convert to send_reply
280 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
282 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
284 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
286 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
287 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
288 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
289 carefully rethought...
291 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
293 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
295 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
296 numeric nick; therefore, we have to use the server name
298 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
300 * ircd/send.c: fix minor bugs
302 * ircd/s_user.c (check_target_limit): mark dead code so I filter
305 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
308 * ircd/parse.c: mark dead code so I filter it when I grep
310 * ircd/map.c: mark dead code so I filter it when I grep
312 * ircd/ircd.c: mark dead code so I filter it when I grep
314 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
317 * ircd/channel.c: mark dead code so I filter it when I grep
319 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
320 hope I'm not stepping on toes...
322 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
323 conversions; use ircd_snprintf in a couple of cases to negate the
324 possibility of buffer overflow
326 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
328 * ircd/channel.c: convert as much as possible to new send
331 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
332 test member->user->from->fd, not from->fd
334 * ircd/gline.c (gline_add): go ahead and add badchans; we just
335 won't look for them in m_gline; this way, they always work...
337 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
339 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
340 ircd_vsnprintf conversion specifiers
342 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
343 I have my conversion specifiers
345 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
347 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
350 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
351 little less brain-dead
353 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
355 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
358 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
361 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
364 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
366 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
368 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
371 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
373 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
374 a numeric as needing to use an explicit pattern, which will be the
375 first argument in the variable argument list
377 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
378 non-prefixed nospoof PING
380 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
381 non-prefixed SERVER login
383 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
384 a numeric usage further up)
386 * include/send.h: declare sendrawto_one
388 * ircd/send.c (sendrawto_one): new function to use ONLY for
389 non-prefixed commands, like PING to client, or PASS/SERVER on
392 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
394 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
395 future expansion (channel numerics?)
397 * include/ircd_snprintf.h: added documentation to # to explain use
398 with %C; added documentation for : to explain use with %C; added
399 documentation for %H for channels
401 * ircd/whocmds.c: use send_reply
403 * ircd/userload.c: use sendcmdto_one
405 * ircd/uping.c: use sendcmdto_one
407 * ircd/send.c: use new flags to %C format string; ':' prefixes
408 client name with a colon for local connects, '#' uses
409 nick!user@host form for local connects
411 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
412 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
414 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
416 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
419 * ircd/s_auth.c: use sendto_opmask_butone
421 * ircd/res.c: use sendcmdto_one
423 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
426 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
428 * ircd/support.c: dumpcore is no longer used, so get rid of it
430 * ircd/parse.c: use send_reply, sendcmdto_one
432 * ircd/map.c: use send_reply
434 * ircd/listener.c: use send_reply
436 * ircd/jupe.c: use sendto_opmask_butone, send_reply
438 * ircd/ircd_reply.c: use send_reply
440 * ircd/ircd.c: use sendto_opmask_butone
442 * ircd/gline.c: use sendto_opmask_butone, send_reply
444 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
445 registered clients; make FLAG_ALT print nick!user@host; make
446 FLAG_COLON print :blah
448 * ircd/class.c (report_classes): use send_reply instead of
451 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
453 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
454 sendto_one with sendcmdto_one
456 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
458 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
459 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
460 sendcmdto_match_butone
462 * include/send.h: declare sendcmdto_match_butone
464 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
466 * ircd/jupe.c: update to use send_reply()
468 * ircd/gline.c: update to use send_reply()
470 * include/ircd_reply.h: declare send_reply
472 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
473 replies; uses ircd_snprintf
475 * ircd/send.c: added comments to redirect searchers to appropriate
476 sendcmdto_* function; moved new functions to end of file; added
477 explanatory comments; reordered arguments; defined new functions
480 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
482 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
484 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
486 * ircd/gline.c: reorder arguments to sendcmdto_* functions
488 * include/send.h: reorder arguments, add explanatory comments,
489 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
490 and vsendto_opmask_butone
492 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
494 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
495 vsendto_op_mask that uses '*' instead of the receiving client
498 * include/send.h: declare sendcmdto_channel_butone; takes a skip
499 argument that allows you to skip (or not to skip) deaf users,
500 users behind bursting servers, and non channel operators
502 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
504 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
505 sendto_channel_butserv has a subtle bug; also wrote
506 sendcmdto_common_channels.
508 * include/send.h: declare new sendcmdto_* functions
510 * ircd/jupe.c: support local deactivations of jupes
512 * ircd/gline.c: support local deactivations of glines
514 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
515 deactivated; if they aren't locally deactivated, then it slaves to
516 the net-wide activation status; JupeIsRemActive() tests only
517 whether the jupe is active everywhere else
519 * include/gline.h: GLINE_LDEACT allows glines to be locally
520 deactivated; if they aren't locally deactivated, then it slaves to
521 the net-wide activation status; GlineIsRemActive() tests only
522 whether the gline is active everywhere else
524 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
525 gline expires after the new one will, we drop the new one,
526 otherwise we add the G-line after that one (so the wide one will
527 apply first); if the new one contains an existing G-line and if it
528 will expire after the existing one, we drop the existing one to
531 * ircd/m_gline.c (mo_gline): opers could issue remote local
532 glines when CONFIG_OPERCMDS was off; fixed
534 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
536 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
539 * ircd/gline.c: add flags argument to gline_activate and
540 gline_deactivate for future expansion
542 * ircd/m_gline.c: pass flags to gline_activate and
545 * include/gline.h: add flags argument to gline_activate and
548 * ircd/jupe.c: add flags argument to jupe_activate and
549 jupe_deactivate for future expansion
551 * include/jupe.h: add flags argument to jupe_activate and
554 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
555 local, active; pass flags to jupe_activate and jupe_deactivate
557 * include/gline.h: remove dead code
559 * ircd/gline.c: make gline expire times relative to CurrentTime,
560 since that should be monotonically increasing, instead of
561 TStime(), which can be set backwards, and which can therefore
562 cause an expire time to increase; make local glines be removed
563 instead of just deactivated; don't let gline_find() look for
564 user@host glines if the mask being looked up is a channel mask
566 * ircd/send.c (vsendcmdto_one): forgot to account for the case
567 where origin is a server and destination is a user
569 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
570 since that should be monotonically increasing, instead of
571 TStime(), which can be set backwards, and which can therefore
572 cause an expire time to increase; make local jupes be removed
573 instead of just deactivated
575 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
576 limit is fine. any other warnings I should know about?
578 2000-04-15 Thomas Helvey <tomh@inxpress.net>
580 * ircd/*.c: const correctness and type safety cleanups to
581 get code to compile with C++ compiler. Still has
582 signed/unsigned comparison warnings.
584 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
586 * ircd/userload.c: change <sys/time.h> include to <time.h> for
589 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
591 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
594 * ircd/s_user.c: move gline_lookup function call into
595 register_user, where it'll have a username to lookup!
597 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
598 functions; also stuff send_error_to_client into return clauses
600 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
601 functions; also use send_error_to_client where that makes sense
603 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
604 functions; also use send_error_to_client where that makes sense
606 * ircd/gline.c: modify to utilize new sendcmdto_* series of
607 functions; also fix gline_lookup() to deal properly with remote
608 clients--boy, do struct Client and struct User need to be cleaned
611 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
614 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
615 sendcmdto_serv_butone(), all utilizing the %v conversion of
618 * include/send.h: define IRC_BUFSIZE, max size of a message;
619 declare sendcmdto_one(), vsendcmdto_one(), and
620 sendcmdto_serv_butone()
622 * include/msg.h: define all the CMD_* constants needed to utilize
623 the new sendcmdto_* series of functions
625 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
627 * ircd/gline.c: remove old, dead code.
629 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
630 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
631 (don't advertise proxies); remove dead code
633 * ircd/parse.c: oper handler for JUPE only lists jupes unless
634 CONFIG_OPERCMDS is enabled
636 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
637 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
639 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
640 always return ERR_DISABLED
642 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
643 enabled, always return ERR_DISABLED
645 * ircd/s_err.c: add error message to indicate disabled commands
647 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
649 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
651 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
652 CONFIG_NEW_MODE to 'y' for now
654 * ircd/gline.c (gline_list): fix a minor formatting bogon
656 * BUGS: since I fixed that bug, might as well mark it fixed.
658 * ircd/m_join.c: look up badchans with GLINE_EXACT
660 * ircd/m_gline.c: fix parc count problems; look up existing
661 G-lines with GLINE_EXACT; only set new lastmod when
662 activating/deactivating existing glines if old lastmod was not 0
664 * ircd/gline.c: forgot to copy the gline reason over; don't
665 propagate a gline with 0 lastmod if origin is user; add
666 GLINE_EXACT to force exact matching of gline mask
668 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
671 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
672 but gline_lookup() actually takes a client--d'oh.
674 2000-04-13 Thomas Helvey <tomh@inxpress.net>
675 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
677 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
679 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
681 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
684 * ircd/whocmds.c: Change idle time calc from socket idle to user
687 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
689 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
690 too, for ircd_snprintf.c
692 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
693 comments; mostly descended from the Linux manpage for printf, but
694 also documenting the extensions.
696 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
697 client; make 'q' be the same as 'L'; remove __inline__; only
698 define EXTENSION if HAVE_LONG_LONG is defined
700 * include/handlers.h: declare m_gline()
702 * ircd/parse.c: gline can be called by users, but it only lists
705 * ircd/s_user.c (set_nick_name): resend gline if a remote server
706 introduces a glined client
708 * ircd/s_serv.c (server_estab): burst glines, too
710 * ircd/gline.c: fix up all the expire times to be offsets;
711 simplify gline_resend()
713 * ircd/m_gline.c: begin coding replacements for ms_gline(),
714 mo_gline(), and m_gline()
716 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
717 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
719 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
721 * tools/Bouncer/*: Add comments/documentation/tags.
722 * tools/Bouncer/*: Add debug defines, make task fork().
724 2000-04-12 Thomas Helvey <tomh@inxpress.net>
725 * ircd/s_err.c: Cleanup s_err.c make one table so we
726 don't have to do anything tricky to get an error string.
728 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
729 * Add port bouncer for http (x/w)
731 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
733 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
734 call to gline_find(); also used GlineReason() instead of direct
735 reference to structure member
737 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
738 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
741 * ircd/channel.c: nothing seems to be called anywhere...
743 * ircd/s_err.c: update a couple of replies to dovetail with new
746 * ircd/gline.c: begin complete re-implementation of gline.c along
747 the lines of the final design of jupe.c
749 * include/gline.h: begin complete re-implementation of gline.c
750 along the lines of the final design of jupe.c
752 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
755 * ircd/ircd_snprintf.c: my new snprintf()-like functions
757 * include/ircd_snprintf.h: my new snprintf()-like functions
759 2000-04-11 Thomas Helvey <tomh@inxpress.net>
760 * ircd/IPcheck.c: removed old dead code
761 * ircd/s_user.c (send_user_info): removed non-standard
762 user not found message for userhost/userip
764 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
766 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
767 * doc/p10.html: Work on chapter 4.
769 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
771 * ircd/channel.c (mode_parse_client): fix coredump on /mode
772 #foobar +o nosuchnick
774 2000-04-10 Perry Lorier <Isomer@coders.net>
777 2000-04-09 Thomas Helvey <tomh@inxpress.net>
778 * include/IPcheck.h: fix prototype
779 * ircd/s_user.c: fix usage of IPcheck_remote_connect
780 * ircd/IPcheck.c: removed unused args
782 2000-04-09 Thomas Helvey <tomh@inxpress.net>
783 * include/IPcheck.h: add proto for IPcheck_expire
785 * ircd/IPcheck.c: Rewrote
787 * ircd/ircd.c: Add IPcheck_expire to main message loop
789 * ircd/s_user.c: Redo target hashing, refactor target code
791 * include/numeric.h: Cleaned up numerics, added which ones are
792 in use by other networks and what they are in use for.
794 * ircd/channel.c: cleaned can_join(), allow anyone through anything
795 if /invited, simplified the function. Opers overusing OPEROVERRIDE
796 will get a message explaining to them not to cheat.
798 * ircd/m_join.c: cleaned up the various join functions, should be
799 a lot more efficient. Still needs work. Now assumes that s<->s
800 won't send it a JOIN 0. Service coders - note this and tread with
803 * ircd/m_stats.c: added Gte-'s stats doc patch.
805 * ircd/m_version.c: /version now returns the 005 numeric as well.
806 as requested by Liandrin.
809 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
811 * ircd/m_clearmode.c: add include for support.h for write_log()
813 * configure: move ircd/crypt/* to tools/*
815 2000-04-06 Thomas Helvey <tomh@inxpress.net>
816 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
817 set client host to server alias if connection from localhost
819 2000-04-06 Perry Lorier <isomer@coders.net>
820 * ircd/ircd.c: Fix core during pinging (oops)
822 2000-04-06 Perry Lorier <isomer@coders.net>
823 * ircd/send.c: fixed wrong ident being sent to channels bug.
824 * include/numerics.h: Updated some of the numerics from other
825 networks. Flagged some as 'unused' by undernet.
827 2000-03-30 Perry Lorier <isomer@coders.net>
828 * ircd/ircd.c: Lets see if this helps the ping problem at all.
829 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
830 time for local clients. (as requested), extended who now returns all
831 the flags (@+!) so you can tell the complete state of a client.
833 2000-03-30 Thomas Helvey <tomh@inxpress.net>
834 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
836 2000-03-30 Perry Lorier <isomer@coders.net>
837 * ircd/parse.c: oops, missed opers.
839 2000-03-30 Perry Lorier <isomer@coders.net>
840 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
841 for so long. Remember: m_ping MUST be in the parse array. :)
843 2000-03-30 Perry Lorier <isomer@coders.net>
844 * ircd/ircd.c: test in check_pings was wrong. I move that we
845 disallow cvs commit after 10pm localtime....
847 2000-03-30 Perry Lorier <isomer@coders.net>
848 * ircd/m_pong.c: Fix it for servers too.
850 2000-03-30 Perry Lorier <isomer@coders.net>
851 * ircd/m_pong.c: Fix ping timeout bugs
853 2000-03-30 Perry Lorier <isomer@coders.net>
854 * ircd/channel.c: Bans had CurrentTime in their when field instead
857 2000-03-31 Thomas Helvey <tomh@ixpress.net>
858 * ircd/numnicks.c (SetXYYCapacity): fix for extended
861 2000-03-30 Perry Lorier <isomer@coders.net>
862 * ircd/m_nick.c: send kills both ways so when we add nick change
863 on collision we don't desync the network.
865 * ircd/map.c: Fixup the map a bit more.
867 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
869 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
871 * ircd/m_opmode.c: Log the mode changes to OPATH
873 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
876 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
879 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
881 * config/config-sh.in: added OPATH for opmode log file
883 * ircd/m_clearmode.c (do_clearmode): updated uses of
884 modebuf_mode_string() for the new usage
886 * ircd/channel.c: added flag MODE_FREE and an int argument to
887 modebuf_mode_string() to indicate that the string must be free'd;
888 updated calls to modebuf_mode_string() for the new usage; called
889 collapse(pretty_mask()) on the ban string and use allocated memory
890 for it; added ban list length accounting; fixed a number of small
891 bugs in ban processing
893 * include/channel.h: added flag MODE_FREE and an int argument to
894 modebuf_mode_string() to indicate that the string must be free'd
896 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
897 keys and limits that are set
899 2000-03-30 Perry Lorier <isomer@coders.net>
900 * ircd/ircd.c: rewrote check_pings() for maintainability
901 and speed. Also changed quit msg's so they don't have
902 redundant nick[host] info in them.
904 * ircd/send.c: Changed write errors to report what error
905 occured (if possible).
907 * ircd/gline.c: added gline comment to the quit.
909 * ircd/m_server.c: Added suggestions to server quits mentioning
910 what went wrong so the admin can fix it earlier instead of asking
913 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
914 servers that aren't fully burst yet. And show '(--s)' for servers
917 * doc/example.conf: Fixed wrapped U:
919 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
921 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
922 mode_parse() (version selectable at compile time)
924 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
926 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
928 * config/config-sh.in: add new config option to enable new m_mode
931 * doc/Configure.help: add documentation for new config option
934 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
935 MODE -v : Not enough parameters
937 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
938 +k and +l even if they weren't set...
940 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
942 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
943 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
944 for; test the 0-th member, not the i-th member, of the client
947 * ircd/m_clearmode.c (do_clearmode): use the new
948 mode_invite_clear() function
950 * ircd/channel.c: cleared up all the compile-time warnings and
953 * include/channel.h: added declarations for mode_ban_invalidate()
954 and mode_invite_clear()
956 * ircd/channel.c: finished mode_parse(), then broke it up into a
957 dozen or so helper functions to make the code easier to read
959 2000-03-29 Thomas Helvey <tomh@inxpress.net>
960 * ircd/ircd.c: refactor server initialization a bit, use
961 getopt for parsing command line, refactor init_sys, main,
964 * ircd/s_bsd.c: add functions for initialization to clean
965 up logic a bit and remove duplicated code.
967 * include/ircd.h: add struct for server process related
970 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
972 * ircd/channel.c: initial definition of mode_parse(); flags to
973 prevent doing the same thing multiple times; helper method
974 send_notoper() to send a "Not oper"/"Not on channel" notice
976 * include/channel.h: declare mode_parse() and helper flags
978 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
979 sending to match the current action of set_mode() closely enough
980 that hopefully there won't be major conflicts
982 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
983 building logic, reversed the order of the arguments to mode
984 commands to have '-' preceed '+'
986 2000-03-29 Thomas Helvey <tomh@inxpress.net>
987 * ircd/s_bsd.c (add_connection): don't disable socket options
988 let OS tune itself and allow important performance tweaks to
991 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
993 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
994 confused by set_mode, which is doing some really weird logic;
995 guess what I'm going to rewrite next? ;)
997 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
999 * include/channel.h: added MODE_SAVE for the bounds checking stuff
1002 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
1003 make it do bounds checking on the buffer; all modes are sent only
1004 if the all parameter is 1; modebuf_flush is the exported wrapper
1006 * include/channel.h: add BOUNCE, renumber flags to get a little
1009 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
1010 BOUNCE; send DESYNCH message
1012 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
1014 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
1015 channel actually has in effect for deletion
1017 * ircd/channel.c: added explanatory comments to all added
1018 functions; made flushing take place at the correct place even if
1019 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
1020 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
1021 is empty, fixed the apparent source, removed some bogus string
1022 termination code, properly terminate the mode strings, add support
1023 for HACK2 and HACK3, made limit strings not be sent if the limit
1024 is being removed, changed where '+' and '-' come from in sent
1025 strings, added support for DEOP flag, set up bouncing code for
1028 * ircd/Makefile.in: ran make depend
1030 * include/channel.h: added new defines for future functionality,
1031 made modebuf_flush() return int so I can use tail recursion
1033 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
1034 to make it all compile
1036 * ircd/m_opmode.c: add msg.h to includes...
1038 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
1040 * ircd/channel.c (modebuf_flush): realized I forgot to
1041 nul-terminate addbuf/rembuf properly...
1043 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
1045 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
1046 sendto_serv_butone--blah^2
1048 * ircd/send.c (sendto_serv_butone): stupid comments confused me
1050 * ircd/channel.c (modebuf_flush): if there are no mode changes to
1051 propagate, we're done...
1053 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
1054 not sendto_all_butone
1056 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
1058 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
1060 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
1063 * ircd/parse.c: added messages for opmode and clearmode
1065 * include/handlers.h: added declarations for mo_opmode(),
1066 ms_opmode(), mo_clearmode(), and ms_clearmode()
1068 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
1071 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
1072 MODEBUF_DEST_OPMODE flag
1074 * ircd/channel.c (modebuf_flush): added new flag,
1075 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1076 to originate from source's server (or source itself, if
1077 IsServer(source)); also causes a server-level MODE to be sent as
1080 * include/channel.h: defined MODEBUF_DEST_SERVER,
1083 * ircd/channel.c: Add another argument to build_string() to handle
1084 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1085 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1088 2000-03-27 Perry Lorier <isomer@coders.net>
1090 * ircd/s_bsd.c: fixed missing 'u' typo.
1092 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
1094 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1095 _mode_string(), _mode_client(), _flush(); also implemented a
1096 simple build_string()
1098 * include/channel.h: added definition of ModeBuf, modebuf_*
1099 manipulation functions, and a couple of helper macros
1101 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1102 * numicks.c: convert extended numerics to use original mask version
1105 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1106 * Merge in changes from production
1107 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1108 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1109 * rfc1459.unet: Add Maniac's documentation for /names 0
1110 * Fix misc. jupe bugs that somehow made it into the tree
1111 * Escape /names 0 to mean /names --Maniac
1112 * Don't core when server asks for info --Maniac
1113 * Add Kev's jupe patch --Bleep
1114 * Add Maniacs squit patch --Bleep
1115 * Merge in u2_10_10_beta07 changes --Bleep
1116 * Merge in u2_10_10_beta06 changes --Bleep
1117 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1118 #-----------------------------------------------------------------------------
1120 # ChangeLog for ircu2.10.11
1122 # $Id: ChangeLog,v 1.132 2000-05-04 17:28:29 kev Exp $
1124 # Insert new changes at beginning of the change list.