1 2000-05-01 Perry Lorier <isomer@coders.net>
2 * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
4 2000-04-30 Perry Lorier <isomer@coders.net>
5 * config/config-sh.in: Fix for CONNEXIT
6 * ircd/s_{user,misc}.c: Fix for CONNEXIT
7 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
8 (Kev: Want to come talk to me about this?)
10 2000-04-30 Steven M. Doyle <steven@doyle.net>
12 - general cleanups and readability enhancements
13 - rewrite of setuid/chroot code.
14 - server will no longer run as root
15 - -DPROFIL compile option removed
16 - Fixed IPcheck API calls
19 - Fixed up chroot compile options
20 - Added options for debug and profile compiles
22 * config/gen.ircd.Makefile
23 - Support for new debug/profile options
26 - Support for new debug/profile options
32 - Removed old API prototypes, added new ones
35 - Readability cleanups (well, I -think-...)
36 - Changed IPRegistryEntry.last_connect to a time_t. The previously
37 used unsigned short was probably causing interesting things after
38 a client had been connected longer than about 65,535 seconds...
39 - Removed old API functions.
42 - Removed IPcheck.h include
44 * Additionally modified IPcheck API calls in:
54 2000-04-30 Perry Lorier <isomer@coders.net>
55 * ircd/s_bsd.c: Sigh. :)
56 * ircd/m_mode.c: fix for modeless channels by poptix.
58 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
60 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
62 * ircd/channel.c (clean_channelname): make clean_channelname also
63 truncate long channel names
65 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
67 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
69 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
72 * include/channel.h: definitions and declarations for the struct
75 2000-04-29 Perry Lorier <isomer@coders.net>
76 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
78 2000-04-29 Perry Lorier <isomer@coders.net>
79 * ircd/s_bsd.c: Add debugging code to IPcheck
81 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
83 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
85 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
88 * ircd/m_userhost.c (m_userhost): add a dead code comment
90 * ircd/m_desynch.c: forgot one...
92 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
94 * ircd/m_proto.c (proto_send_supported): just change a comment so
95 it doesn't show up in my scans
97 * ircd/ircd_reply.c (send_reply): fix a slight bug...
99 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
102 * ircd/parse.c (parse_server): argument wrangling to make
103 processing in do_numeric a little easier to deal with
105 * ircd/s_serv.c (server_estab): SERVER should come from
106 acptr->serv->up, not &me
108 * ircd/m_lusers.c: accidentally left out sptr for a %C
110 * ircd/send.c: hack to support doing wallchops...
112 * ircd/m_whowas.c: convert to new send functions
114 * ircd/m_whois.c: convert to new send functions
116 * ircd/m_who.c: convert to new send functions
118 * ircd/m_wallops.c: convert to new send functions
120 * ircd/m_wallchops.c: convert to new send functions
122 * ircd/m_version.c: convert to new send functions
124 * ircd/m_userip.c: convert to new send functions
126 * ircd/m_userhost.c: convert to new send functions
128 * ircd/m_uping.c: convert to new send functions
130 * ircd/m_trace.c: convert to new send functions
132 * ircd/m_topic.c: convert to new send functions
134 * ircd/m_time.c: convert to new send functions
136 * ircd/m_squit.c: convert to new send functions
138 * ircd/m_silence.c: convert to new send functions
140 * ircd/m_settime.c: convert to new send functions
142 * ircd/m_restart.c: convert to new send functions
144 * ircd/m_rehash.c: convert to new send functions
146 * ircd/m_privmsg.c: convert to new send functions
148 * ircd/m_pong.c: convert to new send functions
150 * ircd/m_ping.c: convert to new send functions
152 * ircd/m_pass.c: convert to new send functions
154 * ircd/m_opmode.c: convert to new send functions
156 * ircd/m_oper.c: convert to new send functions
158 * ircd/m_notice.c: convert to new send functions
160 * ircd/m_nick.c: convert to new send functions
162 * ircd/m_names.c: convert to new send functions
164 * ircd/m_motd.c: convert to new send functions
166 * ircd/m_mode.c: convert to new send functions
168 * ircd/m_map.c: convert to new send functions
170 * ircd/m_lusers.c: convert to new send functions
172 * ircd/m_list.c: convert to new send functions
174 * ircd/m_links.c: convert to new send functions
176 * ircd/m_kill.c: convert to new send functions
178 * ircd/m_jupe.c: convert to new send functions
180 * ircd/m_invite.c: convert to new send functions
182 * ircd/m_info.c: convert to new send functions
184 * ircd/m_help.c: convert to new send functions
186 * ircd/m_gline.c: convert to new send functions
188 * ircd/m_error.c: convert to new send functions
190 * ircd/m_endburst.c: convert to new send functions
192 * ircd/m_die.c: convert to new send functions
194 * ircd/m_destruct.c: convert to new send functions
196 * ircd/m_defaults.c: convert to new send functions
198 * ircd/m_connect.c: convert to new send functions
200 2000-04-28 Perry Lorier <isomer@coders.net>
201 * RELEASE.NOTES: Describe a few more undocumented features.
202 * config/config-sh.in: change the default paths for logging
203 and the recommended number of channels.
204 * include/supported.h: Rearrange slightly, added CHANTYPE's
206 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
208 * ircd/m_close.c: convert to send_reply
210 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
212 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
214 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
216 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
217 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
218 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
219 carefully rethought...
221 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
223 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
225 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
226 numeric nick; therefore, we have to use the server name
228 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
230 * ircd/send.c: fix minor bugs
232 * ircd/s_user.c (check_target_limit): mark dead code so I filter
235 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
238 * ircd/parse.c: mark dead code so I filter it when I grep
240 * ircd/map.c: mark dead code so I filter it when I grep
242 * ircd/ircd.c: mark dead code so I filter it when I grep
244 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
247 * ircd/channel.c: mark dead code so I filter it when I grep
249 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
250 hope I'm not stepping on toes...
252 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
253 conversions; use ircd_snprintf in a couple of cases to negate the
254 possibility of buffer overflow
256 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
258 * ircd/channel.c: convert as much as possible to new send
261 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
262 test member->user->from->fd, not from->fd
264 * ircd/gline.c (gline_add): go ahead and add badchans; we just
265 won't look for them in m_gline; this way, they always work...
267 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
269 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
270 ircd_vsnprintf conversion specifiers
272 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
273 I have my conversion specifiers
275 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
277 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
280 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
281 little less brain-dead
283 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
285 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
288 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
291 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
294 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
296 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
298 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
301 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
303 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
304 a numeric as needing to use an explicit pattern, which will be the
305 first argument in the variable argument list
307 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
308 non-prefixed nospoof PING
310 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
311 non-prefixed SERVER login
313 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
314 a numeric usage further up)
316 * include/send.h: declare sendrawto_one
318 * ircd/send.c (sendrawto_one): new function to use ONLY for
319 non-prefixed commands, like PING to client, or PASS/SERVER on
322 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
324 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
325 future expansion (channel numerics?)
327 * include/ircd_snprintf.h: added documentation to # to explain use
328 with %C; added documentation for : to explain use with %C; added
329 documentation for %H for channels
331 * ircd/whocmds.c: use send_reply
333 * ircd/userload.c: use sendcmdto_one
335 * ircd/uping.c: use sendcmdto_one
337 * ircd/send.c: use new flags to %C format string; ':' prefixes
338 client name with a colon for local connects, '#' uses
339 nick!user@host form for local connects
341 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
342 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
344 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
346 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
349 * ircd/s_auth.c: use sendto_opmask_butone
351 * ircd/res.c: use sendcmdto_one
353 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
356 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
358 * ircd/support.c: dumpcore is no longer used, so get rid of it
360 * ircd/parse.c: use send_reply, sendcmdto_one
362 * ircd/map.c: use send_reply
364 * ircd/listener.c: use send_reply
366 * ircd/jupe.c: use sendto_opmask_butone, send_reply
368 * ircd/ircd_reply.c: use send_reply
370 * ircd/ircd.c: use sendto_opmask_butone
372 * ircd/gline.c: use sendto_opmask_butone, send_reply
374 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
375 registered clients; make FLAG_ALT print nick!user@host; make
376 FLAG_COLON print :blah
378 * ircd/class.c (report_classes): use send_reply instead of
381 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
383 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
384 sendto_one with sendcmdto_one
386 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
388 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
389 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
390 sendcmdto_match_butone
392 * include/send.h: declare sendcmdto_match_butone
394 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
396 * ircd/jupe.c: update to use send_reply()
398 * ircd/gline.c: update to use send_reply()
400 * include/ircd_reply.h: declare send_reply
402 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
403 replies; uses ircd_snprintf
405 * ircd/send.c: added comments to redirect searchers to appropriate
406 sendcmdto_* function; moved new functions to end of file; added
407 explanatory comments; reordered arguments; defined new functions
410 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
412 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
414 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
416 * ircd/gline.c: reorder arguments to sendcmdto_* functions
418 * include/send.h: reorder arguments, add explanatory comments,
419 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
420 and vsendto_opmask_butone
422 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
424 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
425 vsendto_op_mask that uses '*' instead of the receiving client
428 * include/send.h: declare sendcmdto_channel_butone; takes a skip
429 argument that allows you to skip (or not to skip) deaf users,
430 users behind bursting servers, and non channel operators
432 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
434 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
435 sendto_channel_butserv has a subtle bug; also wrote
436 sendcmdto_common_channels.
438 * include/send.h: declare new sendcmdto_* functions
440 * ircd/jupe.c: support local deactivations of jupes
442 * ircd/gline.c: support local deactivations of glines
444 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
445 deactivated; if they aren't locally deactivated, then it slaves to
446 the net-wide activation status; JupeIsRemActive() tests only
447 whether the jupe is active everywhere else
449 * include/gline.h: GLINE_LDEACT allows glines to be locally
450 deactivated; if they aren't locally deactivated, then it slaves to
451 the net-wide activation status; GlineIsRemActive() tests only
452 whether the gline is active everywhere else
454 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
455 gline expires after the new one will, we drop the new one,
456 otherwise we add the G-line after that one (so the wide one will
457 apply first); if the new one contains an existing G-line and if it
458 will expire after the existing one, we drop the existing one to
461 * ircd/m_gline.c (mo_gline): opers could issue remote local
462 glines when CONFIG_OPERCMDS was off; fixed
464 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
466 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
469 * ircd/gline.c: add flags argument to gline_activate and
470 gline_deactivate for future expansion
472 * ircd/m_gline.c: pass flags to gline_activate and
475 * include/gline.h: add flags argument to gline_activate and
478 * ircd/jupe.c: add flags argument to jupe_activate and
479 jupe_deactivate for future expansion
481 * include/jupe.h: add flags argument to jupe_activate and
484 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
485 local, active; pass flags to jupe_activate and jupe_deactivate
487 * include/gline.h: remove dead code
489 * ircd/gline.c: make gline expire times relative to CurrentTime,
490 since that should be monotonically increasing, instead of
491 TStime(), which can be set backwards, and which can therefore
492 cause an expire time to increase; make local glines be removed
493 instead of just deactivated; don't let gline_find() look for
494 user@host glines if the mask being looked up is a channel mask
496 * ircd/send.c (vsendcmdto_one): forgot to account for the case
497 where origin is a server and destination is a user
499 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
500 since that should be monotonically increasing, instead of
501 TStime(), which can be set backwards, and which can therefore
502 cause an expire time to increase; make local jupes be removed
503 instead of just deactivated
505 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
506 limit is fine. any other warnings I should know about?
508 2000-04-15 Thomas Helvey <tomh@inxpress.net>
510 * ircd/*.c: const correctness and type safety cleanups to
511 get code to compile with C++ compiler. Still has
512 signed/unsigned comparison warnings.
514 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
516 * ircd/userload.c: change <sys/time.h> include to <time.h> for
519 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
521 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
524 * ircd/s_user.c: move gline_lookup function call into
525 register_user, where it'll have a username to lookup!
527 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
528 functions; also stuff send_error_to_client into return clauses
530 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
531 functions; also use send_error_to_client where that makes sense
533 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
534 functions; also use send_error_to_client where that makes sense
536 * ircd/gline.c: modify to utilize new sendcmdto_* series of
537 functions; also fix gline_lookup() to deal properly with remote
538 clients--boy, do struct Client and struct User need to be cleaned
541 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
544 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
545 sendcmdto_serv_butone(), all utilizing the %v conversion of
548 * include/send.h: define IRC_BUFSIZE, max size of a message;
549 declare sendcmdto_one(), vsendcmdto_one(), and
550 sendcmdto_serv_butone()
552 * include/msg.h: define all the CMD_* constants needed to utilize
553 the new sendcmdto_* series of functions
555 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
557 * ircd/gline.c: remove old, dead code.
559 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
560 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
561 (don't advertise proxies); remove dead code
563 * ircd/parse.c: oper handler for JUPE only lists jupes unless
564 CONFIG_OPERCMDS is enabled
566 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
567 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
569 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
570 always return ERR_DISABLED
572 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
573 enabled, always return ERR_DISABLED
575 * ircd/s_err.c: add error message to indicate disabled commands
577 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
579 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
581 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
582 CONFIG_NEW_MODE to 'y' for now
584 * ircd/gline.c (gline_list): fix a minor formatting bogon
586 * BUGS: since I fixed that bug, might as well mark it fixed.
588 * ircd/m_join.c: look up badchans with GLINE_EXACT
590 * ircd/m_gline.c: fix parc count problems; look up existing
591 G-lines with GLINE_EXACT; only set new lastmod when
592 activating/deactivating existing glines if old lastmod was not 0
594 * ircd/gline.c: forgot to copy the gline reason over; don't
595 propagate a gline with 0 lastmod if origin is user; add
596 GLINE_EXACT to force exact matching of gline mask
598 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
601 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
602 but gline_lookup() actually takes a client--d'oh.
604 2000-04-13 Thomas Helvey <tomh@inxpress.net>
605 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
607 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
609 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
611 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
614 * ircd/whocmds.c: Change idle time calc from socket idle to user
617 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
619 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
620 too, for ircd_snprintf.c
622 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
623 comments; mostly descended from the Linux manpage for printf, but
624 also documenting the extensions.
626 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
627 client; make 'q' be the same as 'L'; remove __inline__; only
628 define EXTENSION if HAVE_LONG_LONG is defined
630 * include/handlers.h: declare m_gline()
632 * ircd/parse.c: gline can be called by users, but it only lists
635 * ircd/s_user.c (set_nick_name): resend gline if a remote server
636 introduces a glined client
638 * ircd/s_serv.c (server_estab): burst glines, too
640 * ircd/gline.c: fix up all the expire times to be offsets;
641 simplify gline_resend()
643 * ircd/m_gline.c: begin coding replacements for ms_gline(),
644 mo_gline(), and m_gline()
646 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
647 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
649 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
651 * tools/Bouncer/*: Add comments/documentation/tags.
652 * tools/Bouncer/*: Add debug defines, make task fork().
654 2000-04-12 Thomas Helvey <tomh@inxpress.net>
655 * ircd/s_err.c: Cleanup s_err.c make one table so we
656 don't have to do anything tricky to get an error string.
658 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
659 * Add port bouncer for http (x/w)
661 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
663 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
664 call to gline_find(); also used GlineReason() instead of direct
665 reference to structure member
667 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
668 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
671 * ircd/channel.c: nothing seems to be called anywhere...
673 * ircd/s_err.c: update a couple of replies to dovetail with new
676 * ircd/gline.c: begin complete re-implementation of gline.c along
677 the lines of the final design of jupe.c
679 * include/gline.h: begin complete re-implementation of gline.c
680 along the lines of the final design of jupe.c
682 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
685 * ircd/ircd_snprintf.c: my new snprintf()-like functions
687 * include/ircd_snprintf.h: my new snprintf()-like functions
689 2000-04-11 Thomas Helvey <tomh@inxpress.net>
690 * ircd/IPcheck.c: removed old dead code
691 * ircd/s_user.c (send_user_info): removed non-standard
692 user not found message for userhost/userip
694 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
696 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
697 * doc/p10.html: Work on chapter 4.
699 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
701 * ircd/channel.c (mode_parse_client): fix coredump on /mode
702 #foobar +o nosuchnick
704 2000-04-10 Perry Lorier <Isomer@coders.net>
707 2000-04-09 Thomas Helvey <tomh@inxpress.net>
708 * include/IPcheck.h: fix prototype
709 * ircd/s_user.c: fix usage of IPcheck_remote_connect
710 * ircd/IPcheck.c: removed unused args
712 2000-04-09 Thomas Helvey <tomh@inxpress.net>
713 * include/IPcheck.h: add proto for IPcheck_expire
715 * ircd/IPcheck.c: Rewrote
717 * ircd/ircd.c: Add IPcheck_expire to main message loop
719 * ircd/s_user.c: Redo target hashing, refactor target code
721 * include/numeric.h: Cleaned up numerics, added which ones are
722 in use by other networks and what they are in use for.
724 * ircd/channel.c: cleaned can_join(), allow anyone through anything
725 if /invited, simplified the function. Opers overusing OPEROVERRIDE
726 will get a message explaining to them not to cheat.
728 * ircd/m_join.c: cleaned up the various join functions, should be
729 a lot more efficient. Still needs work. Now assumes that s<->s
730 won't send it a JOIN 0. Service coders - note this and tread with
733 * ircd/m_stats.c: added Gte-'s stats doc patch.
735 * ircd/m_version.c: /version now returns the 005 numeric as well.
736 as requested by Liandrin.
739 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
741 * ircd/m_clearmode.c: add include for support.h for write_log()
743 * configure: move ircd/crypt/* to tools/*
745 2000-04-06 Thomas Helvey <tomh@inxpress.net>
746 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
747 set client host to server alias if connection from localhost
749 2000-04-06 Perry Lorier <isomer@coders.net>
750 * ircd/ircd.c: Fix core during pinging (oops)
752 2000-04-06 Perry Lorier <isomer@coders.net>
753 * ircd/send.c: fixed wrong ident being sent to channels bug.
754 * include/numerics.h: Updated some of the numerics from other
755 networks. Flagged some as 'unused' by undernet.
757 2000-03-30 Perry Lorier <isomer@coders.net>
758 * ircd/ircd.c: Lets see if this helps the ping problem at all.
759 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
760 time for local clients. (as requested), extended who now returns all
761 the flags (@+!) so you can tell the complete state of a client.
763 2000-03-30 Thomas Helvey <tomh@inxpress.net>
764 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
766 2000-03-30 Perry Lorier <isomer@coders.net>
767 * ircd/parse.c: oops, missed opers.
769 2000-03-30 Perry Lorier <isomer@coders.net>
770 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
771 for so long. Remember: m_ping MUST be in the parse array. :)
773 2000-03-30 Perry Lorier <isomer@coders.net>
774 * ircd/ircd.c: test in check_pings was wrong. I move that we
775 disallow cvs commit after 10pm localtime....
777 2000-03-30 Perry Lorier <isomer@coders.net>
778 * ircd/m_pong.c: Fix it for servers too.
780 2000-03-30 Perry Lorier <isomer@coders.net>
781 * ircd/m_pong.c: Fix ping timeout bugs
783 2000-03-30 Perry Lorier <isomer@coders.net>
784 * ircd/channel.c: Bans had CurrentTime in their when field instead
787 2000-03-31 Thomas Helvey <tomh@ixpress.net>
788 * ircd/numnicks.c (SetXYYCapacity): fix for extended
791 2000-03-30 Perry Lorier <isomer@coders.net>
792 * ircd/m_nick.c: send kills both ways so when we add nick change
793 on collision we don't desync the network.
795 * ircd/map.c: Fixup the map a bit more.
797 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
799 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
801 * ircd/m_opmode.c: Log the mode changes to OPATH
803 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
806 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
809 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
811 * config/config-sh.in: added OPATH for opmode log file
813 * ircd/m_clearmode.c (do_clearmode): updated uses of
814 modebuf_mode_string() for the new usage
816 * ircd/channel.c: added flag MODE_FREE and an int argument to
817 modebuf_mode_string() to indicate that the string must be free'd;
818 updated calls to modebuf_mode_string() for the new usage; called
819 collapse(pretty_mask()) on the ban string and use allocated memory
820 for it; added ban list length accounting; fixed a number of small
821 bugs in ban processing
823 * include/channel.h: added flag MODE_FREE and an int argument to
824 modebuf_mode_string() to indicate that the string must be free'd
826 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
827 keys and limits that are set
829 2000-03-30 Perry Lorier <isomer@coders.net>
830 * ircd/ircd.c: rewrote check_pings() for maintainability
831 and speed. Also changed quit msg's so they don't have
832 redundant nick[host] info in them.
834 * ircd/send.c: Changed write errors to report what error
835 occured (if possible).
837 * ircd/gline.c: added gline comment to the quit.
839 * ircd/m_server.c: Added suggestions to server quits mentioning
840 what went wrong so the admin can fix it earlier instead of asking
843 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
844 servers that aren't fully burst yet. And show '(--s)' for servers
847 * doc/example.conf: Fixed wrapped U:
849 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
851 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
852 mode_parse() (version selectable at compile time)
854 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
856 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
858 * config/config-sh.in: add new config option to enable new m_mode
861 * doc/Configure.help: add documentation for new config option
864 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
865 MODE -v : Not enough parameters
867 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
868 +k and +l even if they weren't set...
870 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
872 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
873 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
874 for; test the 0-th member, not the i-th member, of the client
877 * ircd/m_clearmode.c (do_clearmode): use the new
878 mode_invite_clear() function
880 * ircd/channel.c: cleared up all the compile-time warnings and
883 * include/channel.h: added declarations for mode_ban_invalidate()
884 and mode_invite_clear()
886 * ircd/channel.c: finished mode_parse(), then broke it up into a
887 dozen or so helper functions to make the code easier to read
889 2000-03-29 Thomas Helvey <tomh@inxpress.net>
890 * ircd/ircd.c: refactor server initialization a bit, use
891 getopt for parsing command line, refactor init_sys, main,
894 * ircd/s_bsd.c: add functions for initialization to clean
895 up logic a bit and remove duplicated code.
897 * include/ircd.h: add struct for server process related
900 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
902 * ircd/channel.c: initial definition of mode_parse(); flags to
903 prevent doing the same thing multiple times; helper method
904 send_notoper() to send a "Not oper"/"Not on channel" notice
906 * include/channel.h: declare mode_parse() and helper flags
908 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
909 sending to match the current action of set_mode() closely enough
910 that hopefully there won't be major conflicts
912 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
913 building logic, reversed the order of the arguments to mode
914 commands to have '-' preceed '+'
916 2000-03-29 Thomas Helvey <tomh@inxpress.net>
917 * ircd/s_bsd.c (add_connection): don't disable socket options
918 let OS tune itself and allow important performance tweaks to
921 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
923 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
924 confused by set_mode, which is doing some really weird logic;
925 guess what I'm going to rewrite next? ;)
927 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
929 * include/channel.h: added MODE_SAVE for the bounds checking stuff
932 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
933 make it do bounds checking on the buffer; all modes are sent only
934 if the all parameter is 1; modebuf_flush is the exported wrapper
936 * include/channel.h: add BOUNCE, renumber flags to get a little
939 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
940 BOUNCE; send DESYNCH message
942 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
944 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
945 channel actually has in effect for deletion
947 * ircd/channel.c: added explanatory comments to all added
948 functions; made flushing take place at the correct place even if
949 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
950 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
951 is empty, fixed the apparent source, removed some bogus string
952 termination code, properly terminate the mode strings, add support
953 for HACK2 and HACK3, made limit strings not be sent if the limit
954 is being removed, changed where '+' and '-' come from in sent
955 strings, added support for DEOP flag, set up bouncing code for
958 * ircd/Makefile.in: ran make depend
960 * include/channel.h: added new defines for future functionality,
961 made modebuf_flush() return int so I can use tail recursion
963 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
964 to make it all compile
966 * ircd/m_opmode.c: add msg.h to includes...
968 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
970 * ircd/channel.c (modebuf_flush): realized I forgot to
971 nul-terminate addbuf/rembuf properly...
973 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
975 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
976 sendto_serv_butone--blah^2
978 * ircd/send.c (sendto_serv_butone): stupid comments confused me
980 * ircd/channel.c (modebuf_flush): if there are no mode changes to
981 propagate, we're done...
983 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
984 not sendto_all_butone
986 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
988 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
990 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
993 * ircd/parse.c: added messages for opmode and clearmode
995 * include/handlers.h: added declarations for mo_opmode(),
996 ms_opmode(), mo_clearmode(), and ms_clearmode()
998 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
1001 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
1002 MODEBUF_DEST_OPMODE flag
1004 * ircd/channel.c (modebuf_flush): added new flag,
1005 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1006 to originate from source's server (or source itself, if
1007 IsServer(source)); also causes a server-level MODE to be sent as
1010 * include/channel.h: defined MODEBUF_DEST_SERVER,
1013 * ircd/channel.c: Add another argument to build_string() to handle
1014 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1015 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1018 2000-03-27 Perry Lorier <isomer@coders.net>
1020 * ircd/s_bsd.c: fixed missing 'u' typo.
1022 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
1024 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1025 _mode_string(), _mode_client(), _flush(); also implemented a
1026 simple build_string()
1028 * include/channel.h: added definition of ModeBuf, modebuf_*
1029 manipulation functions, and a couple of helper macros
1031 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1032 * numicks.c: convert extended numerics to use original mask version
1035 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1036 * Merge in changes from production
1037 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1038 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1039 * rfc1459.unet: Add Maniac's documentation for /names 0
1040 * Fix misc. jupe bugs that somehow made it into the tree
1041 * Escape /names 0 to mean /names --Maniac
1042 * Don't core when server asks for info --Maniac
1043 * Add Kev's jupe patch --Bleep
1044 * Add Maniacs squit patch --Bleep
1045 * Merge in u2_10_10_beta07 changes --Bleep
1046 * Merge in u2_10_10_beta06 changes --Bleep
1047 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1048 #-----------------------------------------------------------------------------
1050 # ChangeLog for ircu2.10.11
1052 # $Id: ChangeLog,v 1.122 2000-04-30 12:41:49 isomer Exp $
1054 # Insert new changes at beginning of the change list.