1 2000-05-01 Kevin L. Mitchell <klmitch@mit.edu>
3 * ircd/m_stats.c: convert to sendcmdto_one / send_reply
5 * ircd/m_kick.c: Completely reimplement m_kick
7 * ircd/channel.c: send_user_joins removed; it was dead code,
10 2000-05-01 Perry Lorier <isomer@coders.net>
11 * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
12 * ircd/channels.c: My fix for the part problem. Untested, probably
13 won't work. Can't be much worse than the current problem.
14 it'll either work or core, take your pick.
17 2000-04-30 Perry Lorier <isomer@coders.net>
18 * config/config-sh.in: Fix for CONNEXIT
19 * ircd/s_{user,misc}.c: Fix for CONNEXIT
20 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
21 (Kev: Want to come talk to me about this?)
23 2000-04-30 Steven M. Doyle <steven@doyle.net>
25 - general cleanups and readability enhancements
26 - rewrite of setuid/chroot code.
27 - server will no longer run as root
28 - -DPROFIL compile option removed
29 - Fixed IPcheck API calls
32 - Fixed up chroot compile options
33 - Added options for debug and profile compiles
35 * config/gen.ircd.Makefile
36 - Support for new debug/profile options
39 - Support for new debug/profile options
45 - Removed old API prototypes, added new ones
48 - Readability cleanups (well, I -think-...)
49 - Changed IPRegistryEntry.last_connect to a time_t. The previously
50 used unsigned short was probably causing interesting things after
51 a client had been connected longer than about 65,535 seconds...
52 - Removed old API functions.
55 - Removed IPcheck.h include
57 * Additionally modified IPcheck API calls in:
67 2000-04-30 Perry Lorier <isomer@coders.net>
68 * ircd/s_bsd.c: Sigh. :)
69 * ircd/m_mode.c: fix for modeless channels by poptix.
71 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
73 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
75 * ircd/channel.c (clean_channelname): make clean_channelname also
76 truncate long channel names
78 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
80 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
82 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
85 * include/channel.h: definitions and declarations for the struct
88 2000-04-29 Perry Lorier <isomer@coders.net>
89 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
91 2000-04-29 Perry Lorier <isomer@coders.net>
92 * ircd/s_bsd.c: Add debugging code to IPcheck
94 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
96 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
98 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
101 * ircd/m_userhost.c (m_userhost): add a dead code comment
103 * ircd/m_desynch.c: forgot one...
105 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
107 * ircd/m_proto.c (proto_send_supported): just change a comment so
108 it doesn't show up in my scans
110 * ircd/ircd_reply.c (send_reply): fix a slight bug...
112 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
115 * ircd/parse.c (parse_server): argument wrangling to make
116 processing in do_numeric a little easier to deal with
118 * ircd/s_serv.c (server_estab): SERVER should come from
119 acptr->serv->up, not &me
121 * ircd/m_lusers.c: accidentally left out sptr for a %C
123 * ircd/send.c: hack to support doing wallchops...
125 * ircd/m_whowas.c: convert to new send functions
127 * ircd/m_whois.c: convert to new send functions
129 * ircd/m_who.c: convert to new send functions
131 * ircd/m_wallops.c: convert to new send functions
133 * ircd/m_wallchops.c: convert to new send functions
135 * ircd/m_version.c: convert to new send functions
137 * ircd/m_userip.c: convert to new send functions
139 * ircd/m_userhost.c: convert to new send functions
141 * ircd/m_uping.c: convert to new send functions
143 * ircd/m_trace.c: convert to new send functions
145 * ircd/m_topic.c: convert to new send functions
147 * ircd/m_time.c: convert to new send functions
149 * ircd/m_squit.c: convert to new send functions
151 * ircd/m_silence.c: convert to new send functions
153 * ircd/m_settime.c: convert to new send functions
155 * ircd/m_restart.c: convert to new send functions
157 * ircd/m_rehash.c: convert to new send functions
159 * ircd/m_privmsg.c: convert to new send functions
161 * ircd/m_pong.c: convert to new send functions
163 * ircd/m_ping.c: convert to new send functions
165 * ircd/m_pass.c: convert to new send functions
167 * ircd/m_opmode.c: convert to new send functions
169 * ircd/m_oper.c: convert to new send functions
171 * ircd/m_notice.c: convert to new send functions
173 * ircd/m_nick.c: convert to new send functions
175 * ircd/m_names.c: convert to new send functions
177 * ircd/m_motd.c: convert to new send functions
179 * ircd/m_mode.c: convert to new send functions
181 * ircd/m_map.c: convert to new send functions
183 * ircd/m_lusers.c: convert to new send functions
185 * ircd/m_list.c: convert to new send functions
187 * ircd/m_links.c: convert to new send functions
189 * ircd/m_kill.c: convert to new send functions
191 * ircd/m_jupe.c: convert to new send functions
193 * ircd/m_invite.c: convert to new send functions
195 * ircd/m_info.c: convert to new send functions
197 * ircd/m_help.c: convert to new send functions
199 * ircd/m_gline.c: convert to new send functions
201 * ircd/m_error.c: convert to new send functions
203 * ircd/m_endburst.c: convert to new send functions
205 * ircd/m_die.c: convert to new send functions
207 * ircd/m_destruct.c: convert to new send functions
209 * ircd/m_defaults.c: convert to new send functions
211 * ircd/m_connect.c: convert to new send functions
213 2000-04-28 Perry Lorier <isomer@coders.net>
214 * RELEASE.NOTES: Describe a few more undocumented features.
215 * config/config-sh.in: change the default paths for logging
216 and the recommended number of channels.
217 * include/supported.h: Rearrange slightly, added CHANTYPE's
219 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
221 * ircd/m_close.c: convert to send_reply
223 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
225 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
227 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
229 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
230 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
231 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
232 carefully rethought...
234 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
236 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
238 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
239 numeric nick; therefore, we have to use the server name
241 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
243 * ircd/send.c: fix minor bugs
245 * ircd/s_user.c (check_target_limit): mark dead code so I filter
248 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
251 * ircd/parse.c: mark dead code so I filter it when I grep
253 * ircd/map.c: mark dead code so I filter it when I grep
255 * ircd/ircd.c: mark dead code so I filter it when I grep
257 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
260 * ircd/channel.c: mark dead code so I filter it when I grep
262 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
263 hope I'm not stepping on toes...
265 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
266 conversions; use ircd_snprintf in a couple of cases to negate the
267 possibility of buffer overflow
269 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
271 * ircd/channel.c: convert as much as possible to new send
274 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
275 test member->user->from->fd, not from->fd
277 * ircd/gline.c (gline_add): go ahead and add badchans; we just
278 won't look for them in m_gline; this way, they always work...
280 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
282 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
283 ircd_vsnprintf conversion specifiers
285 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
286 I have my conversion specifiers
288 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
290 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
293 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
294 little less brain-dead
296 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
298 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
301 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
304 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
307 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
309 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
311 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
314 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
316 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
317 a numeric as needing to use an explicit pattern, which will be the
318 first argument in the variable argument list
320 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
321 non-prefixed nospoof PING
323 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
324 non-prefixed SERVER login
326 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
327 a numeric usage further up)
329 * include/send.h: declare sendrawto_one
331 * ircd/send.c (sendrawto_one): new function to use ONLY for
332 non-prefixed commands, like PING to client, or PASS/SERVER on
335 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
337 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
338 future expansion (channel numerics?)
340 * include/ircd_snprintf.h: added documentation to # to explain use
341 with %C; added documentation for : to explain use with %C; added
342 documentation for %H for channels
344 * ircd/whocmds.c: use send_reply
346 * ircd/userload.c: use sendcmdto_one
348 * ircd/uping.c: use sendcmdto_one
350 * ircd/send.c: use new flags to %C format string; ':' prefixes
351 client name with a colon for local connects, '#' uses
352 nick!user@host form for local connects
354 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
355 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
357 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
359 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
362 * ircd/s_auth.c: use sendto_opmask_butone
364 * ircd/res.c: use sendcmdto_one
366 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
369 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
371 * ircd/support.c: dumpcore is no longer used, so get rid of it
373 * ircd/parse.c: use send_reply, sendcmdto_one
375 * ircd/map.c: use send_reply
377 * ircd/listener.c: use send_reply
379 * ircd/jupe.c: use sendto_opmask_butone, send_reply
381 * ircd/ircd_reply.c: use send_reply
383 * ircd/ircd.c: use sendto_opmask_butone
385 * ircd/gline.c: use sendto_opmask_butone, send_reply
387 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
388 registered clients; make FLAG_ALT print nick!user@host; make
389 FLAG_COLON print :blah
391 * ircd/class.c (report_classes): use send_reply instead of
394 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
396 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
397 sendto_one with sendcmdto_one
399 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
401 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
402 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
403 sendcmdto_match_butone
405 * include/send.h: declare sendcmdto_match_butone
407 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
409 * ircd/jupe.c: update to use send_reply()
411 * ircd/gline.c: update to use send_reply()
413 * include/ircd_reply.h: declare send_reply
415 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
416 replies; uses ircd_snprintf
418 * ircd/send.c: added comments to redirect searchers to appropriate
419 sendcmdto_* function; moved new functions to end of file; added
420 explanatory comments; reordered arguments; defined new functions
423 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
425 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
427 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
429 * ircd/gline.c: reorder arguments to sendcmdto_* functions
431 * include/send.h: reorder arguments, add explanatory comments,
432 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
433 and vsendto_opmask_butone
435 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
437 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
438 vsendto_op_mask that uses '*' instead of the receiving client
441 * include/send.h: declare sendcmdto_channel_butone; takes a skip
442 argument that allows you to skip (or not to skip) deaf users,
443 users behind bursting servers, and non channel operators
445 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
447 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
448 sendto_channel_butserv has a subtle bug; also wrote
449 sendcmdto_common_channels.
451 * include/send.h: declare new sendcmdto_* functions
453 * ircd/jupe.c: support local deactivations of jupes
455 * ircd/gline.c: support local deactivations of glines
457 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
458 deactivated; if they aren't locally deactivated, then it slaves to
459 the net-wide activation status; JupeIsRemActive() tests only
460 whether the jupe is active everywhere else
462 * include/gline.h: GLINE_LDEACT allows glines to be locally
463 deactivated; if they aren't locally deactivated, then it slaves to
464 the net-wide activation status; GlineIsRemActive() tests only
465 whether the gline is active everywhere else
467 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
468 gline expires after the new one will, we drop the new one,
469 otherwise we add the G-line after that one (so the wide one will
470 apply first); if the new one contains an existing G-line and if it
471 will expire after the existing one, we drop the existing one to
474 * ircd/m_gline.c (mo_gline): opers could issue remote local
475 glines when CONFIG_OPERCMDS was off; fixed
477 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
479 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
482 * ircd/gline.c: add flags argument to gline_activate and
483 gline_deactivate for future expansion
485 * ircd/m_gline.c: pass flags to gline_activate and
488 * include/gline.h: add flags argument to gline_activate and
491 * ircd/jupe.c: add flags argument to jupe_activate and
492 jupe_deactivate for future expansion
494 * include/jupe.h: add flags argument to jupe_activate and
497 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
498 local, active; pass flags to jupe_activate and jupe_deactivate
500 * include/gline.h: remove dead code
502 * ircd/gline.c: make gline expire times relative to CurrentTime,
503 since that should be monotonically increasing, instead of
504 TStime(), which can be set backwards, and which can therefore
505 cause an expire time to increase; make local glines be removed
506 instead of just deactivated; don't let gline_find() look for
507 user@host glines if the mask being looked up is a channel mask
509 * ircd/send.c (vsendcmdto_one): forgot to account for the case
510 where origin is a server and destination is a user
512 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
513 since that should be monotonically increasing, instead of
514 TStime(), which can be set backwards, and which can therefore
515 cause an expire time to increase; make local jupes be removed
516 instead of just deactivated
518 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
519 limit is fine. any other warnings I should know about?
521 2000-04-15 Thomas Helvey <tomh@inxpress.net>
523 * ircd/*.c: const correctness and type safety cleanups to
524 get code to compile with C++ compiler. Still has
525 signed/unsigned comparison warnings.
527 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
529 * ircd/userload.c: change <sys/time.h> include to <time.h> for
532 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
534 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
537 * ircd/s_user.c: move gline_lookup function call into
538 register_user, where it'll have a username to lookup!
540 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
541 functions; also stuff send_error_to_client into return clauses
543 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
544 functions; also use send_error_to_client where that makes sense
546 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
547 functions; also use send_error_to_client where that makes sense
549 * ircd/gline.c: modify to utilize new sendcmdto_* series of
550 functions; also fix gline_lookup() to deal properly with remote
551 clients--boy, do struct Client and struct User need to be cleaned
554 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
557 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
558 sendcmdto_serv_butone(), all utilizing the %v conversion of
561 * include/send.h: define IRC_BUFSIZE, max size of a message;
562 declare sendcmdto_one(), vsendcmdto_one(), and
563 sendcmdto_serv_butone()
565 * include/msg.h: define all the CMD_* constants needed to utilize
566 the new sendcmdto_* series of functions
568 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
570 * ircd/gline.c: remove old, dead code.
572 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
573 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
574 (don't advertise proxies); remove dead code
576 * ircd/parse.c: oper handler for JUPE only lists jupes unless
577 CONFIG_OPERCMDS is enabled
579 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
580 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
582 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
583 always return ERR_DISABLED
585 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
586 enabled, always return ERR_DISABLED
588 * ircd/s_err.c: add error message to indicate disabled commands
590 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
592 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
594 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
595 CONFIG_NEW_MODE to 'y' for now
597 * ircd/gline.c (gline_list): fix a minor formatting bogon
599 * BUGS: since I fixed that bug, might as well mark it fixed.
601 * ircd/m_join.c: look up badchans with GLINE_EXACT
603 * ircd/m_gline.c: fix parc count problems; look up existing
604 G-lines with GLINE_EXACT; only set new lastmod when
605 activating/deactivating existing glines if old lastmod was not 0
607 * ircd/gline.c: forgot to copy the gline reason over; don't
608 propagate a gline with 0 lastmod if origin is user; add
609 GLINE_EXACT to force exact matching of gline mask
611 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
614 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
615 but gline_lookup() actually takes a client--d'oh.
617 2000-04-13 Thomas Helvey <tomh@inxpress.net>
618 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
620 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
622 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
624 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
627 * ircd/whocmds.c: Change idle time calc from socket idle to user
630 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
632 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
633 too, for ircd_snprintf.c
635 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
636 comments; mostly descended from the Linux manpage for printf, but
637 also documenting the extensions.
639 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
640 client; make 'q' be the same as 'L'; remove __inline__; only
641 define EXTENSION if HAVE_LONG_LONG is defined
643 * include/handlers.h: declare m_gline()
645 * ircd/parse.c: gline can be called by users, but it only lists
648 * ircd/s_user.c (set_nick_name): resend gline if a remote server
649 introduces a glined client
651 * ircd/s_serv.c (server_estab): burst glines, too
653 * ircd/gline.c: fix up all the expire times to be offsets;
654 simplify gline_resend()
656 * ircd/m_gline.c: begin coding replacements for ms_gline(),
657 mo_gline(), and m_gline()
659 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
660 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
662 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
664 * tools/Bouncer/*: Add comments/documentation/tags.
665 * tools/Bouncer/*: Add debug defines, make task fork().
667 2000-04-12 Thomas Helvey <tomh@inxpress.net>
668 * ircd/s_err.c: Cleanup s_err.c make one table so we
669 don't have to do anything tricky to get an error string.
671 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
672 * Add port bouncer for http (x/w)
674 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
676 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
677 call to gline_find(); also used GlineReason() instead of direct
678 reference to structure member
680 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
681 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
684 * ircd/channel.c: nothing seems to be called anywhere...
686 * ircd/s_err.c: update a couple of replies to dovetail with new
689 * ircd/gline.c: begin complete re-implementation of gline.c along
690 the lines of the final design of jupe.c
692 * include/gline.h: begin complete re-implementation of gline.c
693 along the lines of the final design of jupe.c
695 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
698 * ircd/ircd_snprintf.c: my new snprintf()-like functions
700 * include/ircd_snprintf.h: my new snprintf()-like functions
702 2000-04-11 Thomas Helvey <tomh@inxpress.net>
703 * ircd/IPcheck.c: removed old dead code
704 * ircd/s_user.c (send_user_info): removed non-standard
705 user not found message for userhost/userip
707 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
709 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
710 * doc/p10.html: Work on chapter 4.
712 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
714 * ircd/channel.c (mode_parse_client): fix coredump on /mode
715 #foobar +o nosuchnick
717 2000-04-10 Perry Lorier <Isomer@coders.net>
720 2000-04-09 Thomas Helvey <tomh@inxpress.net>
721 * include/IPcheck.h: fix prototype
722 * ircd/s_user.c: fix usage of IPcheck_remote_connect
723 * ircd/IPcheck.c: removed unused args
725 2000-04-09 Thomas Helvey <tomh@inxpress.net>
726 * include/IPcheck.h: add proto for IPcheck_expire
728 * ircd/IPcheck.c: Rewrote
730 * ircd/ircd.c: Add IPcheck_expire to main message loop
732 * ircd/s_user.c: Redo target hashing, refactor target code
734 * include/numeric.h: Cleaned up numerics, added which ones are
735 in use by other networks and what they are in use for.
737 * ircd/channel.c: cleaned can_join(), allow anyone through anything
738 if /invited, simplified the function. Opers overusing OPEROVERRIDE
739 will get a message explaining to them not to cheat.
741 * ircd/m_join.c: cleaned up the various join functions, should be
742 a lot more efficient. Still needs work. Now assumes that s<->s
743 won't send it a JOIN 0. Service coders - note this and tread with
746 * ircd/m_stats.c: added Gte-'s stats doc patch.
748 * ircd/m_version.c: /version now returns the 005 numeric as well.
749 as requested by Liandrin.
752 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
754 * ircd/m_clearmode.c: add include for support.h for write_log()
756 * configure: move ircd/crypt/* to tools/*
758 2000-04-06 Thomas Helvey <tomh@inxpress.net>
759 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
760 set client host to server alias if connection from localhost
762 2000-04-06 Perry Lorier <isomer@coders.net>
763 * ircd/ircd.c: Fix core during pinging (oops)
765 2000-04-06 Perry Lorier <isomer@coders.net>
766 * ircd/send.c: fixed wrong ident being sent to channels bug.
767 * include/numerics.h: Updated some of the numerics from other
768 networks. Flagged some as 'unused' by undernet.
770 2000-03-30 Perry Lorier <isomer@coders.net>
771 * ircd/ircd.c: Lets see if this helps the ping problem at all.
772 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
773 time for local clients. (as requested), extended who now returns all
774 the flags (@+!) so you can tell the complete state of a client.
776 2000-03-30 Thomas Helvey <tomh@inxpress.net>
777 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
779 2000-03-30 Perry Lorier <isomer@coders.net>
780 * ircd/parse.c: oops, missed opers.
782 2000-03-30 Perry Lorier <isomer@coders.net>
783 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
784 for so long. Remember: m_ping MUST be in the parse array. :)
786 2000-03-30 Perry Lorier <isomer@coders.net>
787 * ircd/ircd.c: test in check_pings was wrong. I move that we
788 disallow cvs commit after 10pm localtime....
790 2000-03-30 Perry Lorier <isomer@coders.net>
791 * ircd/m_pong.c: Fix it for servers too.
793 2000-03-30 Perry Lorier <isomer@coders.net>
794 * ircd/m_pong.c: Fix ping timeout bugs
796 2000-03-30 Perry Lorier <isomer@coders.net>
797 * ircd/channel.c: Bans had CurrentTime in their when field instead
800 2000-03-31 Thomas Helvey <tomh@ixpress.net>
801 * ircd/numnicks.c (SetXYYCapacity): fix for extended
804 2000-03-30 Perry Lorier <isomer@coders.net>
805 * ircd/m_nick.c: send kills both ways so when we add nick change
806 on collision we don't desync the network.
808 * ircd/map.c: Fixup the map a bit more.
810 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
812 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
814 * ircd/m_opmode.c: Log the mode changes to OPATH
816 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
819 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
822 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
824 * config/config-sh.in: added OPATH for opmode log file
826 * ircd/m_clearmode.c (do_clearmode): updated uses of
827 modebuf_mode_string() for the new usage
829 * ircd/channel.c: added flag MODE_FREE and an int argument to
830 modebuf_mode_string() to indicate that the string must be free'd;
831 updated calls to modebuf_mode_string() for the new usage; called
832 collapse(pretty_mask()) on the ban string and use allocated memory
833 for it; added ban list length accounting; fixed a number of small
834 bugs in ban processing
836 * include/channel.h: added flag MODE_FREE and an int argument to
837 modebuf_mode_string() to indicate that the string must be free'd
839 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
840 keys and limits that are set
842 2000-03-30 Perry Lorier <isomer@coders.net>
843 * ircd/ircd.c: rewrote check_pings() for maintainability
844 and speed. Also changed quit msg's so they don't have
845 redundant nick[host] info in them.
847 * ircd/send.c: Changed write errors to report what error
848 occured (if possible).
850 * ircd/gline.c: added gline comment to the quit.
852 * ircd/m_server.c: Added suggestions to server quits mentioning
853 what went wrong so the admin can fix it earlier instead of asking
856 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
857 servers that aren't fully burst yet. And show '(--s)' for servers
860 * doc/example.conf: Fixed wrapped U:
862 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
864 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
865 mode_parse() (version selectable at compile time)
867 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
869 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
871 * config/config-sh.in: add new config option to enable new m_mode
874 * doc/Configure.help: add documentation for new config option
877 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
878 MODE -v : Not enough parameters
880 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
881 +k and +l even if they weren't set...
883 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
885 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
886 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
887 for; test the 0-th member, not the i-th member, of the client
890 * ircd/m_clearmode.c (do_clearmode): use the new
891 mode_invite_clear() function
893 * ircd/channel.c: cleared up all the compile-time warnings and
896 * include/channel.h: added declarations for mode_ban_invalidate()
897 and mode_invite_clear()
899 * ircd/channel.c: finished mode_parse(), then broke it up into a
900 dozen or so helper functions to make the code easier to read
902 2000-03-29 Thomas Helvey <tomh@inxpress.net>
903 * ircd/ircd.c: refactor server initialization a bit, use
904 getopt for parsing command line, refactor init_sys, main,
907 * ircd/s_bsd.c: add functions for initialization to clean
908 up logic a bit and remove duplicated code.
910 * include/ircd.h: add struct for server process related
913 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
915 * ircd/channel.c: initial definition of mode_parse(); flags to
916 prevent doing the same thing multiple times; helper method
917 send_notoper() to send a "Not oper"/"Not on channel" notice
919 * include/channel.h: declare mode_parse() and helper flags
921 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
922 sending to match the current action of set_mode() closely enough
923 that hopefully there won't be major conflicts
925 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
926 building logic, reversed the order of the arguments to mode
927 commands to have '-' preceed '+'
929 2000-03-29 Thomas Helvey <tomh@inxpress.net>
930 * ircd/s_bsd.c (add_connection): don't disable socket options
931 let OS tune itself and allow important performance tweaks to
934 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
936 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
937 confused by set_mode, which is doing some really weird logic;
938 guess what I'm going to rewrite next? ;)
940 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
942 * include/channel.h: added MODE_SAVE for the bounds checking stuff
945 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
946 make it do bounds checking on the buffer; all modes are sent only
947 if the all parameter is 1; modebuf_flush is the exported wrapper
949 * include/channel.h: add BOUNCE, renumber flags to get a little
952 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
953 BOUNCE; send DESYNCH message
955 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
957 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
958 channel actually has in effect for deletion
960 * ircd/channel.c: added explanatory comments to all added
961 functions; made flushing take place at the correct place even if
962 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
963 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
964 is empty, fixed the apparent source, removed some bogus string
965 termination code, properly terminate the mode strings, add support
966 for HACK2 and HACK3, made limit strings not be sent if the limit
967 is being removed, changed where '+' and '-' come from in sent
968 strings, added support for DEOP flag, set up bouncing code for
971 * ircd/Makefile.in: ran make depend
973 * include/channel.h: added new defines for future functionality,
974 made modebuf_flush() return int so I can use tail recursion
976 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
977 to make it all compile
979 * ircd/m_opmode.c: add msg.h to includes...
981 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
983 * ircd/channel.c (modebuf_flush): realized I forgot to
984 nul-terminate addbuf/rembuf properly...
986 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
988 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
989 sendto_serv_butone--blah^2
991 * ircd/send.c (sendto_serv_butone): stupid comments confused me
993 * ircd/channel.c (modebuf_flush): if there are no mode changes to
994 propagate, we're done...
996 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
997 not sendto_all_butone
999 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
1001 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
1003 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
1006 * ircd/parse.c: added messages for opmode and clearmode
1008 * include/handlers.h: added declarations for mo_opmode(),
1009 ms_opmode(), mo_clearmode(), and ms_clearmode()
1011 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
1014 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
1015 MODEBUF_DEST_OPMODE flag
1017 * ircd/channel.c (modebuf_flush): added new flag,
1018 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1019 to originate from source's server (or source itself, if
1020 IsServer(source)); also causes a server-level MODE to be sent as
1023 * include/channel.h: defined MODEBUF_DEST_SERVER,
1026 * ircd/channel.c: Add another argument to build_string() to handle
1027 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1028 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1031 2000-03-27 Perry Lorier <isomer@coders.net>
1033 * ircd/s_bsd.c: fixed missing 'u' typo.
1035 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
1037 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1038 _mode_string(), _mode_client(), _flush(); also implemented a
1039 simple build_string()
1041 * include/channel.h: added definition of ModeBuf, modebuf_*
1042 manipulation functions, and a couple of helper macros
1044 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1045 * numicks.c: convert extended numerics to use original mask version
1048 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1049 * Merge in changes from production
1050 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1051 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1052 * rfc1459.unet: Add Maniac's documentation for /names 0
1053 * Fix misc. jupe bugs that somehow made it into the tree
1054 * Escape /names 0 to mean /names --Maniac
1055 * Don't core when server asks for info --Maniac
1056 * Add Kev's jupe patch --Bleep
1057 * Add Maniacs squit patch --Bleep
1058 * Merge in u2_10_10_beta07 changes --Bleep
1059 * Merge in u2_10_10_beta06 changes --Bleep
1060 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1061 #-----------------------------------------------------------------------------
1063 # ChangeLog for ircu2.10.11
1065 # $Id: ChangeLog,v 1.125 2000-05-01 20:51:38 kev Exp $
1067 # Insert new changes at beginning of the change list.