1 2000-05-04 Kevin L. Mitchell <klmitch@mit.edu>
3 * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
6 * ircd/channel.c (send_channel_modes): deal with one of the last
9 * ircd/m_burst.c (ms_burst): debugged ban processing; removed
12 * ircd/channel.c (modebuf_extract): remove debugging
13 sendto_opmask_butone calls
15 2000-05-03 Kevin L. Mitchell <klmitch@mit.edu>
17 * ircd/channel.c: support a couple of new flags to support using
18 mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
19 of modebuf_extract to extract added flags for use by ms_burst
21 * include/channel.h: a couple of new flags to support using
22 mode_parse inside ms_burst
24 * ircd/m_burst.c (ms_burst): brand new implementation of BURST
26 * ircd/m_endburst.c: add loop to processing of end_of_burst to
27 free empty channels after the BURST is over.
29 * ircd/m_server.c: convert to use new send.c functions--I wanted
30 to rewrite it from scratch, but the logic's pretty complex; I may
31 still rewrite it, though...
33 2000-05-02 Thomas Helvey <tomh@inxpress.net>
35 * ircd/ircd.c: fix broken header include ordering
37 2000-05-02 Thomas Helvey <tomh@inxpress.net>
39 * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
40 review emailed privately
42 * include/IPcheck.h: removed unneeded include
44 2000-05-02 Kevin L. Mitchell <klmitch@mit.edu>
46 * ircd/s_user.c (hunt_server): throw in a comment so I know what
49 * include/querycmds.h (Count_unknownbecomesclient): convert to
52 * ircd/send.c: start removing dead code
54 * include/send.h: start removing dead code
56 * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
59 * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
61 2000-05-01 Kevin L. Mitchell <klmitch@mit.edu>
63 * ircd/m_stats.c: convert to sendcmdto_one / send_reply
65 * ircd/m_kick.c: Completely reimplement m_kick
67 * ircd/channel.c: send_user_joins removed; it was dead code,
70 2000-05-01 Perry Lorier <isomer@coders.net>
71 * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
72 * ircd/channels.c: My fix for the part problem. Untested, probably
73 won't work. Can't be much worse than the current problem.
74 it'll either work or core, take your pick.
77 2000-04-30 Perry Lorier <isomer@coders.net>
78 * config/config-sh.in: Fix for CONNEXIT
79 * ircd/s_{user,misc}.c: Fix for CONNEXIT
80 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
81 (Kev: Want to come talk to me about this?)
83 2000-04-30 Steven M. Doyle <steven@doyle.net>
85 - general cleanups and readability enhancements
86 - rewrite of setuid/chroot code.
87 - server will no longer run as root
88 - -DPROFIL compile option removed
89 - Fixed IPcheck API calls
92 - Fixed up chroot compile options
93 - Added options for debug and profile compiles
95 * config/gen.ircd.Makefile
96 - Support for new debug/profile options
99 - Support for new debug/profile options
105 - Removed old API prototypes, added new ones
108 - Readability cleanups (well, I -think-...)
109 - Changed IPRegistryEntry.last_connect to a time_t. The previously
110 used unsigned short was probably causing interesting things after
111 a client had been connected longer than about 65,535 seconds...
112 - Removed old API functions.
115 - Removed IPcheck.h include
117 * Additionally modified IPcheck API calls in:
127 2000-04-30 Perry Lorier <isomer@coders.net>
128 * ircd/s_bsd.c: Sigh. :)
129 * ircd/m_mode.c: fix for modeless channels by poptix.
131 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
133 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
135 * ircd/channel.c (clean_channelname): make clean_channelname also
136 truncate long channel names
138 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
140 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
142 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
145 * include/channel.h: definitions and declarations for the struct
148 2000-04-29 Perry Lorier <isomer@coders.net>
149 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
151 2000-04-29 Perry Lorier <isomer@coders.net>
152 * ircd/s_bsd.c: Add debugging code to IPcheck
154 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
156 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
158 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
161 * ircd/m_userhost.c (m_userhost): add a dead code comment
163 * ircd/m_desynch.c: forgot one...
165 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
167 * ircd/m_proto.c (proto_send_supported): just change a comment so
168 it doesn't show up in my scans
170 * ircd/ircd_reply.c (send_reply): fix a slight bug...
172 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
175 * ircd/parse.c (parse_server): argument wrangling to make
176 processing in do_numeric a little easier to deal with
178 * ircd/s_serv.c (server_estab): SERVER should come from
179 acptr->serv->up, not &me
181 * ircd/m_lusers.c: accidentally left out sptr for a %C
183 * ircd/send.c: hack to support doing wallchops...
185 * ircd/m_whowas.c: convert to new send functions
187 * ircd/m_whois.c: convert to new send functions
189 * ircd/m_who.c: convert to new send functions
191 * ircd/m_wallops.c: convert to new send functions
193 * ircd/m_wallchops.c: convert to new send functions
195 * ircd/m_version.c: convert to new send functions
197 * ircd/m_userip.c: convert to new send functions
199 * ircd/m_userhost.c: convert to new send functions
201 * ircd/m_uping.c: convert to new send functions
203 * ircd/m_trace.c: convert to new send functions
205 * ircd/m_topic.c: convert to new send functions
207 * ircd/m_time.c: convert to new send functions
209 * ircd/m_squit.c: convert to new send functions
211 * ircd/m_silence.c: convert to new send functions
213 * ircd/m_settime.c: convert to new send functions
215 * ircd/m_restart.c: convert to new send functions
217 * ircd/m_rehash.c: convert to new send functions
219 * ircd/m_privmsg.c: convert to new send functions
221 * ircd/m_pong.c: convert to new send functions
223 * ircd/m_ping.c: convert to new send functions
225 * ircd/m_pass.c: convert to new send functions
227 * ircd/m_opmode.c: convert to new send functions
229 * ircd/m_oper.c: convert to new send functions
231 * ircd/m_notice.c: convert to new send functions
233 * ircd/m_nick.c: convert to new send functions
235 * ircd/m_names.c: convert to new send functions
237 * ircd/m_motd.c: convert to new send functions
239 * ircd/m_mode.c: convert to new send functions
241 * ircd/m_map.c: convert to new send functions
243 * ircd/m_lusers.c: convert to new send functions
245 * ircd/m_list.c: convert to new send functions
247 * ircd/m_links.c: convert to new send functions
249 * ircd/m_kill.c: convert to new send functions
251 * ircd/m_jupe.c: convert to new send functions
253 * ircd/m_invite.c: convert to new send functions
255 * ircd/m_info.c: convert to new send functions
257 * ircd/m_help.c: convert to new send functions
259 * ircd/m_gline.c: convert to new send functions
261 * ircd/m_error.c: convert to new send functions
263 * ircd/m_endburst.c: convert to new send functions
265 * ircd/m_die.c: convert to new send functions
267 * ircd/m_destruct.c: convert to new send functions
269 * ircd/m_defaults.c: convert to new send functions
271 * ircd/m_connect.c: convert to new send functions
273 2000-04-28 Perry Lorier <isomer@coders.net>
274 * RELEASE.NOTES: Describe a few more undocumented features.
275 * config/config-sh.in: change the default paths for logging
276 and the recommended number of channels.
277 * include/supported.h: Rearrange slightly, added CHANTYPE's
279 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
281 * ircd/m_close.c: convert to send_reply
283 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
285 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
287 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
289 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
290 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
291 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
292 carefully rethought...
294 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
296 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
298 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
299 numeric nick; therefore, we have to use the server name
301 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
303 * ircd/send.c: fix minor bugs
305 * ircd/s_user.c (check_target_limit): mark dead code so I filter
308 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
311 * ircd/parse.c: mark dead code so I filter it when I grep
313 * ircd/map.c: mark dead code so I filter it when I grep
315 * ircd/ircd.c: mark dead code so I filter it when I grep
317 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
320 * ircd/channel.c: mark dead code so I filter it when I grep
322 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
323 hope I'm not stepping on toes...
325 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
326 conversions; use ircd_snprintf in a couple of cases to negate the
327 possibility of buffer overflow
329 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
331 * ircd/channel.c: convert as much as possible to new send
334 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
335 test member->user->from->fd, not from->fd
337 * ircd/gline.c (gline_add): go ahead and add badchans; we just
338 won't look for them in m_gline; this way, they always work...
340 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
342 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
343 ircd_vsnprintf conversion specifiers
345 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
346 I have my conversion specifiers
348 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
350 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
353 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
354 little less brain-dead
356 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
358 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
361 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
364 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
367 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
369 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
371 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
374 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
376 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
377 a numeric as needing to use an explicit pattern, which will be the
378 first argument in the variable argument list
380 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
381 non-prefixed nospoof PING
383 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
384 non-prefixed SERVER login
386 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
387 a numeric usage further up)
389 * include/send.h: declare sendrawto_one
391 * ircd/send.c (sendrawto_one): new function to use ONLY for
392 non-prefixed commands, like PING to client, or PASS/SERVER on
395 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
397 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
398 future expansion (channel numerics?)
400 * include/ircd_snprintf.h: added documentation to # to explain use
401 with %C; added documentation for : to explain use with %C; added
402 documentation for %H for channels
404 * ircd/whocmds.c: use send_reply
406 * ircd/userload.c: use sendcmdto_one
408 * ircd/uping.c: use sendcmdto_one
410 * ircd/send.c: use new flags to %C format string; ':' prefixes
411 client name with a colon for local connects, '#' uses
412 nick!user@host form for local connects
414 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
415 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
417 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
419 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
422 * ircd/s_auth.c: use sendto_opmask_butone
424 * ircd/res.c: use sendcmdto_one
426 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
429 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
431 * ircd/support.c: dumpcore is no longer used, so get rid of it
433 * ircd/parse.c: use send_reply, sendcmdto_one
435 * ircd/map.c: use send_reply
437 * ircd/listener.c: use send_reply
439 * ircd/jupe.c: use sendto_opmask_butone, send_reply
441 * ircd/ircd_reply.c: use send_reply
443 * ircd/ircd.c: use sendto_opmask_butone
445 * ircd/gline.c: use sendto_opmask_butone, send_reply
447 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
448 registered clients; make FLAG_ALT print nick!user@host; make
449 FLAG_COLON print :blah
451 * ircd/class.c (report_classes): use send_reply instead of
454 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
456 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
457 sendto_one with sendcmdto_one
459 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
461 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
462 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
463 sendcmdto_match_butone
465 * include/send.h: declare sendcmdto_match_butone
467 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
469 * ircd/jupe.c: update to use send_reply()
471 * ircd/gline.c: update to use send_reply()
473 * include/ircd_reply.h: declare send_reply
475 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
476 replies; uses ircd_snprintf
478 * ircd/send.c: added comments to redirect searchers to appropriate
479 sendcmdto_* function; moved new functions to end of file; added
480 explanatory comments; reordered arguments; defined new functions
483 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
485 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
487 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
489 * ircd/gline.c: reorder arguments to sendcmdto_* functions
491 * include/send.h: reorder arguments, add explanatory comments,
492 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
493 and vsendto_opmask_butone
495 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
497 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
498 vsendto_op_mask that uses '*' instead of the receiving client
501 * include/send.h: declare sendcmdto_channel_butone; takes a skip
502 argument that allows you to skip (or not to skip) deaf users,
503 users behind bursting servers, and non channel operators
505 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
507 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
508 sendto_channel_butserv has a subtle bug; also wrote
509 sendcmdto_common_channels.
511 * include/send.h: declare new sendcmdto_* functions
513 * ircd/jupe.c: support local deactivations of jupes
515 * ircd/gline.c: support local deactivations of glines
517 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
518 deactivated; if they aren't locally deactivated, then it slaves to
519 the net-wide activation status; JupeIsRemActive() tests only
520 whether the jupe is active everywhere else
522 * include/gline.h: GLINE_LDEACT allows glines to be locally
523 deactivated; if they aren't locally deactivated, then it slaves to
524 the net-wide activation status; GlineIsRemActive() tests only
525 whether the gline is active everywhere else
527 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
528 gline expires after the new one will, we drop the new one,
529 otherwise we add the G-line after that one (so the wide one will
530 apply first); if the new one contains an existing G-line and if it
531 will expire after the existing one, we drop the existing one to
534 * ircd/m_gline.c (mo_gline): opers could issue remote local
535 glines when CONFIG_OPERCMDS was off; fixed
537 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
539 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
542 * ircd/gline.c: add flags argument to gline_activate and
543 gline_deactivate for future expansion
545 * ircd/m_gline.c: pass flags to gline_activate and
548 * include/gline.h: add flags argument to gline_activate and
551 * ircd/jupe.c: add flags argument to jupe_activate and
552 jupe_deactivate for future expansion
554 * include/jupe.h: add flags argument to jupe_activate and
557 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
558 local, active; pass flags to jupe_activate and jupe_deactivate
560 * include/gline.h: remove dead code
562 * ircd/gline.c: make gline expire times relative to CurrentTime,
563 since that should be monotonically increasing, instead of
564 TStime(), which can be set backwards, and which can therefore
565 cause an expire time to increase; make local glines be removed
566 instead of just deactivated; don't let gline_find() look for
567 user@host glines if the mask being looked up is a channel mask
569 * ircd/send.c (vsendcmdto_one): forgot to account for the case
570 where origin is a server and destination is a user
572 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
573 since that should be monotonically increasing, instead of
574 TStime(), which can be set backwards, and which can therefore
575 cause an expire time to increase; make local jupes be removed
576 instead of just deactivated
578 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
579 limit is fine. any other warnings I should know about?
581 2000-04-15 Thomas Helvey <tomh@inxpress.net>
583 * ircd/*.c: const correctness and type safety cleanups to
584 get code to compile with C++ compiler. Still has
585 signed/unsigned comparison warnings.
587 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
589 * ircd/userload.c: change <sys/time.h> include to <time.h> for
592 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
594 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
597 * ircd/s_user.c: move gline_lookup function call into
598 register_user, where it'll have a username to lookup!
600 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
601 functions; also stuff send_error_to_client into return clauses
603 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
604 functions; also use send_error_to_client where that makes sense
606 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
607 functions; also use send_error_to_client where that makes sense
609 * ircd/gline.c: modify to utilize new sendcmdto_* series of
610 functions; also fix gline_lookup() to deal properly with remote
611 clients--boy, do struct Client and struct User need to be cleaned
614 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
617 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
618 sendcmdto_serv_butone(), all utilizing the %v conversion of
621 * include/send.h: define IRC_BUFSIZE, max size of a message;
622 declare sendcmdto_one(), vsendcmdto_one(), and
623 sendcmdto_serv_butone()
625 * include/msg.h: define all the CMD_* constants needed to utilize
626 the new sendcmdto_* series of functions
628 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
630 * ircd/gline.c: remove old, dead code.
632 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
633 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
634 (don't advertise proxies); remove dead code
636 * ircd/parse.c: oper handler for JUPE only lists jupes unless
637 CONFIG_OPERCMDS is enabled
639 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
640 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
642 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
643 always return ERR_DISABLED
645 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
646 enabled, always return ERR_DISABLED
648 * ircd/s_err.c: add error message to indicate disabled commands
650 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
652 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
654 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
655 CONFIG_NEW_MODE to 'y' for now
657 * ircd/gline.c (gline_list): fix a minor formatting bogon
659 * BUGS: since I fixed that bug, might as well mark it fixed.
661 * ircd/m_join.c: look up badchans with GLINE_EXACT
663 * ircd/m_gline.c: fix parc count problems; look up existing
664 G-lines with GLINE_EXACT; only set new lastmod when
665 activating/deactivating existing glines if old lastmod was not 0
667 * ircd/gline.c: forgot to copy the gline reason over; don't
668 propagate a gline with 0 lastmod if origin is user; add
669 GLINE_EXACT to force exact matching of gline mask
671 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
674 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
675 but gline_lookup() actually takes a client--d'oh.
677 2000-04-13 Thomas Helvey <tomh@inxpress.net>
678 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
680 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
682 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
684 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
687 * ircd/whocmds.c: Change idle time calc from socket idle to user
690 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
692 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
693 too, for ircd_snprintf.c
695 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
696 comments; mostly descended from the Linux manpage for printf, but
697 also documenting the extensions.
699 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
700 client; make 'q' be the same as 'L'; remove __inline__; only
701 define EXTENSION if HAVE_LONG_LONG is defined
703 * include/handlers.h: declare m_gline()
705 * ircd/parse.c: gline can be called by users, but it only lists
708 * ircd/s_user.c (set_nick_name): resend gline if a remote server
709 introduces a glined client
711 * ircd/s_serv.c (server_estab): burst glines, too
713 * ircd/gline.c: fix up all the expire times to be offsets;
714 simplify gline_resend()
716 * ircd/m_gline.c: begin coding replacements for ms_gline(),
717 mo_gline(), and m_gline()
719 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
720 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
722 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
724 * tools/Bouncer/*: Add comments/documentation/tags.
725 * tools/Bouncer/*: Add debug defines, make task fork().
727 2000-04-12 Thomas Helvey <tomh@inxpress.net>
728 * ircd/s_err.c: Cleanup s_err.c make one table so we
729 don't have to do anything tricky to get an error string.
731 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
732 * Add port bouncer for http (x/w)
734 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
736 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
737 call to gline_find(); also used GlineReason() instead of direct
738 reference to structure member
740 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
741 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
744 * ircd/channel.c: nothing seems to be called anywhere...
746 * ircd/s_err.c: update a couple of replies to dovetail with new
749 * ircd/gline.c: begin complete re-implementation of gline.c along
750 the lines of the final design of jupe.c
752 * include/gline.h: begin complete re-implementation of gline.c
753 along the lines of the final design of jupe.c
755 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
758 * ircd/ircd_snprintf.c: my new snprintf()-like functions
760 * include/ircd_snprintf.h: my new snprintf()-like functions
762 2000-04-11 Thomas Helvey <tomh@inxpress.net>
763 * ircd/IPcheck.c: removed old dead code
764 * ircd/s_user.c (send_user_info): removed non-standard
765 user not found message for userhost/userip
767 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
769 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
770 * doc/p10.html: Work on chapter 4.
772 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
774 * ircd/channel.c (mode_parse_client): fix coredump on /mode
775 #foobar +o nosuchnick
777 2000-04-10 Perry Lorier <Isomer@coders.net>
780 2000-04-09 Thomas Helvey <tomh@inxpress.net>
781 * include/IPcheck.h: fix prototype
782 * ircd/s_user.c: fix usage of IPcheck_remote_connect
783 * ircd/IPcheck.c: removed unused args
785 2000-04-09 Thomas Helvey <tomh@inxpress.net>
786 * include/IPcheck.h: add proto for IPcheck_expire
788 * ircd/IPcheck.c: Rewrote
790 * ircd/ircd.c: Add IPcheck_expire to main message loop
792 * ircd/s_user.c: Redo target hashing, refactor target code
794 * include/numeric.h: Cleaned up numerics, added which ones are
795 in use by other networks and what they are in use for.
797 * ircd/channel.c: cleaned can_join(), allow anyone through anything
798 if /invited, simplified the function. Opers overusing OPEROVERRIDE
799 will get a message explaining to them not to cheat.
801 * ircd/m_join.c: cleaned up the various join functions, should be
802 a lot more efficient. Still needs work. Now assumes that s<->s
803 won't send it a JOIN 0. Service coders - note this and tread with
806 * ircd/m_stats.c: added Gte-'s stats doc patch.
808 * ircd/m_version.c: /version now returns the 005 numeric as well.
809 as requested by Liandrin.
812 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
814 * ircd/m_clearmode.c: add include for support.h for write_log()
816 * configure: move ircd/crypt/* to tools/*
818 2000-04-06 Thomas Helvey <tomh@inxpress.net>
819 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
820 set client host to server alias if connection from localhost
822 2000-04-06 Perry Lorier <isomer@coders.net>
823 * ircd/ircd.c: Fix core during pinging (oops)
825 2000-04-06 Perry Lorier <isomer@coders.net>
826 * ircd/send.c: fixed wrong ident being sent to channels bug.
827 * include/numerics.h: Updated some of the numerics from other
828 networks. Flagged some as 'unused' by undernet.
830 2000-03-30 Perry Lorier <isomer@coders.net>
831 * ircd/ircd.c: Lets see if this helps the ping problem at all.
832 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
833 time for local clients. (as requested), extended who now returns all
834 the flags (@+!) so you can tell the complete state of a client.
836 2000-03-30 Thomas Helvey <tomh@inxpress.net>
837 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
839 2000-03-30 Perry Lorier <isomer@coders.net>
840 * ircd/parse.c: oops, missed opers.
842 2000-03-30 Perry Lorier <isomer@coders.net>
843 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
844 for so long. Remember: m_ping MUST be in the parse array. :)
846 2000-03-30 Perry Lorier <isomer@coders.net>
847 * ircd/ircd.c: test in check_pings was wrong. I move that we
848 disallow cvs commit after 10pm localtime....
850 2000-03-30 Perry Lorier <isomer@coders.net>
851 * ircd/m_pong.c: Fix it for servers too.
853 2000-03-30 Perry Lorier <isomer@coders.net>
854 * ircd/m_pong.c: Fix ping timeout bugs
856 2000-03-30 Perry Lorier <isomer@coders.net>
857 * ircd/channel.c: Bans had CurrentTime in their when field instead
860 2000-03-31 Thomas Helvey <tomh@ixpress.net>
861 * ircd/numnicks.c (SetXYYCapacity): fix for extended
864 2000-03-30 Perry Lorier <isomer@coders.net>
865 * ircd/m_nick.c: send kills both ways so when we add nick change
866 on collision we don't desync the network.
868 * ircd/map.c: Fixup the map a bit more.
870 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
872 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
874 * ircd/m_opmode.c: Log the mode changes to OPATH
876 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
879 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
882 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
884 * config/config-sh.in: added OPATH for opmode log file
886 * ircd/m_clearmode.c (do_clearmode): updated uses of
887 modebuf_mode_string() for the new usage
889 * ircd/channel.c: added flag MODE_FREE and an int argument to
890 modebuf_mode_string() to indicate that the string must be free'd;
891 updated calls to modebuf_mode_string() for the new usage; called
892 collapse(pretty_mask()) on the ban string and use allocated memory
893 for it; added ban list length accounting; fixed a number of small
894 bugs in ban processing
896 * include/channel.h: added flag MODE_FREE and an int argument to
897 modebuf_mode_string() to indicate that the string must be free'd
899 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
900 keys and limits that are set
902 2000-03-30 Perry Lorier <isomer@coders.net>
903 * ircd/ircd.c: rewrote check_pings() for maintainability
904 and speed. Also changed quit msg's so they don't have
905 redundant nick[host] info in them.
907 * ircd/send.c: Changed write errors to report what error
908 occured (if possible).
910 * ircd/gline.c: added gline comment to the quit.
912 * ircd/m_server.c: Added suggestions to server quits mentioning
913 what went wrong so the admin can fix it earlier instead of asking
916 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
917 servers that aren't fully burst yet. And show '(--s)' for servers
920 * doc/example.conf: Fixed wrapped U:
922 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
924 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
925 mode_parse() (version selectable at compile time)
927 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
929 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
931 * config/config-sh.in: add new config option to enable new m_mode
934 * doc/Configure.help: add documentation for new config option
937 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
938 MODE -v : Not enough parameters
940 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
941 +k and +l even if they weren't set...
943 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
945 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
946 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
947 for; test the 0-th member, not the i-th member, of the client
950 * ircd/m_clearmode.c (do_clearmode): use the new
951 mode_invite_clear() function
953 * ircd/channel.c: cleared up all the compile-time warnings and
956 * include/channel.h: added declarations for mode_ban_invalidate()
957 and mode_invite_clear()
959 * ircd/channel.c: finished mode_parse(), then broke it up into a
960 dozen or so helper functions to make the code easier to read
962 2000-03-29 Thomas Helvey <tomh@inxpress.net>
963 * ircd/ircd.c: refactor server initialization a bit, use
964 getopt for parsing command line, refactor init_sys, main,
967 * ircd/s_bsd.c: add functions for initialization to clean
968 up logic a bit and remove duplicated code.
970 * include/ircd.h: add struct for server process related
973 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
975 * ircd/channel.c: initial definition of mode_parse(); flags to
976 prevent doing the same thing multiple times; helper method
977 send_notoper() to send a "Not oper"/"Not on channel" notice
979 * include/channel.h: declare mode_parse() and helper flags
981 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
982 sending to match the current action of set_mode() closely enough
983 that hopefully there won't be major conflicts
985 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
986 building logic, reversed the order of the arguments to mode
987 commands to have '-' preceed '+'
989 2000-03-29 Thomas Helvey <tomh@inxpress.net>
990 * ircd/s_bsd.c (add_connection): don't disable socket options
991 let OS tune itself and allow important performance tweaks to
994 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
996 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
997 confused by set_mode, which is doing some really weird logic;
998 guess what I'm going to rewrite next? ;)
1000 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
1002 * include/channel.h: added MODE_SAVE for the bounds checking stuff
1005 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
1006 make it do bounds checking on the buffer; all modes are sent only
1007 if the all parameter is 1; modebuf_flush is the exported wrapper
1009 * include/channel.h: add BOUNCE, renumber flags to get a little
1012 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
1013 BOUNCE; send DESYNCH message
1015 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
1017 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
1018 channel actually has in effect for deletion
1020 * ircd/channel.c: added explanatory comments to all added
1021 functions; made flushing take place at the correct place even if
1022 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
1023 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
1024 is empty, fixed the apparent source, removed some bogus string
1025 termination code, properly terminate the mode strings, add support
1026 for HACK2 and HACK3, made limit strings not be sent if the limit
1027 is being removed, changed where '+' and '-' come from in sent
1028 strings, added support for DEOP flag, set up bouncing code for
1031 * ircd/Makefile.in: ran make depend
1033 * include/channel.h: added new defines for future functionality,
1034 made modebuf_flush() return int so I can use tail recursion
1036 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
1037 to make it all compile
1039 * ircd/m_opmode.c: add msg.h to includes...
1041 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
1043 * ircd/channel.c (modebuf_flush): realized I forgot to
1044 nul-terminate addbuf/rembuf properly...
1046 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
1048 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
1049 sendto_serv_butone--blah^2
1051 * ircd/send.c (sendto_serv_butone): stupid comments confused me
1053 * ircd/channel.c (modebuf_flush): if there are no mode changes to
1054 propagate, we're done...
1056 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
1057 not sendto_all_butone
1059 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
1061 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
1063 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
1066 * ircd/parse.c: added messages for opmode and clearmode
1068 * include/handlers.h: added declarations for mo_opmode(),
1069 ms_opmode(), mo_clearmode(), and ms_clearmode()
1071 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
1074 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
1075 MODEBUF_DEST_OPMODE flag
1077 * ircd/channel.c (modebuf_flush): added new flag,
1078 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1079 to originate from source's server (or source itself, if
1080 IsServer(source)); also causes a server-level MODE to be sent as
1083 * include/channel.h: defined MODEBUF_DEST_SERVER,
1086 * ircd/channel.c: Add another argument to build_string() to handle
1087 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1088 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1091 2000-03-27 Perry Lorier <isomer@coders.net>
1093 * ircd/s_bsd.c: fixed missing 'u' typo.
1095 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
1097 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1098 _mode_string(), _mode_client(), _flush(); also implemented a
1099 simple build_string()
1101 * include/channel.h: added definition of ModeBuf, modebuf_*
1102 manipulation functions, and a couple of helper macros
1104 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1105 * numicks.c: convert extended numerics to use original mask version
1108 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1109 * Merge in changes from production
1110 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1111 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1112 * rfc1459.unet: Add Maniac's documentation for /names 0
1113 * Fix misc. jupe bugs that somehow made it into the tree
1114 * Escape /names 0 to mean /names --Maniac
1115 * Don't core when server asks for info --Maniac
1116 * Add Kev's jupe patch --Bleep
1117 * Add Maniacs squit patch --Bleep
1118 * Merge in u2_10_10_beta07 changes --Bleep
1119 * Merge in u2_10_10_beta06 changes --Bleep
1120 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1121 #-----------------------------------------------------------------------------
1123 # ChangeLog for ircu2.10.11
1125 # $Id: ChangeLog,v 1.133 2000-05-04 17:43:47 kev Exp $
1127 # Insert new changes at beginning of the change list.