1 2000-04-30 Perry Lorier <isomer@coders.net>
2 * config/config-sh.in: Fix for CONNEXIT
3 * ircd/s_{user,misc}.c: Fix for CONNEXIT
4 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
5 (Kev: Want to come talk to me about this?)
7 2000-04-30 Steven M. Doyle <steven@doyle.net>
9 - general cleanups and readability enhancements
10 - rewrite of setuid/chroot code.
11 - server will no longer run as root
12 - -DPROFIL compile option removed
13 - Fixed IPcheck API calls
16 - Fixed up chroot compile options
17 - Added options for debug and profile compiles
19 * config/gen.ircd.Makefile
20 - Support for new debug/profile options
23 - Support for new debug/profile options
29 - Removed old API prototypes, added new ones
32 - Readability cleanups (well, I -think-...)
33 - Changed IPRegistryEntry.last_connect to a time_t. The previously
34 used unsigned short was probably causing interesting things after
35 a client had been connected longer than about 65,535 seconds...
36 - Removed old API functions.
39 - Removed IPcheck.h include
41 * Additionally modified IPcheck API calls in:
51 2000-04-30 Perry Lorier <isomer@coders.net>
52 * ircd/s_bsd.c: Sigh. :)
53 * ircd/m_mode.c: fix for modeless channels by poptix.
55 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
57 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
59 * ircd/channel.c (clean_channelname): make clean_channelname also
60 truncate long channel names
62 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
64 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
66 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
69 * include/channel.h: definitions and declarations for the struct
72 2000-04-29 Perry Lorier <isomer@coders.net>
73 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
75 2000-04-29 Perry Lorier <isomer@coders.net>
76 * ircd/s_bsd.c: Add debugging code to IPcheck
78 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
80 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
82 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
85 * ircd/m_userhost.c (m_userhost): add a dead code comment
87 * ircd/m_desynch.c: forgot one...
89 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
91 * ircd/m_proto.c (proto_send_supported): just change a comment so
92 it doesn't show up in my scans
94 * ircd/ircd_reply.c (send_reply): fix a slight bug...
96 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
99 * ircd/parse.c (parse_server): argument wrangling to make
100 processing in do_numeric a little easier to deal with
102 * ircd/s_serv.c (server_estab): SERVER should come from
103 acptr->serv->up, not &me
105 * ircd/m_lusers.c: accidentally left out sptr for a %C
107 * ircd/send.c: hack to support doing wallchops...
109 * ircd/m_whowas.c: convert to new send functions
111 * ircd/m_whois.c: convert to new send functions
113 * ircd/m_who.c: convert to new send functions
115 * ircd/m_wallops.c: convert to new send functions
117 * ircd/m_wallchops.c: convert to new send functions
119 * ircd/m_version.c: convert to new send functions
121 * ircd/m_userip.c: convert to new send functions
123 * ircd/m_userhost.c: convert to new send functions
125 * ircd/m_uping.c: convert to new send functions
127 * ircd/m_trace.c: convert to new send functions
129 * ircd/m_topic.c: convert to new send functions
131 * ircd/m_time.c: convert to new send functions
133 * ircd/m_squit.c: convert to new send functions
135 * ircd/m_silence.c: convert to new send functions
137 * ircd/m_settime.c: convert to new send functions
139 * ircd/m_restart.c: convert to new send functions
141 * ircd/m_rehash.c: convert to new send functions
143 * ircd/m_privmsg.c: convert to new send functions
145 * ircd/m_pong.c: convert to new send functions
147 * ircd/m_ping.c: convert to new send functions
149 * ircd/m_pass.c: convert to new send functions
151 * ircd/m_opmode.c: convert to new send functions
153 * ircd/m_oper.c: convert to new send functions
155 * ircd/m_notice.c: convert to new send functions
157 * ircd/m_nick.c: convert to new send functions
159 * ircd/m_names.c: convert to new send functions
161 * ircd/m_motd.c: convert to new send functions
163 * ircd/m_mode.c: convert to new send functions
165 * ircd/m_map.c: convert to new send functions
167 * ircd/m_lusers.c: convert to new send functions
169 * ircd/m_list.c: convert to new send functions
171 * ircd/m_links.c: convert to new send functions
173 * ircd/m_kill.c: convert to new send functions
175 * ircd/m_jupe.c: convert to new send functions
177 * ircd/m_invite.c: convert to new send functions
179 * ircd/m_info.c: convert to new send functions
181 * ircd/m_help.c: convert to new send functions
183 * ircd/m_gline.c: convert to new send functions
185 * ircd/m_error.c: convert to new send functions
187 * ircd/m_endburst.c: convert to new send functions
189 * ircd/m_die.c: convert to new send functions
191 * ircd/m_destruct.c: convert to new send functions
193 * ircd/m_defaults.c: convert to new send functions
195 * ircd/m_connect.c: convert to new send functions
197 2000-04-28 Perry Lorier <isomer@coders.net>
198 * RELEASE.NOTES: Describe a few more undocumented features.
199 * config/config-sh.in: change the default paths for logging
200 and the recommended number of channels.
201 * include/supported.h: Rearrange slightly, added CHANTYPE's
203 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
205 * ircd/m_close.c: convert to send_reply
207 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
209 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
211 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
213 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
214 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
215 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
216 carefully rethought...
218 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
220 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
222 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
223 numeric nick; therefore, we have to use the server name
225 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
227 * ircd/send.c: fix minor bugs
229 * ircd/s_user.c (check_target_limit): mark dead code so I filter
232 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
235 * ircd/parse.c: mark dead code so I filter it when I grep
237 * ircd/map.c: mark dead code so I filter it when I grep
239 * ircd/ircd.c: mark dead code so I filter it when I grep
241 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
244 * ircd/channel.c: mark dead code so I filter it when I grep
246 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
247 hope I'm not stepping on toes...
249 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
250 conversions; use ircd_snprintf in a couple of cases to negate the
251 possibility of buffer overflow
253 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
255 * ircd/channel.c: convert as much as possible to new send
258 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
259 test member->user->from->fd, not from->fd
261 * ircd/gline.c (gline_add): go ahead and add badchans; we just
262 won't look for them in m_gline; this way, they always work...
264 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
266 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
267 ircd_vsnprintf conversion specifiers
269 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
270 I have my conversion specifiers
272 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
274 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
277 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
278 little less brain-dead
280 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
282 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
285 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
288 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
291 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
293 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
295 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
298 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
300 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
301 a numeric as needing to use an explicit pattern, which will be the
302 first argument in the variable argument list
304 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
305 non-prefixed nospoof PING
307 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
308 non-prefixed SERVER login
310 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
311 a numeric usage further up)
313 * include/send.h: declare sendrawto_one
315 * ircd/send.c (sendrawto_one): new function to use ONLY for
316 non-prefixed commands, like PING to client, or PASS/SERVER on
319 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
321 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
322 future expansion (channel numerics?)
324 * include/ircd_snprintf.h: added documentation to # to explain use
325 with %C; added documentation for : to explain use with %C; added
326 documentation for %H for channels
328 * ircd/whocmds.c: use send_reply
330 * ircd/userload.c: use sendcmdto_one
332 * ircd/uping.c: use sendcmdto_one
334 * ircd/send.c: use new flags to %C format string; ':' prefixes
335 client name with a colon for local connects, '#' uses
336 nick!user@host form for local connects
338 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
339 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
341 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
343 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
346 * ircd/s_auth.c: use sendto_opmask_butone
348 * ircd/res.c: use sendcmdto_one
350 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
353 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
355 * ircd/support.c: dumpcore is no longer used, so get rid of it
357 * ircd/parse.c: use send_reply, sendcmdto_one
359 * ircd/map.c: use send_reply
361 * ircd/listener.c: use send_reply
363 * ircd/jupe.c: use sendto_opmask_butone, send_reply
365 * ircd/ircd_reply.c: use send_reply
367 * ircd/ircd.c: use sendto_opmask_butone
369 * ircd/gline.c: use sendto_opmask_butone, send_reply
371 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
372 registered clients; make FLAG_ALT print nick!user@host; make
373 FLAG_COLON print :blah
375 * ircd/class.c (report_classes): use send_reply instead of
378 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
380 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
381 sendto_one with sendcmdto_one
383 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
385 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
386 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
387 sendcmdto_match_butone
389 * include/send.h: declare sendcmdto_match_butone
391 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
393 * ircd/jupe.c: update to use send_reply()
395 * ircd/gline.c: update to use send_reply()
397 * include/ircd_reply.h: declare send_reply
399 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
400 replies; uses ircd_snprintf
402 * ircd/send.c: added comments to redirect searchers to appropriate
403 sendcmdto_* function; moved new functions to end of file; added
404 explanatory comments; reordered arguments; defined new functions
407 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
409 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
411 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
413 * ircd/gline.c: reorder arguments to sendcmdto_* functions
415 * include/send.h: reorder arguments, add explanatory comments,
416 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
417 and vsendto_opmask_butone
419 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
421 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
422 vsendto_op_mask that uses '*' instead of the receiving client
425 * include/send.h: declare sendcmdto_channel_butone; takes a skip
426 argument that allows you to skip (or not to skip) deaf users,
427 users behind bursting servers, and non channel operators
429 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
431 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
432 sendto_channel_butserv has a subtle bug; also wrote
433 sendcmdto_common_channels.
435 * include/send.h: declare new sendcmdto_* functions
437 * ircd/jupe.c: support local deactivations of jupes
439 * ircd/gline.c: support local deactivations of glines
441 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
442 deactivated; if they aren't locally deactivated, then it slaves to
443 the net-wide activation status; JupeIsRemActive() tests only
444 whether the jupe is active everywhere else
446 * include/gline.h: GLINE_LDEACT allows glines to be locally
447 deactivated; if they aren't locally deactivated, then it slaves to
448 the net-wide activation status; GlineIsRemActive() tests only
449 whether the gline is active everywhere else
451 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
452 gline expires after the new one will, we drop the new one,
453 otherwise we add the G-line after that one (so the wide one will
454 apply first); if the new one contains an existing G-line and if it
455 will expire after the existing one, we drop the existing one to
458 * ircd/m_gline.c (mo_gline): opers could issue remote local
459 glines when CONFIG_OPERCMDS was off; fixed
461 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
463 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
466 * ircd/gline.c: add flags argument to gline_activate and
467 gline_deactivate for future expansion
469 * ircd/m_gline.c: pass flags to gline_activate and
472 * include/gline.h: add flags argument to gline_activate and
475 * ircd/jupe.c: add flags argument to jupe_activate and
476 jupe_deactivate for future expansion
478 * include/jupe.h: add flags argument to jupe_activate and
481 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
482 local, active; pass flags to jupe_activate and jupe_deactivate
484 * include/gline.h: remove dead code
486 * ircd/gline.c: make gline expire times relative to CurrentTime,
487 since that should be monotonically increasing, instead of
488 TStime(), which can be set backwards, and which can therefore
489 cause an expire time to increase; make local glines be removed
490 instead of just deactivated; don't let gline_find() look for
491 user@host glines if the mask being looked up is a channel mask
493 * ircd/send.c (vsendcmdto_one): forgot to account for the case
494 where origin is a server and destination is a user
496 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
497 since that should be monotonically increasing, instead of
498 TStime(), which can be set backwards, and which can therefore
499 cause an expire time to increase; make local jupes be removed
500 instead of just deactivated
502 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
503 limit is fine. any other warnings I should know about?
505 2000-04-15 Thomas Helvey <tomh@inxpress.net>
507 * ircd/*.c: const correctness and type safety cleanups to
508 get code to compile with C++ compiler. Still has
509 signed/unsigned comparison warnings.
511 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
513 * ircd/userload.c: change <sys/time.h> include to <time.h> for
516 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
518 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
521 * ircd/s_user.c: move gline_lookup function call into
522 register_user, where it'll have a username to lookup!
524 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
525 functions; also stuff send_error_to_client into return clauses
527 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
528 functions; also use send_error_to_client where that makes sense
530 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
531 functions; also use send_error_to_client where that makes sense
533 * ircd/gline.c: modify to utilize new sendcmdto_* series of
534 functions; also fix gline_lookup() to deal properly with remote
535 clients--boy, do struct Client and struct User need to be cleaned
538 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
541 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
542 sendcmdto_serv_butone(), all utilizing the %v conversion of
545 * include/send.h: define IRC_BUFSIZE, max size of a message;
546 declare sendcmdto_one(), vsendcmdto_one(), and
547 sendcmdto_serv_butone()
549 * include/msg.h: define all the CMD_* constants needed to utilize
550 the new sendcmdto_* series of functions
552 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
554 * ircd/gline.c: remove old, dead code.
556 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
557 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
558 (don't advertise proxies); remove dead code
560 * ircd/parse.c: oper handler for JUPE only lists jupes unless
561 CONFIG_OPERCMDS is enabled
563 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
564 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
566 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
567 always return ERR_DISABLED
569 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
570 enabled, always return ERR_DISABLED
572 * ircd/s_err.c: add error message to indicate disabled commands
574 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
576 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
578 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
579 CONFIG_NEW_MODE to 'y' for now
581 * ircd/gline.c (gline_list): fix a minor formatting bogon
583 * BUGS: since I fixed that bug, might as well mark it fixed.
585 * ircd/m_join.c: look up badchans with GLINE_EXACT
587 * ircd/m_gline.c: fix parc count problems; look up existing
588 G-lines with GLINE_EXACT; only set new lastmod when
589 activating/deactivating existing glines if old lastmod was not 0
591 * ircd/gline.c: forgot to copy the gline reason over; don't
592 propagate a gline with 0 lastmod if origin is user; add
593 GLINE_EXACT to force exact matching of gline mask
595 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
598 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
599 but gline_lookup() actually takes a client--d'oh.
601 2000-04-13 Thomas Helvey <tomh@inxpress.net>
602 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
604 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
606 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
608 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
611 * ircd/whocmds.c: Change idle time calc from socket idle to user
614 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
616 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
617 too, for ircd_snprintf.c
619 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
620 comments; mostly descended from the Linux manpage for printf, but
621 also documenting the extensions.
623 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
624 client; make 'q' be the same as 'L'; remove __inline__; only
625 define EXTENSION if HAVE_LONG_LONG is defined
627 * include/handlers.h: declare m_gline()
629 * ircd/parse.c: gline can be called by users, but it only lists
632 * ircd/s_user.c (set_nick_name): resend gline if a remote server
633 introduces a glined client
635 * ircd/s_serv.c (server_estab): burst glines, too
637 * ircd/gline.c: fix up all the expire times to be offsets;
638 simplify gline_resend()
640 * ircd/m_gline.c: begin coding replacements for ms_gline(),
641 mo_gline(), and m_gline()
643 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
644 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
646 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
648 * tools/Bouncer/*: Add comments/documentation/tags.
649 * tools/Bouncer/*: Add debug defines, make task fork().
651 2000-04-12 Thomas Helvey <tomh@inxpress.net>
652 * ircd/s_err.c: Cleanup s_err.c make one table so we
653 don't have to do anything tricky to get an error string.
655 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
656 * Add port bouncer for http (x/w)
658 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
660 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
661 call to gline_find(); also used GlineReason() instead of direct
662 reference to structure member
664 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
665 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
668 * ircd/channel.c: nothing seems to be called anywhere...
670 * ircd/s_err.c: update a couple of replies to dovetail with new
673 * ircd/gline.c: begin complete re-implementation of gline.c along
674 the lines of the final design of jupe.c
676 * include/gline.h: begin complete re-implementation of gline.c
677 along the lines of the final design of jupe.c
679 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
682 * ircd/ircd_snprintf.c: my new snprintf()-like functions
684 * include/ircd_snprintf.h: my new snprintf()-like functions
686 2000-04-11 Thomas Helvey <tomh@inxpress.net>
687 * ircd/IPcheck.c: removed old dead code
688 * ircd/s_user.c (send_user_info): removed non-standard
689 user not found message for userhost/userip
691 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
693 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
694 * doc/p10.html: Work on chapter 4.
696 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
698 * ircd/channel.c (mode_parse_client): fix coredump on /mode
699 #foobar +o nosuchnick
701 2000-04-10 Perry Lorier <Isomer@coders.net>
704 2000-04-09 Thomas Helvey <tomh@inxpress.net>
705 * include/IPcheck.h: fix prototype
706 * ircd/s_user.c: fix usage of IPcheck_remote_connect
707 * ircd/IPcheck.c: removed unused args
709 2000-04-09 Thomas Helvey <tomh@inxpress.net>
710 * include/IPcheck.h: add proto for IPcheck_expire
712 * ircd/IPcheck.c: Rewrote
714 * ircd/ircd.c: Add IPcheck_expire to main message loop
716 * ircd/s_user.c: Redo target hashing, refactor target code
718 * include/numeric.h: Cleaned up numerics, added which ones are
719 in use by other networks and what they are in use for.
721 * ircd/channel.c: cleaned can_join(), allow anyone through anything
722 if /invited, simplified the function. Opers overusing OPEROVERRIDE
723 will get a message explaining to them not to cheat.
725 * ircd/m_join.c: cleaned up the various join functions, should be
726 a lot more efficient. Still needs work. Now assumes that s<->s
727 won't send it a JOIN 0. Service coders - note this and tread with
730 * ircd/m_stats.c: added Gte-'s stats doc patch.
732 * ircd/m_version.c: /version now returns the 005 numeric as well.
733 as requested by Liandrin.
736 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
738 * ircd/m_clearmode.c: add include for support.h for write_log()
740 * configure: move ircd/crypt/* to tools/*
742 2000-04-06 Thomas Helvey <tomh@inxpress.net>
743 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
744 set client host to server alias if connection from localhost
746 2000-04-06 Perry Lorier <isomer@coders.net>
747 * ircd/ircd.c: Fix core during pinging (oops)
749 2000-04-06 Perry Lorier <isomer@coders.net>
750 * ircd/send.c: fixed wrong ident being sent to channels bug.
751 * include/numerics.h: Updated some of the numerics from other
752 networks. Flagged some as 'unused' by undernet.
754 2000-03-30 Perry Lorier <isomer@coders.net>
755 * ircd/ircd.c: Lets see if this helps the ping problem at all.
756 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
757 time for local clients. (as requested), extended who now returns all
758 the flags (@+!) so you can tell the complete state of a client.
760 2000-03-30 Thomas Helvey <tomh@inxpress.net>
761 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
763 2000-03-30 Perry Lorier <isomer@coders.net>
764 * ircd/parse.c: oops, missed opers.
766 2000-03-30 Perry Lorier <isomer@coders.net>
767 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
768 for so long. Remember: m_ping MUST be in the parse array. :)
770 2000-03-30 Perry Lorier <isomer@coders.net>
771 * ircd/ircd.c: test in check_pings was wrong. I move that we
772 disallow cvs commit after 10pm localtime....
774 2000-03-30 Perry Lorier <isomer@coders.net>
775 * ircd/m_pong.c: Fix it for servers too.
777 2000-03-30 Perry Lorier <isomer@coders.net>
778 * ircd/m_pong.c: Fix ping timeout bugs
780 2000-03-30 Perry Lorier <isomer@coders.net>
781 * ircd/channel.c: Bans had CurrentTime in their when field instead
784 2000-03-31 Thomas Helvey <tomh@ixpress.net>
785 * ircd/numnicks.c (SetXYYCapacity): fix for extended
788 2000-03-30 Perry Lorier <isomer@coders.net>
789 * ircd/m_nick.c: send kills both ways so when we add nick change
790 on collision we don't desync the network.
792 * ircd/map.c: Fixup the map a bit more.
794 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
796 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
798 * ircd/m_opmode.c: Log the mode changes to OPATH
800 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
803 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
806 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
808 * config/config-sh.in: added OPATH for opmode log file
810 * ircd/m_clearmode.c (do_clearmode): updated uses of
811 modebuf_mode_string() for the new usage
813 * ircd/channel.c: added flag MODE_FREE and an int argument to
814 modebuf_mode_string() to indicate that the string must be free'd;
815 updated calls to modebuf_mode_string() for the new usage; called
816 collapse(pretty_mask()) on the ban string and use allocated memory
817 for it; added ban list length accounting; fixed a number of small
818 bugs in ban processing
820 * include/channel.h: added flag MODE_FREE and an int argument to
821 modebuf_mode_string() to indicate that the string must be free'd
823 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
824 keys and limits that are set
826 2000-03-30 Perry Lorier <isomer@coders.net>
827 * ircd/ircd.c: rewrote check_pings() for maintainability
828 and speed. Also changed quit msg's so they don't have
829 redundant nick[host] info in them.
831 * ircd/send.c: Changed write errors to report what error
832 occured (if possible).
834 * ircd/gline.c: added gline comment to the quit.
836 * ircd/m_server.c: Added suggestions to server quits mentioning
837 what went wrong so the admin can fix it earlier instead of asking
840 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
841 servers that aren't fully burst yet. And show '(--s)' for servers
844 * doc/example.conf: Fixed wrapped U:
846 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
848 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
849 mode_parse() (version selectable at compile time)
851 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
853 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
855 * config/config-sh.in: add new config option to enable new m_mode
858 * doc/Configure.help: add documentation for new config option
861 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
862 MODE -v : Not enough parameters
864 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
865 +k and +l even if they weren't set...
867 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
869 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
870 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
871 for; test the 0-th member, not the i-th member, of the client
874 * ircd/m_clearmode.c (do_clearmode): use the new
875 mode_invite_clear() function
877 * ircd/channel.c: cleared up all the compile-time warnings and
880 * include/channel.h: added declarations for mode_ban_invalidate()
881 and mode_invite_clear()
883 * ircd/channel.c: finished mode_parse(), then broke it up into a
884 dozen or so helper functions to make the code easier to read
886 2000-03-29 Thomas Helvey <tomh@inxpress.net>
887 * ircd/ircd.c: refactor server initialization a bit, use
888 getopt for parsing command line, refactor init_sys, main,
891 * ircd/s_bsd.c: add functions for initialization to clean
892 up logic a bit and remove duplicated code.
894 * include/ircd.h: add struct for server process related
897 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
899 * ircd/channel.c: initial definition of mode_parse(); flags to
900 prevent doing the same thing multiple times; helper method
901 send_notoper() to send a "Not oper"/"Not on channel" notice
903 * include/channel.h: declare mode_parse() and helper flags
905 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
906 sending to match the current action of set_mode() closely enough
907 that hopefully there won't be major conflicts
909 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
910 building logic, reversed the order of the arguments to mode
911 commands to have '-' preceed '+'
913 2000-03-29 Thomas Helvey <tomh@inxpress.net>
914 * ircd/s_bsd.c (add_connection): don't disable socket options
915 let OS tune itself and allow important performance tweaks to
918 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
920 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
921 confused by set_mode, which is doing some really weird logic;
922 guess what I'm going to rewrite next? ;)
924 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
926 * include/channel.h: added MODE_SAVE for the bounds checking stuff
929 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
930 make it do bounds checking on the buffer; all modes are sent only
931 if the all parameter is 1; modebuf_flush is the exported wrapper
933 * include/channel.h: add BOUNCE, renumber flags to get a little
936 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
937 BOUNCE; send DESYNCH message
939 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
941 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
942 channel actually has in effect for deletion
944 * ircd/channel.c: added explanatory comments to all added
945 functions; made flushing take place at the correct place even if
946 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
947 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
948 is empty, fixed the apparent source, removed some bogus string
949 termination code, properly terminate the mode strings, add support
950 for HACK2 and HACK3, made limit strings not be sent if the limit
951 is being removed, changed where '+' and '-' come from in sent
952 strings, added support for DEOP flag, set up bouncing code for
955 * ircd/Makefile.in: ran make depend
957 * include/channel.h: added new defines for future functionality,
958 made modebuf_flush() return int so I can use tail recursion
960 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
961 to make it all compile
963 * ircd/m_opmode.c: add msg.h to includes...
965 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
967 * ircd/channel.c (modebuf_flush): realized I forgot to
968 nul-terminate addbuf/rembuf properly...
970 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
972 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
973 sendto_serv_butone--blah^2
975 * ircd/send.c (sendto_serv_butone): stupid comments confused me
977 * ircd/channel.c (modebuf_flush): if there are no mode changes to
978 propagate, we're done...
980 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
981 not sendto_all_butone
983 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
985 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
987 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
990 * ircd/parse.c: added messages for opmode and clearmode
992 * include/handlers.h: added declarations for mo_opmode(),
993 ms_opmode(), mo_clearmode(), and ms_clearmode()
995 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
998 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
999 MODEBUF_DEST_OPMODE flag
1001 * ircd/channel.c (modebuf_flush): added new flag,
1002 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1003 to originate from source's server (or source itself, if
1004 IsServer(source)); also causes a server-level MODE to be sent as
1007 * include/channel.h: defined MODEBUF_DEST_SERVER,
1010 * ircd/channel.c: Add another argument to build_string() to handle
1011 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1012 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1015 2000-03-27 Perry Lorier <isomer@coders.net>
1017 * ircd/s_bsd.c: fixed missing 'u' typo.
1019 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
1021 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1022 _mode_string(), _mode_client(), _flush(); also implemented a
1023 simple build_string()
1025 * include/channel.h: added definition of ModeBuf, modebuf_*
1026 manipulation functions, and a couple of helper macros
1028 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1029 * numicks.c: convert extended numerics to use original mask version
1032 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1033 * Merge in changes from production
1034 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1035 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1036 * rfc1459.unet: Add Maniac's documentation for /names 0
1037 * Fix misc. jupe bugs that somehow made it into the tree
1038 * Escape /names 0 to mean /names --Maniac
1039 * Don't core when server asks for info --Maniac
1040 * Add Kev's jupe patch --Bleep
1041 * Add Maniacs squit patch --Bleep
1042 * Merge in u2_10_10_beta07 changes --Bleep
1043 * Merge in u2_10_10_beta06 changes --Bleep
1044 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1045 #-----------------------------------------------------------------------------
1047 # ChangeLog for ircu2.10.11
1049 # $Id: ChangeLog,v 1.120 2000-04-30 12:00:06 isomer Exp $
1051 # Insert new changes at beginning of the change list.