1 2002-02-25 Carlo Wood <carlo@alinoe.com>
3 * ircd/m_server.c: remove unused variables
5 2002-02-25 Joseph Bongaarts <foxxe@wtfs.net>
7 * ircd/m_map.c: Modified to show a useful output to non-opered
8 clients when HEAD_IN_SAND_MAP is defined. Servers are added to
9 the list when first seen (after receiving SERVER) and that list
10 is sent to clients. Servers are excluded from the list if they are
11 hubs, services, or have been missing for more than 1 week.
13 * ircd/map.c: Created file for map_* functions
15 * include/map.h: Created file for map_* functions
17 * ircd/m_server.c: Added calls to map_update()
19 * ircd/s_misc.c: Added call to map_update()
21 * ircd/parse.c: Changed to use m_map() and mo_map()
23 2002-02-22 Reed Loden <reed@redmagnet.com>
25 * ircd/m_connect.c: Removed an extra : in remote connect message.
27 2002-02-19 Joseph Bongaarts <foxxe@wtfs.net>
29 * ircd/whocmds.c: Local opers should also be able to
30 see servernames in /who
32 * ircd/gline.c: Fix core bug in gline_find()
34 * ircd/m_kill.c: Bug fix for HIS_KILLWHO
36 2002-02-19 John Buttery <john@io.com>
38 * ircd/ircd.c: Updated "No such file" error message.
40 2002-02-18 Joseph Bongaarts <foxxe@wtfs.net>
42 * ircd/m_kill.c: Changed m_kill() to do_kill() because its not
43 a message handler, and some general cleanups and bug fixes.
45 * include/ircd_policy.h: Added HEAD_IN_SAND_KILLWHO for hiding
48 2002-02-16 Tim Vogelsang <net@astrolink.org>
50 * ircd/m_kill.c: added a new static function, m_kill, which
51 performs the actual kill.
53 2002-02-14 Joseph Bongaarts <foxxe@wtfs.net>
55 * Added support for LIST STOP
57 2002-02-13 Joseph Bongaarts <foxxe@wtfs.net>
59 * Merged changes from u2_10_11 to main branch.
61 2002-02-08 Tim Vogelsang <net@astrolink.org>
63 * ircd/m_quit.c: don't prefix user quits with "Quit:" unless a
66 2002-02-06 Kevin L Mitchell <klmitch@mit.edu>
68 * ircd/s_auth.c (read_auth_reply): left out an = in an
69 assertion--shouldn't have had any impact, though
71 * ircd/Makefile.in: add a hook for using ringlog; run make depend
73 * tools/ringlog.c: for the heck of it, add a comment including
76 2002-02-05 Kevin L Mitchell <klmitch@mit.edu>
78 * tools/ringlog.pl: perl script to take output from ringlog and
79 pass it to addr2line to get function, file, and line number
82 * tools/ringlog.c: program/object to help in building function
85 2002-02-04 Alex Badea <vampire@p16.pub.ro>
87 * include/ircd_features.h: added new feature MOTD_BANNER
89 * ircd/ircd_features.c: added new feature MOTD_BANNER
91 * ircd/motd.c (motd_signon): send a one-line banner from
92 FEAT_MOTD_BANNER if it's not NULL and FEAT_NODEFAULTMOTD
95 * doc/example.conf: default value for MOTD_BANNER feature
97 * doc/readme.features: documented the MOTD_BANNER feature
99 2002-02-04 Kevin L Mitchell <klmitch@mit.edu>
101 * ircd/s_debug.c (debug_serveropts): remove deprecated CHROOTDIR
102 check; added character 'A' to the server options string to
103 indicate when assertion checking is enabled
105 2002-02-03 Kevin L Mitchell <klmitch@mit.edu>
107 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
109 * ircd/engine_kqueue.c (set_or_clear): don't generate an ET_ERROR
110 event if the errno is EBADF, since the caller probably already
111 knows about it and just hasn't gotten around to processing it yet
113 * ircd/ircd_events.c: set the GEN_ERROR flag if an ET_ERROR event
114 is generated; don't process socket_events() or socket_state() if
115 an error occurred; add GEN_ERROR to list of flags in gen_flags()
117 * include/ircd_events.h: define new GEN_ERROR flag; add a macro to
120 2002-02-01 Kevin L Mitchell <klmitch@mit.edu>
122 * ircd/channel.c: change make_nick_user_{ip,host} to not use a
123 static buffer--instead, a buffer of the right size (NUH_BUFSIZE or
124 NUI_BUFSIZE--I confess they're not well-named) is allocated by the
127 2002-02-02 Alex Badea <vampire@p16.pub.ro>
129 * include/client.h: added user flag FLAGS_HIDDENHOST
131 * include/ircd_features.h: added FEAT_HOST_HIDING and
134 * include/numeric.h: defined numeric 338 (RPL_WHOISACTUALLY)
135 to report real hostnames and IPs to opers
137 * include/s_user.h: exported hide_hostmask()
139 * include/send.h: changed sendcmdto_channel_butserv to
140 sendcmdto_channel_butserv_butone; ditto for
141 sendcmdto_common_channels
143 * include/struct.h: added realhost to struct User
145 * include/whowas.h: added realhost to struct Whowas
147 * ircd/channel.c: match bans against both real and hidden
148 hostmasks; moved some calls to use sendcmdto_*_butone
150 * ircd/gline.c: match glines agains real host
152 * ircd/ircd_features.c: added FEAT_HOST_HIDING and
155 * ircd/m_account.c: call hide_hostmask() for possibly
156 hiding the user's host
158 * ircd/m_burst.c: moved some calls to use sendcmdto_*_butone
160 * ircd/m_topic.c: moved some calls to use sendcmdto_*_butone
162 * ircd/m_userip.c: report IP 127.0.0.1 if the user has a hidden
165 * ircd/m_who.c: match real hosts, if the query comes from an oper
167 * ircd/m_whois.c: report real hostname and IP to opers
169 * ircd/m_whowas.c: report real hostname to opers
171 * ircd/s_err.c: added user mode 'x' to the list of supported user
172 modes in RPL_MYINFO (004); added RPL_WHOISACTUALLY for reporting
173 real hostnames to opers
175 * ircd/s_misc.c: moved some calls to use sendcmdto_*_butone
177 * ircd/s_serv.c: send real hostname to servers
179 * ircd/s_user.c: send real hostname to servers; added processing
180 of usermode 'x'; added hide_hostmask() which actually does the work
181 of hiding a user's host; moved some calls to use sendcmdto_*_butone
183 * ircd/send.c: changed sendcmdto_channel_butserv to
184 sendcmdto_channel_butserv_butone; ditto for
185 sendcmdto_common_channels
187 * ircd/whocmds.c: extra letter 'x' in WHO reply if the user has
190 * ircd/whowas.c: if needed, store a user's real host so we can
191 report it to opers later
193 * doc/readme.features: documented HOST_HIDING and HIDDEN_HOST
196 * doc/example.conf: default values for HOST_HIDING and
199 2002-02-01 Tim Vogelsang <net@astrolink.org>
201 * ircd/send.c (sendwallto_group_butone): don't sent wallops to
204 2002-01-28 Kevin L Mitchell <klmitch@mit.edu>
206 * ircd/jupe.c (jupe_activate): remove a bogus assertion
208 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
210 * ircd/s_err.c: added new channel mode 'r' to list of supported
211 channel modes in RPL_MYINFO (004); migrated RPL_USERIP to use
212 numeric 340 instead of 307; add ERR_NEEDREGGEDNICK (477) for
213 informing users why they can't join a +r channel
215 * ircd/m_clearmode.c (do_clearmode): add support for MODE_REGONLY
216 (+r) to do_clearmode(); note that it is *not* being added to the
217 default clearmode mask!
219 * ircd/channel.c: don't allow non-+r users to send messages to +r
220 channels from off the channel; add support for MODE_REGONLY (+r)
221 to channel_modes(); don't allow non-+r users to join +r channels
222 without an invite; add support for MODE_REGONLY to the modebuf_*()
223 family of functions (changes in modebuf_flush_int(),
224 modebuf_mode(), and modebuf_extract()); add support for
225 MODE_REGONLY to mode_parse()
227 * include/supported.h (FEATURESVALUES2): added the new channel
228 mode 'r' to the list of supported channel modes
230 * include/numeric.h: move RPL_USERIP to 340 to avoid the 307
231 conflict; add ERR_NEEDREGGEDNICK (477) for the new +r channels
233 * include/channel.h: remove unused MODE_SENDTS; add new
236 * ircd/s_bsd.c (read_packet): remove call to timer_verify()
238 * ircd/list.c: remove calls to timer_verify() from
239 alloc_connection() and dealloc_connection()
241 * ircd/ircd_events.c: turn off timer_verify(); remove calls to it
244 2002-01-27 Kevin L Mitchell <klmitch@mit.edu>
246 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
248 * ircd/ircd_events.c (timer_run): why did I ever use a next
249 pointer when the algorithm guarantees that the head pointer will
250 always be the next pointer?
252 2002-01-26 Kevin L Mitchell <klmitch@mit.edu>
254 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
256 * ircd/s_bsd.c (read_packet): call timer_verify() after adding the
257 client process timer to catch any list corruption
259 * ircd/list.c: surround alloc_connection() and
260 dealloc_connection() with calls to timer_verify()
262 * ircd/ircd_events.c: add sledgehammer known as timer_verify() to
263 verify the timer list's structure; call it around timer_run()
265 2002-01-22 Kevin L Mitchell <klmitch@mit.edu>
267 * ircd/send.c (sendcmdto_common_channels): don't send message to a
268 channel that the source is a zombie on
270 2002-01-13 Kevin L Mitchell <klmitch@mit.edu>
272 * ircd/ircd_events.c (timer_enqueue): one more assertion--make
273 sure a timer has the ACTIVE flag set before enqueueing the timer
275 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
277 * ircd/list.c (dealloc_connection): assert that the process timer
278 has been removed from the timer queue before dealloc_connection()
281 2002-01-12 Kevin L Mitchell <klmitch@mit.edu>
283 * ircd/res.c: don't accept T_A when we're looking for T_PTR
285 * ircd/channel.c (modebuf_flush_int): nuke the code that would
286 send a HACK DESYNCH notice on a HACK(2)--it would be far too
289 * ircd/m_away.c (user_set_away): use AWAYLEN instead of TOPICLEN
291 * include/supported.h: add AWAYLEN to the list of supported
294 * include/ircd_defs.h: add AWAYLEN to specify the maximum length
297 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
299 * ircd/m_mode.c (m_mode): pass extra parameter to channel_modes()
301 * ircd/channel.c: pass a buflen parameter to channel_modes() for
302 pbuf--we were using sizeof(pbuf), which would always be
303 sizeof(char*) before; change send_channel_modes() to pass extra
304 parameter to channel_modes()
306 * include/channel.h: pass a buflen parameter to channel_modes()
309 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
311 * ircd/uping.c (uping_start): initialize some timers
313 * ircd/s_bsd.c (read_packet): use new t_onqueue() macro to figure
314 out when we need to re-add the process timer
316 * ircd/s_auth.c (make_auth_request): initialize a timer
318 * ircd/res.c (init_resolver): initialize some timers
320 * ircd/list.c (alloc_connection): initialize the client process
323 * ircd/ircd_events.c: add a function, timer_init(), to initialize
324 a struct Timer; recast timer_add() to catch when adding a marked
325 timer and not re-enqueue it--but mark it for re-enqueuing; update
326 timer_del() to turn off the GEN_READD flag and to ignore reference
327 counts when destroying the timer--we're using GEN_MARKED as an
328 ersatz referance count; changed timer_run() to work with the new
329 way of doing things; add GEN_ACTIVE and GEN_READD to gen_flags()'s
332 * ircd/ircd.c: initialize some timers
334 * ircd/engine_select.c (engine_loop): initialize a timer
336 * ircd/engine_poll.c (engine_loop): initialize a timer
338 * ircd/engine_kqueue.c (engine_loop): initialize a timer
340 * ircd/engine_devpoll.c (engine_loop): initialize a timer
342 * ircd/IPcheck.c (IPcheck_init): initialize a timer
344 * include/ircd_events.h: add GEN_READD flag for timers to indicate
345 that a timer must be readded; add t_onqueue() macro to check to
346 see if a timer is on the queue (this is a hack, though); added
347 timer_init() to initialize a struct Timer--we're no longer doing
348 the initialization in timer_add()
350 2002-01-11 Kevin L Mitchell <klmitch@mit.edu>
352 * ircd/engine_devpoll.c (engine_loop): relocate an assertion to
353 prevent a core bug *in* the assertion
355 * doc/readme.features: document new POLLS_PER_LOOP feature; change
356 documentation to reflect that OPER_SET now defaults to FALSE
358 * doc/p10.html: documented the new ACCOUNT stuff
360 * doc/example.conf: document new POLLS_PER_LOOP default; change
363 * RELEASE.NOTES: changed documentation to reflect the fact that
364 assertions are now enabled by default and do not cause memory
367 * ircd/res.c (make_cache): removed a bogus assertion we probably
368 never caught because assertions haven't been enabled on production
369 servers for any length of time before
371 * ircd/engine_devpoll.c (engine_loop): ditto for POLLS_PER_DEVPOLL
373 * ircd/engine_kqueue.c (engine_loop): stupid me forgot one
374 instance of POLLS_PER_KQUEUE
376 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
378 * ircd/s_bsd.c (client_timer_callback): only clear the
379 FREEFLAG_TIMER flag when the timer is being destroyed
381 * ircd/ircd_features.c: create a new feature, POLLS_PER_LOOP, and
382 default it to 200; turn OPER_SET off by default
384 * ircd/engine_kqueue.c: dynamically allocate and reallocate the
385 array of events to obtain from the kernel
387 * ircd/engine_devpoll.c: dynamically allocate and reallocate the
388 array of events to obtain from the kernel
390 * include/ircd_features.h: add a new feature for tuning how many
391 events to get from the kernel, for engines that support that
393 * ircd/Makefile.in: re-run make depend to correct dependancies
395 * ircd/m_who.c: remove unneeded inclusion of list.h
397 * ircd/ircd_events.c: remove unneeded inclusion of list.h
399 * ircd/whocmds.c (do_who): hide server name in /who unless
400 requester is an operator; simplify hop count insertion
402 * ircd/s_misc.c (exit_one_client): make sure client's snomask is
405 * ircd/parse.c: use mo_version and mo_admin when opers do /version
408 * ircd/m_whowas.c (m_whowas): use HEAD_IN_SAND_SERVERNAME instead
409 of the static string "*.undernet.org"
411 * ircd/m_version.c: only let ordinary users get version
412 information for the server they are on
414 * ircd/m_admin.c: only let ordinary users get admin information
415 for the server they are on
417 * ircd/channel.c (client_can_send_to_channel): check is_banned()
418 before letting the client speak on a channel s/he is not on
420 * include/supported.h: add NETWORK to feature list
422 * include/handlers.h: declare mo_admin() and mo_version()
424 2002-01-10 Kevin L Mitchell <klmitch@mit.edu>
426 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
428 * ircd/s_debug.c (count_memory): conditionalize on MDEBUG instead
431 * ircd/m_stats.c: conditionalize /stats M on MDEBUG instead of
434 * ircd/ircd_alloc.c: conditionalize on MDEBUG instead of on
437 * ircd/fda.c: conditionalize on MDEBUG instead of on !NDEBUG
439 * ircd/Makefile.in: run make depend on chkconf.c as well
441 * include/ircd_alloc.h: instead of conditionalizing on !NDEBUG,
442 conditionalize on MDEBUG
444 * include/fda.h: instead of conditionalizing on !NDEBUG,
445 conditionalize on MDEBUG
447 * configure: rebuild configure script
449 * configure.in: enable assertion checking by default, since we
450 have now decoupled memory debugging from the NDEBUG macro
452 * ircd/s_user.c (set_nick_name): remove calls to
455 * ircd/s_misc.c (exit_one_client): remove calls to
458 * ircd/s_conf.c (rehash): remove calls to verify_client_list()
460 * ircd/m_who.c (m_who): remove calls to verify_client_list()
462 * ircd/list.c: remove calls to verify_client_list(); keep
463 verify_client_list() around just in case we ever need it again,
464 but never compile it in
466 * ircd/ircd_events.c (event_execute): remove calls to
469 * ircd/client.c (client_get_ping): remove calls to
472 * include/list.h (send_listinfo): remove temporary debugging
473 function verify_client_list()
475 * ircd/uping.c: don't die if the event type is ET_ERROR in socket
478 * ircd/res.c (res_callback): don't die if the event type is
481 * ircd/listener.c (accept_connection): don't die if the event type
484 2002-01-09 Kevin L Mitchell <klmitch@mit.edu>
486 * ircd/s_user.c (set_nick_name): bracket call to
487 add_client_to_list() with calls to verify_client_list()
489 * include/patchlevel.h (PATCHLEVEL): bump patchlevel (again)
491 * ircd/list.c (verify_client_list): add a probabilistic loop
492 detector: for every client added, there is a 2% probability that
493 it will be used to replace the value of sentinel; if at any time,
494 sentinel is found again, we know we're in a loop
496 * ircd/ircd_events.c (event_execute): add verify_client_list()
497 calls wrapping event_execute; at the very least, I'll figure out
498 what event the corruption occurred in
500 * ircd/list.c: moved verify_client_list() to try to keep it from
503 * ircd/Makefile.in (version.c): version.c wasn't dependant on
504 version.h and patchlevel.h, like it was supposed to be
506 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
508 * ircd/s_auth.c (destroy_auth_request): overload send_reports
509 argument to also indicate whether or not to call
510 release_auth_client() and thereby enter the client into the linked
513 * ircd/engine_devpoll.c (engine_loop): remove bogus assertion
515 * include/patchlevel.h (PATCHLEVEL): bump patchlevel
517 * ircd/list.c (free_client): verify that destroy_auth_request()
518 didn't automagically re-add us to the list; we might have to think
519 about this interaction more carefully, actually
521 * ircd/s_auth.c (auth_kill_client): zero the auth pointer before
522 calling free_client(); otherwise, free_client() will try to free
523 the auth by calling destroy_auth_request(), which will call
526 * ircd/s_misc.c (exit_one_client): liberally sprinkle calls to
527 verify_client_list() around to catch any corruption that might
530 * ircd/s_conf.c (rehash): liberally sprinkle calls to
531 verify_client_list() here, since this is about the only routine I
532 can think of that could cause the "core on kill -HUP" bug
534 * ircd/m_who.c: sprinkle calls to verify_client_list() around
535 liberally, since we've seen crashes here; temporarily include the
536 otherwise unneeded list.h header
538 * ircd/list.c: sprinkle calls to verify_client_list() around quite
539 liberally; add debugging asserts to list manipulation functions to
540 catch strange settings for next and prev pointers; define
541 verify_client_list(), which walks the client list and verifies
542 that everything is as it's supposed to be
544 * ircd/client.c: wrap client_get_ping with calls to
545 verify_client_list() to see if that's where we're dying
547 * include/patchlevel.h (PATCHLEVEL): bump to 03
549 * include/list.h: declare verify_client_list() if DEBUGMODE
550 enabled; otherwise, define it to be empty
552 2002-01-08 Kevin L Mitchell <klmitch@mit.edu>
554 * ircd/m_quit.c (m_quit): remove an unused variable
556 * include/patchlevel.h (PATCHLEVEL): bump PATCHLEVEL to 2
558 * ircd/s_user.c: when building the user mode to send to the user,
559 don't include +r; add an extra set of parens to squelch a warning
561 * ircd/m_quit.c (m_quit): use exit_client_msg()
563 * include/patchlevel.h (PATCHLEVEL): bump patch level, so we can
564 keep track of who's running what version
566 * ircd/m_squit.c (ms_squit): remove debugging calls to
569 * Makefile.in: change MAKEFILES to IRCD_MAKEFILES to work around a
570 new gmake "feature" (pull-up from trunk)
572 * ircd/m_quit.c (m_quit): prefix user quits with "Quit:" (pull-up
575 2002-01-07 Kevin L Mitchell <klmitch@mit.edu>
577 * ircd/s_user.c: add FLAGS_ACCOUNT, represented as 'r', to the
578 list of user modes; process account name as part of user mode in
579 NICK decoding (set_nick_name()); add account name to usermode when
580 building the usermode to incorporate in outgoing NICK messages
582 * ircd/s_err.c: add RPL_WHOISACCOUNT for reporting what account a
585 * ircd/parse.c: define the new ACCOUNT command, usable only by
586 servers and ignored by everything else
588 * ircd/m_whois.c: report what account name is associated with a
591 * ircd/m_account.c: implement the ACCOUNT command
593 * ircd/Makefile.in: add m_account.c to the list of sources; ran
596 * include/struct.h: add an account field to struct User
598 * include/numeric.h: add a reply, RPL_WHOISACCOUNT, for reporting
599 what username a user is logged in under
601 * include/msg.h: add ACCOUNT command and token (AC)
603 * include/ircd_defs.h: define ACCOUNTLEN to be 12--this matches
604 the maximum length of a username for X
606 * include/handlers.h: add declaration for ms_account()
608 * include/client.h: add FLAGS_ACCOUNT to flag when a user account
609 name has been set; added FLAGS_ACCOUNT to SEND_UMODES; added
610 IsAccount() and SetAccount() to manipulate the flag
612 * ircd/m_squit.c (ms_squit): if we call FindNServer() on a server
613 name like "Amsterdam2.NL.EU.undernet.org", we get the struct
614 Client for the server with numeric "Am", which happens to be
615 stockholm! To fix this, we look up the full name *first*; if that
616 doesn't get it, *then* we look up by numeric.
618 2001-12-24 Perry Lorier <isomer@coders.net>
619 * ircd/m_server.c: cleanups, maybe this will make the bug easier
622 * ircd/m_stats.c: display maximum number of connects in an I:
624 2001-11-22 Perry Lorier <isomer@coders.net>
625 * ircd/m_squit.c: Bug fix in squit
627 2001-11-03 Greg Sikorski <gte@atomicrevs.demon.co.uk>
628 * ircd/parse.c, include/handlers.h: Give remote whois the correct
631 2001-11-01 Kevin L Mitchell <klmitch@mit.edu>
633 * ircd/send.c: some minor white-space fiddling; recast selector
634 test in sendwallto_group_butone() to remove a warning regarding
635 putting & within parentheses
637 * ircd/m_create.c (ms_create): use time_t instead of int as a
640 * ircd/ircd_reply.c (protocol_violation): it's supposed to be
641 WALL_DESYNCH, not CMD_DESYNCH, if I understand things right--no
642 wonder we weren't seeing any protocol violations!
644 * include/send.h: include time.h for time_t; move WALL_* closer to
645 the function they're used in; some white-space fiddling; add
646 declaration of sendto_opmask_butone_ratelimited()
648 * ircd/m_squit.c (ms_squit): add protocol_violation() calls in the
649 cases where we ignore a squit, so we aren't taken by surprise, at
652 * ircd/m_create.c (ms_create): Display origin server, not origin
655 * ircd/m_create.c (ms_create): Fix "Timestamp drift" server notice
657 2001-10-31 Perry Lorier <isomer@coders.net>
658 * include/m_ping.c: Forward port ping bug
660 2001-10-31 Perry Lorier <isomer@coders.net>
661 * include/patchlevel.h: We're beta now
663 2001-10-31 Perry Lorier <isomer@coders.net>
664 * ircd/s_user.c: fixed hunt_server
666 2001-09-21 Perry Lorier <isomer@coders.net>
667 * ircd/send.c and various: replace sendcmdto_flag_butone with
668 sendwallto_group_butone
670 2001-09-21 Vampire- <unknown>
671 * ircd/ircd_string.c: unique_name_vector round II.
673 2001-09-21 mbuna <mbuna@undernet.org>
674 * configure.in: Add support for darwin
676 2001-09-21 Perry Lorier <isomer@coders.net>
677 * ircd/s_user.c I'm stupid, s/acptr/from/, Hektik pointed it out
679 2001-09-20 Perry Lorier <isomer@coders.net>
681 * Pullups from 2.10.10.pl16
682 * Added some warnings, and the concept of rate limited snotices
684 2001-08-31 Kevin L Mitchell <klmitch@mit.edu>
686 * ircd/channel.c: use "%u" to format limit arguments; use
687 strtoul() to process limit arguments in a /mode command--note:
688 most clients seem to truncate the integer, probably because
689 they're using atoi, and perhaps signed ints
691 2001-08-17 Kevin L Mitchell <klmitch@mit.edu>
693 * ircd/numnicks.c: include stdlib.h for exit()
695 * ircd/ircd_log.c: include stdlib.h for exit()
697 * ircd/ircd_events.c: include stdlib.h for exit()
699 * ircd/s_stats.c: remove description of /stats v, since it's gone
701 * ircd/m_wallops.c (mo_wallops): add "*" to the beginning of
702 /wallops to distinguish wallops from wallusers
704 * ircd/m_error.c (mr_error): ignore ERROR from clients that aren't
705 in the "handshake" or "connecting" states--I think the latter will
708 * doc/Authors: apply delete's Authors patch
710 * RELEASE.NOTES: rewrite RELEASE.NOTES, basing it a little on
713 * README: rewrite README
715 2001-07-31 Kevin L. Mitchell <klmitch@mit.edu>
717 * ircd/s_serv.c (server_estab): remove unused variable split
719 * ircd/parse.c: add mr_error to the parse table
721 * ircd/m_error.c (mr_error): add mr_error() to handle ERRORs from
722 unregistered connections--if IsUserPort() is true, the ERROR is
723 ignored, otherwise, the message is saved
725 2001-07-28 Kevin L. Mitchell <klmitch@mit.edu>
727 * ircd/m_kill.c (ms_kill): another minor typo *sigh*
729 * ircd/s_user.c (send_supported): oops, minor typo...
731 * ircd/s_user.c: implement send_supported() to send two ISUPPORT
732 messages containing our feature buffers; make register_user() use
735 * ircd/s_misc.c (exit_client): make sure not to give away a remote
736 server in the ERROR message sent to the client; if the killer is a
737 server, we substitute our name in its place
739 * ircd/m_version.c (m_version): use send_supported() to send the
740 ISUPPORT values to the user
742 * ircd/m_nick.c: shave nick collision kills here a bit, too, for
743 the same reasons as for m_kill.c
745 * ircd/m_kill.c: shave kills a bit so that the results look
746 exactly the same no matter where you are; if we didn't do this, it
747 would be possible to map the network by looking at the differences
748 between kills originating under various circumstances
750 * include/supported.h: split the features into two, so as to not
751 bust the parameter count when sending the features list
753 * include/s_user.h: declare new send_supported() function to send
754 the ISUPPORT information
756 2001-07-27 Kevin L. Mitchell <klmitch@mit.edu>
758 * ircd/s_bsd.c: disable IP (*not* TCP) options to prevent
759 source-routed spoofing attacks; this is only available under
760 u2.10.11, so don't even bother, since no one but testers are using
763 2001-07-25 Kevin L. Mitchell <klmitch@mit.edu>
765 * include/ircd_policy.h: enable HEAD_IN_SAND_REMOTE by default
767 * ircd/s_err.c: put in a . for reporting link version on /trace,
768 to match what /version does
770 2001-07-21 Kevin L. Mitchell <klmitch@mit.edu>
772 * ircd/s_misc.c (exit_client): servers don't understand what the
773 numeric nick ERROR is supposed to mean, so they ignore error
774 messages, resulting in not knowing why we were rejected; use
775 sendcmdto_one for servers and sendrawto_one for clients
777 2001-07-17 Kevin L. Mitchell <klmitch@mit.edu>
779 * ircd/m_burst.c (ms_burst): in the case of a modeless channel and
780 a nick collide, a bare BURST may be propagated; adjust the
781 enforced parameter count to accept the bare BURST
783 2001-07-12 Kevin L. Mitchell <klmitch@mit.edu>
785 * ircd/s_bsd.c: mark a client as having been IP checked
787 * ircd/IPcheck.c (ip_registry_check_remote): remove unneeded
788 second call to SetIPChecked()
790 2001-07-11 Kevin L. Mitchell <klmitch@mit.edu>
792 * ircd/engine_poll.c: deal with POLLHUP properly (hopefully)
794 * ircd/engine_devpoll.c: deal with POLLHUP properly (hopefully)
796 2001-07-09 Kevin L. Mitchell <klmitch@mit.edu>
798 * ircd/os_bsd.c (os_get_rusage): move buf into the two ifdef'd
799 sections so that if neither is used, the declaration of buf will
800 not elicit an "unused variable" warning under NetBSD
802 * ircd/m_map.c: include string.h to declare strcpy (fix warnings
805 * ircd/m_away.c: include string.h to declare strcpy/strlen (fix
808 * ircd/ircd_log.c: include string.h to declare strcpy/strlen (fix
811 * ircd/client.c: include string.h to declare memset (fix warnings
814 * ircd/channel.c: remove unused functions next_overlapped_ban,
815 del_banid, and is_deopped (fix warnings under -O1)
817 * ircd/IPcheck.c: include string.h to declare memset/memcpy (fix
820 2001-06-29 Kevin L. Mitchell <klmitch@mit.edu>
822 * ircd/s_user.c (set_user_mode): clear the snomask if the user
823 isn't supposed to receive server notices anymore
825 * ircd/ircd_features.c: change CONFIG_OPERCMDS to default to FALSE
827 * configure.in: use AC_MSG_CHECKING/AC_MSG_RESULT when checking
828 installation prefix; default devpoll and kqueue to on (they get
829 turned off if the required headers aren't present)
831 * ircd/whocmds.c (do_who): use ircd_snprintf() instead of
832 sprintf_irc(); it's a bit hackish, but it'll do for now
834 * ircd/support.c: remove unused #include
836 * ircd/send.c: remove unused #include
838 * ircd/s_user.c: use ircd_snprintf() instead of sprintf_irc()
840 * ircd/s_serv.c: remove unused #include
842 * ircd/s_misc.c: use ircd_snprintf() and friends instead of
843 sprintf_irc() and friends
845 * ircd/s_err.c: moved atoi_tab[] from ircd/sprintf_irc.c to
846 ircd/s_err.c, which is the only other file to refer to it
848 * ircd/s_conf.c (conf_add_deny): use ircd_snprintf() instead of
851 * ircd/s_bsd.c (connect_server): use ircd_snprintf() instead of
854 * ircd/s_auth.c: use ircd_snprintf() instead of sprintf_irc()
856 * ircd/res.c: use ircd_snprintf() instead of sprintf_irc()
858 * ircd/m_version.c: use ircd_snprintf() instead of sprintf_irc()
860 * ircd/m_kill.c: use ircd_snprintf() instead of sprintf_irc()
862 * ircd/listener.c: use ircd_snprintf() instead of sprintf_irc()
864 * ircd/gline.c: use ircd_snprintf() instead of sprintf_irc()
866 * ircd/channel.c: don't include sprintf_irc.h; use ircd_snprintf()
867 instead of sprintf_irc()
869 * ircd/Makefile.in: remove sprintf_irc.c from sources list; run
872 * include/ircd_string.h: remove declaration of sprintf_irc() (what
873 was it doing here anyway?)
875 * include/sprintf_irc.h: removed unneeded source file
877 * ircd/sprintf_irc.c: removed unneeded source file
879 * ircd/s_debug.c (count_memory): remove some dead code
881 * ircd/s_auth.c: remove some dead code
883 * ircd/res.c (update_list): remove some dead code
885 * ircd/m_whowas.c: remove some dead code
887 * ircd/m_whois.c: remove some dead code
889 * ircd/m_who.c: remove some dead code
891 * ircd/m_wallusers.c: remove some dead code
893 * ircd/m_wallops.c: remove some dead code
895 * ircd/m_wallchops.c: remove some dead code
897 * ircd/m_version.c: remove some dead code
899 * ircd/m_userip.c: remove some dead code
901 * ircd/m_userhost.c: remove some dead code
903 * ircd/m_uping.c: remove some dead code
905 * ircd/m_trace.c: remove some dead code
907 * ircd/m_topic.c: remove some dead code
909 * ircd/m_tmpl.c: remove some dead code
911 * ircd/m_time.c: remove some dead code
913 * ircd/m_squit.c: remove some dead code
915 * ircd/m_silence.c: remove some dead code
917 * ircd/m_settime.c: remove some dead code
919 * ircd/m_set.c: remove some dead code
921 * ircd/m_server.c: remove some dead code
923 * ircd/m_rpong.c: remove some dead code
925 * ircd/m_rping.c: remove some dead code
927 * ircd/m_restart.c: remove some dead code
929 * ircd/m_reset.c: remove some dead code
931 * ircd/m_rehash.c: remove some dead code
933 * ircd/m_quit.c: remove some dead code
935 * ircd/m_proto.c: remove some dead code
937 * ircd/m_privs.c: remove some dead code
939 * ircd/m_privmsg.c: remove some dead code
941 * ircd/m_pong.c: remove some dead code
943 * ircd/m_ping.c: remove some dead code
945 * ircd/m_pass.c: remove some dead code
947 * ircd/m_part.c: remove some dead code
949 * ircd/m_opmode.c: remove some dead code
951 * ircd/m_oper.c: remove some dead code
953 * ircd/m_notice.c: remove some dead code
955 * ircd/m_nick.c: remove some dead code
957 * ircd/m_map.c: remove some dead code
959 * ircd/m_lusers.c: remove some dead code
961 * ircd/m_list.c: remove some dead code
963 * ircd/m_links.c: remove some dead code
965 * ircd/m_kill.c: remove some dead code
967 * ircd/m_kick.c: remove some dead code
969 * ircd/m_jupe.c: remove some dead code
971 * ircd/m_join.c: remove some dead code
973 * ircd/m_ison.c: remove some dead code
975 * ircd/m_invite.c: remove some dead code
977 * ircd/m_info.c: remove some dead code
979 * ircd/m_help.c: remove some dead code
981 * ircd/m_gline.c: remove some dead code
983 * ircd/m_get.c: remove some dead code
985 * ircd/m_error.c: remove some dead code
987 * ircd/m_endburst.c: remove some dead code
989 * ircd/m_die.c: remove some dead code
991 * ircd/m_desynch.c: remove some dead code
993 * ircd/m_destruct.c: remove some dead code
995 * ircd/m_defaults.c: remove some dead code
997 * ircd/m_create.c: remove some dead code, along with an #if 1
999 * ircd/m_cprivmsg.c: remove some dead code
1001 * ircd/m_connect.c: remove some dead code
1003 * ircd/m_close.c: remove some dead code
1005 * ircd/m_clearmode.c: remove some dead code
1007 * ircd/m_burst.c: remove some dead code
1009 * ircd/m_away.c: remove some dead code
1011 * ircd/m_admin.c: remove some dead code
1013 * ircd/listener.c (accept_connection): remove some dead code
1015 * ircd/ircd_reply.c (need_more_params): remove some dead code
1017 * ircd/channel.c (add_banid): remove some dead code
1019 * include/support.h: remove some dead code
1021 * include/querycmds.h: remove some dead code
1023 * doc/readme.chroot: document how to do chroot operation
1025 2001-06-28 Kevin L. Mitchell <klmitch@mit.edu>
1027 * ircd/Makefile.in: tune for VPATH builds/installs; add a rule to
1028 force bin directory to be created if necessary prior to
1029 installation; run make depend
1031 * doc/Makefile.in (install): tune for VPATH installs by cd'ing to
1034 * Makefile.in: tune to detect Makefile.in changes in
1035 subdirectories and to create installation directory indicated by
1038 * ircd/whocmds.c (count_users): routine to count the number of
1039 users matching a given user@host mask
1041 * ircd/s_err.c: add error messages for ERR_LONGMASK,
1042 ERR_TOOMANYUSERS, and ERR_MASKTOOWIDE
1044 * ircd/m_gline.c: look for and advance past '!' flag on G-lines
1045 from operators; only set GLINE_OPERFORCE flag if oper has the
1046 PRIV_WIDE_GLINE privilege
1048 * ircd/ircd_features.c: add GLINEMAXUSERCOUNT, which is the
1049 maximum number of users a G-line can impact before it has to be
1050 forced; OPER_WIDE_GLINE, to allow operators to use ! to force a
1051 wide G-line to be set; and LOCOP_WIDE_GLINE, to allow local
1052 operators to use ! to force a wide G-line to be set
1054 * ircd/gline.c: make make_gline() be called with separate user and
1055 host arguments, and not call canon_userhost() directly; implement
1056 gline_checkmask() to verify that a host mask is acceptable; move
1057 BADCHAN check up in gline_add(), and check passed-in mask under
1058 certain circumstances for acceptability; fix call to
1059 sendto_opmask_butone() to handle separation of userhost into user
1060 and host in gline_add(); update call to make_gline()
1062 * ircd/client.c: use FEAT_OPER_WIDE_GLINE and
1063 FEAT_LOCOP_WIDE_GLINE to set PRIV_WIDE_GLINE for an operator; add
1064 PRIV_WIDE_GLINE to privtab[] for client_report_privs()
1066 * include/whocmds.h (count_users): declare routine to count users
1067 matching a given user@host mask
1069 * include/numeric.h: added three new error returns: ERR_LONGMASK
1070 -- mask can't be formatted into a buffer; ERR_TOOMANYUSERS -- too
1071 many users would be impacted by the mask; ERR_MASKTOOWIDE -- mask
1072 contains wildcards in the wrong places
1074 * include/ircd_features.h: add FEAT_GLINEMAXUSERCOUNT,
1075 FEAT_OPER_WIDE_GLINE, and FEAT_LOCOP_WIDE_GLINE
1077 * include/gline.h (GLINE_OPERFORCE): provides a way for m_gline()
1078 to signal to gline_add() that the operator attempted to force the
1081 * include/client.h (PRIV_WIDE_GLINE): new privilege for operators
1083 * doc/readme.gline: update to document new "!" prefix to a G-line
1086 * doc/readme.features: document GLINEMAXUSERCOUNT,
1087 OPER_WIDE_GLINE, and LOCOP_WIDE_GLINE
1089 * doc/example.conf: update to mention new features along with
1092 2001-06-27 Kevin L. Mitchell <klmitch@mit.edu>
1094 * doc/example.conf: updated example.conf from Braden
1097 * include/supported.h: forward-port from pl15
1099 2001-06-25 Kevin L. Mitchell <klmitch@mit.edu>
1101 * ircd/whocmds.c: include ircd_policy.h and implement
1102 HEAD_IN_SAND_WHO_OPCOUNT--forward-port from pl15
1104 * ircd/m_whois.c: forward-port of the idle-time hiding code from
1105 pl15; this also required passing parc into do_whois(), which also
1106 meant passing parc into do_wilds()--*sigh*
1108 * include/ircd_policy.h: add a couple more HEAD_IN_SAND
1109 #define's--WHOIS_IDLETIME and WHO_HOPCOUNT
1111 2001-06-22 Kevin L. Mitchell <klmitch@mit.edu>
1113 * tools/wrapper.c: add a wrapper program that can be used to
1114 adjust file descriptor limits and root directories; program must
1115 be run as root--NOT SETUID!--and given appropriate -u arguments
1117 * doc/readme.log: documentation of how to configure logging
1119 * doc/readme.features: documentation of each feature (except for
1122 2001-06-21 Kevin L. Mitchell <klmitch@mit.edu>
1124 * Makefile.in (config): add a deprecation notice with a pointer to
1127 * tools/transition: shell script to convert old compile-time
1128 options into new compile-time options and appropriate F-lines
1130 * tools/mkchroot: shell-script to prepare the chroot area by
1131 copying over all the necessary libraries so they can be found
1133 2001-06-20 Kevin L. Mitchell <klmitch@mit.edu>
1135 * INSTALL: partial update of INSTALL for u2.10.11 release...
1137 2001-06-14 Kevin L. Mitchell <klmitch@mit.edu>
1139 * ircd/table_gen.c (makeTables): finally got tired of the
1140 "overflow in implicit conversion" warning, so just got rid of it
1141 by explicitly casting UCHAR_MAX to a (default) char; diffs show no
1142 differences in the tables generated
1144 2001-06-11 Kevin L. Mitchell <klmitch@mit.edu>
1146 * ircd/send.c (sendcmdto_match_butone): don't let the server crash
1147 if a client is in the STAT_CONNECTING status
1149 2001-06-10 Kevin L. Mitchell <klmitch@mit.edu>
1151 * ircd/send.c: remove unused vsendcmdto_one(), consolidating it
1152 into sendcmdto_one(); define new sendcmdto_prio_one(), which
1153 places the message into the priority queue
1155 * ircd/s_user.c (hunt_server_prio_cmd): definition of
1156 hunt_server_prio_cmd(), which simply calls sendcmdto_prio_one()
1157 instead of sendcmdto_one()
1159 * ircd/m_settime.c: use sendcmdto_prio_one() and
1160 hunt_server_prio_cmd() to send SETTIME
1162 * ircd/m_server.c: use sendcmdto_prio_one() to send SETTIME
1164 * include/send.h: removed declaration for unused vsendcmdto_one();
1165 added a declaration for sendcmdto_prio_one()
1167 * include/s_user.h: declare hunt_server_prio_cmd(), which calls
1168 sendcmdto_prio_one()
1170 * ircd/send.c (sendcmdto_flag_butone): oops; /wallops should be
1171 put in the server's priority queue, too...
1173 * ircd/ircd.c: don't check LPATH for accessibility at all
1175 2001-06-08 Kevin L. Mitchell <klmitch@mit.edu>
1177 * ircd/s_serv.c (server_estab): send a +h flag in our SERVER
1178 command if we're configured as a hub; send individual server flags
1181 * ircd/s_bsd.c (completed_connection): send a +h flag in our
1182 SERVER command if we're configured as a hub
1184 * ircd/m_server.c: implement parv[7] as a mode-like string; +h
1185 sets the FLAGS_HUB flag for a server; +s sets the FLAGS_SERVICE
1186 flag for a server; +hs sets both flags; also modify CMD_SERVER
1187 format string to send the flags
1189 * include/client.h: define two new flags, FLAGS_HUB and
1190 FLAGS_SERVICE to mark services and hubs as such; define testing
1191 macros, setting macros
1193 * ircd/s_user.c: remove deprecated struct Gline* argument to
1194 register_user(); remove GLINE rebroadcast; do not send GLINE
1195 acknowledgement parameter to NICK; do not look for GLINE
1196 acknowledgement parameter to NICK while parsing
1198 * ircd/s_serv.c (server_estab): remove deprecated struct Jupe*
1199 argument to server_estab(); do not send JUPE/GLINE acknowledgement
1200 parameters for SERVER or NICK
1202 * ircd/m_user.c (m_user): remove deprecated argument to
1205 * ircd/m_server.c: remove deprecated argument to server_estab();
1206 remove documentation comment regarding JUPE acknowledgement
1207 parameter to SERVER; remove JUPE rebroadcast
1209 * ircd/m_pong.c (mr_pong): remove deprecated argument to
1212 * ircd/m_nick.c: remove documentation comment regarding GLINE
1213 acknowledgement parameter to NICK
1215 * ircd/jupe.c: use user's real name in JUPE server notices if
1216 HEAD_IN_SAND_SNOTICES is defined
1218 * ircd/ircd.c: remove deprecated chroot() code; remove deprecated
1219 setuid code; correct ancient DEBUG vs DEBUGMODE typo
1221 * ircd/gline.c: use user's real name in GLINE server notices if
1222 HEAD_IN_SAND_SNOTICES is defined
1224 * ircd/channel.c (modebuf_flush_int): make apparent source be
1225 local server, not oper's server; use user's real name in hack
1226 notices and DESYNC notices if HEAD_IN_SAND_SNOTICES is defined
1228 * include/s_user.h: remove struct Gline pre-declaration; remove
1229 deprecated struct Gline argument from register_user()
1231 * include/s_serv.h: remove struct Jupe pre-declaration; remove
1232 deprecated struct Jupe argument from server_estab()
1234 2001-06-07 Kevin L. Mitchell <klmitch@mit.edu>
1236 * ircd/s_stats.c (hunt_stats): forward-port from pl15 of all the
1237 changes required to control remote stats
1239 * ircd/s_numeric.c (do_numeric): rewrite numeric origins if
1240 recipient is not an operator and HEAD_IN_SAND_REWRITE is defined
1241 [forward-port from pl15]
1243 * ircd/m_whowas.c (m_whowas): report server name only if requester
1244 is an operator [forward-port from pl15]
1246 * ircd/m_whois.c (do_whois): /whois <mynick> now correctly reports
1247 my server; if HEAD_IN_SAND_REMOTE is 1, ignore the middle argument
1248 and obtain the report from the user's server [forward-port from
1251 * ircd/m_who.c: add missing include for ircd_policy.h
1252 [forward-port from pl15]
1254 * ircd/m_version.c (m_version): require oper access for remote
1255 /version if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
1257 * ircd/m_time.c (m_time): require oper access for remote /time if
1258 HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
1260 * ircd/m_stats.c: pass extra argument to hunt_stats(); correct
1261 missing semicolon [forward-port from pl15]
1263 * ircd/m_nick.c (ms_nick): hide the origin of certain collision
1264 kills [forward-port from pl15]
1266 * ircd/m_motd.c (m_motd): require oper access for remote /motd if
1267 HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
1269 * ircd/m_lusers.c (m_lusers): require oper access for remote
1270 /lusers if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
1272 * ircd/m_burst.c (ms_burst): server-added bans are stored using
1273 local server name, to hide remote server names; modes also are to
1274 originate from the local server [forward-port from pl15]
1276 * ircd/m_admin.c (m_admin): require oper access for remote /admin
1277 if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
1279 * ircd/channel.c (add_banid): if a server is adding a ban, use my
1280 server name to hide the remote server's name [forward-port from
1283 * ircd/Makefile.in: ran make depend
1285 * include/s_stats.h: hunt_stats() has to have an extra argument to
1286 support the forward-port from pl15
1288 * include/ircd_policy.h: #define HEAD_IN_SAND_STATS_P; add
1289 HEAD_IN_SAND_{BANWHO,REWRITE,REMOTE} [forward-port from pl15]
1291 * ircd/engine_poll.c (engine_loop): remove bogus assert that I
1292 forgot to check in the events branch
1294 2001-06-06 Kevin L. Mitchell <klmitch@mit.edu>
1296 * ircd/res.c (init_resolver): don't start DNS expires with a 0
1297 relative timeout--if the server starts slow, timeouts could be
1298 messy...there's probably a better solution, but this'll do for now
1300 * ircd/os_solaris.c: _XOPEN_SOURCE doesn't get along with Solaris
1301 headers very well; include stropts.h; define an os_set_tos()
1303 * ircd/os_generic.c (os_set_tos): added an os_set_tos() for
1306 * ircd/ircd.c: if there are no C-lines, we don't want to have a
1307 timer that expires at the absolute time of 0--it kinda blocks all
1310 * ircd/engine_devpoll.c: some includes for open(); declare errcode
1311 and codesize in engine_loop()
1313 * ircd/list.c (free_client): remove bogus check on timer active
1316 * ircd/s_auth.c: pull out destruction code in
1317 auth_timeout_request() into an externally-visible
1318 destroy_auth_request(); manage cli_auth pointer in client
1319 structure; use it for an extra assertion check
1321 * ircd/list.c: include s_auth.h for destroy_auth_request(); add
1322 debugging notices to show flow when deallocating
1323 connections/clients; call destroy_auth_request() when free'ing a
1324 client that has an auth outstanding; don't free the connection if
1325 the process timer is unmarked but still active
1327 * ircd/ircd_events.c: set GEN_ACTIVE when initializing a generator
1328 and reset it before calling the event handler for an ET_DESTROY
1331 * include/s_auth.h (destroy_auth_request): declare
1332 destroy_auth_request(), which can be used to destroy an
1333 outstanding auth request if a client socket goes away before the
1334 auth exchange is completed
1336 * include/ircd_events.h: add an active flag to keep track of
1337 whether or not particular generators are active, for the
1338 convenience of functions using the API
1340 * include/client.h: add a pointer for auth requests to struct
1341 Connection so we can kill outstanding auth requests if a client
1342 socket closes unexpectedly
1344 * ircd/s_bsd.c: cli_connect() could become 0 during the course of
1345 the sock or timer callback; take that into account in the assert
1347 * ircd/list.c: add magic number checking and setting--magic
1348 numbers are zero'd on frees to detect double-frees; add back
1349 setting of cli_from() to 0 to break the back-link from the struct
1352 * ircd/ircd.c: set me's magic number correctly
1354 * include/client.h: define magic numbers and accessor/verifier
1357 * ircd/list.c: assert that dealloc_client() is called with
1358 cli_connect(cptr) == 0; set cli_connect(cptr) to 0 before calling
1359 dealloc_client(); don't mess with cli_from(cptr)
1361 * ircd/s_bsd.c: only attempt to dealloc a connection if the
1362 associated client has already been destroyed, or at least delinked
1364 2001-06-05 Kevin L. Mitchell <klmitch@mit.edu>
1366 * ircd/list.c (free_client): only try to delete the socket when
1367 the fd hasn't already been closed, avoiding a double-free
1369 * ircd/list.c (free_connection): make sure the client is really
1370 gone before doing away with the connection
1372 * ircd/s_bsd.c: record that socket has been added in con_freeflag
1373 field; queue a socket_del() as soon as the socket is close()'d;
1374 use con_freeflag & FREEFLAG_TIMER instead of con_timer; clear
1375 FREEFLAG_SOCKET on ET_DESTROY event in client_sock_callback(),
1376 then dealloc the connection if safe; mark socket as dead when
1377 there's a read error or EOF; clear FREEFLAG_TIMER flag upon entry
1378 to client_timer_callback(); dealloc connection if safe upon
1379 ET_DESTROY event in client_timer_callback()
1381 * ircd/list.c: use con_freeflag instead of con_timer; only dealloc
1382 the connection if both socket and timer have been destroyed;
1383 destroy both socket and timer explicitly and carefully
1385 * include/client.h: replace the con_timer field with a
1386 con_freeflag field, to indicate what still needs freeing; define
1389 * ircd/engine_select.c (engine_loop): duh...sockList[i] could
1392 * ircd/engine_devpoll.c (engine_loop): duh...sockList[i] could
1395 * ircd/s_bsd.c: add some extra assertions to try to track down a
1398 * ircd/engine_select.c (engine_loop): add an extra assert to try
1399 to track down a corruption problem
1401 * ircd/engine_poll.c (engine_loop): add an extra assert to try to
1402 track down a corruption problem
1404 * ircd/engine_kqueue.c (engine_loop): add an extra assert to try
1405 to track down a corruption problem
1407 * ircd/engine_devpoll.c (engine_loop): skip slots that have become
1408 empty during processing; add an extra assert to try to track down
1409 a corruption problem
1411 * ircd/engine_kqueue.c (engine_delete): make sure to zero deleted
1414 2001-06-04 Kevin L. Mitchell <klmitch@mit.edu>
1416 * ircd/s_bsd.c (client_sock_callback): client is no longer
1417 blocked, so we must mark it as unblocked
1419 * ircd/engine_select.c: add Debug() calls galore; add handling for
1420 SS_NOTSOCK; use a dummy sock variable to keep things from
1421 disappearing on us; correct timeout calculation; update nfds for
1424 * ircd/engine_poll.c: use new debugging level (DEBUG_ENGINE);
1425 remove a spurious "if (sock)" which will always be true; update
1428 * ircd/engine_kqueue.c: add Debug() calls galore; add handling for
1429 SS_NOTSOCK (just in case); correct timeout calculation
1431 * ircd/engine_devpoll.c: add Debug() calls galore; add handling
1432 for SS_NOTSOCK; correct timeout calculation; add EAGAIN handling
1434 * include/s_debug.h (DEBUG_ENGINE): add new debugging level;
1435 pretty-indent numbers
1437 * ircd/engine_poll.c (engine_loop): break out SS_NOTSOCK
1438 case--it's not a socket; the check for writability is most likely
1439 not needed, but present for completeness
1441 2001-05-24 Kevin L. Mitchell <klmitch@mit.edu>
1443 * ircd/s_bsd.c: add Debug messages; call read_packet() even if the
1444 no newline flag is set; call read_packet() when the timer expires,
1445 regardless of what's in the buffer--read_packet() should be able
1448 * ircd/IPcheck.c (ip_registry_connect_succeeded): correct a NOTICE
1449 sent to clients to include the client nickname (duh)
1451 * ircd/ircd_events.c: don't destroy a timer if it's already marked
1452 for destruction; replace a missing ! in socket_del()
1454 * ircd/engine_poll.c (engine_loop): reference a temporary variable
1455 so we don't have to worry about sockList[i] going away
1457 * ircd/s_bsd.c (client_sock_callback): add Debug messages
1459 * ircd/s_auth.c: add Debug messages all over the place
1461 * ircd/ircd_events.c: add and edit some Debug messages; add a list
1462 of routines to convert some of the enums and flags from numbers
1463 into human-readable strings for the Debug messages
1465 * ircd/engine_poll.c: hack some Debug messages to use the new name
1466 conversion routines in ircd_events.c; add an extra assert for a
1467 condition that shouldn't ever happen; apparently recv() can return
1468 EAGAIN when poll() returns readable--I wonder why...
1470 * include/ircd_events.h: declare some helper routines under
1473 2001-05-23 Kevin L. Mitchell <klmitch@mit.edu>
1475 * ircd/s_bsd.c (client_sock_callback): add an extra assertion
1478 * ircd/s_auth.c: add more Debug messages
1480 * ircd/list.c (make_client): add an extra assertion check
1482 * ircd/ircd_events.c (socket_events): don't call the engine events
1483 changer if we haven't actually made any changes to the event mask
1485 * ircd/uping.c: add some Debug messages
1487 * ircd/s_stats.c: document new /STATS e
1489 * ircd/s_err.c: add RPL_STATSENGINE to report the engine name
1491 * ircd/s_bsd.c: remove static client_timer variable; in
1492 read_packet(), if there's still data in the client's recvQ after
1493 parsing, add a 2 second timer (con_proc); fix the ET_DESTROY case
1494 of client_sock_callback to handle destroying the timer properly;
1495 rewrote client_timer_callback from scratch to be called on an
1498 * ircd/m_stats.c: add /STATS e to report the engine name
1500 * ircd/list.c: deal with con_timer field in struct Connection
1501 properly; correct a core-level bug in remove_client_from_list--if
1502 the client is the only one in the list, we try to update
1503 GlobalClientList's cli_prev pointer--not good
1505 * ircd/ircd.c: remove call to init_client_timer()
1507 * ircd/engine_poll.c: made Debug messages more uniform by
1508 prepending "poll:" to them all; corrected an off-by-one error that
1509 caused poll_count to be 1 less than the actual count and removed
1510 my work-around; added Debug messages to indicate which socket is
1511 being checked and what the results are
1513 * ircd/Makefile.in: ran a make depend
1515 * include/s_bsd.h: remove init_client_timer(), since we're doing
1518 * include/numeric.h (RPL_STATSENGINE): a stats reply to report the
1521 * include/ircd_policy.h (HEAD_IN_SAND_STATS_E): turn off /stats e
1522 reports for non-opers
1524 * include/client.h: add con_timer and con_proc fields to struct
1525 Connection and define accessor macros--con_timer marks that
1526 con_proc contains a valid timer, and con_proc is used to pace user
1529 * ircd/s_bsd.c (close_connection): let free_client() destroy the
1532 * ircd/s_auth.c (start_auth): add a Debug call to indicate when
1533 auth has begun on a client
1535 * ircd/ircd_events.c: ensure that event_execute() is called with a
1536 non-NULL event; modify event_add() macro to properly zero list
1537 bits; modify gen_dequeue() to not try to clip it out of a list
1538 it's already been clipped out of; change signal socket
1539 initialization to use state SS_NOTSOCK; permit timeout values of
1540 0 in add_timer(); add many Debug calls; change socket_del() and
1541 timer_del() to always set the GEN_DESTROY flag; use GEN_MARKED in
1542 timer_run() instead of GEN_DESTROY so that event_generate() will
1543 pass on the events; remove the switch and replace with a simpler
1544 if-then-else tree in timer_run(); don't allow destroyed sockets to
1545 be destroyed again, nor their states or event masks to be changed
1547 * ircd/ircd.c: initialize "running" to 1
1549 * ircd/engine_poll.c: deal with SS_NOTSOCK "sockets"; add Debug
1550 messages all over the place; fix a counting problem in
1551 engine_add(); turn wait into a signed integer and set it to -1
1552 only if timer_next() returns 0; adjust wait time to be relative;
1553 don't call gen_ref_dec() if socket disappeared while we were
1556 * include/ircd_events.h: the pipe for signals is not a socket, so
1557 we must mark it as such--added SS_NOTSOCK for that special socket;
1558 events won't be generated if GEN_DESTROY is on, so add GEN_MARKED
1559 for the benefit of timer_run()
1561 * configure.in: add --enable-pedantic and --enable-warnings to
1562 turn on (and off) -Wall -pedantic in CFLAGS
1564 2001-05-21 Kevin L. Mitchell <klmitch@mit.edu>
1566 * ircd/s_conf.c: change "s_addr" element accesses to "address"
1569 * include/s_conf.h: on some systems, "s_addr" is a macro; use
1572 2001-05-18 Kevin L. Mitchell <klmitch@mit.edu>
1574 * ircd/engine_kqueue.c: include ircd_alloc.h; set_or_clear returns
1575 void in this file; add a missing semi-colon; declare errcode,
1578 * ircd/uping.c (uping_sender_callback): it's pptr, not uping
1580 * ircd/s_user.c (register_user): comment out spurious reference to
1583 * ircd/s_serv.c (server_estab): comment out spurious reference to
1586 * ircd/s_conf.c (read_configuration_file): comment out spurious
1587 reference to nextping and nextconnect
1589 * ircd/s_bsd.c: comment out some spurious references to formerly
1590 global (now non-existant) variables; correct a couple of typos
1592 * ircd/s_auth.c: pre-declare some functions referenced in the
1593 callback; correct a typo
1595 * ircd/res.c (start_resolver): pass errno value of ENFILE
1597 * ircd/listener.c (accept_connection): you know your API is messed
1598 up when...variables that shouldn't have been global crop up in
1601 * ircd/list.c (free_client): substitution of == for =
1603 * ircd/ircd_signal.c: include assert.h for assertion checking;
1604 check ev_data() to find out what signal generated event
1606 * ircd/ircd_events.c: some references to the variable "timer"
1607 should have been references to the variable "ptr"
1609 * ircd/engine_select.c: it's struct fd_set, not struct fdset;
1610 ev_timer(ev) is already a timer pointer; declare codesize as a
1611 size_t to correct signedness issue; use timer_next(), not
1614 * ircd/engine_poll.c: ev_timer(ev) is already a timer pointer;
1615 select fd out of struct pollfd in assertion checking; declare
1616 errcode and codesize; use timer_next(), not time_next()
1618 * ircd/engine_kqueue.c: ev_timer(ev) is already a timer pointer;
1619 use function timer_next(), not time_next()
1621 * ircd/engine_devpoll.c: ev_timer(ev) is already a timer pointer;
1622 use function timer_next(), not time_next()
1624 * ircd/Makefile.in (IRCD_SRC): add ircd_events.c to the list of
1625 compiled sources; do make depend
1627 * include/list.h: pre-declare struct Connection
1629 * include/ircd_events.h (gen_ref_inc): cast to the right structure
1632 * include/s_auth.h: duh; missing */
1634 2001-05-10 Kevin L. Mitchell <klmitch@mit.edu>
1636 * ircd/send.c: update write events status after sending data or
1637 accumulating data to be sent
1639 * ircd/m_list.c (m_list): update write events status after
1640 canceling a running /list
1642 * ircd/channel.c (list_next_channels): update write events status
1643 after listing a few channels
1645 * ircd/s_bsd.c: extensive changes to update to new events model;
1646 remove on_write_unblocked() and the two implementations of
1647 read_message(), which have been deprecated by this change
1649 * ircd/s_auth.c: set the socket events we're interested in for
1650 clients; simplify some logic that does the connect_nonb followed
1653 * ircd/list.c: define free_connection() to free a connection
1654 that's become freeable once the struct Socket has been
1655 deallocated; fix up free_client() to take this new behavior into
1658 * ircd/ircd.c: call init_client_timer()
1660 * include/s_bsd.h: declare new REGISTER_ERROR_MESSAGE when unable
1661 to register connect-in-progress with events system; declare
1662 init_client_timer() (HACK!) to preserve rate-limiting behavior
1664 * include/list.h: declare new free_connection()
1666 * include/client.h: add a struct Socket to struct Connection
1668 2001-05-09 Kevin L. Mitchell <klmitch@mit.edu>
1670 * ircd/ircd_signal.c: massage the handlers for SIGHUP, SIGINT, and
1671 SIGTERM into event callbacks; perform the actions in the
1672 callbacks, since they're not called in the context of the signal;
1673 set up the signal callbacks in the event engine
1675 * ircd/ircd_events.c (signal_callback): we're supposed to look for
1676 a specific signal; don't generate an event if there is no signal
1679 * ircd/ircd.c: nuke nextconnect and nextping and replace them with
1680 connect_timer and ping_timer; massage try_connections() and
1681 check_pings() into timer callbacks that re-add themselves at the
1682 right time; remove ircd.c's "event_loop()"; initialize the event
1683 system and the connect_timer and ping_timer
1685 * ircd/uping.c: correct a couple more typos
1687 * ircd/s_auth.c: rework to use new events system
1689 * ircd/os_solaris.c (os_connect_nonb): update to new interface
1691 * ircd/os_openbsd.c (os_connect_nonb): update to new interface
1693 * ircd/os_linux.c (os_connect_nonb): update to new interface
1695 * ircd/os_generic.c (os_connect_nonb): update to new interface
1697 * ircd/os_bsd.c (os_connect_nonb): update to new interface
1699 * include/s_auth.h: remove deprecated members of struct
1700 AuthRequest, replacing them with struct Socket and struct Timer
1701 structures; add flags to indicate when these structures have been
1702 released by the event system; remove the deprecated
1703 timeout_auth_queries()
1705 * include/ircd_osdep.h (os_connect_nonb): connect could complete
1706 immediately, so change the interface to handle that possibility
1708 * ircd/uping.c (uping_server): noticed and corrected a typo
1710 * ircd/listener.c: set up to use ircd_event's struct Socket by
1711 adding an socket_add() call to inetport(), replacing
1712 free_listener() with socket_del() in close_listener(), and
1713 reworking accept_connection to be called as the callback
1715 * ircd/ircd.c: add a call to IPcheck_init()
1717 * ircd/IPcheck.c: remove IPcheck_expire(); rework
1718 ip_registry_expire() to be called from a timer; write
1719 IPcheck_init() to set up the expiration timer (hard-coded for a
1720 60-second expiration time)
1722 * include/listener.h: add a struct Socket to the struct Listener;
1723 remove accept_connection()
1725 * include/IPcheck.h: add IPcheck_init(), remove IPcheck_expire()
1727 2001-05-08 Kevin L. Mitchell <klmitch@mit.edu>
1729 * ircd/ircd_events.c: include config.h; use USE_KQUEUE and
1730 USE_DEVPOLL instead of HAVE_KQUEUE and HAVE_DEVPOLL_H
1732 * ircd/engine_select.c: include config.h; set FD_SETSIZE to
1733 MAXCONNECTIONS, not IRCD_FD_SETSIZE...
1735 * ircd/engine_poll.c: include config.h
1737 * ircd/engine_kqueue.c: include config.h
1739 * ircd/engine_devpoll.c: include config.h
1741 * ircd/Makefile.in: include engine sources in compilation and make
1744 * configure.in: add checks for enabling the /dev/poll- and
1745 kqueue-based engines
1747 * acconfig.h: add lines for USE_DEVPOLL and USE_KQUEUE
1749 * ircd/Makefile.in: work in the engine sources
1751 2001-05-07 Kevin L. Mitchell <klmitch@mit.edu>
1753 * ircd/m_settime.c: include ircd_snprintf.h
1755 * ircd/ircd_relay.c: stomp a couple of gcc warnings suggesting
1756 parens around a construct that had both || and &&
1758 * ircd/chkconf.c: #include "config.h" to get some important
1761 * ircd/Makefile.in: revamp ircd makefile for new build system
1763 * doc/Makefile.in: revamp doc makefile for new build system
1765 * config/*: Removed old build system files
1767 * stamp-h.in: a stamp file
1769 * install-sh: install-sh for new build system
1771 * configure.in: configure.in for new build system
1773 * configure: configure script for new build system (built by
1776 * config.sub: config.sub for new build system
1778 * config.h.in: config.h.in for new build system (built by
1781 * config.guess: config.guess for new build system
1783 * aclocal.m4: aclocal.m4 for new build system (built by aclocal
1786 * acinclude.m4: aclocal.m4 macros for new build system
1788 * acconfig.h: config.h skeleton for new build system
1790 * Makefile.in: modify for new build system
1792 2001-05-01 Kevin L. Mitchell <klmitch@mit.edu>
1794 * ircd/s_err.c: get rid of the last vestiges of TIME_T_FMT
1796 * ircd/m_settime.c: get rid of the last vestiges of TIME_T_FMT
1798 * ircd/m_server.c: get rid of the last vestiges of TIME_T_FMT
1800 2001-05-01 Perry Lorier <Isomer@coders.net>
1801 * doc/iauth.doc: Protocol for iauth server. (from hybrid).
1802 * doc/linux-poll.patch: Patch to make Linux under 2.2 not deadlock
1803 when you have far far too many sockets in use.
1804 * {include,ircd}/iauth.c: A start on iauth support.
1806 2001-05-01 Perry Lorier <Isomer@coders.net>
1807 * ircd/s_err.c: Suggested wording change.
1808 * ircd/s_user.c: Users aren't target limited against +k users.
1809 * ircd/chkconf.c: Made it compile again, who knows if it works, but
1810 now I can at least make install
1811 * various: Cleanups on m_*.c files.
1814 2001-04-23 Kevin L. Mitchell <klmitch@mit.edu>
1816 * ircd/s_misc.c (exit_client): make netsplit server notice say the
1819 * ircd/m_links.c (m_links_redirect): forward-port RPL_ENDOFLINKS
1820 change to make Khaled happy...
1822 * ircd/m_whois.c (do_whois): pull-up of m_whois() fix
1825 2001-04-21 Kevin L. Mitchell <klmitch@mit.edu>
1827 * ircd/msgq.c: finally remove the msgq_integrity() hack, as it's
1828 turned up no more bugs
1830 * ircd/ircd.c: use /* */ comments instead of // comments--all the
1833 * ircd/s_conf.c (conf_add_server): use /* */ comments instead of
1834 // comments--all the world's not gcc :(
1836 * ircd/runmalloc.c: finally garbage-collect unused file
1838 * include/runmalloc.h: finally garbage-collect unused file
1840 * ircd/<multiple files>: addition of '#include "config.h"' before
1841 all other includes in most .c files
1843 * include/<multiple files>: remove includes of config.h, which are
1844 now going into the raw .c files
1846 2001-04-20 Kevin L. Mitchell <klmitch@mit.edu>
1848 * ircd/m_whois.c (do_whois): display proper server name if the
1849 user is looking up himself
1851 * ircd/m_who.c (m_who): disable match by servername or display of
1852 server names by non-opers
1854 * include/ircd_policy.h: add define for
1855 HEAD_IN_SAND_WHO_SERVERNAME to cover full intent of sub-motion 15
1858 2001-04-18 Kevin L. Mitchell <klmitch@mit.edu>
1860 * ircd/s_conf.c: keep the $R in memory so we can see it clearly
1861 when we do a /stats k
1863 * ircd/s_user.c (set_user_mode): pull-up of changes to prevent
1864 users from turning on +s and +g
1866 * ircd/s_misc.c (exit_client): pull-up of changes to turn off
1869 * ircd/parse.c: pull-up of changes to disable /trace, /links, and
1872 * ircd/m_whois.c (do_whois): pull-up of server name masking for
1875 * ircd/m_user.c (m_user): removal of umode and snomask defaulting
1878 * ircd/m_stats.c (m_stats): pull-up of stats-disabling stuff
1880 * ircd/m_map.c (m_map_redirect): pull-up of m_map_redirect()
1882 * ircd/m_links.c (m_links_redirect): pull-up of m_links_redirect()
1884 * ircd/channel.c (channel_modes): pull-up of channel key display
1887 * include/ircd_policy.h: pull-up of ircd_policy.h
1889 * include/client.h: pull-up of Set/ClearServNotice()
1891 * ircd/gline.c (do_gline): report client name in G-line message
1894 * ircd/s_user.c (register_user): pull-up--show IP address in some
1895 server notices dealing only with users; report which connection
1898 * ircd/s_stats.c (report_deny_list): use conf->flags &
1899 DENY_FLAGS_IP insteaf of conf->ip_kill
1901 * ircd/m_stats.c (report_klines): use conf->flags & DENY_FLAGS_IP
1902 insteaf of conf->ip_kill
1904 * ircd/s_conf.c: use flags field in struct DenyConf; pull-up of
1907 * include/s_conf.h: use a flags field in struct DenyConf; define
1908 DENY_FLAGS_FILE, DENY_FLAGS_IP, and DENY_FLAGS_REALNAME for
1909 pull-up of K-line by real name
1911 * ircd/m_trace.c: pull-up of IP show for user connections
1913 * doc/example.conf: pull-up of the realname K-line documentation
1915 * ircd/ircd.c: forward port of pid file advisory locking mechanism
1917 2001-04-16 Kevin L. Mitchell <klmitch@mit.edu>
1919 * ircd/send.c (sendcmdto_flag_butone): recast to just broadcast to
1920 all servers, rather than to only servers that have +w/+g/whatever
1921 users on them; among other things, this removes that atrocity
1922 known as sentalong[] from this function
1924 * ircd/m_admin.c: must include ircd.h to declare "me"; must
1925 include hash.h to declare FindUser()
1927 * ircd/m_wallusers.c: implementation of WALLUSERS
1929 * ircd/m_desynch.c (ms_desynch): only send DESYNCHs to opers
1931 * ircd/m_wallops.c: only send WALLOPS to opers
1933 * ircd/parse.c: add WALLUSERS command to parser table
1935 * include/handlers.h: declare wallusers handlers
1937 * include/msg.h: add WALLUSERS command
1939 * ircd/send.c (sendcmdto_flag_butone): if FLAGS_OPER is or'd with
1940 flag, send only to appropriate opers
1942 2001-04-13 Kevin L. Mitchell <klmitch@mit.edu>
1944 * ircd/uping.c: refit to use the new events interface
1946 * ircd/res.c: refit to use the new events interface
1948 * ircd/ircd_events.c: create timer_chg(), which permits a
1949 (non-periodic) timer's expire time to be modified; change the
1950 logic in timer_run() so that timers that were re-added while the
1951 event was being processed will not be destroyed prematurely
1953 * include/uping.h: include the events header, declare some extra
1954 fields in struct UPing, remove timeout value, and define some
1955 flags for marking which cleanup items have yet to be done
1957 * include/ircd_events.h: add a prototype for timer_chg() to change
1958 the expire time of a running timer
1960 2001-03-13 Joseph Bongaarts <foxxe@wtfs.net>
1961 * ircd/os_openbsd.c: Tweaked the openbsd hack a bit.
1963 2001-03-07 Joseph Bongaarts <foxxe@wtfs.net>
1965 * config/configure.in: Add check for OpenBSD
1967 * ircd/os_openbsd.c: Add seperate os dep file for openbsd which
1968 differs from generic BSD, particularly in its handling of
1971 2001-02-12 Kevin L. Mitchell <klmitch@mit.edu>
1973 * ircd/m_gline.c (ms_gline): propagate a G-line that happened to
1974 have been added by a U-lined server, rather than going through the
1975 activate/deactivate logic; propagate G-line removals by U-lined
1978 * ircd/gline.c: rename propagate_gline() to gline_propagate();
1979 make gline_propagate() return an int 0 (convenience return); only
1980 update lastmod in gline_activate() and gline_deactivate() if the
1981 current lastmod is non-zero, since 0 lastmod is our flag of a
1982 U-lined server having added a G-line
1984 * include/gline.h (gline_propagate): exporting the G-line
1985 propagation function
1987 * ircd/m_list.c (m_list): duh; permit explicit channel name
1988 specification only when /list gets two arguments ("Kev
1989 #wasteland") rather than when /list gets more than two
1990 arguments--nice braino
1992 2001-01-29 Thomas Helvey <twhelvey1@home.com>
1994 * ircd/ircd_reply.c (need_more_params): fix bug that allowed
1995 unregistered clients to spam opers with protocol violation
1996 messages. Note: the bugfix may have eliminated some useful
1997 protocol violation messages.
1998 Please send protocol violation messages explicitly from the
1999 functions they are discovered in, you have much better context
2000 for the error there and it helps to document the behavior of the
2001 server. This was also a design bug in that it violated the
2002 "A function should do one thing" heuristic. Patching this one
2003 would have resulted in a continuous spawning of other bugs over
2004 the next 3 years, so I killed it. Check around for stuff this
2005 broke and readd the calls to protocol_violation in the functions
2006 that need to send the message.
2008 2001-01-29 Kevin L. Mitchell <klmitch@mit.edu>
2010 * ircd/channel.c (mode_parse_ban): stopper a tiny leak--if a ban
2011 already existed, then the logic would (attempt to) skip it, but
2012 would not free the ban string; now the ban string is free'd and
2013 the ban count is decremented, releasing the ban for use
2015 * ircd/s_user.c: make send_umode_out() take a prop argument
2016 instead of testing for the PRIV_PROPAGATE privilege itself; fix
2017 set_umode() to use this new argument, calculating it before
2018 calculating the new privileges for a -o'd user
2020 * ircd/m_oper.c (m_oper): pass the new prop argument to
2023 * ircd/channel.c (mode_parse_ban): turn off MODE_ADD bit in bans
2024 that we're not actually going to add because they already exist;
2025 test that particular bit before adding to the linked list
2027 * include/s_user.h: add a prop argument to send_umode_out() to
2028 indicate whether or not to propagate the user mode
2030 2001-01-24 Kevin L. Mitchell <klmitch@mit.edu>
2032 * ircd/msgq.c: ircd_vsnprintf() returns the number of bytes that
2033 it would have written; upper-bound the number to prevent overflows
2034 by proxy; also, tune buffer size given to ircd_vsnprintf() to take
2035 into account the fact that ircd_vsnprintf() already takes the
2036 terminal \0 into account
2038 2001-01-22 Kevin L. Mitchell <klmitch@mit.edu>
2040 * ircd/msgq.c: add an incredibly ugly hack to attempt to track
2041 down an apparent buffer overflow; remove msgq_map(), since it's no
2042 longer used anywhere; slight tweaks to prevent off-by-one errors,
2043 but these can't explain the problems we've seen
2045 * include/msgq.h: remove msgq_map(), since it's no longer used
2048 2001-01-18 Kevin L. Mitchell <klmitch@mit.edu>
2050 * ircd/s_user.c (set_nick_name): call client_set_privs() after
2053 2001-01-17 Kevin L. Mitchell <klmitch@mit.edu>
2055 * ircd/s_bsd.c (read_message): fix a typo in the select version of
2058 * ircd/whowas.c (whowas_free): MyFree() is a macro that expects
2059 its argument to be an lvalue, which means we can't use
2060 whowas_clean()'s handy-dandy "return ww" feature
2062 * ircd/ircd_features.c: default LOCOP_KILL to TRUE--oops...
2064 2001-01-16 Kevin L. Mitchell <klmitch@mit.edu>
2066 * ircd/ircd_events.c (timer_run): it's possible that the timer got
2067 deleted during the callback processing, so don't go to the bother
2068 of requeuing it if the destroy flag is set
2070 * ircd/engine_select.c: define FD_SETSIZE to be IRCD_FD_SETSIZE
2071 out of config.h if this is a *BSD; include errno.h (oops);
2072 decrement error count after an hour using a timer; use FD_SETSIZE
2073 constant instead of IRCD_FD_SETSIZE constant; fill in event
2076 * ircd/engine_poll.c: include errno.h (oops); decrement error
2077 count after an hour using a timer; fill in event processing code
2079 * ircd/engine_kqueue.c: include errno.h (oops); decrement error
2080 count after an hour using a timer; assert events filter is either
2081 EVFILT_READ or EVFILT_WRITE; fill in event processing code
2083 * ircd/engine_devpoll.c: include errno.h (oops); decrement error
2084 count after an hour using a timer; fill in event processing code
2086 2001-01-15 Kevin L. Mitchell <klmitch@mit.edu>
2088 * ircd/client.c: fixed feattab; basically, when I changed features
2089 to use small integers specifying bit positions, instead of the
2090 bits themselves, I forgot to update feattab to not | these
2091 privileges together; also fixed a bug in the antiprivs masking
2092 loop in client_set_privs()--last index wouldn't get parsed
2094 2001-01-11 Kevin L. Mitchell <klmitch@mit.edu>
2096 * ircd/ircd_events.c: call event_generate() with new data
2097 argument; make it set that field in struct Event; make
2098 socket_add() return the value of the eng_add callback
2100 * ircd/engine_select.c: make engine_add() return a
2101 successful/unsuccessful status; add bounds-checking outside of an
2102 assert; use accessor macros; use log_write(), not the deprecated
2103 ircd_log(); add an assert to engine_loop() to double-check for
2104 data structure corruption
2106 * ircd/engine_poll.c: make engine_add() return a
2107 successful/unsuccessful status; add bounds-checking outside of an
2108 assert; use accessor macros; use log_write(), not the deprecated
2109 ircd_log(); add an assert to engine_loop() to double-check for
2110 data structure corruption
2112 * ircd/engine_kqueue.c: implementation of an engine for kqueue()
2114 * ircd/engine_devpoll.c: implementation of an engine for /dev/poll
2116 * include/ircd_events.h: define some accessor macros; add ev_data
2117 to struct Event for certain important data--errno values, for
2118 instance; make EngineAdd callback tell us if it was successful or
2119 not; add extra argument to event_generate(); make socket_add()
2120 return the status from EngineAdd
2122 2001-01-10 Kevin L. Mitchell <klmitch@mit.edu>
2124 * ircd/ircd_events.c: pass initializer information about how many
2125 total _filedescriptors_ may be opened at once
2127 * ircd/ircd.c: use exported "running" instead of unexported
2130 * ircd/engine_select.c: implementation of an event engine based on
2133 * ircd/engine_poll.c: implementation of an event engine based on
2136 * include/ircd_events.h: pass the engine initializer an integer
2137 specifing how many _filedescriptors_ may be opened at once
2139 * include/ircd.h: running has to be exported for the engine_*
2142 2001-01-09 Kevin L. Mitchell <klmitch@mit.edu>
2144 * ircd/ircd_events.c: include some needed headers; add some
2145 comments; make evEngines[] const; bundle sig_sock and sig_fd into
2146 a struct named sigInfo; rework struct evInfo to have a queue of
2147 _generators_, and only when threaded; added a gen_init() function
2148 to centralize generator initialization; fix various compile-time
2149 errors; rework event_add() for new queueing scheme and checked for
2150 compile-time errors; add casts where needed; spell evEngines[]
2151 correctly; make engine_name() return const char*
2153 * include/ircd_events.h: type EventCallBack depends on struct
2154 Event, so pre-declare it; put _event_ queue into generators, and
2155 only when threaded; give engine data a union to store both ints
2156 and pointers; make engine name a const; fix gen_ref_dec() macro;
2157 make engine_name() return a const char*
2159 * ircd/ircd_events.c: gen_dequeue() is now exported, so move it
2160 down with the non-static functions; modify event_execute() to use
2161 the new gen_ref_dec() to simplify code; make sure event_generate()
2162 does not generate new events for generators marked for destruction
2164 * include/ircd_events.h: the engines, at least, may need to modify
2165 reference counts to keep generators from going away while
2166 something still points at them, so add reference counter
2167 manipulators and export gen_dequeue() for them
2169 * ircd/ircd_events.c: set up the list of engines to try; set up
2170 the signal struct Socket; rename netInfo to evInfo; move static
2171 functions near the beginning of the file; do away with
2172 signal_signal() (since we no longer keep a signal count ourselves)
2173 and call event_generate() directly from signal_callback--also
2174 renamed some functions; allow signal_callback() to read up to
2175 SIGS_PER_SOCK at once from the signal pipe; add event_init() to
2176 initialize the entire event system; add event_loop() to call the
2177 engine's event loop; initialize new struct GenHeader member,
2178 gh_engdata; remove timer_next(); add socket_add() function to add
2179 a socket; add socket_del() to mark a socket for deletion; add
2180 socket_state() to transition a socket between states; add
2181 socket_events() to set what events we're interested in on the
2182 socket; add engine_name() to retrieve event engine's name
2184 * include/ircd_events.h: add engine data field to struct
2185 GenHeader; rename SOCK_ACTION_REMOVE to SOCK_ACTION_DEL; add a
2186 note about states vs s_events; remove signal count; fold union
2187 Generator back into struct Event; remove count members from struct
2188 Generators; redefine engine callbacks to not take a struct
2189 Engine*; add explanatory comments to callback definitions; add
2190 some engine callbacks to handle operations; remove struct Engine
2191 flag member--can detect single flag from eng_signal member; add
2192 event_init(), event_loop(), engine_name(), and the socket_*()
2193 functions; make timer_next() a macro to avoid a function call
2195 2001-01-08 Kevin L. Mitchell <klmitch@mit.edu>
2197 * include/ircd_events.h: rename to ircd_events.h, since it handles
2198 events, not just networking stuff; add signal support; more
2199 structural rearrangement
2201 * ircd/ircd_events.c: rename to ircd_events.c, since it handles
2202 events, not just networking stuff; add signal support; more
2203 structural rearrangement
2205 2001-01-07 Kevin L. Mitchell <klmitch@mit.edu>
2207 * ircd/ircd_network.c: implement timer API; add reference counts
2210 * include/ircd_network.h: firm up some pieces of the interface;
2211 split out members everything has into a separate structure; add
2212 reference counts; add timer API
2214 2001-01-06 Kevin L. Mitchell <klmitch@mit.edu>
2216 * ircd/ircd_network.c: static data and event manipulation
2217 functions for new event processing system
2219 * include/ircd_network.h: data structures for new event processing
2222 2001-01-03 Kevin L. Mitchell <klmitch@mit.edu>
2224 * ircd/whowas.c: Completely re-did the old allocation scheme by
2225 turning it into a linked list, permitting the
2226 NICKNAMEHISTORYLENGTH feature to be changed on the fly
2228 * ircd/s_debug.c (count_memory): use FEAT_NICKNAMEHISTORYLENGTH
2229 feature instead of old #define
2231 * ircd/ircd_features.c: add NICKNAMEHISTORYLENGTH feature as an
2232 integer feature with a notify callback (whowas_realloc)
2234 * ircd/client.c (client_set_privs): second memset was supposed to
2235 be over antiprivs, not privs; thanks, Chris Behrens
2236 <cbehrens@xo.com> for pointing that out...
2238 * include/whowas.h: new elements for an extra linked list in
2239 struct Whowas; a notify function for feature value changes
2241 * include/ircd_features.h: new feature--FEAT_NICKNAMEHISTORYLENGTH
2243 * config/config-sh.in: NICKNAMEHISTORYLENGTH is now a feature
2245 2001-01-02 Kevin L. Mitchell <klmitch@mit.edu>
2247 * config/config-sh.in: get rid of DEFAULT_LIST_PARAMETER
2248 compile-time option--now in features subsystem
2250 * ircd/motd.c (motd_init): rework motd_init() to be called as the
2251 notify function for MPATH and RPATH features (should probably
2252 split it up a bit, though...)
2254 * ircd/m_privs.c (mo_privs): if called with no parameters, return
2255 privs of the caller, rather than an error
2257 * ircd/m_list.c: pull usage message into its own function; pull
2258 list parameter processing into its own function that does not
2259 modify the contents of the parameter; add list_set_default() to
2260 set the default list parameter (uses the notify hook); rework
2261 m_list() to make use of these functions; removed dead code
2263 * ircd/ircd_log.c (log_feature_mark): make sure to return 0, since
2264 we have no notify handler
2266 * ircd/ircd_features.c: add notify callback for notification of
2267 value changes; give mark callback an int return value to indicate
2268 whether or not to call the notify callback; fix up feature macros
2269 for new notify callback; add DEFAULT_LIST_PARAM feature; rewrite
2270 string handling in feature_set() to deal with def_str being a null
2271 pointer; wrote feature_init() to set up all defaults appropriately
2273 * ircd/ircd.c (main): call feature_init() instead of
2274 feature_mark(), to avoid calling notify functions while setting up
2277 * ircd/client.c: updated to deal with new privileges structure
2279 * ircd/class.c: updated so init_class() can be called should one
2280 of PINGFREQUENCY, CONNECTFREQUENCY, MAXIMUM_LINKS, or
2281 DEFAULTMAXSENDQLENGTH be changed
2283 * include/ircd_log.h: log_feature_mark() updated to fit with new
2286 * include/ircd_features.h: added DEFAULT_LIST_PARAM feature and
2287 feature_init() function (found necessary since adding the notify
2288 stuff and notifying motd.c during start-up...before we defined
2291 * include/client.h: move privs around to enable addition of more
2292 bits if necessary; based on the FD_* macros
2294 * include/channel.h: declare list_set_default (actually located in
2297 * ircd/s_user.c: retrieve MAXSILES and MAXSILELENGTH (now
2298 AVBANLEN*MAXSILES) from features subsystem
2300 * ircd/s_debug.c (debug_serveropts): CMDLINE_CONFIG doesn't go to
2303 * ircd/s_bsd.c: retrieve HANGONGOODLINK and HANGONRETRYDELAY from
2304 the features subsystem
2306 * ircd/s_auth.c (start_auth): NODNS migrated to the features
2309 * ircd/random.c: created random_seed_set() function to set seed
2310 value, along with some stuff to make ircrandom() a little more
2311 random--state preserving, xor of time instead of direct usage,
2312 etc.; it's still a pseudo-random number generator, though, and
2313 hopefully I haven't broken the randomness
2315 * ircd/m_version.c: FEATUREVALUES makes use of feature_int() calls
2317 * ircd/m_join.c: use features interface to retrieve
2320 * ircd/ircd_features.c: add NODISP flag for super-secret features;
2321 add a whole bunch of new features migrated over from make config
2323 * ircd/ircd.c: use features interface to retrieve PINGFREQUENCY,
2324 CONNECTTIMEOUT, and TIMESEC
2326 * ircd/client.c (client_get_ping): use features interface to
2327 retrieve PINGFREQUENCY
2329 * ircd/class.c: use features interface to retrieve PINGFREQUENCY,
2330 CONNECTFREQUENCY, MAXIMUM_LINKS, and DEFAULTMAXSENDQLENGTH
2332 * ircd/chkconf.c (DEFAULTMAXSENDQLENGTH): since it's now in the
2333 features subsystem, we have to add something explicit
2335 * ircd/channel.c: use features interface to retrieve
2336 KILLCHASETIMELIMIT, MAXBANLENGTH, MAXBANS, and MAXCHANNELSPERUSER;
2337 note that MAXBANLENGTH is now calculated dynamically from MAXBANS
2340 * ircd/Makefile.in: run make depend
2342 * include/supported.h (FEATURESVALUES): update to reference
2345 * include/random.h: add prototype for random_seed_set
2347 * include/ircd_features.h: add several more features
2349 * include/channel.h: move MAXBANS and MAXBANLENGTH into feature
2352 * config/config-sh.in: feature-ized some more stuff
2354 * include/motd.h: some new elements in motd.h for motd.c changes
2356 * ircd/motd.c: motd_cache() now searches a list of already cached
2357 MOTD files; saves us from having duplicate caches in memory if
2358 there are two identical T-lines for two different sites...
2360 2001-01-02 Perry Lorier <isomer@coders.net>
2361 * ircd/motd.c: don't core if the motd isn't found. Bug found by
2364 2001-01-02 Perry Lorier <isomer@coders.net>
2365 * ircd/s_err.c: Added third param to 004 - the channel modes that tage params. Used by hybrid/epic.
2366 * ircd/s_channels.c: Added fix for msg'ing a -n+m channel - thanks
2367 to guppy for noticing, and hektik for providing the fix.
2368 * misc others: Minor cleanups, added more protocol_violations, ripped
2369 out more P09 stuffs, bit more protocol neg stuff.
2371 2000-12-19 Kevin L. Mitchell <klmitch@mit.edu>
2373 * ircd/m_ison.c (m_ison): Dianora says that ISON has to end with a
2374 space (*sigh* stupid clients...)
2376 * ircd/s_user.c: make WALLOPS_OPER_ONLY a feature managed through
2379 * ircd/s_err.c: get rid of GODMODE conditionals
2381 * ircd/s_debug.c (debug_serveropts): switch to using appropriate
2382 calls into the features subsystem for various serveropts
2385 * ircd/s_conf.c (find_conf_entry): get rid of USEONE conditional
2387 * ircd/s_bsd.c: remove GODMODE conditional; use features subsystem
2388 to get value of VIRTUAL_HOST and CLIENT_FLOOD; remove
2389 NOFLOWCONTROL conditional
2391 * ircd/s_auth.c: use features subsystem to determine value of
2394 * ircd/parse.c: get rid of NOOPER and GODMODE conditionals; use
2395 features subsystem to determine the setting of IDLE_FROM_MSG
2397 * ircd/numnicks.c: get rid of EXTENDED_NUMERICS conditionals
2399 * ircd/motd.c: get value of NODEFAULTMOTD from features subsystem;
2400 use features subsystem to get motd file names
2402 * ircd/m_settime.c: get value of RELIABLE_CLOCK from features
2405 * ircd/m_server.c: get rid of CRYPT_LINK_PASSWORD, since it does
2406 us no good; use features subsystem to figure out if we need to do
2407 HUB-type stuff; make TESTNET debugging sendto_opmask_butone's use
2408 the Debug(()) macro instead; get value of RELIABLE_CLOCK from
2411 * ircd/m_privmsg.c: get IDLE_FROM_MSG from the features subsystem
2413 * ircd/m_oper.c: get CRYPT_OPER_PASSWORD from the features
2416 * ircd/m_connect.c: get SERVER_PORT from the features subsystem
2418 * ircd/ircd_log.c (log_set_file): fix a bug that kept log files
2419 from getting marked if they were already set to something...
2421 * ircd/ircd_features.c: add a flag to indicates read-only access;
2422 add several new features that used to be compile-time selected
2424 * ircd/ircd.c: grab pidfile out of feature subsystem; don't check
2425 access to motd files (what the heck?); make sure to initialize the
2426 feature subsystem before trying to write the config file
2428 * ircd/dbuf.c: use feature_int() to retrieve BUFFERPOOL settings;
2429 use feature_bool() to figure out if we're using the FERGUSON
2432 * ircd/Makefile.in: MPATH and RPATH are now done differently, so
2433 remove the clause that creates empty files of that name; also ran
2436 * include/sys.h: CLIENT_FLOOD is now a feature; unfortunately,
2437 there is no easy way to bounds-check it at present
2439 * include/querycmds.h: make sure ircd_features.h is included; use
2440 feature_str(FEAT_DOMAINNAME) in calls to match()
2442 * include/ircd_features.h: many new features that used to be
2443 compile-time selected
2445 * config/config-sh.in: add * to DOMAINNAME; try also using first
2446 argument to search in /etc/resolv.conf; removed many compile-time
2447 options that now can be configured through the features system
2449 2000-12-18 Kevin L. Mitchell <klmitch@mit.edu>
2451 * doc/api/log.txt: how to use the logging API
2453 * doc/api/features.txt: how to use the features API
2455 * doc/api/api.txt: how to write API documentation
2457 * include/ircd_features.h: rearranged a couple of features for
2460 * ircd/ircd_features.c: cleaned up the macros some; rearranged
2461 some code to all go into the switch; rearranged a couple of
2462 features for neatness purposes
2464 2000-12-16 Greg Sikorski <gte@atomicrevs.demon.co.uk>
2465 * ircd/os_bsd.c: Added os_set_tos for BSD users.
2467 2000-12-16 Kevin L. Mitchell <klmitch@mit.edu>
2469 * ircd/ircd_features.c: Isomer almost got it right; you need to
2470 use F_I(), since it's an integer value, not a boolean value. The
2471 asserts in feature_int would catch you out... Also made the F_*
2474 * ircd/s_err.c: define RPL_PRIVS reply
2476 * ircd/parse.c: put new PRIVS command into command table
2478 * ircd/m_privs.c (mo_privs): message handler to report operator
2481 * ircd/ircd_features.c: declare new features OPER_SET and
2482 LOCOP_SET; redo boolean testing routine to accept TRUE, YES, and
2483 ON for boolean TRUE, and FALSE, NO, and OFF for boolean FALSE
2485 * ircd/client.c: simplify client_set_privs() with a table that
2486 defines what features to test for; add new client_report_privs()
2488 * ircd/Makefile.in: compile new m_privs.c; run make depend
2490 * include/numeric.h (RPL_PRIVS): new reply numeric for displaying
2491 an operator's privileges
2493 * include/msg.h: define new command: PRIVS
2495 * include/ircd_features.h: create new features OPER_SET and
2496 LOCOP_SET for controlling access to /set
2498 * include/handlers.h (mo_privs): declare message handler for
2499 reporting oper privileges
2501 * include/client.h (client_report_privs): declare function to
2502 report what privileges an oper has
2504 * ircd/m_whois.c (do_whois): fix a bug that caused /whois to
2505 report that a user is an oper if the oper doing the /whois had
2508 2000-12-17 Isomer <Isomer@coders.net>
2509 * ircd/listener.c: added support for TOS twiddling as a 'feature'.
2511 2000-12-17 Isomer <Isomer@coders.net>
2512 * ircd/os_linux.c: add TOS stuffs
2514 * ircd/listener.c: add TOS stuffs
2516 2000-12-16 Kevin L. Mitchell <klmitch@mit.edu>
2518 * ircd/whocmds.c (do_who): use HasPriv to determine whether or not
2519 to indicate a user is an oper
2521 * ircd/s_user.c: clear privileges setting when deopping; don't
2522 propagate +o unless user has PRIV_PROPAGATE privilege
2524 * ircd/s_debug.c (debug_serveropts): created debug_serveropts()
2525 function and replaced how the server option string is generated
2527 * ircd/parse.c: remove conditional on CONFIG_OPERCMDS
2529 * ircd/m_whois.c (do_whois): use HasPriv to determine whether or
2530 not to indicate the user is an operator
2532 * ircd/m_who.c: use HasPriv to determine whether or not a user
2533 should be displayed in the list of opers
2535 * ircd/m_version.c: call debug_serveropts() to get server option
2538 * ircd/m_userip.c (userip_formatter): use HasPriv to determine
2539 whether or not to show oper status
2541 * ircd/m_userhost.c (userhost_formatter): use HasPriv to determine
2542 whether or not to show oper status
2544 * ircd/m_restart.c (mo_restart): replace ugly #ifdef conditional
2545 checks with HasPriv check; remove dead code
2547 * ircd/m_rehash.c (mo_rehash): replace ugly #ifdef conditional
2548 checks with HasPriv check
2550 * ircd/m_opmode.c (mo_opmode): use HasPriv to check permissions;
2551 use feature_bool to check if disabled
2553 * ircd/m_oper.c (m_oper): set oper priviliges
2555 * ircd/m_mode.c (m_mode): replace #ifdef conditional with HasPriv
2558 * ircd/m_kill.c (mo_kill): use HasPriv checks to determine if we
2561 * ircd/m_kick.c (m_kick): replace #ifdef conditional with HasPriv
2564 * ircd/m_jupe.c (mo_jupe): rework permissions checking structure;
2565 use feature_bool to check if disabled
2567 * ircd/m_join.c (m_join): remove BADCHAN conditional; replace
2568 #ifdef conditional with a HasPriv check
2570 * ircd/m_gline.c (mo_gline): rework permissions checking
2571 structure; use feature_bool to check if any part is disabled
2573 * ircd/m_die.c: replace ugly #ifdef conditionals with HasPriv
2574 check; remove dead code
2576 * ircd/m_clearmode.c: use feature_bool() to detect if we're
2577 disabled; use HasPriv to figure out what we're permitted to do;
2578 only allow clearmode on moded channels
2580 * ircd/ircd_features.c: define various features; use HasPriv to
2581 verify permissions to set/reset
2583 * ircd/gline.c (gline_add): use HasPriv instead of #ifdef
2586 * ircd/client.c (client_set_privs): function to set an oper's
2589 * ircd/channel.c: use HasPriv calls instead of #ifdef conditionals
2591 * include/whocmds.h: deconditionalize several macros and
2592 substitute appropriate calls to HasPriv()
2594 * include/s_debug.h: get rid of global serveropts[]; define new
2595 function debug_serveropts() to build that string on the fly
2597 * include/ircd_features.h: define some features
2599 * include/client.h: add privs member to struct Connection; define
2602 * include/channel.h: no longer using IsOperOnLocalChannel; remove
2603 conditional of MAGIC_OPER_OVERRIDE on OPER_WALK_THROUGH_LMODES
2605 * doc/Configure.help: remove help information for deprecated
2608 * config/config-sh.in: remove certain deprecated options having to
2609 do with what opers can and cannot do--first stage in moving
2610 compile-time constants into the .conf
2612 2000-12-16 Isomer <Isomer@coders.net>
2613 * ircd/parse.c: detect if the prefix is missing and try and recover
2616 2000-12-15 Kevin L. Mitchell <klmitch@mit.edu>
2618 * ircd/ircd_log.c: found and fixed some bugs in the debug logging
2619 code that would sometimes result in the log file not being
2620 reopened--which meant that a user could connect and get the
2621 logging output--oops
2623 * ircd/Makefile.in: run make depend...
2625 * ircd/s_stats.c: get rid of report_feature_list()
2627 * ircd/s_err.c: add the 'bad value' error message, shift error
2628 messages over somewhat
2630 * ircd/s_debug.c (debug_init): call log_debug_init with the
2633 * ircd/s_conf.c (read_configuration_file): unmark features before
2634 reading the config file, then reset unmarked features after
2635 reading the config file
2637 * ircd/m_stats.c: use feature_report() instead of
2638 report_feature_list()
2640 * ircd/ircd_log.c: fix log_debug_file (bogus assertion); add
2641 special 'mark' flags and use them; add the stuff needed by the
2644 * ircd/ircd_features.c: rework the features API and add gobs of
2645 comments to try to explain what some of these complex functions
2648 * include/s_stats.h: get rid of report_feature_list(); use
2649 feature_report() instead
2651 * include/numeric.h: added a new error message and shifted old
2652 values over some--this is, after all, an alpha
2654 * include/ircd_log.h: log_debug_init now takes an integer to tell
2655 it if it should be using the tty; added a couple of functions
2656 required by the features API
2658 * include/ircd_features.h: add an enum and some more functions to
2659 flesh out the feature API--it should now be possible to put all
2660 those compile-time constants in the config file!
2662 * ircd/send.c: got the direction of the assert incorrect...
2664 * ircd/send.c: implement the efficiency of flush_connections by
2665 creating a linked list of struct Connection's with queued data;
2666 also get rid of flush_sendq_except and make sure to yank
2667 connections out of the list when their sendQs become empty (notice
2668 the assertion in flush_connections!)
2670 * ircd/s_bsd.c (close_connection): must yank the Connection out of
2673 * ircd/list.c (dealloc_connection): must yank the Connection out
2676 * ircd/dbuf.c (dbuf_put): call flush_connections instead of the
2677 deprecated flush_sendq_except
2679 * ircd/client.c: define a couple new helper functions for sendq
2680 threading--this will make the flush_connections function in send.c
2681 considerably more efficient by creating a linked list of
2682 Connections that have queued data to send
2684 * include/send.h: remove flush_sendq_except, as it's not used
2687 * include/client.h: declare a couple new helper functions for the
2688 sendq threading system
2690 2000-12-14 Kevin L. Mitchell <klmitch@mit.edu>
2692 * ircd/m_ison.c (m_ison): Apply Diane Bruce's patch to make ISON
2695 * ircd/s_debug.c (count_memory): modify to report for clients and
2696 connections, not local clients and remote clients
2698 * ircd/list.c: fiddle with the client-fiddling functions to take
2699 into account the divorce of struct Connection from struct Client
2701 * ircd/ircd.c: define a struct Connection for me, initialize it,
2702 and link it into the right place (ewww, globals!)
2704 * include/client.h: remove CLIENT_{LOCAL,REMOTE}_SIZE; split
2705 struct Client into struct Client and struct Connection; redefine
2706 local-portion accessor macros to go through struct Client to the
2707 struct Connection; define struct Connection accessor macros
2709 2000-12-13 Kevin L. Mitchell <klmitch@mit.edu>
2711 * ircd/whowas.c: missed a couple of accesses to a struct Client
2713 * ircd/uping.c: missed a couple of accesses to a struct Client
2715 * ircd/send.c: missed a couple of accesses to a struct Client
2717 * ircd/s_user.c: missed a couple of accesses to a struct Client
2719 * ircd/s_misc.c: missed a couple of accesses to a struct Client
2721 * ircd/s_conf.c: missed a couple of accesses to a struct Client
2723 * ircd/s_bsd.c: missed a couple of accesses to a struct Client
2725 * ircd/s_auth.c: missed a couple of accesses to a struct Client
2727 * ircd/res.c: missed a couple of accesses to a struct Client
2729 * ircd/parse.c: missed a couple of accesses to a struct Client
2731 * ircd/m_whois.c: use new accessor macros for struct Client
2733 * ircd/m_who.c: use new accessor macros for struct Client
2735 * ircd/m_wallchops.c: use new accessor macros for struct Client
2737 * ircd/m_version.c: use new accessor macros for struct Client
2739 * ircd/m_userip.c: use new accessor macros for struct Client
2741 * ircd/m_userhost.c: use new accessor macros for struct Client
2743 * ircd/m_user.c: use new accessor macros for struct Client
2745 * ircd/m_uping.c: use new accessor macros for struct Client
2747 * ircd/m_trace.c: use new accessor macros for struct Client
2749 * ircd/m_topic.c: use new accessor macros for struct Client
2751 * ircd/m_time.c: use new accessor macros for struct Client
2753 * ircd/m_stats.c: use new accessor macros for struct Client
2755 * ircd/m_squit.c: use new accessor macros for struct Client
2757 * ircd/m_silence.c: use new accessor macros for struct Client
2759 * ircd/m_server.c: use new accessor macros for struct Client;
2762 * ircd/m_rpong.c: use new accessor macros for struct Client
2764 * ircd/m_rping.c: use new accessor macros for struct Client
2766 * ircd/m_quit.c: use new accessor macros for struct Client
2768 * ircd/m_privmsg.c: use new accessor macros for struct Client
2770 * ircd/m_pong.c: use new accessor macros for struct Client; remove
2773 * ircd/m_ping.c: use new accessor macros for struct Client
2775 * ircd/m_pass.c: use new accessor macros for struct Client
2777 * ircd/m_part.c: use new accessor macros for struct Client
2779 * ircd/m_oper.c: use new accessor macros for struct Client
2781 * ircd/m_notice.c: use new accessor macros for struct Client
2783 * ircd/m_nick.c: use new accessor macros for struct Client
2785 * ircd/m_names.c: use new accessor macros for struct Client
2787 * ircd/m_mode.c: use new accessor macros for struct Client
2789 * ircd/m_map.c: use new accessor macros for struct Client
2791 * ircd/m_list.c: use new accessor macros for struct Client
2793 * ircd/m_links.c: use new accessor macros for struct Client;
2794 remove some dead code
2796 * ircd/m_kill.c: use new accessor macros for struct Client; remove
2799 * ircd/m_kick.c: use new accessor macros for struct Client
2801 * ircd/m_join.c: use new accessor macros for struct Client; remove
2804 * ircd/m_ison.c: use new accessor macros for struct Client
2806 * ircd/m_invite.c: use new accessor macros for struct Client
2808 * ircd/m_info.c: use new accessor macros for struct Client
2810 * ircd/m_gline.c: use new accessor macros for struct Client
2812 * ircd/m_error.c: use new accessor macros for struct Client
2814 * ircd/m_create.c: use new accessor macros for struct Client
2816 * ircd/m_connect.c: use new accessor macros for struct Client;
2817 removed some dead code
2819 * ircd/m_burst.c: use new accessor macros for struct Client
2821 * ircd/m_away.c: use new accessor macros for struct Client
2823 * ircd/m_admin.c: use new accessor macros for struct Client
2825 * ircd/hash.c: missed a couple of accesses to a struct Client
2827 * ircd/gline.c: missed a couple of accesses to a struct Client
2829 * ircd/crule.c: missed a couple of accesses to a struct Client
2831 * ircd/class.c: missed an access to a struct Client
2833 * ircd/channel.c: missed a couple of accesses to a struct Client
2835 * ircd/IPcheck.c: missed an access to a struct Client
2837 * include/querycmds.h: fix a couple of stats macros to use
2838 structure accessor macros
2840 * include/client.h: change structure member names to highlight any
2841 places in the code I've missed
2843 2000-12-12 Kevin L. Mitchell <klmitch@mit.edu>
2845 * ircd/whowas.c: use new struct Client accessor macros
2847 * ircd/whocmds.c: use new struct Client accessor macros
2849 * ircd/send.c: use new struct Client accessor macros
2851 * ircd/s_user.c: use new struct Client accessor macros; removed
2854 * ircd/s_serv.c: use new struct Client accessor macros; removed
2857 * ircd/s_numeric.c: use new struct Client accessor macros
2859 * ircd/s_misc.c: use new struct Client accessor macros
2861 * ircd/s_debug.c: use new struct Client accessor macros
2863 * ircd/s_conf.c: use new struct Client accessor macros
2865 * ircd/s_bsd.c: use new struct Client accessor macros
2867 * ircd/s_auth.c: use new struct Client accessor macros
2869 * ircd/parse.c: use new struct Client accessor macros
2871 * ircd/packet.c: use new struct Client accessor macros
2873 * ircd/numnicks.c: use new struct Client accessor macros
2875 * ircd/motd.c: use new struct Client accessor macros
2877 * ircd/listener.c: use new struct Client accessor macros
2879 * ircd/list.c: use new struct Client accessor macros
2881 * ircd/jupe.c: use new struct Client accessor macros
2883 * ircd/ircd_snprintf.c: use new struct Client accessor macros
2885 * ircd/ircd_reply.c: use new struct Client accessor macros
2887 * ircd/ircd_relay.c: use new struct Client accessor macros
2889 * ircd/ircd.c: use new struct Client accessor macros
2891 * ircd/gline.c: catch some instances of me.<stuff> I missed
2894 * ircd/client.c: use cli_ instead of con_
2896 * ircd/class.c: use cli_ instead of con_
2898 * ircd/channel.c: use cli_ instead of con_
2900 * ircd/IPcheck.c: use cli_ instead of con_; catch some instances
2901 of me.<stuff> I missed previously
2903 * include/client.h: use cli_ instead of con_...seemed like a good
2904 idea at the time *shrug*
2906 2000-12-11 Kevin L. Mitchell <klmitch@mit.edu>
2908 * ircd/hash.c: use struct Client accessor macros
2910 * ircd/gline.c: use struct Client accessor macros
2912 * ircd/crule.c: use struct Client accessor macros
2914 * ircd/client.c: use struct Client accessor macros; remove some
2917 * ircd/class.c: use struct Client accessor macros
2919 * ircd/channel.c: use struct Client accessor macros; remove some
2922 * ircd/IPcheck.c: use struct Client accessor macros
2924 * include/numnicks.h: use struct Client accessor macros
2926 * include/client.h: first step to divorcing struct Client and
2927 struct Connection--define accessor macros and use them
2929 * ircd/gline.c: When Uworld removed Uworld-set G-lines, only the
2930 uplink would remove them. This is because the removal protocol
2931 message wasn't being sent to the uplinks. This is fixed by fixing
2932 propagate_gline() to send the proper number of arguments depending
2933 on whether or not we're adding or deleting the Uworld gline, and
2934 by having gline_deactivate() make sure to turn off the active bit
2935 and call propagate_gline() if it's a Uworld gline
2937 2000-12-10 Kevin L. Mitchell <klmitch@mit.edu>
2939 * ircd/os_generic.c: make sure IOV_MAX gets defined, just in case
2941 * ircd/os_bsd.c: apparently BSD doesn't have IOV_MAX defined
2942 anywhere intelligent...
2944 2000-12-09 Kevin L. Mitchell <klmitch@mit.edu>
2946 * ircd/send.c (send_queued): call deliver_it with appropriate
2949 * ircd/s_serv.c: reorder a couple of headers--cosmetic
2951 * ircd/s_bsd.c (deliver_it): make deliver_it work with a struct
2954 * ircd/os_solaris.c (os_sendv_nonb): function for calling writev
2955 with appropriate iovec
2957 * ircd/os_linux.c (os_sendv_nonb): function for calling writev
2958 with appropriate iovec
2960 * ircd/os_generic.c (os_sendv_nonb): function for calling writev
2961 with appropriate iovec
2963 * ircd/os_bsd.c (os_sendv_nonb): function for calling writev with
2966 * ircd/msgq.c (msgq_mapiov): add a len_p argument for totalling up
2967 exactly how much we're trying to write out to the fd
2969 * include/s_bsd.h: make deliver_it take a struct MsgQ
2971 * include/msgq.h: add a len_p argument to msgq_mapiov to help
2972 detect short writes that indicate possible socket blocking
2974 * include/ircd_osdep.h: declare os_sendv_nonb()
2976 * ircd/channel.c (modebuf_mode): don't add empty modes...
2978 2000-12-08 Kevin L. Mitchell <klmitch@mit.edu>
2980 * include/send.h: add prio argument to send_buffer to select
2981 between normal and priority queues
2983 * ircd/s_user.c (send_user_info): add prio argument to send_buffer
2986 * ircd/m_ison.c (m_ison): add prio argument to send_buffer call
2988 * ircd/ircd_reply.c (send_reply): add prio argument to send_buffer
2991 * ircd/channel.c (send_channel_modes): add prio argument to
2994 * ircd/send.c (send_buffer): add a prio argument to select the
2995 priority queue; update send.c functions to use it
2997 * ircd/msgq.c (msgq_add): remove msgq_prio; fold msgq_link and
2998 msgq_add; add a prio argument to msgq_add to select the priority
3001 * include/msgq.h: remove msgq_prio; add a prio argument to
3004 * ircd/send.c: remove sendbuf; remove GODMODE code; switch to
3005 using msgq functions instead of dbuf functions; remove old, dead
3006 sendto_* functions; redo send_buffer to take a struct MsgBuf;
3007 rework sendcmdto_* functions to make use of the new struct MsgBuf
3009 * ircd/s_user.c: remove hunt_server; restructure send_user_info to
3010 make appropriate use of struct MsgBuf
3012 * ircd/s_debug.c (count_memory): count memory used by the MsgQ
3013 system and report it
3015 * ircd/s_conf.c (read_configuration_file): use
3016 sendto_opmask_butone instead of the now dead sendto_op_mask
3018 * ircd/s_bsd.c: switch to using appropriate MsgQLength and other
3021 * ircd/parse.c (parse_server): get rid of a piece of GODMODE code
3023 * ircd/msgq.c: add msgq_append and msgq_bufleft; fix a bug in
3026 * ircd/m_version.c: fix spelling in comments marking dead code
3028 * ircd/m_userip.c (userip_formatter): restructure to make use of
3031 * ircd/m_userhost.c (userhost_formatter): restructure to make use
3034 * ircd/m_stats.c: use MsgQLength on a sendQ
3036 * ircd/m_settime.c: use MsgQLength instead of DBufLength on a
3037 sendQ; mark a piece of dead code
3039 * ircd/m_names.c: use send_reply instead of sendto_one
3041 * ircd/m_mode.c: use new mode; remove old dead code
3043 * ircd/m_ison.c (m_ison): restructure to make use of struct MsgBuf
3045 * ircd/m_burst.c: use BUFSIZE instead of IRC_BUFSIZE; remove old
3048 * ircd/listener.c (accept_connection): use sendto_opmask_butone
3049 instead of sendto_op_mask
3051 * ircd/list.c (free_client): use MsgQClear to clear sendQ
3053 * ircd/ircd_reply.c: remove send_error_to_client; restructure
3054 send_reply to make use of struct MsgBuf
3056 * ircd/dbuf.c (dbuf_put): remove argument to flush_sendq_except,
3057 since its no longer used (at least currently)
3059 * ircd/channel.c: restructure send_channel_modes to make use of
3060 struct MsgBuf; remove set_mode, add_token_to_sendbuf, cancel_mode,
3061 and send_hack_notice; use BUFSIZE instead of IRC_BUFSIZE
3063 * ircd/Makefile.in: add msgq.c to list of sources; run make depend
3065 * ircd/IPcheck.c: use sendcmdto_one instead of sendto_one
3067 * include/send.h: send_buffer now takes a struct MsgBuf * instead
3068 of a char *; flush_sendq_except now takes no arguments, as sendq
3069 flushing currently only happens in dbuf.h and sendQ is a struct
3070 MsgQ; remove prototypes for a lot of old sendto_* functions that
3071 aren't used anymore; remove sendbuf and IRC_BUFSIZE--the former is
3072 no longer needed, and the latter is identical to BUFSIZE in
3075 * include/s_user.h: make InfoFormatter take a struct MsgBuf*
3076 instead of a char *; also make it return void, instead of char *
3078 * include/msgq.h: add msgq_append and msgq_bufleft functions
3080 * include/client.h: use a struct MsgQ instead of a struct DBuf for
3083 * doc/Configure.help: Remove help for compile-time options that
3086 * config/config-sh.in: remove CONFIG_NEWMODE
3088 * ircd/m_server.c (mr_server): don't send server IPs in any server
3091 * ircd/msgq.c (msgq_vmake): add \r\n to messages
3093 2000-12-07 Kevin L. Mitchell <klmitch@mit.edu>
3095 * include/msgq.h: declare the MsgQ API
3097 * ircd/msgq.c: implementation of new MsgQ system
3099 2000-12-06 Kevin L. Mitchell <klmitch@mit.edu>
3101 * ircd/ircd_features.c: #include was supposed to be for
3102 ircd_features.h, not features.h--missed when I had to do a
3103 rename because of namespace collision
3105 2000-12-05 Greg Sikorski <gte@atomicrevs.demon.co.uk>
3106 * ircd/m_topic.c: Added missing braces that caused all remote
3107 topics to be ignored.
3109 2000-12-04 Kevin L. Mitchell <klmitch@mit.edu>
3111 * ircd/m_create.c: I'm tired of the exit_client warning :)
3112 (ms_create): discovered that exit_client() was being called with
3115 * ircd/s_misc.c (exit_client): remove all dependance on
3116 FNAME_USERLOG, since that's now gone; log only to LS_USER
3118 * ircd/s_debug.c: USE_SYSLOG no longer means anything
3120 * ircd/m_oper.c (m_oper): no longer log to LS_OPERLOG--we already
3123 * ircd/m_kill.c: no longer conditionalize on SYSLOG_KILL
3125 * ircd/ircd_log.c: remove LS_OPERLOG, LS_USERLOG
3127 * include/ircd_log.h: remove LS_OPERLOG, LS_USERLOG--they serve
3128 the same purpose as LS_USER and LS_OPER
3130 * config/config-sh.in: remove no longer relevant log config
3133 * ircd/uping.c (uping_init): use log_write instead of ircd_log
3135 * ircd/s_misc.c (exit_client): use log_write instead of ircd_log
3137 * ircd/s_conf.c: use log_write instead of ircd_log
3139 * ircd/s_bsd.c (report_error): use log_write instead of ircd_log
3141 * ircd/s_auth.c (timeout_auth_queries): use log_write instead of
3144 * ircd/res.c (send_res_msg): use log_write instead of ircd_log
3146 * ircd/m_who.c: use log_write instead of write_log; no longer
3147 conditionalize on WPATH; mark dead ircd_log calls
3149 * ircd/m_uping.c: mark dead ircd_log call
3151 * ircd/m_server.c (mr_server): use log_write instead of ircd_log
3153 * ircd/m_restart.c: use log_write instead of ircd_log; mark dead
3156 * ircd/m_rehash.c (mo_rehash): use log_write instead of ircd_log
3158 * ircd/m_oper.c: use log_write instead of ircd_log; no longer
3159 conditionalize on FNAME_OPERLOG; mark dead ircd_log calls
3161 * ircd/m_kill.c: mark dead ircd_log calls
3163 * ircd/m_connect.c: use log_write instead of ircd_log; mark dead
3166 * ircd/m_clearmode.c: use log_write instead of write_log; no
3167 longer conditionalize on OPATH
3169 * ircd/jupe.c: use log_write instead of write_log; no longer
3170 conditionalize on JPATH
3172 * ircd/ircd_log.c: add USER subsystem; remove ircd_log() compat
3173 function; fix a couple of bugs
3175 * ircd/ircd_alloc.c: fixed a comment
3177 * ircd/ircd.c: use log_write instead of ircd_log; fold server
3178 notice generation in a couple of cases
3180 * ircd/gline.c: use log_write instead of write_log; no longer
3181 conditionalize on GPATH
3183 * ircd/channel.c (modebuf_flush_int): use log_write instead of
3184 write_log; no longer conditionalize on OPATH
3186 * ircd/Makefile.in: run make depend, since dependencies have
3189 * doc/example.conf: add system USER to documentation
3191 * include/ircd_log.h: add system USER; remove old ircd_log()
3194 2000-12-04 Isomer <isomer@coders.net>
3195 * ircd/m_names.c: Add NAMES_EON to do_names to say add a
3196 'end_of_names' reply when done.
3197 * ircd/m_join.c: use NAMES_EON as mentioned above
3199 2000-12-01 net <simms@LUCIDA.QC.CA>
3201 * ircd/motd.c: add a freelist for struct Motds
3203 2000-11-30 Kevin L. Mitchell <klmitch@mit.edu>
3205 * ircd/s_stats.c (report_feature_list): report features--only
3206 local opers can see logging configuration, since it doesn't really
3207 mean anything to users
3209 * ircd/s_err.c: add reply messages for new feature subsystem
3211 * ircd/s_conf.c: add F lines to .conf
3213 * ircd/parse.c: add the message descriptions for /set, /reset, and
3216 * ircd/m_stats.c: add /stats f
3218 * ircd/m_set.c (mo_set): implement /set
3220 * ircd/m_reset.c (mo_reset): implement /reset
3222 * ircd/m_rehash.c: /rehash m now flushes MOTD cache, and /rehash l
3223 reopens log files (for log file rotation)
3225 * ircd/m_get.c (mo_get): implement /get
3227 * ircd/ircd_log.c: use int instead of void return value; add
3228 log_report_features() and log_canon(); fix a function that
3229 disappears if DEBUGMODE not #define'd
3231 * ircd/ircd_features.c: functions to manipulate feature settings
3232 either from the config file or with the new /set, /reset, and /get
3235 * ircd/Makefile.in: add new .c files, run make depend
3237 * include/s_stats.h: declare report_feature_list() (/stats f
3240 * include/numeric.h: add RPL_STATSFLINE, RPL_FEATURE,
3241 ERR_NOFEATURE, ERR_BADLOGTYPE, ERR_BADLOGSYS, and ERR_BADLOGVALUE
3244 * include/msg.h: add defines for SET, RESET, and GET
3246 * include/ircd_log.h: add a function to canonicalize subsystem
3247 names; change some void return values to int
3249 * include/ircd_features.h: new features subsystem handles all the
3250 manipulation of special features, like log files
3252 * include/handlers.h: declare new mo_{s,res,g}et message handlers
3253 for fiddling with features run-time
3255 * include/client.h (SNO_DEFAULT): don't set SNO_DEBUG by default;
3256 seemed like a good idea at the time...
3258 * doc/example.conf: document new F lines
3260 2000-11-29 Kevin L. Mitchell <klmitch@mit.edu>
3262 * ircd/s_debug.c: rewrite debug_init() and vdebug() in terms of
3263 new logging functions, which have special support for the debug
3264 log; added loop detection to vdebug(), so that I can
3265 sendto_opmask_butone() from log_vwrite() without incurring another
3268 * ircd/s_conf.c (rehash): call log_reopen() from rehash routine;
3269 this allows log file rotations
3271 * ircd/m_kill.c: call log_write_kill() instead of ircd_log_kill()
3273 * ircd/ircd_log.c: much more work fleshing out the interface;
3274 removed old interface; included backwards-compat ircd_log()
3275 function that logs to subsystem LS_OLDLOG
3277 * ircd/ircd.c: switch to new log_init()/log_close()/log_reopen()
3280 * include/ircd_log.h: include stdarg.h for va_list; move ordering
3281 warning to top of file; fill out LogSys enum; declare new
3282 log_debug_init(), log_vwrite(), log_write_kill(), and
3283 log_[sg]et_*() functions; add flags argument to log_write();
3284 defined flags to inhibit various logging actions
3286 * include/client.h: added support for new SNO_DEBUG, enabled only
3287 if DEBUGMODE is defined
3289 2000-11-28 Kevin L. Mitchell <klmitch@mit.edu>
3291 * ircd/ircd_log.c: make sure the various LOG_* constants are
3292 defined (probably not needed, since #include <syslog.h> isn't
3293 conditional); various static data needed for the new logging
3294 functions; definitions of new logging functions
3296 * include/ircd_log.h: new LogSys enum, declarations for part of
3299 * ircd/motd.c: we were setting type to MOTD_CLASS unconditionally,
3300 which was of course stupid; switched to using switch/case in
3301 initialization in motd_create(); zero the MotdList.other pointer
3304 * ircd/ircd.c (main): motd_init() has to come before init_conf(),
3305 or we overwrite init_conf()'s hard work with respect to T-lines
3307 2000-11-27 Kevin L. Mitchell <klmitch@mit.edu>
3309 * ircd/s_stats.c: comment out report_motd_list and include a
3310 reference to motd_report()
3312 * ircd/s_conf.c: rip out the old MOTD manipulation functions; call
3313 motd_add() from the conf parser; call motd_clear() from the rehash
3314 routine; remove the no longer needed memory clearing and reloading
3315 stuff from the rehash service routine
3317 * ircd/motd.c: loads new API, including static internal functions
3318 to do allocation/deallocation, etc.
3320 * ircd/m_stats.c: use new motd_report() instead of
3323 * ircd/m_motd.c: use new syntax for motd_send()
3325 * ircd/ircd.c: use new motd_init() function
3327 * ircd/Makefile.in (SRC): forgot to add motd.c to SRC in
3328 Makefile.(in); also ran make depend
3330 * include/motd.h: don't need config.h, but now do need time.h;
3331 define new structures and constants; redefine old API and define
3334 2000-11-22 Kevin L. Mitchell <klmitch@mit.edu>
3336 * ircd/s_user.c (register_user): use motd_signon() instead of
3337 calling m_motd; much cleaner this way
3339 * ircd/motd.c: write the new motd_* stuff to make MOTD handling
3342 * ircd/m_motd.c: rewrite m{,s}_motd to call out to new motd_*
3345 * include/motd.h: define new MOTD API stuff
3347 2000-11-20 Kevin L. Mitchell <klmitch@mit.edu>
3349 * ircd/ircd_reply.c (protocol_violation): rewrite
3350 protocol_violation so it'll actually work
3352 oh, yeah, use %s -> cptr->name, instead of %c -> cptr, so we get
3353 the client's real name in there.
3355 * ircd/m_motd.c (m_motd): Iso's addition of get_client_class(sptr)
3356 resulted in core dumps if NODEFAULTMOTD is defined, because m_motd
3357 gets called from register_user with a NULL sptr. This is probably
3358 a design problem, but this bandaid will do for now...
3360 2000-11-19 Isomer <isomer@coders.net>
3361 * ircd/ircd_reply.c: added 'protocol_violation', thus alerting us
3362 to problems in the server<->server protocol.
3364 * ircd/m_connect.c: allow remote connects with a port of '0'
3365 meaning to use the port in the config file.
3367 * ircd/m_create.c: Enable hacking protection, lets see how far we
3370 * ircd/m_error.c: The RFC says never accept ERROR from unreg'd
3371 clients, so we don't any more.
3373 * ircd/m_kill.c: The kill path is now made up of numnicks of servers,
3374 and the user@host is displayed of the victim.
3376 * ircd/m_map.c: reloaded 'dump_map'.
3378 * ircd/m_trace.c: allow per class T:
3380 * ircd/m_stats.c: allow local opers /remote stats anywhere on the 'net.
3382 2000-11-17 Isomer <isomer@coders.net>
3384 * ircd/m_topic.c: Fixed bug where we'd only send to clients topics
3385 that were the *same* instead of different. Oh the embarrasment!
3387 * ircd/IPcheck.c: Merged net's fix.
3389 2000-11-02 Kevin L. Mitchell <klmitch@mit.edu>
3391 * ircd/m_whois.c: remove compiler warning by adding a newline to
3394 * ircd/m_names.c: moved the flags up to s_user.h
3396 * ircd/m_join.c: call do_names instead of m_names; restructure
3397 ms_join to never transmute a JOIN into a CREATE, but use the TS in
3398 the JOIN (if present) to timestamp the channel
3400 * ircd/channel.c: send JOINs individually, instead of grouping
3401 them, so that we can send the channel's creation time
3403 * include/s_user.h: declare do_names()
3405 2000-10-30 Isomer <isomer@coders.net>
3406 * ircd/m_oper.c: Fixed warning
3408 2000-10-30 Isomer <isomer@coders.net>
3409 * ircd/m_oper.c: Fixed over agressive cut and no paste
3411 2000-10-30 Isomer <isomer@coders.net>
3413 * ircd/m_topic.c: Restructured, fixed bug where topics on local
3414 channels are propergated (I forget who pointed this out to me, but
3415 thanks anyway). Also to save bandwidth don't send the topic to
3416 users if the topic is already the same on the server (but still
3417 propergate to other servers). X/W's "autotopic" feature must
3418 chew a lot of bandwidth, hopefully this will help reduce this.
3420 * doc/rfc1459.rfc: Updated documentation on /topic.
3422 * ircd/listener.c: snotice warnings about failed accept()'s
3423 potentially warning admins that they're running out of fd's.
3425 * ircd/stats.c, ircd/class.c: Removed /stats v, added number of
3426 people in a class in /stats y
3428 * ircd/m_create.c: Checks for timewarp hacking and squit's
3429 evil servers. (currently disabled)
3432 2000-10-30 net <simms@lucida.qc.ca>
3434 * ircd/gline.c: Fixed various bugs Isomer left behind.
3436 2000-10-26 Kevin L. Mitchell <klmitch@mit.edu>
3438 * ircd/m_join.c (m_join): reply on attempt to join a BADCHANed
3439 channel is now ERR_BANNEDFROMCHAN instead of ERR_BADCHANNAME
3441 2000-10-24 Kevin L. Mitchell <klmitch@mit.edu>
3443 * ircd/channel.c: ok, now last mode rules; mode +ps will always
3444 result in +s (and won't send a mode if the channel is already +s);
3445 mode +sp will always result in +p; -n+n on a +n channel results in
3446 no mode change; -n+n on a -n channel results in a +n mode change;
3449 2000-10-23 Kevin L. Mitchell <klmitch@mit.edu>
3451 * ircd/channel.c: add "add" and "del" elements to ParseState to
3452 avoid not-too-pretty -p+s when +s is sufficient; fix a bug in
3453 mode_parse_limit that caused it to clear all channel modes
3454 prematurely; restructure mode_parse_mode to avoid calling
3455 modebuf_mode too early (ties in with first mentioned change);
3456 better logic for +p/+s mutual exclusivity; initialize "add" and
3457 "del" elements in mode_parse; send simple modes down to
3458 modebuf_mode after the loop in mode_parse
3460 2000-09-28 Greg Sikorski <gte@atomicrevs.demon.co.uk>
3461 * ircd/m_names.c: Fixed a non-lethal logic error that
3462 triggers an assert() in find_member_link while debugging.
3463 (Spotted by Maniac-).
3464 2000-09-19 Thomas Helvey <helveytw@home.com>
3465 * ircd/s_conf.c: move K:lines to their own list and data
3466 structures, add supporting code.
3467 * ircd/m_stats.c: cleanup stats processing a bit move
3468 kline listing code to a new function, haven't figured
3469 out where it goes yet tho'
3470 * ircd/s_stats.c: added K:line bulk lister
3471 * include/s_conf.h: added new DenyConf struct
3472 * *[ch]: fixeup code that depended on changes
3474 2000-09-17 Thomas Helvey <helveytw@home.com>
3475 * ircd/class.c: encapsulate class list
3476 * include/class.h: clean up classes
3477 * * fixup code that depended on changes
3479 2000-09-17 Thomas Helvey <helveytw@home.com>
3480 * ircd/s_conf.c: add me to local conf
3481 * include/s_conf.h: move CONF_ME macro to chkconf.c
3482 * ircd/s_bsd.c: cleanup initialization, allow virtual host
3483 to be changed by rehash
3485 2000-09-17 Thomas Helvey <helveytw@home.com>
3486 * include/class.h: add missing prototype
3487 * ircd/class.c: make argument to get_conf_class const
3489 2000-09-17 Thomas Helvey <helveytw@home.com>
3490 * ircd/*.c: merged in changes from 2.10.10.pl12, cleanup
3492 * ircd/*.h: merged in changes from 2.10.10.pl12, cleanup
3495 2000-09-16 Thomas Helvey <helveytw@home.com>
3496 * ircd/s_conf.c: add code for server struct
3497 * ircd/client.c: copy of class.c sort of, new file for client
3498 specific operations, will move things here as appropriate,
3499 currently only one function is exported from here.
3500 * ircd/*.c: general logic cleanups, convert negatives to
3501 positives in places.
3503 2000-09-16 Thomas Helvey <helveytw@home.com>
3504 * ircd/s_conf.c: add code for new crule data structs, strip quotes
3505 * ircd/crule.c: clean up scary casting a bit, type safety stuff
3506 * include/s_conf.h: add CRuleConf struct and support, remove
3508 * include/crule.h: type safety cleanups
3509 * ircd/*.c: fixup code that depended on stuff I changed
3511 2000-09-15 Thomas Helvey <helveytw@home.com>
3512 * ircd/s_conf.c: start adding code for new conf data structs, changed
3513 listeners, admin line, motd lines, class lines. Move validate_hostent
3514 to resolver. General mayhem.
3515 * include/s_conf.h: new data structs and accessors
3516 * ircd/res.c: move validate_hostent here, rewrite, use regular
3517 expression for validation.
3518 * doc/example.conf: update docs for port
3520 2000-09-14 Thomas Helvey <helveytw@home.com>
3521 * ircd/s_conf.c (conf_init): rewrite conf file parser, start to break
3522 up conf_init into managable chunks.
3523 * ircd/listener.c (set_listener_mask): fix logic bug core dump.
3524 * include/s_conf.h: add new data struct for local info (unwinding the mess).
3526 2000-09-13 Thomas Helvey <helveytw@home.com>
3527 * ircd/list.c: put Clients in free lists, pre-allocate MAXCONNECTIONS
3529 * ircd/list.c: put SLinks in free lists
3530 * ircd/channel.c: put Memberships in free lists
3531 * ircd/ircd.c: rearrange initializations a bit in main
3532 Note: With these changes, ircd NEVER frees Clients, SLinks or
3533 Memberships. It will also rarely need to allocate new
3534 ones during net bursts and other disruptions. This should
3535 cut down on memory fragmentation a bit as well.
3537 2000-08-30 Kevin L. Mitchell <klmitch@mit.edu>
3539 * ircd/m_names.c (do_names): pull-up from do_names fix in
3542 2000-07-15 Perry Lorier <Isomer@coders.net>
3543 * various: IP only k:'s and G:'s now do bit tests instead of two(!)
3544 match()'s. Major Major cpu savings. Also speed up the
3545 other case slightly. As a side effect you can now
3546 k/Gline *@10.0.0.0/8. I'll do bans tomorrow, it's nearing
3549 2000-07-15 Perry Lorier <Isomer@coders.net>
3550 * various: Fixed warnings after compiling on an alpha.
3551 2000-07-09 Perry Lorier <Isomer@coders.net>
3552 * doc/ircd.8: Applied grammitical changes by Liandrin, applied
3553 changes suggested by various other people.
3554 * ircd/IPcheck.c: More bug fixes. Current problem appears to be
3555 that it gets a corrupt entry somehow.
3556 2000-07-09 Greg Sikorski <gte@atomicrevs.demon.co.uk>
3557 * ircd/m_oper.c: Clean up compiler warning.
3559 2000-07-08 Perry Lorier <Isomer@coders.net>
3560 * doc/ircd.8: Updated the documentation, it was slightly out of date
3561 being updated around 1989.
3562 * ircd/m_whois.c: Rewrote for clarity, and probably a bit more speed.
3563 fixed a few minor glitches.
3564 * doc/rfc1459.unet: Updated.
3565 * ircd/IPcheck.c: Fixed more bugs.
3566 * ircd/s_bsd.c: We now keep track of servers we've conected.
3568 2000-07-02 Perry Lorier <Isomer@coders.net>
3569 * ircd/s_misc.c: Fixed remote IPcheck bug. Ok, I'm a moron, so sue
3570 me. Thanks to Hektik, thanks thanks thanks thanks
3571 thanks thanks thanks thanks thank thanks thank thanks
3573 2000-07-01 Perry Lorier <Isomer@coders.net>
3574 * ircd/s_conf.c: "Fixed" the "bug" where people would "evade" K:'s.
3575 * ircd/s_conf.c, include/IPcheck.h: Fixed compile warnings.
3577 2000-06-22 Perry Lorier <Isomer@coders.net>
3578 * ircd/IPcheck.c: Large chunks redone.
3579 * ircd/s_conf.c: Changes due to IPcheck - ONE nolonger supported,
3580 single AND double digit limits are allowed now.
3581 * misc other: Changes to IPcheck.
3583 2000-06-30 Perry Lorier <Isomer@coders.net>
3584 * ircd/ircd.c: Fix command line parameter bugs.
3586 2000-06-30 Perry Lorier <Isomer@coders.net>
3587 * ircd/m_kill.c: Fixed bug with LOCAL_KILL_ONLY
3588 * ircd/m_nick.c: Tidied things up.
3590 2000-06-12 Joseph Bongaarts <foxxe@trms.com>
3591 * ircd/m_stats.c: Iso forgot mo_stats when he added /stats v
3593 2000-05-29 Perry Lorier <Isomer@coders.net>
3594 * ircd/m_stats.c: add /stats v to do only the last part of the /trace
3595 * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
3596 you think it'll get bored and fix itself?
3598 2000-06-09 Greg Sikorski <gte@atomicrevs.demon.co.uk>
3600 * ircd/m_names.c: Clean up compiler warnings.
3602 2000-06-09 Kevin L. Mitchell <klmitch@mit.edu>
3604 * ircd/channel.c (mode_parse_client): don't send warning if
3605 there's not enough arguments for a +/-o/v; means the habit of
3606 doing "/mode #channel +oooooo bob" doesn't result in a bunch of
3609 2000-06-04 Greg Sikorski <gte@atomicrevs.demon.co.uk>
3611 * ircd/m_names.c: Re-factor code to remove unneccessary
3612 GlobalChannelList iteration every time someone joins a channel.
3614 2000-06-02 Kevin L. Mitchell <klmitch@mit.edu>
3616 * ircd/s_user.c: add struct Gline * argument to register_user;
3617 look up global glines and repropagate them if necessary; send
3618 acknowledgement of gline to remote servers when registering users
3620 * ircd/s_serv.c (server_estab): don't send acknowledgement of
3621 local glines to remote servers; do send gline acknowledgement of
3624 * ircd/m_user.c (m_user): pass new struct Gline * argument to
3627 * ircd/m_pong.c: pass new struct Gline * argument to register_user
3629 * ircd/m_nick.c (ms_nick): document protocol change
3631 * ircd/gline.c: support GLINE_LASTMOD
3633 * include/s_user.h: add struct Gline * argument to register_user
3635 * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
3637 * ircd/s_conf.c (find_kill): add unsigned int argument to
3640 * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
3641 glines; add unsigned int argument to gline_lookup()
3643 * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
3644 argument to gline_lookup()
3646 * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
3647 parameter, or when it falls out of bounds: see comments prior to
3648 call to jupe_resend(); call server_estab with struct Jupe
3649 parameter, so that we place the appropriate %<lastmod> in the
3652 * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
3653 server, as well as for servers when we're sending the BURST
3655 * include/s_serv.h: add a struct Jupe * to the arguments for
3656 server_estab() so that we can send the appropriate lastmod
3659 * ircd/m_gline.c (ms_gline): actually, this should be the
3660 slightest bit more efficient...
3662 * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
3663 bit more efficient...
3665 * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
3668 * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
3671 * ircd/channel.c (joinbuf_join): really remove user from local
3674 2000-05-29 Perry Lorier <Isomer@coders.net>
3675 * ircd/m_names.c: Removed redundant space.
3676 * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
3678 2000-05-18 Kevin L. Mitchell <klmitch@mit.edu>
3680 * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
3683 2000-05-04 Kevin L. Mitchell <klmitch@mit.edu>
3685 * ircd/channel.c: replace bogus assertions with returns, which is
3686 logically correct; only wipe out limit/key if they were originally
3687 set in the first place; remove user from channel when doing a
3688 PARTALL; only send MODE +o for user CREATEing channel if user is
3689 not MyUser--CREATE will only be used if the channel did not
3690 originally exist, therefore we can assume no one local is on the
3691 channel anyway, and we don't exactly need for the user to see an
3692 explicit +o for themselves
3694 * doc/readme.gline: describe the syntax of the GLINE command
3696 * doc/readme.jupe: update to reflect a couple of changes to JUPE
3698 * ircd/gline.c: don't propagate local changes
3700 * ircd/jupe.c: don't propagate local changes
3702 * ircd/m_gline.c (mo_gline): force local flag when deactivating
3703 glines with 0 lastmod
3705 * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
3706 are now removed instead of being deactivated
3708 * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
3709 -<mask>" be accepted
3711 * ircd/channel.c (send_channel_modes): deal with one of the last
3714 * ircd/m_burst.c (ms_burst): debugged ban processing; removed
3717 * ircd/channel.c (modebuf_extract): remove debugging
3718 sendto_opmask_butone calls
3720 2000-05-03 Kevin L. Mitchell <klmitch@mit.edu>
3722 * ircd/channel.c: support a couple of new flags to support using
3723 mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
3724 of modebuf_extract to extract added flags for use by ms_burst
3726 * include/channel.h: a couple of new flags to support using
3727 mode_parse inside ms_burst
3729 * ircd/m_burst.c (ms_burst): brand new implementation of BURST
3731 * ircd/m_endburst.c: add loop to processing of end_of_burst to
3732 free empty channels after the BURST is over.
3734 * ircd/m_server.c: convert to use new send.c functions--I wanted
3735 to rewrite it from scratch, but the logic's pretty complex; I may
3736 still rewrite it, though...
3738 2000-05-02 Thomas Helvey <tomh@inxpress.net>
3740 * ircd/ircd.c: fix broken header include ordering
3742 2000-05-02 Thomas Helvey <tomh@inxpress.net>
3744 * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
3745 review emailed privately
3747 * include/IPcheck.h: removed unneeded include
3749 2000-05-02 Kevin L. Mitchell <klmitch@mit.edu>
3751 * ircd/s_user.c (hunt_server): throw in a comment so I know what
3752 the sendto_one is for
3754 * include/querycmds.h (Count_unknownbecomesclient): convert to
3755 sendto_opmask_butone
3757 * ircd/send.c: start removing dead code
3759 * include/send.h: start removing dead code
3761 * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
3764 * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
3766 2000-05-01 Kevin L. Mitchell <klmitch@mit.edu>
3768 * ircd/m_stats.c: convert to sendcmdto_one / send_reply
3770 * ircd/m_kick.c: Completely reimplement m_kick
3772 * ircd/channel.c: send_user_joins removed; it was dead code,
3775 2000-05-01 Perry Lorier <isomer@coders.net>
3776 * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
3777 * ircd/channels.c: My fix for the part problem. Untested, probably
3778 won't work. Can't be much worse than the current problem.
3779 it'll either work or core, take your pick.
3782 2000-04-30 Perry Lorier <isomer@coders.net>
3783 * config/config-sh.in: Fix for CONNEXIT
3784 * ircd/s_{user,misc}.c: Fix for CONNEXIT
3785 * ircd/m_invite.c: Fix for incorrectly numnickified invite.
3786 (Kev: Want to come talk to me about this?)
3788 2000-04-30 Steven M. Doyle <steven@doyle.net>
3790 - general cleanups and readability enhancements
3791 - rewrite of setuid/chroot code.
3792 - server will no longer run as root
3793 - -DPROFIL compile option removed
3794 - Fixed IPcheck API calls
3796 * config/config-sh.in
3797 - Fixed up chroot compile options
3798 - Added options for debug and profile compiles
3800 * config/gen.ircd.Makefile
3801 - Support for new debug/profile options
3804 - Support for new debug/profile options
3806 * ircd/ircd_signal.c
3810 - Removed old API prototypes, added new ones
3813 - Readability cleanups (well, I -think-...)
3814 - Changed IPRegistryEntry.last_connect to a time_t. The previously
3815 used unsigned short was probably causing interesting things after
3816 a client had been connected longer than about 65,535 seconds...
3817 - Removed old API functions.
3820 - Removed IPcheck.h include
3822 * Additionally modified IPcheck API calls in:
3832 2000-04-30 Perry Lorier <isomer@coders.net>
3833 * ircd/s_bsd.c: Sigh. :)
3834 * ircd/m_mode.c: fix for modeless channels by poptix.
3836 2000-04-29 Kevin L. Mitchell <klmitch@mit.edu>
3838 * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
3840 * ircd/channel.c (clean_channelname): make clean_channelname also
3841 truncate long channel names
3843 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
3845 * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
3847 * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
3850 * include/channel.h: definitions and declarations for the struct
3853 2000-04-29 Perry Lorier <isomer@coders.net>
3854 * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
3856 2000-04-29 Perry Lorier <isomer@coders.net>
3857 * ircd/s_bsd.c: Add debugging code to IPcheck
3859 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
3861 * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
3863 * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
3866 * ircd/m_userhost.c (m_userhost): add a dead code comment
3868 * ircd/m_desynch.c: forgot one...
3870 * ircd/m_rehash.c (mo_rehash): er, duplicates :)
3872 * ircd/m_proto.c (proto_send_supported): just change a comment so
3873 it doesn't show up in my scans
3875 * ircd/ircd_reply.c (send_reply): fix a slight bug...
3877 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
3880 * ircd/parse.c (parse_server): argument wrangling to make
3881 processing in do_numeric a little easier to deal with
3883 * ircd/s_serv.c (server_estab): SERVER should come from
3884 acptr->serv->up, not &me
3886 * ircd/m_lusers.c: accidentally left out sptr for a %C
3888 * ircd/send.c: hack to support doing wallchops...
3890 * ircd/m_whowas.c: convert to new send functions
3892 * ircd/m_whois.c: convert to new send functions
3894 * ircd/m_who.c: convert to new send functions
3896 * ircd/m_wallops.c: convert to new send functions
3898 * ircd/m_wallchops.c: convert to new send functions
3900 * ircd/m_version.c: convert to new send functions
3902 * ircd/m_userip.c: convert to new send functions
3904 * ircd/m_userhost.c: convert to new send functions
3906 * ircd/m_uping.c: convert to new send functions
3908 * ircd/m_trace.c: convert to new send functions
3910 * ircd/m_topic.c: convert to new send functions
3912 * ircd/m_time.c: convert to new send functions
3914 * ircd/m_squit.c: convert to new send functions
3916 * ircd/m_silence.c: convert to new send functions
3918 * ircd/m_settime.c: convert to new send functions
3920 * ircd/m_restart.c: convert to new send functions
3922 * ircd/m_rehash.c: convert to new send functions
3924 * ircd/m_privmsg.c: convert to new send functions
3926 * ircd/m_pong.c: convert to new send functions
3928 * ircd/m_ping.c: convert to new send functions
3930 * ircd/m_pass.c: convert to new send functions
3932 * ircd/m_opmode.c: convert to new send functions
3934 * ircd/m_oper.c: convert to new send functions
3936 * ircd/m_notice.c: convert to new send functions
3938 * ircd/m_nick.c: convert to new send functions
3940 * ircd/m_names.c: convert to new send functions
3942 * ircd/m_motd.c: convert to new send functions
3944 * ircd/m_mode.c: convert to new send functions
3946 * ircd/m_map.c: convert to new send functions
3948 * ircd/m_lusers.c: convert to new send functions
3950 * ircd/m_list.c: convert to new send functions
3952 * ircd/m_links.c: convert to new send functions
3954 * ircd/m_kill.c: convert to new send functions
3956 * ircd/m_jupe.c: convert to new send functions
3958 * ircd/m_invite.c: convert to new send functions
3960 * ircd/m_info.c: convert to new send functions
3962 * ircd/m_help.c: convert to new send functions
3964 * ircd/m_gline.c: convert to new send functions
3966 * ircd/m_error.c: convert to new send functions
3968 * ircd/m_endburst.c: convert to new send functions
3970 * ircd/m_die.c: convert to new send functions
3972 * ircd/m_destruct.c: convert to new send functions
3974 * ircd/m_defaults.c: convert to new send functions
3976 * ircd/m_connect.c: convert to new send functions
3978 2000-04-28 Perry Lorier <isomer@coders.net>
3979 * RELEASE.NOTES: Describe a few more undocumented features.
3980 * config/config-sh.in: change the default paths for logging
3981 and the recommended number of channels.
3982 * include/supported.h: Rearrange slightly, added CHANTYPE's
3984 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
3986 * ircd/m_close.c: convert to send_reply
3988 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
3990 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
3992 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
3994 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
3995 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
3996 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
3997 carefully rethought...
3999 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
4001 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
4003 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
4004 numeric nick; therefore, we have to use the server name
4006 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
4008 * ircd/send.c: fix minor bugs
4010 * ircd/s_user.c (check_target_limit): mark dead code so I filter
4013 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
4016 * ircd/parse.c: mark dead code so I filter it when I grep
4018 * ircd/map.c: mark dead code so I filter it when I grep
4020 * ircd/ircd.c: mark dead code so I filter it when I grep
4022 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
4025 * ircd/channel.c: mark dead code so I filter it when I grep
4027 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
4028 hope I'm not stepping on toes...
4030 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
4031 conversions; use ircd_snprintf in a couple of cases to negate the
4032 possibility of buffer overflow
4034 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
4036 * ircd/channel.c: convert as much as possible to new send
4039 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
4040 test member->user->from->fd, not from->fd
4042 * ircd/gline.c (gline_add): go ahead and add badchans; we just
4043 won't look for them in m_gline; this way, they always work...
4045 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
4047 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
4048 ircd_vsnprintf conversion specifiers
4050 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
4051 I have my conversion specifiers
4053 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
4055 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
4058 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
4059 little less brain-dead
4061 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
4063 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
4066 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
4069 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
4072 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
4074 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
4076 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
4079 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
4081 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
4082 a numeric as needing to use an explicit pattern, which will be the
4083 first argument in the variable argument list
4085 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
4086 non-prefixed nospoof PING
4088 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
4089 non-prefixed SERVER login
4091 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
4092 a numeric usage further up)
4094 * include/send.h: declare sendrawto_one
4096 * ircd/send.c (sendrawto_one): new function to use ONLY for
4097 non-prefixed commands, like PING to client, or PASS/SERVER on
4100 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
4102 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
4103 future expansion (channel numerics?)
4105 * include/ircd_snprintf.h: added documentation to # to explain use
4106 with %C; added documentation for : to explain use with %C; added
4107 documentation for %H for channels
4109 * ircd/whocmds.c: use send_reply
4111 * ircd/userload.c: use sendcmdto_one
4113 * ircd/uping.c: use sendcmdto_one
4115 * ircd/send.c: use new flags to %C format string; ':' prefixes
4116 client name with a colon for local connects, '#' uses
4117 nick!user@host form for local connects
4119 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
4120 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
4122 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
4124 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
4127 * ircd/s_auth.c: use sendto_opmask_butone
4129 * ircd/res.c: use sendcmdto_one
4131 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
4132 debugging assertions
4134 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
4136 * ircd/support.c: dumpcore is no longer used, so get rid of it
4138 * ircd/parse.c: use send_reply, sendcmdto_one
4140 * ircd/map.c: use send_reply
4142 * ircd/listener.c: use send_reply
4144 * ircd/jupe.c: use sendto_opmask_butone, send_reply
4146 * ircd/ircd_reply.c: use send_reply
4148 * ircd/ircd.c: use sendto_opmask_butone
4150 * ircd/gline.c: use sendto_opmask_butone, send_reply
4152 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
4153 registered clients; make FLAG_ALT print nick!user@host; make
4154 FLAG_COLON print :blah
4156 * ircd/class.c (report_classes): use send_reply instead of
4159 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
4161 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
4162 sendto_one with sendcmdto_one
4164 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
4166 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
4167 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
4168 sendcmdto_match_butone
4170 * include/send.h: declare sendcmdto_match_butone
4172 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
4174 * ircd/jupe.c: update to use send_reply()
4176 * ircd/gline.c: update to use send_reply()
4178 * include/ircd_reply.h: declare send_reply
4180 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
4181 replies; uses ircd_snprintf
4183 * ircd/send.c: added comments to redirect searchers to appropriate
4184 sendcmdto_* function; moved new functions to end of file; added
4185 explanatory comments; reordered arguments; defined new functions
4188 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
4190 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
4192 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
4194 * ircd/gline.c: reorder arguments to sendcmdto_* functions
4196 * include/send.h: reorder arguments, add explanatory comments,
4197 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
4198 and vsendto_opmask_butone
4200 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
4202 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
4203 vsendto_op_mask that uses '*' instead of the receiving client
4206 * include/send.h: declare sendcmdto_channel_butone; takes a skip
4207 argument that allows you to skip (or not to skip) deaf users,
4208 users behind bursting servers, and non channel operators
4210 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
4212 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
4213 sendto_channel_butserv has a subtle bug; also wrote
4214 sendcmdto_common_channels.
4216 * include/send.h: declare new sendcmdto_* functions
4218 * ircd/jupe.c: support local deactivations of jupes
4220 * ircd/gline.c: support local deactivations of glines
4222 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
4223 deactivated; if they aren't locally deactivated, then it slaves to
4224 the net-wide activation status; JupeIsRemActive() tests only
4225 whether the jupe is active everywhere else
4227 * include/gline.h: GLINE_LDEACT allows glines to be locally
4228 deactivated; if they aren't locally deactivated, then it slaves to
4229 the net-wide activation status; GlineIsRemActive() tests only
4230 whether the gline is active everywhere else
4232 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
4233 gline expires after the new one will, we drop the new one,
4234 otherwise we add the G-line after that one (so the wide one will
4235 apply first); if the new one contains an existing G-line and if it
4236 will expire after the existing one, we drop the existing one to
4239 * ircd/m_gline.c (mo_gline): opers could issue remote local
4240 glines when CONFIG_OPERCMDS was off; fixed
4242 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
4244 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
4245 this is a local JUPE
4247 * ircd/gline.c: add flags argument to gline_activate and
4248 gline_deactivate for future expansion
4250 * ircd/m_gline.c: pass flags to gline_activate and
4253 * include/gline.h: add flags argument to gline_activate and
4256 * ircd/jupe.c: add flags argument to jupe_activate and
4257 jupe_deactivate for future expansion
4259 * include/jupe.h: add flags argument to jupe_activate and
4262 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
4263 local, active; pass flags to jupe_activate and jupe_deactivate
4265 * include/gline.h: remove dead code
4267 * ircd/gline.c: make gline expire times relative to CurrentTime,
4268 since that should be monotonically increasing, instead of
4269 TStime(), which can be set backwards, and which can therefore
4270 cause an expire time to increase; make local glines be removed
4271 instead of just deactivated; don't let gline_find() look for
4272 user@host glines if the mask being looked up is a channel mask
4274 * ircd/send.c (vsendcmdto_one): forgot to account for the case
4275 where origin is a server and destination is a user
4277 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
4278 since that should be monotonically increasing, instead of
4279 TStime(), which can be set backwards, and which can therefore
4280 cause an expire time to increase; make local jupes be removed
4281 instead of just deactivated
4283 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
4284 limit is fine. any other warnings I should know about?
4286 2000-04-15 Thomas Helvey <tomh@inxpress.net>
4288 * ircd/*.c: const correctness and type safety cleanups to
4289 get code to compile with C++ compiler. Still has
4290 signed/unsigned comparison warnings.
4292 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
4294 * ircd/userload.c: change <sys/time.h> include to <time.h> for
4297 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
4299 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
4300 and convert acptr...
4302 * ircd/s_user.c: move gline_lookup function call into
4303 register_user, where it'll have a username to lookup!
4305 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
4306 functions; also stuff send_error_to_client into return clauses
4308 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
4309 functions; also use send_error_to_client where that makes sense
4311 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
4312 functions; also use send_error_to_client where that makes sense
4314 * ircd/gline.c: modify to utilize new sendcmdto_* series of
4315 functions; also fix gline_lookup() to deal properly with remote
4316 clients--boy, do struct Client and struct User need to be cleaned
4319 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
4322 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
4323 sendcmdto_serv_butone(), all utilizing the %v conversion of
4326 * include/send.h: define IRC_BUFSIZE, max size of a message;
4327 declare sendcmdto_one(), vsendcmdto_one(), and
4328 sendcmdto_serv_butone()
4330 * include/msg.h: define all the CMD_* constants needed to utilize
4331 the new sendcmdto_* series of functions
4333 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
4335 * ircd/gline.c: remove old, dead code.
4337 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
4338 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
4339 (don't advertise proxies); remove dead code
4341 * ircd/parse.c: oper handler for JUPE only lists jupes unless
4342 CONFIG_OPERCMDS is enabled
4344 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
4345 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
4347 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
4348 always return ERR_DISABLED
4350 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
4351 enabled, always return ERR_DISABLED
4353 * ircd/s_err.c: add error message to indicate disabled commands
4355 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
4357 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
4359 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
4360 CONFIG_NEW_MODE to 'y' for now
4362 * ircd/gline.c (gline_list): fix a minor formatting bogon
4364 * BUGS: since I fixed that bug, might as well mark it fixed.
4366 * ircd/m_join.c: look up badchans with GLINE_EXACT
4368 * ircd/m_gline.c: fix parc count problems; look up existing
4369 G-lines with GLINE_EXACT; only set new lastmod when
4370 activating/deactivating existing glines if old lastmod was not 0
4372 * ircd/gline.c: forgot to copy the gline reason over; don't
4373 propagate a gline with 0 lastmod if origin is user; add
4374 GLINE_EXACT to force exact matching of gline mask
4376 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
4379 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
4380 but gline_lookup() actually takes a client--d'oh.
4382 2000-04-13 Thomas Helvey <tomh@inxpress.net>
4383 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
4385 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
4387 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
4389 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
4392 * ircd/whocmds.c: Change idle time calc from socket idle to user
4395 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
4397 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
4398 too, for ircd_snprintf.c
4400 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
4401 comments; mostly descended from the Linux manpage for printf, but
4402 also documenting the extensions.
4404 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
4405 client; make 'q' be the same as 'L'; remove __inline__; only
4406 define EXTENSION if HAVE_LONG_LONG is defined
4408 * include/handlers.h: declare m_gline()
4410 * ircd/parse.c: gline can be called by users, but it only lists
4413 * ircd/s_user.c (set_nick_name): resend gline if a remote server
4414 introduces a glined client
4416 * ircd/s_serv.c (server_estab): burst glines, too
4418 * ircd/gline.c: fix up all the expire times to be offsets;
4419 simplify gline_resend()
4421 * ircd/m_gline.c: begin coding replacements for ms_gline(),
4422 mo_gline(), and m_gline()
4424 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
4425 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
4427 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
4429 * tools/Bouncer/*: Add comments/documentation/tags.
4430 * tools/Bouncer/*: Add debug defines, make task fork().
4432 2000-04-12 Thomas Helvey <tomh@inxpress.net>
4433 * ircd/s_err.c: Cleanup s_err.c make one table so we
4434 don't have to do anything tricky to get an error string.
4436 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
4437 * Add port bouncer for http (x/w)
4439 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
4441 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
4442 call to gline_find(); also used GlineReason() instead of direct
4443 reference to structure member
4445 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
4446 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
4449 * ircd/channel.c: nothing seems to be called anywhere...
4451 * ircd/s_err.c: update a couple of replies to dovetail with new
4454 * ircd/gline.c: begin complete re-implementation of gline.c along
4455 the lines of the final design of jupe.c
4457 * include/gline.h: begin complete re-implementation of gline.c
4458 along the lines of the final design of jupe.c
4460 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
4461 %s by %s" message...
4463 * ircd/ircd_snprintf.c: my new snprintf()-like functions
4465 * include/ircd_snprintf.h: my new snprintf()-like functions
4467 2000-04-11 Thomas Helvey <tomh@inxpress.net>
4468 * ircd/IPcheck.c: removed old dead code
4469 * ircd/s_user.c (send_user_info): removed non-standard
4470 user not found message for userhost/userip
4472 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
4474 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
4475 * doc/p10.html: Work on chapter 4.
4477 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
4479 * ircd/channel.c (mode_parse_client): fix coredump on /mode
4480 #foobar +o nosuchnick
4482 2000-04-10 Perry Lorier <Isomer@coders.net>
4485 2000-04-09 Thomas Helvey <tomh@inxpress.net>
4486 * include/IPcheck.h: fix prototype
4487 * ircd/s_user.c: fix usage of IPcheck_remote_connect
4488 * ircd/IPcheck.c: removed unused args
4490 2000-04-09 Thomas Helvey <tomh@inxpress.net>
4491 * include/IPcheck.h: add proto for IPcheck_expire
4493 * ircd/IPcheck.c: Rewrote
4495 * ircd/ircd.c: Add IPcheck_expire to main message loop
4497 * ircd/s_user.c: Redo target hashing, refactor target code
4499 * include/numeric.h: Cleaned up numerics, added which ones are
4500 in use by other networks and what they are in use for.
4502 * ircd/channel.c: cleaned can_join(), allow anyone through anything
4503 if /invited, simplified the function. Opers overusing OPEROVERRIDE
4504 will get a message explaining to them not to cheat.
4506 * ircd/m_join.c: cleaned up the various join functions, should be
4507 a lot more efficient. Still needs work. Now assumes that s<->s
4508 won't send it a JOIN 0. Service coders - note this and tread with
4511 * ircd/m_stats.c: added Gte-'s stats doc patch.
4513 * ircd/m_version.c: /version now returns the 005 numeric as well.
4514 as requested by Liandrin.
4517 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
4519 * ircd/m_clearmode.c: add include for support.h for write_log()
4521 * configure: move ircd/crypt/* to tools/*
4523 2000-04-06 Thomas Helvey <tomh@inxpress.net>
4524 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
4525 set client host to server alias if connection from localhost
4527 2000-04-06 Perry Lorier <isomer@coders.net>
4528 * ircd/ircd.c: Fix core during pinging (oops)
4530 2000-04-06 Perry Lorier <isomer@coders.net>
4531 * ircd/send.c: fixed wrong ident being sent to channels bug.
4532 * include/numerics.h: Updated some of the numerics from other
4533 networks. Flagged some as 'unused' by undernet.
4535 2000-03-30 Perry Lorier <isomer@coders.net>
4536 * ircd/ircd.c: Lets see if this helps the ping problem at all.
4537 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
4538 time for local clients. (as requested), extended who now returns all
4539 the flags (@+!) so you can tell the complete state of a client.
4541 2000-03-30 Thomas Helvey <tomh@inxpress.net>
4542 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
4544 2000-03-30 Perry Lorier <isomer@coders.net>
4545 * ircd/parse.c: oops, missed opers.
4547 2000-03-30 Perry Lorier <isomer@coders.net>
4548 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
4549 for so long. Remember: m_ping MUST be in the parse array. :)
4551 2000-03-30 Perry Lorier <isomer@coders.net>
4552 * ircd/ircd.c: test in check_pings was wrong. I move that we
4553 disallow cvs commit after 10pm localtime....
4555 2000-03-30 Perry Lorier <isomer@coders.net>
4556 * ircd/m_pong.c: Fix it for servers too.
4558 2000-03-30 Perry Lorier <isomer@coders.net>
4559 * ircd/m_pong.c: Fix ping timeout bugs
4561 2000-03-30 Perry Lorier <isomer@coders.net>
4562 * ircd/channel.c: Bans had CurrentTime in their when field instead
4565 2000-03-31 Thomas Helvey <tomh@ixpress.net>
4566 * ircd/numnicks.c (SetXYYCapacity): fix for extended
4569 2000-03-30 Perry Lorier <isomer@coders.net>
4570 * ircd/m_nick.c: send kills both ways so when we add nick change
4571 on collision we don't desync the network.
4573 * ircd/map.c: Fixup the map a bit more.
4575 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
4577 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
4579 * ircd/m_opmode.c: Log the mode changes to OPATH
4581 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
4584 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
4587 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
4589 * config/config-sh.in: added OPATH for opmode log file
4591 * ircd/m_clearmode.c (do_clearmode): updated uses of
4592 modebuf_mode_string() for the new usage
4594 * ircd/channel.c: added flag MODE_FREE and an int argument to
4595 modebuf_mode_string() to indicate that the string must be free'd;
4596 updated calls to modebuf_mode_string() for the new usage; called
4597 collapse(pretty_mask()) on the ban string and use allocated memory
4598 for it; added ban list length accounting; fixed a number of small
4599 bugs in ban processing
4601 * include/channel.h: added flag MODE_FREE and an int argument to
4602 modebuf_mode_string() to indicate that the string must be free'd
4604 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
4605 keys and limits that are set
4607 2000-03-30 Perry Lorier <isomer@coders.net>
4608 * ircd/ircd.c: rewrote check_pings() for maintainability
4609 and speed. Also changed quit msg's so they don't have
4610 redundant nick[host] info in them.
4612 * ircd/send.c: Changed write errors to report what error
4613 occured (if possible).
4615 * ircd/gline.c: added gline comment to the quit.
4617 * ircd/m_server.c: Added suggestions to server quits mentioning
4618 what went wrong so the admin can fix it earlier instead of asking
4621 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
4622 servers that aren't fully burst yet. And show '(--s)' for servers
4625 * doc/example.conf: Fixed wrapped U:
4627 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
4629 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
4630 mode_parse() (version selectable at compile time)
4632 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
4634 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
4636 * config/config-sh.in: add new config option to enable new m_mode
4639 * doc/Configure.help: add documentation for new config option
4642 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
4643 MODE -v : Not enough parameters
4645 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
4646 +k and +l even if they weren't set...
4648 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
4650 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
4651 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
4652 for; test the 0-th member, not the i-th member, of the client
4655 * ircd/m_clearmode.c (do_clearmode): use the new
4656 mode_invite_clear() function
4658 * ircd/channel.c: cleared up all the compile-time warnings and
4661 * include/channel.h: added declarations for mode_ban_invalidate()
4662 and mode_invite_clear()
4664 * ircd/channel.c: finished mode_parse(), then broke it up into a
4665 dozen or so helper functions to make the code easier to read
4667 2000-03-29 Thomas Helvey <tomh@inxpress.net>
4668 * ircd/ircd.c: refactor server initialization a bit, use
4669 getopt for parsing command line, refactor init_sys, main,
4672 * ircd/s_bsd.c: add functions for initialization to clean
4673 up logic a bit and remove duplicated code.
4675 * include/ircd.h: add struct for server process related
4678 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
4680 * ircd/channel.c: initial definition of mode_parse(); flags to
4681 prevent doing the same thing multiple times; helper method
4682 send_notoper() to send a "Not oper"/"Not on channel" notice
4684 * include/channel.h: declare mode_parse() and helper flags
4686 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
4687 sending to match the current action of set_mode() closely enough
4688 that hopefully there won't be major conflicts
4690 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
4691 building logic, reversed the order of the arguments to mode
4692 commands to have '-' preceed '+'
4694 2000-03-29 Thomas Helvey <tomh@inxpress.net>
4695 * ircd/s_bsd.c (add_connection): don't disable socket options
4696 let OS tune itself and allow important performance tweaks to
4699 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
4701 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
4702 confused by set_mode, which is doing some really weird logic;
4703 guess what I'm going to rewrite next? ;)
4705 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
4707 * include/channel.h: added MODE_SAVE for the bounds checking stuff
4710 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
4711 make it do bounds checking on the buffer; all modes are sent only
4712 if the all parameter is 1; modebuf_flush is the exported wrapper
4714 * include/channel.h: add BOUNCE, renumber flags to get a little
4717 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
4718 BOUNCE; send DESYNCH message
4720 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
4722 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
4723 channel actually has in effect for deletion
4725 * ircd/channel.c: added explanatory comments to all added
4726 functions; made flushing take place at the correct place even if
4727 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
4728 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
4729 is empty, fixed the apparent source, removed some bogus string
4730 termination code, properly terminate the mode strings, add support
4731 for HACK2 and HACK3, made limit strings not be sent if the limit
4732 is being removed, changed where '+' and '-' come from in sent
4733 strings, added support for DEOP flag, set up bouncing code for
4736 * ircd/Makefile.in: ran make depend
4738 * include/channel.h: added new defines for future functionality,
4739 made modebuf_flush() return int so I can use tail recursion
4741 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
4742 to make it all compile
4744 * ircd/m_opmode.c: add msg.h to includes...
4746 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
4748 * ircd/channel.c (modebuf_flush): realized I forgot to
4749 nul-terminate addbuf/rembuf properly...
4751 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
4753 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
4754 sendto_serv_butone--blah^2
4756 * ircd/send.c (sendto_serv_butone): stupid comments confused me
4758 * ircd/channel.c (modebuf_flush): if there are no mode changes to
4759 propagate, we're done...
4761 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
4762 not sendto_all_butone
4764 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
4766 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
4768 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
4771 * ircd/parse.c: added messages for opmode and clearmode
4773 * include/handlers.h: added declarations for mo_opmode(),
4774 ms_opmode(), mo_clearmode(), and ms_clearmode()
4776 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
4779 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
4780 MODEBUF_DEST_OPMODE flag
4782 * ircd/channel.c (modebuf_flush): added new flag,
4783 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
4784 to originate from source's server (or source itself, if
4785 IsServer(source)); also causes a server-level MODE to be sent as
4788 * include/channel.h: defined MODEBUF_DEST_SERVER,
4791 * ircd/channel.c: Add another argument to build_string() to handle
4792 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
4793 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
4796 2000-03-27 Perry Lorier <isomer@coders.net>
4798 * ircd/s_bsd.c: fixed missing 'u' typo.
4800 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
4802 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
4803 _mode_string(), _mode_client(), _flush(); also implemented a
4804 simple build_string()
4806 * include/channel.h: added definition of ModeBuf, modebuf_*
4807 manipulation functions, and a couple of helper macros