1 2000-06-09 Greg Sikorski <gte@atomicrevs.demon.co.uk>
3 * ircd/m_names.c: Clean up compiler warnings.
5 2000-06-09 Kevin L. Mitchell <klmitch@mit.edu>
7 * ircd/channel.c (mode_parse_client): don't send warning if
8 there's not enough arguments for a +/-o/v; means the habit of
9 doing "/mode #channel +oooooo bob" doesn't result in a bunch of
12 2000-06-04 Greg Sikorski <gte@atomicrevs.demon.co.uk>
14 * ircd/m_names.c: Re-factor code to remove unneccessary
15 GlobalChannelList iteration every time someone joins a channel.
17 2000-06-02 Kevin L. Mitchell <klmitch@mit.edu>
19 * ircd/s_user.c: add struct Gline * argument to register_user;
20 look up global glines and repropagate them if necessary; send
21 acknowledgement of gline to remote servers when registering users
23 * ircd/s_serv.c (server_estab): don't send acknowledgement of
24 local glines to remote servers; do send gline acknowledgement of
27 * ircd/m_user.c (m_user): pass new struct Gline * argument to
30 * ircd/m_pong.c: pass new struct Gline * argument to register_user
32 * ircd/m_nick.c (ms_nick): document protocol change
34 * ircd/gline.c: support GLINE_LASTMOD
36 * include/s_user.h: add struct Gline * argument to register_user
38 * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
40 * ircd/s_conf.c (find_kill): add unsigned int argument to
43 * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
44 glines; add unsigned int argument to gline_lookup()
46 * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
47 argument to gline_lookup()
49 * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
50 parameter, or when it falls out of bounds: see comments prior to
51 call to jupe_resend(); call server_estab with struct Jupe
52 parameter, so that we place the appropriate %<lastmod> in the
55 * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
56 server, as well as for servers when we're sending the BURST
58 * include/s_serv.h: add a struct Jupe * to the arguments for
59 server_estab() so that we can send the appropriate lastmod
62 * ircd/m_gline.c (ms_gline): actually, this should be the
63 slightest bit more efficient...
65 * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
68 * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
71 * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
74 * ircd/channel.c (joinbuf_join): really remove user from local
77 2000-05-29 Perry Lorier <Isomer@coders.net>
78 * ircd/m_names.c: Removed redundant space.
79 * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
81 2000-05-18 Kevin L. Mitchell <klmitch@mit.edu>
83 * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
86 2000-05-04 Kevin L. Mitchell <klmitch@mit.edu>
88 * ircd/channel.c: replace bogus assertions with returns, which is
89 logically correct; only wipe out limit/key if they were originally
90 set in the first place; remove user from channel when doing a
91 PARTALL; only send MODE +o for user CREATEing channel if user is
92 not MyUser--CREATE will only be used if the channel did not
93 originally exist, therefore we can assume no one local is on the
94 channel anyway, and we don't exactly need for the user to see an
95 explicit +o for themselves
97 * doc/readme.gline: describe the syntax of the GLINE command
99 * doc/readme.jupe: update to reflect a couple of changes to JUPE
101 * ircd/gline.c: don't propagate local changes
103 * ircd/jupe.c: don't propagate local changes
105 * ircd/m_gline.c (mo_gline): force local flag when deactivating
106 glines with 0 lastmod
108 * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
109 are now removed instead of being deactivated
111 * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
114 * ircd/channel.c (send_channel_modes): deal with one of the last
117 * ircd/m_burst.c (ms_burst): debugged ban processing; removed
120 * ircd/channel.c (modebuf_extract): remove debugging
121 sendto_opmask_butone calls
123 2000-05-03 Kevin L. Mitchell <klmitch@mit.edu>
125 * ircd/channel.c: support a couple of new flags to support using
126 mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
127 of modebuf_extract to extract added flags for use by ms_burst
129 * include/channel.h: a couple of new flags to support using
130 mode_parse inside ms_burst
132 * ircd/m_burst.c (ms_burst): brand new implementation of BURST
134 * ircd/m_endburst.c: add loop to processing of end_of_burst to
135 free empty channels after the BURST is over.
137 * ircd/m_server.c: convert to use new send.c functions--I wanted
138 to rewrite it from scratch, but the logic's pretty complex; I may
139 still rewrite it, though...
141 2000-05-02 Thomas Helvey <tomh@inxpress.net>
143 * ircd/ircd.c: fix broken header include ordering
145 2000-05-02 Thomas Helvey <tomh@inxpress.net>
147 * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
148 review emailed privately
150 * include/IPcheck.h: removed unneeded include
152 2000-05-02 Kevin L. Mitchell <klmitch@mit.edu>
154 * ircd/s_user.c (hunt_server): throw in a comment so I know what
155 the sendto_one is for
157 * include/querycmds.h (Count_unknownbecomesclient): convert to
160 * ircd/send.c: start removing dead code
162 * include/send.h: start removing dead code
164 * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
167 * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
169 2000-05-01 Kevin L. Mitchell <klmitch@mit.edu>
171 * ircd/m_stats.c: convert to sendcmdto_one / send_reply
173 * ircd/m_kick.c: Completely reimplement m_kick
175 * ircd/channel.c: send_user_joins removed; it was dead code,
178 2000-05-01 Perry Lorier <isomer@coders.net>
179 * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
180 * ircd/channels.c: My fix for the part problem. Untested, probably
181 won't work. Can't be much worse than the current problem.
182 it'll either work or core, take your pick.
185 2000-04-30 Perry Lorier <isomer@coders.net>
186 * config/config-sh.in: Fix for CONNEXIT
187 * ircd/s_{user,misc}.c: Fix for CONNEXIT
188 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
189 (Kev: Want to come talk to me about this?)
191 2000-04-30 Steven M. Doyle <steven@doyle.net>
193 - general cleanups and readability enhancements
194 - rewrite of setuid/chroot code.
195 - server will no longer run as root
196 - -DPROFIL compile option removed
197 - Fixed IPcheck API calls
199 * config/config-sh.in
200 - Fixed up chroot compile options
201 - Added options for debug and profile compiles
203 * config/gen.ircd.Makefile
204 - Support for new debug/profile options
207 - Support for new debug/profile options
213 - Removed old API prototypes, added new ones
216 - Readability cleanups (well, I -think-...)
217 - Changed IPRegistryEntry.last_connect to a time_t. The previously
218 used unsigned short was probably causing interesting things after
219 a client had been connected longer than about 65,535 seconds...
220 - Removed old API functions.
223 - Removed IPcheck.h include
225 * Additionally modified IPcheck API calls in:
235 2000-04-30 Perry Lorier <isomer@coders.net>
236 * ircd/s_bsd.c: Sigh. :)
237 * ircd/m_mode.c: fix for modeless channels by poptix.
239 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
241 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
243 * ircd/channel.c (clean_channelname): make clean_channelname also
244 truncate long channel names
246 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
248 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
250 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
253 * include/channel.h: definitions and declarations for the struct
256 2000-04-29 Perry Lorier <isomer@coders.net>
257 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
259 2000-04-29 Perry Lorier <isomer@coders.net>
260 * ircd/s_bsd.c: Add debugging code to IPcheck
262 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
264 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
266 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
269 * ircd/m_userhost.c (m_userhost): add a dead code comment
271 * ircd/m_desynch.c: forgot one...
273 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
275 * ircd/m_proto.c (proto_send_supported): just change a comment so
276 it doesn't show up in my scans
278 * ircd/ircd_reply.c (send_reply): fix a slight bug...
280 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
283 * ircd/parse.c (parse_server): argument wrangling to make
284 processing in do_numeric a little easier to deal with
286 * ircd/s_serv.c (server_estab): SERVER should come from
287 acptr->serv->up, not &me
289 * ircd/m_lusers.c: accidentally left out sptr for a %C
291 * ircd/send.c: hack to support doing wallchops...
293 * ircd/m_whowas.c: convert to new send functions
295 * ircd/m_whois.c: convert to new send functions
297 * ircd/m_who.c: convert to new send functions
299 * ircd/m_wallops.c: convert to new send functions
301 * ircd/m_wallchops.c: convert to new send functions
303 * ircd/m_version.c: convert to new send functions
305 * ircd/m_userip.c: convert to new send functions
307 * ircd/m_userhost.c: convert to new send functions
309 * ircd/m_uping.c: convert to new send functions
311 * ircd/m_trace.c: convert to new send functions
313 * ircd/m_topic.c: convert to new send functions
315 * ircd/m_time.c: convert to new send functions
317 * ircd/m_squit.c: convert to new send functions
319 * ircd/m_silence.c: convert to new send functions
321 * ircd/m_settime.c: convert to new send functions
323 * ircd/m_restart.c: convert to new send functions
325 * ircd/m_rehash.c: convert to new send functions
327 * ircd/m_privmsg.c: convert to new send functions
329 * ircd/m_pong.c: convert to new send functions
331 * ircd/m_ping.c: convert to new send functions
333 * ircd/m_pass.c: convert to new send functions
335 * ircd/m_opmode.c: convert to new send functions
337 * ircd/m_oper.c: convert to new send functions
339 * ircd/m_notice.c: convert to new send functions
341 * ircd/m_nick.c: convert to new send functions
343 * ircd/m_names.c: convert to new send functions
345 * ircd/m_motd.c: convert to new send functions
347 * ircd/m_mode.c: convert to new send functions
349 * ircd/m_map.c: convert to new send functions
351 * ircd/m_lusers.c: convert to new send functions
353 * ircd/m_list.c: convert to new send functions
355 * ircd/m_links.c: convert to new send functions
357 * ircd/m_kill.c: convert to new send functions
359 * ircd/m_jupe.c: convert to new send functions
361 * ircd/m_invite.c: convert to new send functions
363 * ircd/m_info.c: convert to new send functions
365 * ircd/m_help.c: convert to new send functions
367 * ircd/m_gline.c: convert to new send functions
369 * ircd/m_error.c: convert to new send functions
371 * ircd/m_endburst.c: convert to new send functions
373 * ircd/m_die.c: convert to new send functions
375 * ircd/m_destruct.c: convert to new send functions
377 * ircd/m_defaults.c: convert to new send functions
379 * ircd/m_connect.c: convert to new send functions
381 2000-04-28 Perry Lorier <isomer@coders.net>
382 * RELEASE.NOTES: Describe a few more undocumented features.
383 * config/config-sh.in: change the default paths for logging
384 and the recommended number of channels.
385 * include/supported.h: Rearrange slightly, added CHANTYPE's
387 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
389 * ircd/m_close.c: convert to send_reply
391 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
393 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
395 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
397 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
398 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
399 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
400 carefully rethought...
402 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
404 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
406 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
407 numeric nick; therefore, we have to use the server name
409 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
411 * ircd/send.c: fix minor bugs
413 * ircd/s_user.c (check_target_limit): mark dead code so I filter
416 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
419 * ircd/parse.c: mark dead code so I filter it when I grep
421 * ircd/map.c: mark dead code so I filter it when I grep
423 * ircd/ircd.c: mark dead code so I filter it when I grep
425 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
428 * ircd/channel.c: mark dead code so I filter it when I grep
430 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
431 hope I'm not stepping on toes...
433 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
434 conversions; use ircd_snprintf in a couple of cases to negate the
435 possibility of buffer overflow
437 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
439 * ircd/channel.c: convert as much as possible to new send
442 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
443 test member->user->from->fd, not from->fd
445 * ircd/gline.c (gline_add): go ahead and add badchans; we just
446 won't look for them in m_gline; this way, they always work...
448 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
450 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
451 ircd_vsnprintf conversion specifiers
453 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
454 I have my conversion specifiers
456 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
458 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
461 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
462 little less brain-dead
464 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
466 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
469 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
472 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
475 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
477 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
479 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
482 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
484 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
485 a numeric as needing to use an explicit pattern, which will be the
486 first argument in the variable argument list
488 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
489 non-prefixed nospoof PING
491 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
492 non-prefixed SERVER login
494 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
495 a numeric usage further up)
497 * include/send.h: declare sendrawto_one
499 * ircd/send.c (sendrawto_one): new function to use ONLY for
500 non-prefixed commands, like PING to client, or PASS/SERVER on
503 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
505 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
506 future expansion (channel numerics?)
508 * include/ircd_snprintf.h: added documentation to # to explain use
509 with %C; added documentation for : to explain use with %C; added
510 documentation for %H for channels
512 * ircd/whocmds.c: use send_reply
514 * ircd/userload.c: use sendcmdto_one
516 * ircd/uping.c: use sendcmdto_one
518 * ircd/send.c: use new flags to %C format string; ':' prefixes
519 client name with a colon for local connects, '#' uses
520 nick!user@host form for local connects
522 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
523 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
525 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
527 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
530 * ircd/s_auth.c: use sendto_opmask_butone
532 * ircd/res.c: use sendcmdto_one
534 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
537 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
539 * ircd/support.c: dumpcore is no longer used, so get rid of it
541 * ircd/parse.c: use send_reply, sendcmdto_one
543 * ircd/map.c: use send_reply
545 * ircd/listener.c: use send_reply
547 * ircd/jupe.c: use sendto_opmask_butone, send_reply
549 * ircd/ircd_reply.c: use send_reply
551 * ircd/ircd.c: use sendto_opmask_butone
553 * ircd/gline.c: use sendto_opmask_butone, send_reply
555 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
556 registered clients; make FLAG_ALT print nick!user@host; make
557 FLAG_COLON print :blah
559 * ircd/class.c (report_classes): use send_reply instead of
562 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
564 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
565 sendto_one with sendcmdto_one
567 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
569 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
570 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
571 sendcmdto_match_butone
573 * include/send.h: declare sendcmdto_match_butone
575 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
577 * ircd/jupe.c: update to use send_reply()
579 * ircd/gline.c: update to use send_reply()
581 * include/ircd_reply.h: declare send_reply
583 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
584 replies; uses ircd_snprintf
586 * ircd/send.c: added comments to redirect searchers to appropriate
587 sendcmdto_* function; moved new functions to end of file; added
588 explanatory comments; reordered arguments; defined new functions
591 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
593 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
595 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
597 * ircd/gline.c: reorder arguments to sendcmdto_* functions
599 * include/send.h: reorder arguments, add explanatory comments,
600 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
601 and vsendto_opmask_butone
603 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
605 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
606 vsendto_op_mask that uses '*' instead of the receiving client
609 * include/send.h: declare sendcmdto_channel_butone; takes a skip
610 argument that allows you to skip (or not to skip) deaf users,
611 users behind bursting servers, and non channel operators
613 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
615 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
616 sendto_channel_butserv has a subtle bug; also wrote
617 sendcmdto_common_channels.
619 * include/send.h: declare new sendcmdto_* functions
621 * ircd/jupe.c: support local deactivations of jupes
623 * ircd/gline.c: support local deactivations of glines
625 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
626 deactivated; if they aren't locally deactivated, then it slaves to
627 the net-wide activation status; JupeIsRemActive() tests only
628 whether the jupe is active everywhere else
630 * include/gline.h: GLINE_LDEACT allows glines to be locally
631 deactivated; if they aren't locally deactivated, then it slaves to
632 the net-wide activation status; GlineIsRemActive() tests only
633 whether the gline is active everywhere else
635 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
636 gline expires after the new one will, we drop the new one,
637 otherwise we add the G-line after that one (so the wide one will
638 apply first); if the new one contains an existing G-line and if it
639 will expire after the existing one, we drop the existing one to
642 * ircd/m_gline.c (mo_gline): opers could issue remote local
643 glines when CONFIG_OPERCMDS was off; fixed
645 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
647 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
650 * ircd/gline.c: add flags argument to gline_activate and
651 gline_deactivate for future expansion
653 * ircd/m_gline.c: pass flags to gline_activate and
656 * include/gline.h: add flags argument to gline_activate and
659 * ircd/jupe.c: add flags argument to jupe_activate and
660 jupe_deactivate for future expansion
662 * include/jupe.h: add flags argument to jupe_activate and
665 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
666 local, active; pass flags to jupe_activate and jupe_deactivate
668 * include/gline.h: remove dead code
670 * ircd/gline.c: make gline expire times relative to CurrentTime,
671 since that should be monotonically increasing, instead of
672 TStime(), which can be set backwards, and which can therefore
673 cause an expire time to increase; make local glines be removed
674 instead of just deactivated; don't let gline_find() look for
675 user@host glines if the mask being looked up is a channel mask
677 * ircd/send.c (vsendcmdto_one): forgot to account for the case
678 where origin is a server and destination is a user
680 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
681 since that should be monotonically increasing, instead of
682 TStime(), which can be set backwards, and which can therefore
683 cause an expire time to increase; make local jupes be removed
684 instead of just deactivated
686 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
687 limit is fine. any other warnings I should know about?
689 2000-04-15 Thomas Helvey <tomh@inxpress.net>
691 * ircd/*.c: const correctness and type safety cleanups to
692 get code to compile with C++ compiler. Still has
693 signed/unsigned comparison warnings.
695 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
697 * ircd/userload.c: change <sys/time.h> include to <time.h> for
700 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
702 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
705 * ircd/s_user.c: move gline_lookup function call into
706 register_user, where it'll have a username to lookup!
708 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
709 functions; also stuff send_error_to_client into return clauses
711 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
712 functions; also use send_error_to_client where that makes sense
714 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
715 functions; also use send_error_to_client where that makes sense
717 * ircd/gline.c: modify to utilize new sendcmdto_* series of
718 functions; also fix gline_lookup() to deal properly with remote
719 clients--boy, do struct Client and struct User need to be cleaned
722 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
725 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
726 sendcmdto_serv_butone(), all utilizing the %v conversion of
729 * include/send.h: define IRC_BUFSIZE, max size of a message;
730 declare sendcmdto_one(), vsendcmdto_one(), and
731 sendcmdto_serv_butone()
733 * include/msg.h: define all the CMD_* constants needed to utilize
734 the new sendcmdto_* series of functions
736 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
738 * ircd/gline.c: remove old, dead code.
740 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
741 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
742 (don't advertise proxies); remove dead code
744 * ircd/parse.c: oper handler for JUPE only lists jupes unless
745 CONFIG_OPERCMDS is enabled
747 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
748 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
750 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
751 always return ERR_DISABLED
753 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
754 enabled, always return ERR_DISABLED
756 * ircd/s_err.c: add error message to indicate disabled commands
758 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
760 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
762 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
763 CONFIG_NEW_MODE to 'y' for now
765 * ircd/gline.c (gline_list): fix a minor formatting bogon
767 * BUGS: since I fixed that bug, might as well mark it fixed.
769 * ircd/m_join.c: look up badchans with GLINE_EXACT
771 * ircd/m_gline.c: fix parc count problems; look up existing
772 G-lines with GLINE_EXACT; only set new lastmod when
773 activating/deactivating existing glines if old lastmod was not 0
775 * ircd/gline.c: forgot to copy the gline reason over; don't
776 propagate a gline with 0 lastmod if origin is user; add
777 GLINE_EXACT to force exact matching of gline mask
779 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
782 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
783 but gline_lookup() actually takes a client--d'oh.
785 2000-04-13 Thomas Helvey <tomh@inxpress.net>
786 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
788 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
790 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
792 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
795 * ircd/whocmds.c: Change idle time calc from socket idle to user
798 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
800 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
801 too, for ircd_snprintf.c
803 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
804 comments; mostly descended from the Linux manpage for printf, but
805 also documenting the extensions.
807 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
808 client; make 'q' be the same as 'L'; remove __inline__; only
809 define EXTENSION if HAVE_LONG_LONG is defined
811 * include/handlers.h: declare m_gline()
813 * ircd/parse.c: gline can be called by users, but it only lists
816 * ircd/s_user.c (set_nick_name): resend gline if a remote server
817 introduces a glined client
819 * ircd/s_serv.c (server_estab): burst glines, too
821 * ircd/gline.c: fix up all the expire times to be offsets;
822 simplify gline_resend()
824 * ircd/m_gline.c: begin coding replacements for ms_gline(),
825 mo_gline(), and m_gline()
827 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
828 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
830 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
832 * tools/Bouncer/*: Add comments/documentation/tags.
833 * tools/Bouncer/*: Add debug defines, make task fork().
835 2000-04-12 Thomas Helvey <tomh@inxpress.net>
836 * ircd/s_err.c: Cleanup s_err.c make one table so we
837 don't have to do anything tricky to get an error string.
839 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
840 * Add port bouncer for http (x/w)
842 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
844 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
845 call to gline_find(); also used GlineReason() instead of direct
846 reference to structure member
848 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
849 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
852 * ircd/channel.c: nothing seems to be called anywhere...
854 * ircd/s_err.c: update a couple of replies to dovetail with new
857 * ircd/gline.c: begin complete re-implementation of gline.c along
858 the lines of the final design of jupe.c
860 * include/gline.h: begin complete re-implementation of gline.c
861 along the lines of the final design of jupe.c
863 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
866 * ircd/ircd_snprintf.c: my new snprintf()-like functions
868 * include/ircd_snprintf.h: my new snprintf()-like functions
870 2000-04-11 Thomas Helvey <tomh@inxpress.net>
871 * ircd/IPcheck.c: removed old dead code
872 * ircd/s_user.c (send_user_info): removed non-standard
873 user not found message for userhost/userip
875 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
877 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
878 * doc/p10.html: Work on chapter 4.
880 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
882 * ircd/channel.c (mode_parse_client): fix coredump on /mode
883 #foobar +o nosuchnick
885 2000-04-10 Perry Lorier <Isomer@coders.net>
888 2000-04-09 Thomas Helvey <tomh@inxpress.net>
889 * include/IPcheck.h: fix prototype
890 * ircd/s_user.c: fix usage of IPcheck_remote_connect
891 * ircd/IPcheck.c: removed unused args
893 2000-04-09 Thomas Helvey <tomh@inxpress.net>
894 * include/IPcheck.h: add proto for IPcheck_expire
896 * ircd/IPcheck.c: Rewrote
898 * ircd/ircd.c: Add IPcheck_expire to main message loop
900 * ircd/s_user.c: Redo target hashing, refactor target code
902 * include/numeric.h: Cleaned up numerics, added which ones are
903 in use by other networks and what they are in use for.
905 * ircd/channel.c: cleaned can_join(), allow anyone through anything
906 if /invited, simplified the function. Opers overusing OPEROVERRIDE
907 will get a message explaining to them not to cheat.
909 * ircd/m_join.c: cleaned up the various join functions, should be
910 a lot more efficient. Still needs work. Now assumes that s<->s
911 won't send it a JOIN 0. Service coders - note this and tread with
914 * ircd/m_stats.c: added Gte-'s stats doc patch.
916 * ircd/m_version.c: /version now returns the 005 numeric as well.
917 as requested by Liandrin.
920 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
922 * ircd/m_clearmode.c: add include for support.h for write_log()
924 * configure: move ircd/crypt/* to tools/*
926 2000-04-06 Thomas Helvey <tomh@inxpress.net>
927 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
928 set client host to server alias if connection from localhost
930 2000-04-06 Perry Lorier <isomer@coders.net>
931 * ircd/ircd.c: Fix core during pinging (oops)
933 2000-04-06 Perry Lorier <isomer@coders.net>
934 * ircd/send.c: fixed wrong ident being sent to channels bug.
935 * include/numerics.h: Updated some of the numerics from other
936 networks. Flagged some as 'unused' by undernet.
938 2000-03-30 Perry Lorier <isomer@coders.net>
939 * ircd/ircd.c: Lets see if this helps the ping problem at all.
940 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
941 time for local clients. (as requested), extended who now returns all
942 the flags (@+!) so you can tell the complete state of a client.
944 2000-03-30 Thomas Helvey <tomh@inxpress.net>
945 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
947 2000-03-30 Perry Lorier <isomer@coders.net>
948 * ircd/parse.c: oops, missed opers.
950 2000-03-30 Perry Lorier <isomer@coders.net>
951 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
952 for so long. Remember: m_ping MUST be in the parse array. :)
954 2000-03-30 Perry Lorier <isomer@coders.net>
955 * ircd/ircd.c: test in check_pings was wrong. I move that we
956 disallow cvs commit after 10pm localtime....
958 2000-03-30 Perry Lorier <isomer@coders.net>
959 * ircd/m_pong.c: Fix it for servers too.
961 2000-03-30 Perry Lorier <isomer@coders.net>
962 * ircd/m_pong.c: Fix ping timeout bugs
964 2000-03-30 Perry Lorier <isomer@coders.net>
965 * ircd/channel.c: Bans had CurrentTime in their when field instead
968 2000-03-31 Thomas Helvey <tomh@ixpress.net>
969 * ircd/numnicks.c (SetXYYCapacity): fix for extended
972 2000-03-30 Perry Lorier <isomer@coders.net>
973 * ircd/m_nick.c: send kills both ways so when we add nick change
974 on collision we don't desync the network.
976 * ircd/map.c: Fixup the map a bit more.
978 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
980 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
982 * ircd/m_opmode.c: Log the mode changes to OPATH
984 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
987 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
990 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
992 * config/config-sh.in: added OPATH for opmode log file
994 * ircd/m_clearmode.c (do_clearmode): updated uses of
995 modebuf_mode_string() for the new usage
997 * ircd/channel.c: added flag MODE_FREE and an int argument to
998 modebuf_mode_string() to indicate that the string must be free'd;
999 updated calls to modebuf_mode_string() for the new usage; called
1000 collapse(pretty_mask()) on the ban string and use allocated memory
1001 for it; added ban list length accounting; fixed a number of small
1002 bugs in ban processing
1004 * include/channel.h: added flag MODE_FREE and an int argument to
1005 modebuf_mode_string() to indicate that the string must be free'd
1007 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
1008 keys and limits that are set
1010 2000-03-30 Perry Lorier <isomer@coders.net>
1011 * ircd/ircd.c: rewrote check_pings() for maintainability
1012 and speed. Also changed quit msg's so they don't have
1013 redundant nick[host] info in them.
1015 * ircd/send.c: Changed write errors to report what error
1016 occured (if possible).
1018 * ircd/gline.c: added gline comment to the quit.
1020 * ircd/m_server.c: Added suggestions to server quits mentioning
1021 what went wrong so the admin can fix it earlier instead of asking
1024 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
1025 servers that aren't fully burst yet. And show '(--s)' for servers
1028 * doc/example.conf: Fixed wrapped U:
1030 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
1032 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
1033 mode_parse() (version selectable at compile time)
1035 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
1037 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
1039 * config/config-sh.in: add new config option to enable new m_mode
1042 * doc/Configure.help: add documentation for new config option
1045 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
1046 MODE -v : Not enough parameters
1048 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
1049 +k and +l even if they weren't set...
1051 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
1053 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
1054 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
1055 for; test the 0-th member, not the i-th member, of the client
1058 * ircd/m_clearmode.c (do_clearmode): use the new
1059 mode_invite_clear() function
1061 * ircd/channel.c: cleared up all the compile-time warnings and
1064 * include/channel.h: added declarations for mode_ban_invalidate()
1065 and mode_invite_clear()
1067 * ircd/channel.c: finished mode_parse(), then broke it up into a
1068 dozen or so helper functions to make the code easier to read
1070 2000-03-29 Thomas Helvey <tomh@inxpress.net>
1071 * ircd/ircd.c: refactor server initialization a bit, use
1072 getopt for parsing command line, refactor init_sys, main,
1075 * ircd/s_bsd.c: add functions for initialization to clean
1076 up logic a bit and remove duplicated code.
1078 * include/ircd.h: add struct for server process related
1081 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
1083 * ircd/channel.c: initial definition of mode_parse(); flags to
1084 prevent doing the same thing multiple times; helper method
1085 send_notoper() to send a "Not oper"/"Not on channel" notice
1087 * include/channel.h: declare mode_parse() and helper flags
1089 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
1090 sending to match the current action of set_mode() closely enough
1091 that hopefully there won't be major conflicts
1093 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
1094 building logic, reversed the order of the arguments to mode
1095 commands to have '-' preceed '+'
1097 2000-03-29 Thomas Helvey <tomh@inxpress.net>
1098 * ircd/s_bsd.c (add_connection): don't disable socket options
1099 let OS tune itself and allow important performance tweaks to
1102 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
1104 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
1105 confused by set_mode, which is doing some really weird logic;
1106 guess what I'm going to rewrite next? ;)
1108 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
1110 * include/channel.h: added MODE_SAVE for the bounds checking stuff
1113 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
1114 make it do bounds checking on the buffer; all modes are sent only
1115 if the all parameter is 1; modebuf_flush is the exported wrapper
1117 * include/channel.h: add BOUNCE, renumber flags to get a little
1120 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
1121 BOUNCE; send DESYNCH message
1123 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
1125 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
1126 channel actually has in effect for deletion
1128 * ircd/channel.c: added explanatory comments to all added
1129 functions; made flushing take place at the correct place even if
1130 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
1131 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
1132 is empty, fixed the apparent source, removed some bogus string
1133 termination code, properly terminate the mode strings, add support
1134 for HACK2 and HACK3, made limit strings not be sent if the limit
1135 is being removed, changed where '+' and '-' come from in sent
1136 strings, added support for DEOP flag, set up bouncing code for
1139 * ircd/Makefile.in: ran make depend
1141 * include/channel.h: added new defines for future functionality,
1142 made modebuf_flush() return int so I can use tail recursion
1144 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
1145 to make it all compile
1147 * ircd/m_opmode.c: add msg.h to includes...
1149 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
1151 * ircd/channel.c (modebuf_flush): realized I forgot to
1152 nul-terminate addbuf/rembuf properly...
1154 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
1156 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
1157 sendto_serv_butone--blah^2
1159 * ircd/send.c (sendto_serv_butone): stupid comments confused me
1161 * ircd/channel.c (modebuf_flush): if there are no mode changes to
1162 propagate, we're done...
1164 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
1165 not sendto_all_butone
1167 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
1169 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
1171 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
1174 * ircd/parse.c: added messages for opmode and clearmode
1176 * include/handlers.h: added declarations for mo_opmode(),
1177 ms_opmode(), mo_clearmode(), and ms_clearmode()
1179 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
1182 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
1183 MODEBUF_DEST_OPMODE flag
1185 * ircd/channel.c (modebuf_flush): added new flag,
1186 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1187 to originate from source's server (or source itself, if
1188 IsServer(source)); also causes a server-level MODE to be sent as
1191 * include/channel.h: defined MODEBUF_DEST_SERVER,
1194 * ircd/channel.c: Add another argument to build_string() to handle
1195 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1196 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1199 2000-03-27 Perry Lorier <isomer@coders.net>
1201 * ircd/s_bsd.c: fixed missing 'u' typo.
1203 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
1205 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1206 _mode_string(), _mode_client(), _flush(); also implemented a
1207 simple build_string()
1209 * include/channel.h: added definition of ModeBuf, modebuf_*
1210 manipulation functions, and a couple of helper macros
1212 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1213 * numicks.c: convert extended numerics to use original mask version
1216 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1217 * Merge in changes from production
1218 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1219 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1220 * rfc1459.unet: Add Maniac's documentation for /names 0
1221 * Fix misc. jupe bugs that somehow made it into the tree
1222 * Escape /names 0 to mean /names --Maniac
1223 * Don't core when server asks for info --Maniac
1224 * Add Kev's jupe patch --Bleep
1225 * Add Maniacs squit patch --Bleep
1226 * Merge in u2_10_10_beta07 changes --Bleep
1227 * Merge in u2_10_10_beta06 changes --Bleep
1228 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1229 #-----------------------------------------------------------------------------
1231 # ChangeLog for ircu2.10.11
1233 # $Id: ChangeLog,v 1.146 2000-06-09 20:56:03 gte Exp $
1235 # Insert new changes at beginning of the change list.