1 2000-07-02 Perry Lorier <Isomer@coders.net>
2 * ircd/s_misc.c: Fixed remote IPcheck bug. Ok, I'm a moron, so sue
3 me. Thanks to Hektik, thanks thanks thanks thanks
4 thanks thanks thanks thanks thank thanks thank thanks
6 2000-07-01 Perry Lorier <Isomer@coders.net>
7 * ircd/s_conf.c: "Fixed" the "bug" where people would "evade" K:'s.
8 * ircd/s_conf.c, include/IPcheck.h: Fixed compile warnings.
10 2000-06-22 Perry Lorier <Isomer@coders.net>
11 * ircd/IPcheck.c: Large chunks redone.
12 * ircd/s_conf.c: Changes due to IPcheck - ONE nolonger supported,
13 single AND double digit limits are allowed now.
14 * misc other: Changes to IPcheck.
16 2000-06-30 Perry Lorier <Isomer@coders.net>
17 * ircd/ircd.c: Fix command line parameter bugs.
19 2000-06-30 Perry Lorier <Isomer@coders.net>
20 * ircd/m_kill.c: Fixed bug with LOCAL_KILL_ONLY
21 * ircd/m_nick.c: Tidied things up.
23 2000-06-12 Joseph Bongaarts <foxxe@trms.com>
24 * ircd/m_stats.c: Iso forgot mo_stats when he added /stats v
26 2000-05-29 Perry Lorier <Isomer@coders.net>
27 * ircd/m_stats.c: add /stats v to do only the last part of the /trace
28 * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
29 you think it'll get bored and fix itself?
31 2000-06-09 Greg Sikorski <gte@atomicrevs.demon.co.uk>
33 * ircd/m_names.c: Clean up compiler warnings.
35 2000-06-09 Kevin L. Mitchell <klmitch@mit.edu>
37 * ircd/channel.c (mode_parse_client): don't send warning if
38 there's not enough arguments for a +/-o/v; means the habit of
39 doing "/mode #channel +oooooo bob" doesn't result in a bunch of
42 2000-06-04 Greg Sikorski <gte@atomicrevs.demon.co.uk>
44 * ircd/m_names.c: Re-factor code to remove unneccessary
45 GlobalChannelList iteration every time someone joins a channel.
47 2000-06-02 Kevin L. Mitchell <klmitch@mit.edu>
49 * ircd/s_user.c: add struct Gline * argument to register_user;
50 look up global glines and repropagate them if necessary; send
51 acknowledgement of gline to remote servers when registering users
53 * ircd/s_serv.c (server_estab): don't send acknowledgement of
54 local glines to remote servers; do send gline acknowledgement of
57 * ircd/m_user.c (m_user): pass new struct Gline * argument to
60 * ircd/m_pong.c: pass new struct Gline * argument to register_user
62 * ircd/m_nick.c (ms_nick): document protocol change
64 * ircd/gline.c: support GLINE_LASTMOD
66 * include/s_user.h: add struct Gline * argument to register_user
68 * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
70 * ircd/s_conf.c (find_kill): add unsigned int argument to
73 * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
74 glines; add unsigned int argument to gline_lookup()
76 * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
77 argument to gline_lookup()
79 * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
80 parameter, or when it falls out of bounds: see comments prior to
81 call to jupe_resend(); call server_estab with struct Jupe
82 parameter, so that we place the appropriate %<lastmod> in the
85 * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
86 server, as well as for servers when we're sending the BURST
88 * include/s_serv.h: add a struct Jupe * to the arguments for
89 server_estab() so that we can send the appropriate lastmod
92 * ircd/m_gline.c (ms_gline): actually, this should be the
93 slightest bit more efficient...
95 * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
98 * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
101 * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
104 * ircd/channel.c (joinbuf_join): really remove user from local
107 2000-05-29 Perry Lorier <Isomer@coders.net>
108 * ircd/m_names.c: Removed redundant space.
109 * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
111 2000-05-18 Kevin L. Mitchell <klmitch@mit.edu>
113 * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
116 2000-05-04 Kevin L. Mitchell <klmitch@mit.edu>
118 * ircd/channel.c: replace bogus assertions with returns, which is
119 logically correct; only wipe out limit/key if they were originally
120 set in the first place; remove user from channel when doing a
121 PARTALL; only send MODE +o for user CREATEing channel if user is
122 not MyUser--CREATE will only be used if the channel did not
123 originally exist, therefore we can assume no one local is on the
124 channel anyway, and we don't exactly need for the user to see an
125 explicit +o for themselves
127 * doc/readme.gline: describe the syntax of the GLINE command
129 * doc/readme.jupe: update to reflect a couple of changes to JUPE
131 * ircd/gline.c: don't propagate local changes
133 * ircd/jupe.c: don't propagate local changes
135 * ircd/m_gline.c (mo_gline): force local flag when deactivating
136 glines with 0 lastmod
138 * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
139 are now removed instead of being deactivated
141 * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
144 * ircd/channel.c (send_channel_modes): deal with one of the last
147 * ircd/m_burst.c (ms_burst): debugged ban processing; removed
150 * ircd/channel.c (modebuf_extract): remove debugging
151 sendto_opmask_butone calls
153 2000-05-03 Kevin L. Mitchell <klmitch@mit.edu>
155 * ircd/channel.c: support a couple of new flags to support using
156 mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
157 of modebuf_extract to extract added flags for use by ms_burst
159 * include/channel.h: a couple of new flags to support using
160 mode_parse inside ms_burst
162 * ircd/m_burst.c (ms_burst): brand new implementation of BURST
164 * ircd/m_endburst.c: add loop to processing of end_of_burst to
165 free empty channels after the BURST is over.
167 * ircd/m_server.c: convert to use new send.c functions--I wanted
168 to rewrite it from scratch, but the logic's pretty complex; I may
169 still rewrite it, though...
171 2000-05-02 Thomas Helvey <tomh@inxpress.net>
173 * ircd/ircd.c: fix broken header include ordering
175 2000-05-02 Thomas Helvey <tomh@inxpress.net>
177 * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
178 review emailed privately
180 * include/IPcheck.h: removed unneeded include
182 2000-05-02 Kevin L. Mitchell <klmitch@mit.edu>
184 * ircd/s_user.c (hunt_server): throw in a comment so I know what
185 the sendto_one is for
187 * include/querycmds.h (Count_unknownbecomesclient): convert to
190 * ircd/send.c: start removing dead code
192 * include/send.h: start removing dead code
194 * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
197 * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
199 2000-05-01 Kevin L. Mitchell <klmitch@mit.edu>
201 * ircd/m_stats.c: convert to sendcmdto_one / send_reply
203 * ircd/m_kick.c: Completely reimplement m_kick
205 * ircd/channel.c: send_user_joins removed; it was dead code,
208 2000-05-01 Perry Lorier <isomer@coders.net>
209 * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
210 * ircd/channels.c: My fix for the part problem. Untested, probably
211 won't work. Can't be much worse than the current problem.
212 it'll either work or core, take your pick.
215 2000-04-30 Perry Lorier <isomer@coders.net>
216 * config/config-sh.in: Fix for CONNEXIT
217 * ircd/s_{user,misc}.c: Fix for CONNEXIT
218 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
219 (Kev: Want to come talk to me about this?)
221 2000-04-30 Steven M. Doyle <steven@doyle.net>
223 - general cleanups and readability enhancements
224 - rewrite of setuid/chroot code.
225 - server will no longer run as root
226 - -DPROFIL compile option removed
227 - Fixed IPcheck API calls
229 * config/config-sh.in
230 - Fixed up chroot compile options
231 - Added options for debug and profile compiles
233 * config/gen.ircd.Makefile
234 - Support for new debug/profile options
237 - Support for new debug/profile options
243 - Removed old API prototypes, added new ones
246 - Readability cleanups (well, I -think-...)
247 - Changed IPRegistryEntry.last_connect to a time_t. The previously
248 used unsigned short was probably causing interesting things after
249 a client had been connected longer than about 65,535 seconds...
250 - Removed old API functions.
253 - Removed IPcheck.h include
255 * Additionally modified IPcheck API calls in:
265 2000-04-30 Perry Lorier <isomer@coders.net>
266 * ircd/s_bsd.c: Sigh. :)
267 * ircd/m_mode.c: fix for modeless channels by poptix.
269 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
271 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
273 * ircd/channel.c (clean_channelname): make clean_channelname also
274 truncate long channel names
276 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
278 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
280 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
283 * include/channel.h: definitions and declarations for the struct
286 2000-04-29 Perry Lorier <isomer@coders.net>
287 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
289 2000-04-29 Perry Lorier <isomer@coders.net>
290 * ircd/s_bsd.c: Add debugging code to IPcheck
292 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
294 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
296 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
299 * ircd/m_userhost.c (m_userhost): add a dead code comment
301 * ircd/m_desynch.c: forgot one...
303 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
305 * ircd/m_proto.c (proto_send_supported): just change a comment so
306 it doesn't show up in my scans
308 * ircd/ircd_reply.c (send_reply): fix a slight bug...
310 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
313 * ircd/parse.c (parse_server): argument wrangling to make
314 processing in do_numeric a little easier to deal with
316 * ircd/s_serv.c (server_estab): SERVER should come from
317 acptr->serv->up, not &me
319 * ircd/m_lusers.c: accidentally left out sptr for a %C
321 * ircd/send.c: hack to support doing wallchops...
323 * ircd/m_whowas.c: convert to new send functions
325 * ircd/m_whois.c: convert to new send functions
327 * ircd/m_who.c: convert to new send functions
329 * ircd/m_wallops.c: convert to new send functions
331 * ircd/m_wallchops.c: convert to new send functions
333 * ircd/m_version.c: convert to new send functions
335 * ircd/m_userip.c: convert to new send functions
337 * ircd/m_userhost.c: convert to new send functions
339 * ircd/m_uping.c: convert to new send functions
341 * ircd/m_trace.c: convert to new send functions
343 * ircd/m_topic.c: convert to new send functions
345 * ircd/m_time.c: convert to new send functions
347 * ircd/m_squit.c: convert to new send functions
349 * ircd/m_silence.c: convert to new send functions
351 * ircd/m_settime.c: convert to new send functions
353 * ircd/m_restart.c: convert to new send functions
355 * ircd/m_rehash.c: convert to new send functions
357 * ircd/m_privmsg.c: convert to new send functions
359 * ircd/m_pong.c: convert to new send functions
361 * ircd/m_ping.c: convert to new send functions
363 * ircd/m_pass.c: convert to new send functions
365 * ircd/m_opmode.c: convert to new send functions
367 * ircd/m_oper.c: convert to new send functions
369 * ircd/m_notice.c: convert to new send functions
371 * ircd/m_nick.c: convert to new send functions
373 * ircd/m_names.c: convert to new send functions
375 * ircd/m_motd.c: convert to new send functions
377 * ircd/m_mode.c: convert to new send functions
379 * ircd/m_map.c: convert to new send functions
381 * ircd/m_lusers.c: convert to new send functions
383 * ircd/m_list.c: convert to new send functions
385 * ircd/m_links.c: convert to new send functions
387 * ircd/m_kill.c: convert to new send functions
389 * ircd/m_jupe.c: convert to new send functions
391 * ircd/m_invite.c: convert to new send functions
393 * ircd/m_info.c: convert to new send functions
395 * ircd/m_help.c: convert to new send functions
397 * ircd/m_gline.c: convert to new send functions
399 * ircd/m_error.c: convert to new send functions
401 * ircd/m_endburst.c: convert to new send functions
403 * ircd/m_die.c: convert to new send functions
405 * ircd/m_destruct.c: convert to new send functions
407 * ircd/m_defaults.c: convert to new send functions
409 * ircd/m_connect.c: convert to new send functions
411 2000-04-28 Perry Lorier <isomer@coders.net>
412 * RELEASE.NOTES: Describe a few more undocumented features.
413 * config/config-sh.in: change the default paths for logging
414 and the recommended number of channels.
415 * include/supported.h: Rearrange slightly, added CHANTYPE's
417 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
419 * ircd/m_close.c: convert to send_reply
421 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
423 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
425 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
427 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
428 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
429 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
430 carefully rethought...
432 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
434 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
436 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
437 numeric nick; therefore, we have to use the server name
439 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
441 * ircd/send.c: fix minor bugs
443 * ircd/s_user.c (check_target_limit): mark dead code so I filter
446 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
449 * ircd/parse.c: mark dead code so I filter it when I grep
451 * ircd/map.c: mark dead code so I filter it when I grep
453 * ircd/ircd.c: mark dead code so I filter it when I grep
455 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
458 * ircd/channel.c: mark dead code so I filter it when I grep
460 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
461 hope I'm not stepping on toes...
463 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
464 conversions; use ircd_snprintf in a couple of cases to negate the
465 possibility of buffer overflow
467 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
469 * ircd/channel.c: convert as much as possible to new send
472 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
473 test member->user->from->fd, not from->fd
475 * ircd/gline.c (gline_add): go ahead and add badchans; we just
476 won't look for them in m_gline; this way, they always work...
478 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
480 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
481 ircd_vsnprintf conversion specifiers
483 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
484 I have my conversion specifiers
486 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
488 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
491 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
492 little less brain-dead
494 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
496 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
499 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
502 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
505 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
507 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
509 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
512 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
514 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
515 a numeric as needing to use an explicit pattern, which will be the
516 first argument in the variable argument list
518 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
519 non-prefixed nospoof PING
521 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
522 non-prefixed SERVER login
524 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
525 a numeric usage further up)
527 * include/send.h: declare sendrawto_one
529 * ircd/send.c (sendrawto_one): new function to use ONLY for
530 non-prefixed commands, like PING to client, or PASS/SERVER on
533 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
535 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
536 future expansion (channel numerics?)
538 * include/ircd_snprintf.h: added documentation to # to explain use
539 with %C; added documentation for : to explain use with %C; added
540 documentation for %H for channels
542 * ircd/whocmds.c: use send_reply
544 * ircd/userload.c: use sendcmdto_one
546 * ircd/uping.c: use sendcmdto_one
548 * ircd/send.c: use new flags to %C format string; ':' prefixes
549 client name with a colon for local connects, '#' uses
550 nick!user@host form for local connects
552 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
553 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
555 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
557 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
560 * ircd/s_auth.c: use sendto_opmask_butone
562 * ircd/res.c: use sendcmdto_one
564 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
567 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
569 * ircd/support.c: dumpcore is no longer used, so get rid of it
571 * ircd/parse.c: use send_reply, sendcmdto_one
573 * ircd/map.c: use send_reply
575 * ircd/listener.c: use send_reply
577 * ircd/jupe.c: use sendto_opmask_butone, send_reply
579 * ircd/ircd_reply.c: use send_reply
581 * ircd/ircd.c: use sendto_opmask_butone
583 * ircd/gline.c: use sendto_opmask_butone, send_reply
585 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
586 registered clients; make FLAG_ALT print nick!user@host; make
587 FLAG_COLON print :blah
589 * ircd/class.c (report_classes): use send_reply instead of
592 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
594 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
595 sendto_one with sendcmdto_one
597 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
599 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
600 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
601 sendcmdto_match_butone
603 * include/send.h: declare sendcmdto_match_butone
605 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
607 * ircd/jupe.c: update to use send_reply()
609 * ircd/gline.c: update to use send_reply()
611 * include/ircd_reply.h: declare send_reply
613 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
614 replies; uses ircd_snprintf
616 * ircd/send.c: added comments to redirect searchers to appropriate
617 sendcmdto_* function; moved new functions to end of file; added
618 explanatory comments; reordered arguments; defined new functions
621 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
623 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
625 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
627 * ircd/gline.c: reorder arguments to sendcmdto_* functions
629 * include/send.h: reorder arguments, add explanatory comments,
630 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
631 and vsendto_opmask_butone
633 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
635 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
636 vsendto_op_mask that uses '*' instead of the receiving client
639 * include/send.h: declare sendcmdto_channel_butone; takes a skip
640 argument that allows you to skip (or not to skip) deaf users,
641 users behind bursting servers, and non channel operators
643 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
645 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
646 sendto_channel_butserv has a subtle bug; also wrote
647 sendcmdto_common_channels.
649 * include/send.h: declare new sendcmdto_* functions
651 * ircd/jupe.c: support local deactivations of jupes
653 * ircd/gline.c: support local deactivations of glines
655 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
656 deactivated; if they aren't locally deactivated, then it slaves to
657 the net-wide activation status; JupeIsRemActive() tests only
658 whether the jupe is active everywhere else
660 * include/gline.h: GLINE_LDEACT allows glines to be locally
661 deactivated; if they aren't locally deactivated, then it slaves to
662 the net-wide activation status; GlineIsRemActive() tests only
663 whether the gline is active everywhere else
665 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
666 gline expires after the new one will, we drop the new one,
667 otherwise we add the G-line after that one (so the wide one will
668 apply first); if the new one contains an existing G-line and if it
669 will expire after the existing one, we drop the existing one to
672 * ircd/m_gline.c (mo_gline): opers could issue remote local
673 glines when CONFIG_OPERCMDS was off; fixed
675 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
677 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
680 * ircd/gline.c: add flags argument to gline_activate and
681 gline_deactivate for future expansion
683 * ircd/m_gline.c: pass flags to gline_activate and
686 * include/gline.h: add flags argument to gline_activate and
689 * ircd/jupe.c: add flags argument to jupe_activate and
690 jupe_deactivate for future expansion
692 * include/jupe.h: add flags argument to jupe_activate and
695 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
696 local, active; pass flags to jupe_activate and jupe_deactivate
698 * include/gline.h: remove dead code
700 * ircd/gline.c: make gline expire times relative to CurrentTime,
701 since that should be monotonically increasing, instead of
702 TStime(), which can be set backwards, and which can therefore
703 cause an expire time to increase; make local glines be removed
704 instead of just deactivated; don't let gline_find() look for
705 user@host glines if the mask being looked up is a channel mask
707 * ircd/send.c (vsendcmdto_one): forgot to account for the case
708 where origin is a server and destination is a user
710 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
711 since that should be monotonically increasing, instead of
712 TStime(), which can be set backwards, and which can therefore
713 cause an expire time to increase; make local jupes be removed
714 instead of just deactivated
716 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
717 limit is fine. any other warnings I should know about?
719 2000-04-15 Thomas Helvey <tomh@inxpress.net>
721 * ircd/*.c: const correctness and type safety cleanups to
722 get code to compile with C++ compiler. Still has
723 signed/unsigned comparison warnings.
725 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
727 * ircd/userload.c: change <sys/time.h> include to <time.h> for
730 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
732 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
735 * ircd/s_user.c: move gline_lookup function call into
736 register_user, where it'll have a username to lookup!
738 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
739 functions; also stuff send_error_to_client into return clauses
741 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
742 functions; also use send_error_to_client where that makes sense
744 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
745 functions; also use send_error_to_client where that makes sense
747 * ircd/gline.c: modify to utilize new sendcmdto_* series of
748 functions; also fix gline_lookup() to deal properly with remote
749 clients--boy, do struct Client and struct User need to be cleaned
752 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
755 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
756 sendcmdto_serv_butone(), all utilizing the %v conversion of
759 * include/send.h: define IRC_BUFSIZE, max size of a message;
760 declare sendcmdto_one(), vsendcmdto_one(), and
761 sendcmdto_serv_butone()
763 * include/msg.h: define all the CMD_* constants needed to utilize
764 the new sendcmdto_* series of functions
766 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
768 * ircd/gline.c: remove old, dead code.
770 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
771 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
772 (don't advertise proxies); remove dead code
774 * ircd/parse.c: oper handler for JUPE only lists jupes unless
775 CONFIG_OPERCMDS is enabled
777 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
778 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
780 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
781 always return ERR_DISABLED
783 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
784 enabled, always return ERR_DISABLED
786 * ircd/s_err.c: add error message to indicate disabled commands
788 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
790 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
792 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
793 CONFIG_NEW_MODE to 'y' for now
795 * ircd/gline.c (gline_list): fix a minor formatting bogon
797 * BUGS: since I fixed that bug, might as well mark it fixed.
799 * ircd/m_join.c: look up badchans with GLINE_EXACT
801 * ircd/m_gline.c: fix parc count problems; look up existing
802 G-lines with GLINE_EXACT; only set new lastmod when
803 activating/deactivating existing glines if old lastmod was not 0
805 * ircd/gline.c: forgot to copy the gline reason over; don't
806 propagate a gline with 0 lastmod if origin is user; add
807 GLINE_EXACT to force exact matching of gline mask
809 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
812 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
813 but gline_lookup() actually takes a client--d'oh.
815 2000-04-13 Thomas Helvey <tomh@inxpress.net>
816 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
818 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
820 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
822 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
825 * ircd/whocmds.c: Change idle time calc from socket idle to user
828 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
830 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
831 too, for ircd_snprintf.c
833 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
834 comments; mostly descended from the Linux manpage for printf, but
835 also documenting the extensions.
837 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
838 client; make 'q' be the same as 'L'; remove __inline__; only
839 define EXTENSION if HAVE_LONG_LONG is defined
841 * include/handlers.h: declare m_gline()
843 * ircd/parse.c: gline can be called by users, but it only lists
846 * ircd/s_user.c (set_nick_name): resend gline if a remote server
847 introduces a glined client
849 * ircd/s_serv.c (server_estab): burst glines, too
851 * ircd/gline.c: fix up all the expire times to be offsets;
852 simplify gline_resend()
854 * ircd/m_gline.c: begin coding replacements for ms_gline(),
855 mo_gline(), and m_gline()
857 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
858 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
860 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
862 * tools/Bouncer/*: Add comments/documentation/tags.
863 * tools/Bouncer/*: Add debug defines, make task fork().
865 2000-04-12 Thomas Helvey <tomh@inxpress.net>
866 * ircd/s_err.c: Cleanup s_err.c make one table so we
867 don't have to do anything tricky to get an error string.
869 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
870 * Add port bouncer for http (x/w)
872 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
874 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
875 call to gline_find(); also used GlineReason() instead of direct
876 reference to structure member
878 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
879 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
882 * ircd/channel.c: nothing seems to be called anywhere...
884 * ircd/s_err.c: update a couple of replies to dovetail with new
887 * ircd/gline.c: begin complete re-implementation of gline.c along
888 the lines of the final design of jupe.c
890 * include/gline.h: begin complete re-implementation of gline.c
891 along the lines of the final design of jupe.c
893 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
896 * ircd/ircd_snprintf.c: my new snprintf()-like functions
898 * include/ircd_snprintf.h: my new snprintf()-like functions
900 2000-04-11 Thomas Helvey <tomh@inxpress.net>
901 * ircd/IPcheck.c: removed old dead code
902 * ircd/s_user.c (send_user_info): removed non-standard
903 user not found message for userhost/userip
905 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
907 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
908 * doc/p10.html: Work on chapter 4.
910 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
912 * ircd/channel.c (mode_parse_client): fix coredump on /mode
913 #foobar +o nosuchnick
915 2000-04-10 Perry Lorier <Isomer@coders.net>
918 2000-04-09 Thomas Helvey <tomh@inxpress.net>
919 * include/IPcheck.h: fix prototype
920 * ircd/s_user.c: fix usage of IPcheck_remote_connect
921 * ircd/IPcheck.c: removed unused args
923 2000-04-09 Thomas Helvey <tomh@inxpress.net>
924 * include/IPcheck.h: add proto for IPcheck_expire
926 * ircd/IPcheck.c: Rewrote
928 * ircd/ircd.c: Add IPcheck_expire to main message loop
930 * ircd/s_user.c: Redo target hashing, refactor target code
932 * include/numeric.h: Cleaned up numerics, added which ones are
933 in use by other networks and what they are in use for.
935 * ircd/channel.c: cleaned can_join(), allow anyone through anything
936 if /invited, simplified the function. Opers overusing OPEROVERRIDE
937 will get a message explaining to them not to cheat.
939 * ircd/m_join.c: cleaned up the various join functions, should be
940 a lot more efficient. Still needs work. Now assumes that s<->s
941 won't send it a JOIN 0. Service coders - note this and tread with
944 * ircd/m_stats.c: added Gte-'s stats doc patch.
946 * ircd/m_version.c: /version now returns the 005 numeric as well.
947 as requested by Liandrin.
950 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
952 * ircd/m_clearmode.c: add include for support.h for write_log()
954 * configure: move ircd/crypt/* to tools/*
956 2000-04-06 Thomas Helvey <tomh@inxpress.net>
957 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
958 set client host to server alias if connection from localhost
960 2000-04-06 Perry Lorier <isomer@coders.net>
961 * ircd/ircd.c: Fix core during pinging (oops)
963 2000-04-06 Perry Lorier <isomer@coders.net>
964 * ircd/send.c: fixed wrong ident being sent to channels bug.
965 * include/numerics.h: Updated some of the numerics from other
966 networks. Flagged some as 'unused' by undernet.
968 2000-03-30 Perry Lorier <isomer@coders.net>
969 * ircd/ircd.c: Lets see if this helps the ping problem at all.
970 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
971 time for local clients. (as requested), extended who now returns all
972 the flags (@+!) so you can tell the complete state of a client.
974 2000-03-30 Thomas Helvey <tomh@inxpress.net>
975 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
977 2000-03-30 Perry Lorier <isomer@coders.net>
978 * ircd/parse.c: oops, missed opers.
980 2000-03-30 Perry Lorier <isomer@coders.net>
981 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
982 for so long. Remember: m_ping MUST be in the parse array. :)
984 2000-03-30 Perry Lorier <isomer@coders.net>
985 * ircd/ircd.c: test in check_pings was wrong. I move that we
986 disallow cvs commit after 10pm localtime....
988 2000-03-30 Perry Lorier <isomer@coders.net>
989 * ircd/m_pong.c: Fix it for servers too.
991 2000-03-30 Perry Lorier <isomer@coders.net>
992 * ircd/m_pong.c: Fix ping timeout bugs
994 2000-03-30 Perry Lorier <isomer@coders.net>
995 * ircd/channel.c: Bans had CurrentTime in their when field instead
998 2000-03-31 Thomas Helvey <tomh@ixpress.net>
999 * ircd/numnicks.c (SetXYYCapacity): fix for extended
1002 2000-03-30 Perry Lorier <isomer@coders.net>
1003 * ircd/m_nick.c: send kills both ways so when we add nick change
1004 on collision we don't desync the network.
1006 * ircd/map.c: Fixup the map a bit more.
1008 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
1010 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
1012 * ircd/m_opmode.c: Log the mode changes to OPATH
1014 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
1017 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
1020 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
1022 * config/config-sh.in: added OPATH for opmode log file
1024 * ircd/m_clearmode.c (do_clearmode): updated uses of
1025 modebuf_mode_string() for the new usage
1027 * ircd/channel.c: added flag MODE_FREE and an int argument to
1028 modebuf_mode_string() to indicate that the string must be free'd;
1029 updated calls to modebuf_mode_string() for the new usage; called
1030 collapse(pretty_mask()) on the ban string and use allocated memory
1031 for it; added ban list length accounting; fixed a number of small
1032 bugs in ban processing
1034 * include/channel.h: added flag MODE_FREE and an int argument to
1035 modebuf_mode_string() to indicate that the string must be free'd
1037 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
1038 keys and limits that are set
1040 2000-03-30 Perry Lorier <isomer@coders.net>
1041 * ircd/ircd.c: rewrote check_pings() for maintainability
1042 and speed. Also changed quit msg's so they don't have
1043 redundant nick[host] info in them.
1045 * ircd/send.c: Changed write errors to report what error
1046 occured (if possible).
1048 * ircd/gline.c: added gline comment to the quit.
1050 * ircd/m_server.c: Added suggestions to server quits mentioning
1051 what went wrong so the admin can fix it earlier instead of asking
1054 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
1055 servers that aren't fully burst yet. And show '(--s)' for servers
1058 * doc/example.conf: Fixed wrapped U:
1060 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
1062 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
1063 mode_parse() (version selectable at compile time)
1065 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
1067 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
1069 * config/config-sh.in: add new config option to enable new m_mode
1072 * doc/Configure.help: add documentation for new config option
1075 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
1076 MODE -v : Not enough parameters
1078 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
1079 +k and +l even if they weren't set...
1081 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
1083 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
1084 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
1085 for; test the 0-th member, not the i-th member, of the client
1088 * ircd/m_clearmode.c (do_clearmode): use the new
1089 mode_invite_clear() function
1091 * ircd/channel.c: cleared up all the compile-time warnings and
1094 * include/channel.h: added declarations for mode_ban_invalidate()
1095 and mode_invite_clear()
1097 * ircd/channel.c: finished mode_parse(), then broke it up into a
1098 dozen or so helper functions to make the code easier to read
1100 2000-03-29 Thomas Helvey <tomh@inxpress.net>
1101 * ircd/ircd.c: refactor server initialization a bit, use
1102 getopt for parsing command line, refactor init_sys, main,
1105 * ircd/s_bsd.c: add functions for initialization to clean
1106 up logic a bit and remove duplicated code.
1108 * include/ircd.h: add struct for server process related
1111 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
1113 * ircd/channel.c: initial definition of mode_parse(); flags to
1114 prevent doing the same thing multiple times; helper method
1115 send_notoper() to send a "Not oper"/"Not on channel" notice
1117 * include/channel.h: declare mode_parse() and helper flags
1119 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
1120 sending to match the current action of set_mode() closely enough
1121 that hopefully there won't be major conflicts
1123 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
1124 building logic, reversed the order of the arguments to mode
1125 commands to have '-' preceed '+'
1127 2000-03-29 Thomas Helvey <tomh@inxpress.net>
1128 * ircd/s_bsd.c (add_connection): don't disable socket options
1129 let OS tune itself and allow important performance tweaks to
1132 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
1134 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
1135 confused by set_mode, which is doing some really weird logic;
1136 guess what I'm going to rewrite next? ;)
1138 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
1140 * include/channel.h: added MODE_SAVE for the bounds checking stuff
1143 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
1144 make it do bounds checking on the buffer; all modes are sent only
1145 if the all parameter is 1; modebuf_flush is the exported wrapper
1147 * include/channel.h: add BOUNCE, renumber flags to get a little
1150 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
1151 BOUNCE; send DESYNCH message
1153 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
1155 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
1156 channel actually has in effect for deletion
1158 * ircd/channel.c: added explanatory comments to all added
1159 functions; made flushing take place at the correct place even if
1160 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
1161 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
1162 is empty, fixed the apparent source, removed some bogus string
1163 termination code, properly terminate the mode strings, add support
1164 for HACK2 and HACK3, made limit strings not be sent if the limit
1165 is being removed, changed where '+' and '-' come from in sent
1166 strings, added support for DEOP flag, set up bouncing code for
1169 * ircd/Makefile.in: ran make depend
1171 * include/channel.h: added new defines for future functionality,
1172 made modebuf_flush() return int so I can use tail recursion
1174 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
1175 to make it all compile
1177 * ircd/m_opmode.c: add msg.h to includes...
1179 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
1181 * ircd/channel.c (modebuf_flush): realized I forgot to
1182 nul-terminate addbuf/rembuf properly...
1184 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
1186 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
1187 sendto_serv_butone--blah^2
1189 * ircd/send.c (sendto_serv_butone): stupid comments confused me
1191 * ircd/channel.c (modebuf_flush): if there are no mode changes to
1192 propagate, we're done...
1194 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
1195 not sendto_all_butone
1197 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
1199 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
1201 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
1204 * ircd/parse.c: added messages for opmode and clearmode
1206 * include/handlers.h: added declarations for mo_opmode(),
1207 ms_opmode(), mo_clearmode(), and ms_clearmode()
1209 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
1212 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
1213 MODEBUF_DEST_OPMODE flag
1215 * ircd/channel.c (modebuf_flush): added new flag,
1216 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1217 to originate from source's server (or source itself, if
1218 IsServer(source)); also causes a server-level MODE to be sent as
1221 * include/channel.h: defined MODEBUF_DEST_SERVER,
1224 * ircd/channel.c: Add another argument to build_string() to handle
1225 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1226 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1229 2000-03-27 Perry Lorier <isomer@coders.net>
1231 * ircd/s_bsd.c: fixed missing 'u' typo.
1233 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
1235 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1236 _mode_string(), _mode_client(), _flush(); also implemented a
1237 simple build_string()
1239 * include/channel.h: added definition of ModeBuf, modebuf_*
1240 manipulation functions, and a couple of helper macros
1242 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1243 * numicks.c: convert extended numerics to use original mask version
1246 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1247 * Merge in changes from production
1248 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1249 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1250 * rfc1459.unet: Add Maniac's documentation for /names 0
1251 * Fix misc. jupe bugs that somehow made it into the tree
1252 * Escape /names 0 to mean /names --Maniac
1253 * Don't core when server asks for info --Maniac
1254 * Add Kev's jupe patch --Bleep
1255 * Add Maniacs squit patch --Bleep
1256 * Merge in u2_10_10_beta07 changes --Bleep
1257 * Merge in u2_10_10_beta06 changes --Bleep
1258 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1259 #-----------------------------------------------------------------------------
1261 # ChangeLog for ircu2.10.11
1263 # $Id: ChangeLog,v 1.153 2000-07-02 01:06:17 isomer Exp $
1265 # Insert new changes at beginning of the change list.