1 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
3 * ircd/m_lusers.c: accidentally left out sptr for a %C
5 * ircd/send.c: hack to support doing wallchops...
7 * ircd/m_whowas.c: convert to new send functions
9 * ircd/m_whois.c: convert to new send functions
11 * ircd/m_who.c: convert to new send functions
13 * ircd/m_wallops.c: convert to new send functions
15 * ircd/m_wallchops.c: convert to new send functions
17 * ircd/m_version.c: convert to new send functions
19 * ircd/m_userip.c: convert to new send functions
21 * ircd/m_userhost.c: convert to new send functions
23 * ircd/m_uping.c: convert to new send functions
25 * ircd/m_trace.c: convert to new send functions
27 * ircd/m_topic.c: convert to new send functions
29 * ircd/m_time.c: convert to new send functions
31 * ircd/m_squit.c: convert to new send functions
33 * ircd/m_silence.c: convert to new send functions
35 * ircd/m_settime.c: convert to new send functions
37 * ircd/m_restart.c: convert to new send functions
39 * ircd/m_rehash.c: convert to new send functions
41 * ircd/m_privmsg.c: convert to new send functions
43 * ircd/m_pong.c: convert to new send functions
45 * ircd/m_ping.c: convert to new send functions
47 * ircd/m_pass.c: convert to new send functions
49 * ircd/m_opmode.c: convert to new send functions
51 * ircd/m_oper.c: convert to new send functions
53 * ircd/m_notice.c: convert to new send functions
55 * ircd/m_nick.c: convert to new send functions
57 * ircd/m_names.c: convert to new send functions
59 * ircd/m_motd.c: convert to new send functions
61 * ircd/m_mode.c: convert to new send functions
63 * ircd/m_map.c: convert to new send functions
65 * ircd/m_lusers.c: convert to new send functions
67 * ircd/m_list.c: convert to new send functions
69 * ircd/m_links.c: convert to new send functions
71 * ircd/m_kill.c: convert to new send functions
73 * ircd/m_jupe.c: convert to new send functions
75 * ircd/m_invite.c: convert to new send functions
77 * ircd/m_info.c: convert to new send functions
79 * ircd/m_help.c: convert to new send functions
81 * ircd/m_gline.c: convert to new send functions
83 * ircd/m_error.c: convert to new send functions
85 * ircd/m_endburst.c: convert to new send functions
87 * ircd/m_die.c: convert to new send functions
89 * ircd/m_destruct.c: convert to new send functions
91 * ircd/m_defaults.c: convert to new send functions
93 * ircd/m_connect.c: convert to new send functions
95 2000-04-28 Perry Lorier <isomer@coders.net>
96 * RELEASE.NOTES: Describe a few more undocumented features.
97 * config/config-sh.in: change the default paths for logging
98 and the recommended number of channels.
99 * include/supported.h: Rearrange slightly, added CHANTYPE's
101 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
103 * ircd/m_close.c: convert to send_reply
105 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
107 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
109 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
111 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
112 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
113 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
114 carefully rethought...
116 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
118 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
120 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
121 numeric nick; therefore, we have to use the server name
123 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
125 * ircd/send.c: fix minor bugs
127 * ircd/s_user.c (check_target_limit): mark dead code so I filter
130 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
133 * ircd/parse.c: mark dead code so I filter it when I grep
135 * ircd/map.c: mark dead code so I filter it when I grep
137 * ircd/ircd.c: mark dead code so I filter it when I grep
139 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
142 * ircd/channel.c: mark dead code so I filter it when I grep
144 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
145 hope I'm not stepping on toes...
147 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
148 conversions; use ircd_snprintf in a couple of cases to negate the
149 possibility of buffer overflow
151 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
153 * ircd/channel.c: convert as much as possible to new send
156 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
157 test member->user->from->fd, not from->fd
159 * ircd/gline.c (gline_add): go ahead and add badchans; we just
160 won't look for them in m_gline; this way, they always work...
162 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
164 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
165 ircd_vsnprintf conversion specifiers
167 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
168 I have my conversion specifiers
170 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
172 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
175 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
176 little less brain-dead
178 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
180 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
183 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
186 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
189 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
191 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
193 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
196 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
198 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
199 a numeric as needing to use an explicit pattern, which will be the
200 first argument in the variable argument list
202 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
203 non-prefixed nospoof PING
205 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
206 non-prefixed SERVER login
208 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
209 a numeric usage further up)
211 * include/send.h: declare sendrawto_one
213 * ircd/send.c (sendrawto_one): new function to use ONLY for
214 non-prefixed commands, like PING to client, or PASS/SERVER on
217 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
219 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
220 future expansion (channel numerics?)
222 * include/ircd_snprintf.h: added documentation to # to explain use
223 with %C; added documentation for : to explain use with %C; added
224 documentation for %H for channels
226 * ircd/whocmds.c: use send_reply
228 * ircd/userload.c: use sendcmdto_one
230 * ircd/uping.c: use sendcmdto_one
232 * ircd/send.c: use new flags to %C format string; ':' prefixes
233 client name with a colon for local connects, '#' uses
234 nick!user@host form for local connects
236 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
237 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
239 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
241 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
244 * ircd/s_auth.c: use sendto_opmask_butone
246 * ircd/res.c: use sendcmdto_one
248 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
251 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
253 * ircd/support.c: dumpcore is no longer used, so get rid of it
255 * ircd/parse.c: use send_reply, sendcmdto_one
257 * ircd/map.c: use send_reply
259 * ircd/listener.c: use send_reply
261 * ircd/jupe.c: use sendto_opmask_butone, send_reply
263 * ircd/ircd_reply.c: use send_reply
265 * ircd/ircd.c: use sendto_opmask_butone
267 * ircd/gline.c: use sendto_opmask_butone, send_reply
269 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
270 registered clients; make FLAG_ALT print nick!user@host; make
271 FLAG_COLON print :blah
273 * ircd/class.c (report_classes): use send_reply instead of
276 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
278 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
279 sendto_one with sendcmdto_one
281 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
283 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
284 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
285 sendcmdto_match_butone
287 * include/send.h: declare sendcmdto_match_butone
289 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
291 * ircd/jupe.c: update to use send_reply()
293 * ircd/gline.c: update to use send_reply()
295 * include/ircd_reply.h: declare send_reply
297 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
298 replies; uses ircd_snprintf
300 * ircd/send.c: added comments to redirect searchers to appropriate
301 sendcmdto_* function; moved new functions to end of file; added
302 explanatory comments; reordered arguments; defined new functions
305 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
307 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
309 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
311 * ircd/gline.c: reorder arguments to sendcmdto_* functions
313 * include/send.h: reorder arguments, add explanatory comments,
314 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
315 and vsendto_opmask_butone
317 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
319 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
320 vsendto_op_mask that uses '*' instead of the receiving client
323 * include/send.h: declare sendcmdto_channel_butone; takes a skip
324 argument that allows you to skip (or not to skip) deaf users,
325 users behind bursting servers, and non channel operators
327 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
329 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
330 sendto_channel_butserv has a subtle bug; also wrote
331 sendcmdto_common_channels.
333 * include/send.h: declare new sendcmdto_* functions
335 * ircd/jupe.c: support local deactivations of jupes
337 * ircd/gline.c: support local deactivations of glines
339 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
340 deactivated; if they aren't locally deactivated, then it slaves to
341 the net-wide activation status; JupeIsRemActive() tests only
342 whether the jupe is active everywhere else
344 * include/gline.h: GLINE_LDEACT allows glines to be locally
345 deactivated; if they aren't locally deactivated, then it slaves to
346 the net-wide activation status; GlineIsRemActive() tests only
347 whether the gline is active everywhere else
349 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
350 gline expires after the new one will, we drop the new one,
351 otherwise we add the G-line after that one (so the wide one will
352 apply first); if the new one contains an existing G-line and if it
353 will expire after the existing one, we drop the existing one to
356 * ircd/m_gline.c (mo_gline): opers could issue remote local
357 glines when CONFIG_OPERCMDS was off; fixed
359 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
361 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
364 * ircd/gline.c: add flags argument to gline_activate and
365 gline_deactivate for future expansion
367 * ircd/m_gline.c: pass flags to gline_activate and
370 * include/gline.h: add flags argument to gline_activate and
373 * ircd/jupe.c: add flags argument to jupe_activate and
374 jupe_deactivate for future expansion
376 * include/jupe.h: add flags argument to jupe_activate and
379 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
380 local, active; pass flags to jupe_activate and jupe_deactivate
382 * include/gline.h: remove dead code
384 * ircd/gline.c: make gline expire times relative to CurrentTime,
385 since that should be monotonically increasing, instead of
386 TStime(), which can be set backwards, and which can therefore
387 cause an expire time to increase; make local glines be removed
388 instead of just deactivated; don't let gline_find() look for
389 user@host glines if the mask being looked up is a channel mask
391 * ircd/send.c (vsendcmdto_one): forgot to account for the case
392 where origin is a server and destination is a user
394 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
395 since that should be monotonically increasing, instead of
396 TStime(), which can be set backwards, and which can therefore
397 cause an expire time to increase; make local jupes be removed
398 instead of just deactivated
400 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
401 limit is fine. any other warnings I should know about?
403 2000-04-15 Thomas Helvey <tomh@inxpress.net>
405 * ircd/*.c: const correctness and type safety cleanups to
406 get code to compile with C++ compiler. Still has
407 signed/unsigned comparison warnings.
409 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
411 * ircd/userload.c: change <sys/time.h> include to <time.h> for
414 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
416 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
419 * ircd/s_user.c: move gline_lookup function call into
420 register_user, where it'll have a username to lookup!
422 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
423 functions; also stuff send_error_to_client into return clauses
425 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
426 functions; also use send_error_to_client where that makes sense
428 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
429 functions; also use send_error_to_client where that makes sense
431 * ircd/gline.c: modify to utilize new sendcmdto_* series of
432 functions; also fix gline_lookup() to deal properly with remote
433 clients--boy, do struct Client and struct User need to be cleaned
436 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
439 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
440 sendcmdto_serv_butone(), all utilizing the %v conversion of
443 * include/send.h: define IRC_BUFSIZE, max size of a message;
444 declare sendcmdto_one(), vsendcmdto_one(), and
445 sendcmdto_serv_butone()
447 * include/msg.h: define all the CMD_* constants needed to utilize
448 the new sendcmdto_* series of functions
450 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
452 * ircd/gline.c: remove old, dead code.
454 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
455 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
456 (don't advertise proxies); remove dead code
458 * ircd/parse.c: oper handler for JUPE only lists jupes unless
459 CONFIG_OPERCMDS is enabled
461 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
462 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
464 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
465 always return ERR_DISABLED
467 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
468 enabled, always return ERR_DISABLED
470 * ircd/s_err.c: add error message to indicate disabled commands
472 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
474 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
476 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
477 CONFIG_NEW_MODE to 'y' for now
479 * ircd/gline.c (gline_list): fix a minor formatting bogon
481 * BUGS: since I fixed that bug, might as well mark it fixed.
483 * ircd/m_join.c: look up badchans with GLINE_EXACT
485 * ircd/m_gline.c: fix parc count problems; look up existing
486 G-lines with GLINE_EXACT; only set new lastmod when
487 activating/deactivating existing glines if old lastmod was not 0
489 * ircd/gline.c: forgot to copy the gline reason over; don't
490 propagate a gline with 0 lastmod if origin is user; add
491 GLINE_EXACT to force exact matching of gline mask
493 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
496 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
497 but gline_lookup() actually takes a client--d'oh.
499 2000-04-13 Thomas Helvey <tomh@inxpress.net>
500 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
502 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
504 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
506 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
509 * ircd/whocmds.c: Change idle time calc from socket idle to user
512 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
514 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
515 too, for ircd_snprintf.c
517 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
518 comments; mostly descended from the Linux manpage for printf, but
519 also documenting the extensions.
521 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
522 client; make 'q' be the same as 'L'; remove __inline__; only
523 define EXTENSION if HAVE_LONG_LONG is defined
525 * include/handlers.h: declare m_gline()
527 * ircd/parse.c: gline can be called by users, but it only lists
530 * ircd/s_user.c (set_nick_name): resend gline if a remote server
531 introduces a glined client
533 * ircd/s_serv.c (server_estab): burst glines, too
535 * ircd/gline.c: fix up all the expire times to be offsets;
536 simplify gline_resend()
538 * ircd/m_gline.c: begin coding replacements for ms_gline(),
539 mo_gline(), and m_gline()
541 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
542 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
544 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
546 * tools/Bouncer/*: Add comments/documentation/tags.
547 * tools/Bouncer/*: Add debug defines, make task fork().
549 2000-04-12 Thomas Helvey <tomh@inxpress.net>
550 * ircd/s_err.c: Cleanup s_err.c make one table so we
551 don't have to do anything tricky to get an error string.
553 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
554 * Add port bouncer for http (x/w)
556 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
558 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
559 call to gline_find(); also used GlineReason() instead of direct
560 reference to structure member
562 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
563 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
566 * ircd/channel.c: nothing seems to be called anywhere...
568 * ircd/s_err.c: update a couple of replies to dovetail with new
571 * ircd/gline.c: begin complete re-implementation of gline.c along
572 the lines of the final design of jupe.c
574 * include/gline.h: begin complete re-implementation of gline.c
575 along the lines of the final design of jupe.c
577 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
580 * ircd/ircd_snprintf.c: my new snprintf()-like functions
582 * include/ircd_snprintf.h: my new snprintf()-like functions
584 2000-04-11 Thomas Helvey <tomh@inxpress.net>
585 * ircd/IPcheck.c: removed old dead code
586 * ircd/s_user.c (send_user_info): removed non-standard
587 user not found message for userhost/userip
589 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
591 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
592 * doc/p10.html: Work on chapter 4.
594 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
596 * ircd/channel.c (mode_parse_client): fix coredump on /mode
597 #foobar +o nosuchnick
599 2000-04-10 Perry Lorier <Isomer@coders.net>
602 2000-04-09 Thomas Helvey <tomh@inxpress.net>
603 * include/IPcheck.h: fix prototype
604 * ircd/s_user.c: fix usage of IPcheck_remote_connect
605 * ircd/IPcheck.c: removed unused args
607 2000-04-09 Thomas Helvey <tomh@inxpress.net>
608 * include/IPcheck.h: add proto for IPcheck_expire
610 * ircd/IPcheck.c: Rewrote
612 * ircd/ircd.c: Add IPcheck_expire to main message loop
614 * ircd/s_user.c: Redo target hashing, refactor target code
616 * include/numeric.h: Cleaned up numerics, added which ones are
617 in use by other networks and what they are in use for.
619 * ircd/channel.c: cleaned can_join(), allow anyone through anything
620 if /invited, simplified the function. Opers overusing OPEROVERRIDE
621 will get a message explaining to them not to cheat.
623 * ircd/m_join.c: cleaned up the various join functions, should be
624 a lot more efficient. Still needs work. Now assumes that s<->s
625 won't send it a JOIN 0. Service coders - note this and tread with
628 * ircd/m_stats.c: added Gte-'s stats doc patch.
630 * ircd/m_version.c: /version now returns the 005 numeric as well.
631 as requested by Liandrin.
634 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
636 * ircd/m_clearmode.c: add include for support.h for write_log()
638 * configure: move ircd/crypt/* to tools/*
640 2000-04-06 Thomas Helvey <tomh@inxpress.net>
641 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
642 set client host to server alias if connection from localhost
644 2000-04-06 Perry Lorier <isomer@coders.net>
645 * ircd/ircd.c: Fix core during pinging (oops)
647 2000-04-06 Perry Lorier <isomer@coders.net>
648 * ircd/send.c: fixed wrong ident being sent to channels bug.
649 * include/numerics.h: Updated some of the numerics from other
650 networks. Flagged some as 'unused' by undernet.
652 2000-03-30 Perry Lorier <isomer@coders.net>
653 * ircd/ircd.c: Lets see if this helps the ping problem at all.
654 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
655 time for local clients. (as requested), extended who now returns all
656 the flags (@+!) so you can tell the complete state of a client.
658 2000-03-30 Thomas Helvey <tomh@inxpress.net>
659 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
661 2000-03-30 Perry Lorier <isomer@coders.net>
662 * ircd/parse.c: oops, missed opers.
664 2000-03-30 Perry Lorier <isomer@coders.net>
665 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
666 for so long. Remember: m_ping MUST be in the parse array. :)
668 2000-03-30 Perry Lorier <isomer@coders.net>
669 * ircd/ircd.c: test in check_pings was wrong. I move that we
670 disallow cvs commit after 10pm localtime....
672 2000-03-30 Perry Lorier <isomer@coders.net>
673 * ircd/m_pong.c: Fix it for servers too.
675 2000-03-30 Perry Lorier <isomer@coders.net>
676 * ircd/m_pong.c: Fix ping timeout bugs
678 2000-03-30 Perry Lorier <isomer@coders.net>
679 * ircd/channel.c: Bans had CurrentTime in their when field instead
682 2000-03-31 Thomas Helvey <tomh@ixpress.net>
683 * ircd/numnicks.c (SetXYYCapacity): fix for extended
686 2000-03-30 Perry Lorier <isomer@coders.net>
687 * ircd/m_nick.c: send kills both ways so when we add nick change
688 on collision we don't desync the network.
690 * ircd/map.c: Fixup the map a bit more.
692 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
694 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
696 * ircd/m_opmode.c: Log the mode changes to OPATH
698 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
701 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
704 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
706 * config/config-sh.in: added OPATH for opmode log file
708 * ircd/m_clearmode.c (do_clearmode): updated uses of
709 modebuf_mode_string() for the new usage
711 * ircd/channel.c: added flag MODE_FREE and an int argument to
712 modebuf_mode_string() to indicate that the string must be free'd;
713 updated calls to modebuf_mode_string() for the new usage; called
714 collapse(pretty_mask()) on the ban string and use allocated memory
715 for it; added ban list length accounting; fixed a number of small
716 bugs in ban processing
718 * include/channel.h: added flag MODE_FREE and an int argument to
719 modebuf_mode_string() to indicate that the string must be free'd
721 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
722 keys and limits that are set
724 2000-03-30 Perry Lorier <isomer@coders.net>
725 * ircd/ircd.c: rewrote check_pings() for maintainability
726 and speed. Also changed quit msg's so they don't have
727 redundant nick[host] info in them.
729 * ircd/send.c: Changed write errors to report what error
730 occured (if possible).
732 * ircd/gline.c: added gline comment to the quit.
734 * ircd/m_server.c: Added suggestions to server quits mentioning
735 what went wrong so the admin can fix it earlier instead of asking
738 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
739 servers that aren't fully burst yet. And show '(--s)' for servers
742 * doc/example.conf: Fixed wrapped U:
744 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
746 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
747 mode_parse() (version selectable at compile time)
749 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
751 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
753 * config/config-sh.in: add new config option to enable new m_mode
756 * doc/Configure.help: add documentation for new config option
759 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
760 MODE -v : Not enough parameters
762 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
763 +k and +l even if they weren't set...
765 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
767 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
768 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
769 for; test the 0-th member, not the i-th member, of the client
772 * ircd/m_clearmode.c (do_clearmode): use the new
773 mode_invite_clear() function
775 * ircd/channel.c: cleared up all the compile-time warnings and
778 * include/channel.h: added declarations for mode_ban_invalidate()
779 and mode_invite_clear()
781 * ircd/channel.c: finished mode_parse(), then broke it up into a
782 dozen or so helper functions to make the code easier to read
784 2000-03-29 Thomas Helvey <tomh@inxpress.net>
785 * ircd/ircd.c: refactor server initialization a bit, use
786 getopt for parsing command line, refactor init_sys, main,
789 * ircd/s_bsd.c: add functions for initialization to clean
790 up logic a bit and remove duplicated code.
792 * include/ircd.h: add struct for server process related
795 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
797 * ircd/channel.c: initial definition of mode_parse(); flags to
798 prevent doing the same thing multiple times; helper method
799 send_notoper() to send a "Not oper"/"Not on channel" notice
801 * include/channel.h: declare mode_parse() and helper flags
803 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
804 sending to match the current action of set_mode() closely enough
805 that hopefully there won't be major conflicts
807 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
808 building logic, reversed the order of the arguments to mode
809 commands to have '-' preceed '+'
811 2000-03-29 Thomas Helvey <tomh@inxpress.net>
812 * ircd/s_bsd.c (add_connection): don't disable socket options
813 let OS tune itself and allow important performance tweaks to
816 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
818 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
819 confused by set_mode, which is doing some really weird logic;
820 guess what I'm going to rewrite next? ;)
822 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
824 * include/channel.h: added MODE_SAVE for the bounds checking stuff
827 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
828 make it do bounds checking on the buffer; all modes are sent only
829 if the all parameter is 1; modebuf_flush is the exported wrapper
831 * include/channel.h: add BOUNCE, renumber flags to get a little
834 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
835 BOUNCE; send DESYNCH message
837 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
839 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
840 channel actually has in effect for deletion
842 * ircd/channel.c: added explanatory comments to all added
843 functions; made flushing take place at the correct place even if
844 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
845 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
846 is empty, fixed the apparent source, removed some bogus string
847 termination code, properly terminate the mode strings, add support
848 for HACK2 and HACK3, made limit strings not be sent if the limit
849 is being removed, changed where '+' and '-' come from in sent
850 strings, added support for DEOP flag, set up bouncing code for
853 * ircd/Makefile.in: ran make depend
855 * include/channel.h: added new defines for future functionality,
856 made modebuf_flush() return int so I can use tail recursion
858 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
859 to make it all compile
861 * ircd/m_opmode.c: add msg.h to includes...
863 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
865 * ircd/channel.c (modebuf_flush): realized I forgot to
866 nul-terminate addbuf/rembuf properly...
868 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
870 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
871 sendto_serv_butone--blah^2
873 * ircd/send.c (sendto_serv_butone): stupid comments confused me
875 * ircd/channel.c (modebuf_flush): if there are no mode changes to
876 propagate, we're done...
878 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
879 not sendto_all_butone
881 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
883 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
885 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
888 * ircd/parse.c: added messages for opmode and clearmode
890 * include/handlers.h: added declarations for mo_opmode(),
891 ms_opmode(), mo_clearmode(), and ms_clearmode()
893 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
896 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
897 MODEBUF_DEST_OPMODE flag
899 * ircd/channel.c (modebuf_flush): added new flag,
900 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
901 to originate from source's server (or source itself, if
902 IsServer(source)); also causes a server-level MODE to be sent as
905 * include/channel.h: defined MODEBUF_DEST_SERVER,
908 * ircd/channel.c: Add another argument to build_string() to handle
909 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
910 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
913 2000-03-27 Perry Lorier <isomer@coders.net>
915 * ircd/s_bsd.c: fixed missing 'u' typo.
917 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
919 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
920 _mode_string(), _mode_client(), _flush(); also implemented a
921 simple build_string()
923 * include/channel.h: added definition of ModeBuf, modebuf_*
924 manipulation functions, and a couple of helper macros
926 2000-03-24 Thomas Helvey <tomh@inxpress.net>
927 * numicks.c: convert extended numerics to use original mask version
930 2000-03-23 Thomas Helvey <tomh@inxpress.net>
931 * Merge in changes from production
932 2000-03-22 Thomas Helvey <tomh@inxpress.net>
933 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
934 * rfc1459.unet: Add Maniac's documentation for /names 0
935 * Fix misc. jupe bugs that somehow made it into the tree
936 * Escape /names 0 to mean /names --Maniac
937 * Don't core when server asks for info --Maniac
938 * Add Kev's jupe patch --Bleep
939 * Add Maniacs squit patch --Bleep
940 * Merge in u2_10_10_beta07 changes --Bleep
941 * Merge in u2_10_10_beta06 changes --Bleep
942 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
943 #-----------------------------------------------------------------------------
945 # ChangeLog for ircu2.10.11
947 # $Id: ChangeLog,v 1.109 2000-04-28 15:10:14 kev Exp $
949 # Insert new changes at beginning of the change list.