1 2000-05-29 Perry Lorier <Isomer@coders.net>
2 * ircd/m_stats.c: add /stats v to do only the last part of the /trace
3 * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
4 you think it'll get bored and fix itself?
6 2000-06-09 Greg Sikorski <gte@atomicrevs.demon.co.uk>
8 * ircd/m_names.c: Clean up compiler warnings.
10 2000-06-09 Kevin L. Mitchell <klmitch@mit.edu>
12 * ircd/channel.c (mode_parse_client): don't send warning if
13 there's not enough arguments for a +/-o/v; means the habit of
14 doing "/mode #channel +oooooo bob" doesn't result in a bunch of
17 2000-06-04 Greg Sikorski <gte@atomicrevs.demon.co.uk>
19 * ircd/m_names.c: Re-factor code to remove unneccessary
20 GlobalChannelList iteration every time someone joins a channel.
22 2000-06-02 Kevin L. Mitchell <klmitch@mit.edu>
24 * ircd/s_user.c: add struct Gline * argument to register_user;
25 look up global glines and repropagate them if necessary; send
26 acknowledgement of gline to remote servers when registering users
28 * ircd/s_serv.c (server_estab): don't send acknowledgement of
29 local glines to remote servers; do send gline acknowledgement of
32 * ircd/m_user.c (m_user): pass new struct Gline * argument to
35 * ircd/m_pong.c: pass new struct Gline * argument to register_user
37 * ircd/m_nick.c (ms_nick): document protocol change
39 * ircd/gline.c: support GLINE_LASTMOD
41 * include/s_user.h: add struct Gline * argument to register_user
43 * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
45 * ircd/s_conf.c (find_kill): add unsigned int argument to
48 * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
49 glines; add unsigned int argument to gline_lookup()
51 * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
52 argument to gline_lookup()
54 * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
55 parameter, or when it falls out of bounds: see comments prior to
56 call to jupe_resend(); call server_estab with struct Jupe
57 parameter, so that we place the appropriate %<lastmod> in the
60 * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
61 server, as well as for servers when we're sending the BURST
63 * include/s_serv.h: add a struct Jupe * to the arguments for
64 server_estab() so that we can send the appropriate lastmod
67 * ircd/m_gline.c (ms_gline): actually, this should be the
68 slightest bit more efficient...
70 * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
73 * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
76 * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
79 * ircd/channel.c (joinbuf_join): really remove user from local
82 2000-05-29 Perry Lorier <Isomer@coders.net>
83 * ircd/m_names.c: Removed redundant space.
84 * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
86 2000-05-18 Kevin L. Mitchell <klmitch@mit.edu>
88 * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
91 2000-05-04 Kevin L. Mitchell <klmitch@mit.edu>
93 * ircd/channel.c: replace bogus assertions with returns, which is
94 logically correct; only wipe out limit/key if they were originally
95 set in the first place; remove user from channel when doing a
96 PARTALL; only send MODE +o for user CREATEing channel if user is
97 not MyUser--CREATE will only be used if the channel did not
98 originally exist, therefore we can assume no one local is on the
99 channel anyway, and we don't exactly need for the user to see an
100 explicit +o for themselves
102 * doc/readme.gline: describe the syntax of the GLINE command
104 * doc/readme.jupe: update to reflect a couple of changes to JUPE
106 * ircd/gline.c: don't propagate local changes
108 * ircd/jupe.c: don't propagate local changes
110 * ircd/m_gline.c (mo_gline): force local flag when deactivating
111 glines with 0 lastmod
113 * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
114 are now removed instead of being deactivated
116 * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
119 * ircd/channel.c (send_channel_modes): deal with one of the last
122 * ircd/m_burst.c (ms_burst): debugged ban processing; removed
125 * ircd/channel.c (modebuf_extract): remove debugging
126 sendto_opmask_butone calls
128 2000-05-03 Kevin L. Mitchell <klmitch@mit.edu>
130 * ircd/channel.c: support a couple of new flags to support using
131 mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
132 of modebuf_extract to extract added flags for use by ms_burst
134 * include/channel.h: a couple of new flags to support using
135 mode_parse inside ms_burst
137 * ircd/m_burst.c (ms_burst): brand new implementation of BURST
139 * ircd/m_endburst.c: add loop to processing of end_of_burst to
140 free empty channels after the BURST is over.
142 * ircd/m_server.c: convert to use new send.c functions--I wanted
143 to rewrite it from scratch, but the logic's pretty complex; I may
144 still rewrite it, though...
146 2000-05-02 Thomas Helvey <tomh@inxpress.net>
148 * ircd/ircd.c: fix broken header include ordering
150 2000-05-02 Thomas Helvey <tomh@inxpress.net>
152 * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
153 review emailed privately
155 * include/IPcheck.h: removed unneeded include
157 2000-05-02 Kevin L. Mitchell <klmitch@mit.edu>
159 * ircd/s_user.c (hunt_server): throw in a comment so I know what
160 the sendto_one is for
162 * include/querycmds.h (Count_unknownbecomesclient): convert to
165 * ircd/send.c: start removing dead code
167 * include/send.h: start removing dead code
169 * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
172 * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
174 2000-05-01 Kevin L. Mitchell <klmitch@mit.edu>
176 * ircd/m_stats.c: convert to sendcmdto_one / send_reply
178 * ircd/m_kick.c: Completely reimplement m_kick
180 * ircd/channel.c: send_user_joins removed; it was dead code,
183 2000-05-01 Perry Lorier <isomer@coders.net>
184 * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
185 * ircd/channels.c: My fix for the part problem. Untested, probably
186 won't work. Can't be much worse than the current problem.
187 it'll either work or core, take your pick.
190 2000-04-30 Perry Lorier <isomer@coders.net>
191 * config/config-sh.in: Fix for CONNEXIT
192 * ircd/s_{user,misc}.c: Fix for CONNEXIT
193 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
194 (Kev: Want to come talk to me about this?)
196 2000-04-30 Steven M. Doyle <steven@doyle.net>
198 - general cleanups and readability enhancements
199 - rewrite of setuid/chroot code.
200 - server will no longer run as root
201 - -DPROFIL compile option removed
202 - Fixed IPcheck API calls
204 * config/config-sh.in
205 - Fixed up chroot compile options
206 - Added options for debug and profile compiles
208 * config/gen.ircd.Makefile
209 - Support for new debug/profile options
212 - Support for new debug/profile options
218 - Removed old API prototypes, added new ones
221 - Readability cleanups (well, I -think-...)
222 - Changed IPRegistryEntry.last_connect to a time_t. The previously
223 used unsigned short was probably causing interesting things after
224 a client had been connected longer than about 65,535 seconds...
225 - Removed old API functions.
228 - Removed IPcheck.h include
230 * Additionally modified IPcheck API calls in:
240 2000-04-30 Perry Lorier <isomer@coders.net>
241 * ircd/s_bsd.c: Sigh. :)
242 * ircd/m_mode.c: fix for modeless channels by poptix.
244 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
246 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
248 * ircd/channel.c (clean_channelname): make clean_channelname also
249 truncate long channel names
251 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
253 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
255 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
258 * include/channel.h: definitions and declarations for the struct
261 2000-04-29 Perry Lorier <isomer@coders.net>
262 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
264 2000-04-29 Perry Lorier <isomer@coders.net>
265 * ircd/s_bsd.c: Add debugging code to IPcheck
267 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
269 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
271 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
274 * ircd/m_userhost.c (m_userhost): add a dead code comment
276 * ircd/m_desynch.c: forgot one...
278 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
280 * ircd/m_proto.c (proto_send_supported): just change a comment so
281 it doesn't show up in my scans
283 * ircd/ircd_reply.c (send_reply): fix a slight bug...
285 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
288 * ircd/parse.c (parse_server): argument wrangling to make
289 processing in do_numeric a little easier to deal with
291 * ircd/s_serv.c (server_estab): SERVER should come from
292 acptr->serv->up, not &me
294 * ircd/m_lusers.c: accidentally left out sptr for a %C
296 * ircd/send.c: hack to support doing wallchops...
298 * ircd/m_whowas.c: convert to new send functions
300 * ircd/m_whois.c: convert to new send functions
302 * ircd/m_who.c: convert to new send functions
304 * ircd/m_wallops.c: convert to new send functions
306 * ircd/m_wallchops.c: convert to new send functions
308 * ircd/m_version.c: convert to new send functions
310 * ircd/m_userip.c: convert to new send functions
312 * ircd/m_userhost.c: convert to new send functions
314 * ircd/m_uping.c: convert to new send functions
316 * ircd/m_trace.c: convert to new send functions
318 * ircd/m_topic.c: convert to new send functions
320 * ircd/m_time.c: convert to new send functions
322 * ircd/m_squit.c: convert to new send functions
324 * ircd/m_silence.c: convert to new send functions
326 * ircd/m_settime.c: convert to new send functions
328 * ircd/m_restart.c: convert to new send functions
330 * ircd/m_rehash.c: convert to new send functions
332 * ircd/m_privmsg.c: convert to new send functions
334 * ircd/m_pong.c: convert to new send functions
336 * ircd/m_ping.c: convert to new send functions
338 * ircd/m_pass.c: convert to new send functions
340 * ircd/m_opmode.c: convert to new send functions
342 * ircd/m_oper.c: convert to new send functions
344 * ircd/m_notice.c: convert to new send functions
346 * ircd/m_nick.c: convert to new send functions
348 * ircd/m_names.c: convert to new send functions
350 * ircd/m_motd.c: convert to new send functions
352 * ircd/m_mode.c: convert to new send functions
354 * ircd/m_map.c: convert to new send functions
356 * ircd/m_lusers.c: convert to new send functions
358 * ircd/m_list.c: convert to new send functions
360 * ircd/m_links.c: convert to new send functions
362 * ircd/m_kill.c: convert to new send functions
364 * ircd/m_jupe.c: convert to new send functions
366 * ircd/m_invite.c: convert to new send functions
368 * ircd/m_info.c: convert to new send functions
370 * ircd/m_help.c: convert to new send functions
372 * ircd/m_gline.c: convert to new send functions
374 * ircd/m_error.c: convert to new send functions
376 * ircd/m_endburst.c: convert to new send functions
378 * ircd/m_die.c: convert to new send functions
380 * ircd/m_destruct.c: convert to new send functions
382 * ircd/m_defaults.c: convert to new send functions
384 * ircd/m_connect.c: convert to new send functions
386 2000-04-28 Perry Lorier <isomer@coders.net>
387 * RELEASE.NOTES: Describe a few more undocumented features.
388 * config/config-sh.in: change the default paths for logging
389 and the recommended number of channels.
390 * include/supported.h: Rearrange slightly, added CHANTYPE's
392 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
394 * ircd/m_close.c: convert to send_reply
396 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
398 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
400 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
402 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
403 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
404 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
405 carefully rethought...
407 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
409 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
411 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
412 numeric nick; therefore, we have to use the server name
414 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
416 * ircd/send.c: fix minor bugs
418 * ircd/s_user.c (check_target_limit): mark dead code so I filter
421 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
424 * ircd/parse.c: mark dead code so I filter it when I grep
426 * ircd/map.c: mark dead code so I filter it when I grep
428 * ircd/ircd.c: mark dead code so I filter it when I grep
430 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
433 * ircd/channel.c: mark dead code so I filter it when I grep
435 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
436 hope I'm not stepping on toes...
438 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
439 conversions; use ircd_snprintf in a couple of cases to negate the
440 possibility of buffer overflow
442 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
444 * ircd/channel.c: convert as much as possible to new send
447 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
448 test member->user->from->fd, not from->fd
450 * ircd/gline.c (gline_add): go ahead and add badchans; we just
451 won't look for them in m_gline; this way, they always work...
453 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
455 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
456 ircd_vsnprintf conversion specifiers
458 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
459 I have my conversion specifiers
461 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
463 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
466 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
467 little less brain-dead
469 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
471 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
474 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
477 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
480 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
482 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
484 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
487 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
489 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
490 a numeric as needing to use an explicit pattern, which will be the
491 first argument in the variable argument list
493 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
494 non-prefixed nospoof PING
496 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
497 non-prefixed SERVER login
499 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
500 a numeric usage further up)
502 * include/send.h: declare sendrawto_one
504 * ircd/send.c (sendrawto_one): new function to use ONLY for
505 non-prefixed commands, like PING to client, or PASS/SERVER on
508 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
510 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
511 future expansion (channel numerics?)
513 * include/ircd_snprintf.h: added documentation to # to explain use
514 with %C; added documentation for : to explain use with %C; added
515 documentation for %H for channels
517 * ircd/whocmds.c: use send_reply
519 * ircd/userload.c: use sendcmdto_one
521 * ircd/uping.c: use sendcmdto_one
523 * ircd/send.c: use new flags to %C format string; ':' prefixes
524 client name with a colon for local connects, '#' uses
525 nick!user@host form for local connects
527 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
528 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
530 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
532 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
535 * ircd/s_auth.c: use sendto_opmask_butone
537 * ircd/res.c: use sendcmdto_one
539 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
542 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
544 * ircd/support.c: dumpcore is no longer used, so get rid of it
546 * ircd/parse.c: use send_reply, sendcmdto_one
548 * ircd/map.c: use send_reply
550 * ircd/listener.c: use send_reply
552 * ircd/jupe.c: use sendto_opmask_butone, send_reply
554 * ircd/ircd_reply.c: use send_reply
556 * ircd/ircd.c: use sendto_opmask_butone
558 * ircd/gline.c: use sendto_opmask_butone, send_reply
560 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
561 registered clients; make FLAG_ALT print nick!user@host; make
562 FLAG_COLON print :blah
564 * ircd/class.c (report_classes): use send_reply instead of
567 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
569 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
570 sendto_one with sendcmdto_one
572 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
574 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
575 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
576 sendcmdto_match_butone
578 * include/send.h: declare sendcmdto_match_butone
580 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
582 * ircd/jupe.c: update to use send_reply()
584 * ircd/gline.c: update to use send_reply()
586 * include/ircd_reply.h: declare send_reply
588 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
589 replies; uses ircd_snprintf
591 * ircd/send.c: added comments to redirect searchers to appropriate
592 sendcmdto_* function; moved new functions to end of file; added
593 explanatory comments; reordered arguments; defined new functions
596 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
598 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
600 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
602 * ircd/gline.c: reorder arguments to sendcmdto_* functions
604 * include/send.h: reorder arguments, add explanatory comments,
605 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
606 and vsendto_opmask_butone
608 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
610 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
611 vsendto_op_mask that uses '*' instead of the receiving client
614 * include/send.h: declare sendcmdto_channel_butone; takes a skip
615 argument that allows you to skip (or not to skip) deaf users,
616 users behind bursting servers, and non channel operators
618 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
620 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
621 sendto_channel_butserv has a subtle bug; also wrote
622 sendcmdto_common_channels.
624 * include/send.h: declare new sendcmdto_* functions
626 * ircd/jupe.c: support local deactivations of jupes
628 * ircd/gline.c: support local deactivations of glines
630 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
631 deactivated; if they aren't locally deactivated, then it slaves to
632 the net-wide activation status; JupeIsRemActive() tests only
633 whether the jupe is active everywhere else
635 * include/gline.h: GLINE_LDEACT allows glines to be locally
636 deactivated; if they aren't locally deactivated, then it slaves to
637 the net-wide activation status; GlineIsRemActive() tests only
638 whether the gline is active everywhere else
640 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
641 gline expires after the new one will, we drop the new one,
642 otherwise we add the G-line after that one (so the wide one will
643 apply first); if the new one contains an existing G-line and if it
644 will expire after the existing one, we drop the existing one to
647 * ircd/m_gline.c (mo_gline): opers could issue remote local
648 glines when CONFIG_OPERCMDS was off; fixed
650 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
652 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
655 * ircd/gline.c: add flags argument to gline_activate and
656 gline_deactivate for future expansion
658 * ircd/m_gline.c: pass flags to gline_activate and
661 * include/gline.h: add flags argument to gline_activate and
664 * ircd/jupe.c: add flags argument to jupe_activate and
665 jupe_deactivate for future expansion
667 * include/jupe.h: add flags argument to jupe_activate and
670 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
671 local, active; pass flags to jupe_activate and jupe_deactivate
673 * include/gline.h: remove dead code
675 * ircd/gline.c: make gline expire times relative to CurrentTime,
676 since that should be monotonically increasing, instead of
677 TStime(), which can be set backwards, and which can therefore
678 cause an expire time to increase; make local glines be removed
679 instead of just deactivated; don't let gline_find() look for
680 user@host glines if the mask being looked up is a channel mask
682 * ircd/send.c (vsendcmdto_one): forgot to account for the case
683 where origin is a server and destination is a user
685 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
686 since that should be monotonically increasing, instead of
687 TStime(), which can be set backwards, and which can therefore
688 cause an expire time to increase; make local jupes be removed
689 instead of just deactivated
691 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
692 limit is fine. any other warnings I should know about?
694 2000-04-15 Thomas Helvey <tomh@inxpress.net>
696 * ircd/*.c: const correctness and type safety cleanups to
697 get code to compile with C++ compiler. Still has
698 signed/unsigned comparison warnings.
700 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
702 * ircd/userload.c: change <sys/time.h> include to <time.h> for
705 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
707 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
710 * ircd/s_user.c: move gline_lookup function call into
711 register_user, where it'll have a username to lookup!
713 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
714 functions; also stuff send_error_to_client into return clauses
716 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
717 functions; also use send_error_to_client where that makes sense
719 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
720 functions; also use send_error_to_client where that makes sense
722 * ircd/gline.c: modify to utilize new sendcmdto_* series of
723 functions; also fix gline_lookup() to deal properly with remote
724 clients--boy, do struct Client and struct User need to be cleaned
727 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
730 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
731 sendcmdto_serv_butone(), all utilizing the %v conversion of
734 * include/send.h: define IRC_BUFSIZE, max size of a message;
735 declare sendcmdto_one(), vsendcmdto_one(), and
736 sendcmdto_serv_butone()
738 * include/msg.h: define all the CMD_* constants needed to utilize
739 the new sendcmdto_* series of functions
741 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
743 * ircd/gline.c: remove old, dead code.
745 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
746 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
747 (don't advertise proxies); remove dead code
749 * ircd/parse.c: oper handler for JUPE only lists jupes unless
750 CONFIG_OPERCMDS is enabled
752 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
753 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
755 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
756 always return ERR_DISABLED
758 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
759 enabled, always return ERR_DISABLED
761 * ircd/s_err.c: add error message to indicate disabled commands
763 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
765 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
767 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
768 CONFIG_NEW_MODE to 'y' for now
770 * ircd/gline.c (gline_list): fix a minor formatting bogon
772 * BUGS: since I fixed that bug, might as well mark it fixed.
774 * ircd/m_join.c: look up badchans with GLINE_EXACT
776 * ircd/m_gline.c: fix parc count problems; look up existing
777 G-lines with GLINE_EXACT; only set new lastmod when
778 activating/deactivating existing glines if old lastmod was not 0
780 * ircd/gline.c: forgot to copy the gline reason over; don't
781 propagate a gline with 0 lastmod if origin is user; add
782 GLINE_EXACT to force exact matching of gline mask
784 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
787 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
788 but gline_lookup() actually takes a client--d'oh.
790 2000-04-13 Thomas Helvey <tomh@inxpress.net>
791 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
793 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
795 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
797 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
800 * ircd/whocmds.c: Change idle time calc from socket idle to user
803 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
805 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
806 too, for ircd_snprintf.c
808 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
809 comments; mostly descended from the Linux manpage for printf, but
810 also documenting the extensions.
812 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
813 client; make 'q' be the same as 'L'; remove __inline__; only
814 define EXTENSION if HAVE_LONG_LONG is defined
816 * include/handlers.h: declare m_gline()
818 * ircd/parse.c: gline can be called by users, but it only lists
821 * ircd/s_user.c (set_nick_name): resend gline if a remote server
822 introduces a glined client
824 * ircd/s_serv.c (server_estab): burst glines, too
826 * ircd/gline.c: fix up all the expire times to be offsets;
827 simplify gline_resend()
829 * ircd/m_gline.c: begin coding replacements for ms_gline(),
830 mo_gline(), and m_gline()
832 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
833 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
835 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
837 * tools/Bouncer/*: Add comments/documentation/tags.
838 * tools/Bouncer/*: Add debug defines, make task fork().
840 2000-04-12 Thomas Helvey <tomh@inxpress.net>
841 * ircd/s_err.c: Cleanup s_err.c make one table so we
842 don't have to do anything tricky to get an error string.
844 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
845 * Add port bouncer for http (x/w)
847 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
849 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
850 call to gline_find(); also used GlineReason() instead of direct
851 reference to structure member
853 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
854 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
857 * ircd/channel.c: nothing seems to be called anywhere...
859 * ircd/s_err.c: update a couple of replies to dovetail with new
862 * ircd/gline.c: begin complete re-implementation of gline.c along
863 the lines of the final design of jupe.c
865 * include/gline.h: begin complete re-implementation of gline.c
866 along the lines of the final design of jupe.c
868 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
871 * ircd/ircd_snprintf.c: my new snprintf()-like functions
873 * include/ircd_snprintf.h: my new snprintf()-like functions
875 2000-04-11 Thomas Helvey <tomh@inxpress.net>
876 * ircd/IPcheck.c: removed old dead code
877 * ircd/s_user.c (send_user_info): removed non-standard
878 user not found message for userhost/userip
880 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
882 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
883 * doc/p10.html: Work on chapter 4.
885 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
887 * ircd/channel.c (mode_parse_client): fix coredump on /mode
888 #foobar +o nosuchnick
890 2000-04-10 Perry Lorier <Isomer@coders.net>
893 2000-04-09 Thomas Helvey <tomh@inxpress.net>
894 * include/IPcheck.h: fix prototype
895 * ircd/s_user.c: fix usage of IPcheck_remote_connect
896 * ircd/IPcheck.c: removed unused args
898 2000-04-09 Thomas Helvey <tomh@inxpress.net>
899 * include/IPcheck.h: add proto for IPcheck_expire
901 * ircd/IPcheck.c: Rewrote
903 * ircd/ircd.c: Add IPcheck_expire to main message loop
905 * ircd/s_user.c: Redo target hashing, refactor target code
907 * include/numeric.h: Cleaned up numerics, added which ones are
908 in use by other networks and what they are in use for.
910 * ircd/channel.c: cleaned can_join(), allow anyone through anything
911 if /invited, simplified the function. Opers overusing OPEROVERRIDE
912 will get a message explaining to them not to cheat.
914 * ircd/m_join.c: cleaned up the various join functions, should be
915 a lot more efficient. Still needs work. Now assumes that s<->s
916 won't send it a JOIN 0. Service coders - note this and tread with
919 * ircd/m_stats.c: added Gte-'s stats doc patch.
921 * ircd/m_version.c: /version now returns the 005 numeric as well.
922 as requested by Liandrin.
925 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
927 * ircd/m_clearmode.c: add include for support.h for write_log()
929 * configure: move ircd/crypt/* to tools/*
931 2000-04-06 Thomas Helvey <tomh@inxpress.net>
932 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
933 set client host to server alias if connection from localhost
935 2000-04-06 Perry Lorier <isomer@coders.net>
936 * ircd/ircd.c: Fix core during pinging (oops)
938 2000-04-06 Perry Lorier <isomer@coders.net>
939 * ircd/send.c: fixed wrong ident being sent to channels bug.
940 * include/numerics.h: Updated some of the numerics from other
941 networks. Flagged some as 'unused' by undernet.
943 2000-03-30 Perry Lorier <isomer@coders.net>
944 * ircd/ircd.c: Lets see if this helps the ping problem at all.
945 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
946 time for local clients. (as requested), extended who now returns all
947 the flags (@+!) so you can tell the complete state of a client.
949 2000-03-30 Thomas Helvey <tomh@inxpress.net>
950 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
952 2000-03-30 Perry Lorier <isomer@coders.net>
953 * ircd/parse.c: oops, missed opers.
955 2000-03-30 Perry Lorier <isomer@coders.net>
956 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
957 for so long. Remember: m_ping MUST be in the parse array. :)
959 2000-03-30 Perry Lorier <isomer@coders.net>
960 * ircd/ircd.c: test in check_pings was wrong. I move that we
961 disallow cvs commit after 10pm localtime....
963 2000-03-30 Perry Lorier <isomer@coders.net>
964 * ircd/m_pong.c: Fix it for servers too.
966 2000-03-30 Perry Lorier <isomer@coders.net>
967 * ircd/m_pong.c: Fix ping timeout bugs
969 2000-03-30 Perry Lorier <isomer@coders.net>
970 * ircd/channel.c: Bans had CurrentTime in their when field instead
973 2000-03-31 Thomas Helvey <tomh@ixpress.net>
974 * ircd/numnicks.c (SetXYYCapacity): fix for extended
977 2000-03-30 Perry Lorier <isomer@coders.net>
978 * ircd/m_nick.c: send kills both ways so when we add nick change
979 on collision we don't desync the network.
981 * ircd/map.c: Fixup the map a bit more.
983 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
985 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
987 * ircd/m_opmode.c: Log the mode changes to OPATH
989 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
992 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
995 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
997 * config/config-sh.in: added OPATH for opmode log file
999 * ircd/m_clearmode.c (do_clearmode): updated uses of
1000 modebuf_mode_string() for the new usage
1002 * ircd/channel.c: added flag MODE_FREE and an int argument to
1003 modebuf_mode_string() to indicate that the string must be free'd;
1004 updated calls to modebuf_mode_string() for the new usage; called
1005 collapse(pretty_mask()) on the ban string and use allocated memory
1006 for it; added ban list length accounting; fixed a number of small
1007 bugs in ban processing
1009 * include/channel.h: added flag MODE_FREE and an int argument to
1010 modebuf_mode_string() to indicate that the string must be free'd
1012 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
1013 keys and limits that are set
1015 2000-03-30 Perry Lorier <isomer@coders.net>
1016 * ircd/ircd.c: rewrote check_pings() for maintainability
1017 and speed. Also changed quit msg's so they don't have
1018 redundant nick[host] info in them.
1020 * ircd/send.c: Changed write errors to report what error
1021 occured (if possible).
1023 * ircd/gline.c: added gline comment to the quit.
1025 * ircd/m_server.c: Added suggestions to server quits mentioning
1026 what went wrong so the admin can fix it earlier instead of asking
1029 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
1030 servers that aren't fully burst yet. And show '(--s)' for servers
1033 * doc/example.conf: Fixed wrapped U:
1035 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
1037 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
1038 mode_parse() (version selectable at compile time)
1040 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
1042 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
1044 * config/config-sh.in: add new config option to enable new m_mode
1047 * doc/Configure.help: add documentation for new config option
1050 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
1051 MODE -v : Not enough parameters
1053 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
1054 +k and +l even if they weren't set...
1056 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
1058 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
1059 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
1060 for; test the 0-th member, not the i-th member, of the client
1063 * ircd/m_clearmode.c (do_clearmode): use the new
1064 mode_invite_clear() function
1066 * ircd/channel.c: cleared up all the compile-time warnings and
1069 * include/channel.h: added declarations for mode_ban_invalidate()
1070 and mode_invite_clear()
1072 * ircd/channel.c: finished mode_parse(), then broke it up into a
1073 dozen or so helper functions to make the code easier to read
1075 2000-03-29 Thomas Helvey <tomh@inxpress.net>
1076 * ircd/ircd.c: refactor server initialization a bit, use
1077 getopt for parsing command line, refactor init_sys, main,
1080 * ircd/s_bsd.c: add functions for initialization to clean
1081 up logic a bit and remove duplicated code.
1083 * include/ircd.h: add struct for server process related
1086 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
1088 * ircd/channel.c: initial definition of mode_parse(); flags to
1089 prevent doing the same thing multiple times; helper method
1090 send_notoper() to send a "Not oper"/"Not on channel" notice
1092 * include/channel.h: declare mode_parse() and helper flags
1094 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
1095 sending to match the current action of set_mode() closely enough
1096 that hopefully there won't be major conflicts
1098 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
1099 building logic, reversed the order of the arguments to mode
1100 commands to have '-' preceed '+'
1102 2000-03-29 Thomas Helvey <tomh@inxpress.net>
1103 * ircd/s_bsd.c (add_connection): don't disable socket options
1104 let OS tune itself and allow important performance tweaks to
1107 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
1109 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
1110 confused by set_mode, which is doing some really weird logic;
1111 guess what I'm going to rewrite next? ;)
1113 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
1115 * include/channel.h: added MODE_SAVE for the bounds checking stuff
1118 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
1119 make it do bounds checking on the buffer; all modes are sent only
1120 if the all parameter is 1; modebuf_flush is the exported wrapper
1122 * include/channel.h: add BOUNCE, renumber flags to get a little
1125 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
1126 BOUNCE; send DESYNCH message
1128 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
1130 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
1131 channel actually has in effect for deletion
1133 * ircd/channel.c: added explanatory comments to all added
1134 functions; made flushing take place at the correct place even if
1135 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
1136 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
1137 is empty, fixed the apparent source, removed some bogus string
1138 termination code, properly terminate the mode strings, add support
1139 for HACK2 and HACK3, made limit strings not be sent if the limit
1140 is being removed, changed where '+' and '-' come from in sent
1141 strings, added support for DEOP flag, set up bouncing code for
1144 * ircd/Makefile.in: ran make depend
1146 * include/channel.h: added new defines for future functionality,
1147 made modebuf_flush() return int so I can use tail recursion
1149 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
1150 to make it all compile
1152 * ircd/m_opmode.c: add msg.h to includes...
1154 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
1156 * ircd/channel.c (modebuf_flush): realized I forgot to
1157 nul-terminate addbuf/rembuf properly...
1159 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
1161 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
1162 sendto_serv_butone--blah^2
1164 * ircd/send.c (sendto_serv_butone): stupid comments confused me
1166 * ircd/channel.c (modebuf_flush): if there are no mode changes to
1167 propagate, we're done...
1169 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
1170 not sendto_all_butone
1172 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
1174 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
1176 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
1179 * ircd/parse.c: added messages for opmode and clearmode
1181 * include/handlers.h: added declarations for mo_opmode(),
1182 ms_opmode(), mo_clearmode(), and ms_clearmode()
1184 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
1187 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
1188 MODEBUF_DEST_OPMODE flag
1190 * ircd/channel.c (modebuf_flush): added new flag,
1191 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1192 to originate from source's server (or source itself, if
1193 IsServer(source)); also causes a server-level MODE to be sent as
1196 * include/channel.h: defined MODEBUF_DEST_SERVER,
1199 * ircd/channel.c: Add another argument to build_string() to handle
1200 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1201 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1204 2000-03-27 Perry Lorier <isomer@coders.net>
1206 * ircd/s_bsd.c: fixed missing 'u' typo.
1208 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
1210 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1211 _mode_string(), _mode_client(), _flush(); also implemented a
1212 simple build_string()
1214 * include/channel.h: added definition of ModeBuf, modebuf_*
1215 manipulation functions, and a couple of helper macros
1217 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1218 * numicks.c: convert extended numerics to use original mask version
1221 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1222 * Merge in changes from production
1223 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1224 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1225 * rfc1459.unet: Add Maniac's documentation for /names 0
1226 * Fix misc. jupe bugs that somehow made it into the tree
1227 * Escape /names 0 to mean /names --Maniac
1228 * Don't core when server asks for info --Maniac
1229 * Add Kev's jupe patch --Bleep
1230 * Add Maniacs squit patch --Bleep
1231 * Merge in u2_10_10_beta07 changes --Bleep
1232 * Merge in u2_10_10_beta06 changes --Bleep
1233 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1234 #-----------------------------------------------------------------------------
1236 # ChangeLog for ircu2.10.11
1238 # $Id: ChangeLog,v 1.147 2000-06-13 03:01:21 isomer Exp $
1240 # Insert new changes at beginning of the change list.