2 * ircd-ratbox: A slightly useful ircd.
3 * send.c: Functions for sending messages.
5 * Copyright (C) 1990 Jarkko Oikarinen and University of Oulu, Co Center
6 * Copyright (C) 1996-2002 Hybrid Development Team
7 * Copyright (C) 2002-2005 ircd-ratbox development team
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
24 * $Id: send.c 3520 2007-06-30 22:15:35Z jilles $
38 #include "s_newconf.h"
43 #define LOG_BUFSIZE 2048
45 /* send the message to the link the target is attached to */
46 #define send_linebuf(a,b) _send_linebuf((a->from ? a->from : a) ,b)
48 static void send_queued_write(rb_fde_t
*F
, void *data
);
50 unsigned long current_serial
= 0L;
52 struct Client
*remote_rehash_oper_p
;
56 * inputs - client to send to, linebuf to attach
58 * side effects - linebuf is attached to client
61 _send_linebuf(struct Client
*to
, buf_head_t
*linebuf
)
65 sendto_realops_snomask(SNO_GENERAL
, L_ALL
, "Trying to send message to myself!");
69 if(!MyConnect(to
) || IsIOError(to
))
72 if(rb_linebuf_len(&to
->localClient
->buf_sendq
) > get_sendq(to
))
76 sendto_realops_snomask(SNO_GENERAL
, L_ALL
,
77 "Max SendQ limit exceeded for %s: %u > %lu",
79 rb_linebuf_len(&to
->localClient
->buf_sendq
),
82 ilog(L_SERVER
, "Max SendQ limit exceeded for %s: %u > %lu",
83 log_client_name(to
, SHOW_IP
),
84 rb_linebuf_len(&to
->localClient
->buf_sendq
),
89 to
->flags
|= FLAGS_SENDQEX
;
96 /* just attach the linebuf to the sendq instead of
97 * generating a new one
99 rb_linebuf_attach(&to
->localClient
->buf_sendq
, linebuf
);
103 ** Update statistics. The following is slightly incorrect
104 ** because it counts messages even if queued, but bytes
105 ** only really sent. Queued bytes get updated in SendQueued.
107 to
->localClient
->sendM
+= 1;
108 me
.localClient
->sendM
+= 1;
109 if(rb_linebuf_len(&to
->localClient
->buf_sendq
) > 0)
114 /* send_linebuf_remote()
116 * inputs - client to attach to, sender, linebuf
118 * side effects - client has linebuf attached
121 send_linebuf_remote(struct Client
*to
, struct Client
*from
, buf_head_t
*linebuf
)
126 /* we assume the caller has already tested for fake direction */
128 _send_linebuf(to
, linebuf
);
132 /* send_queued_write()
134 * inputs - fd to have queue sent, client we're sending to
135 * outputs - contents of queue
136 * side effects - write is rescheduled if queue isnt emptied
139 send_queued(struct Client
*to
)
142 #ifdef USE_IODEBUG_HOOKS
145 rb_fde_t
*F
= to
->localClient
->F
;
149 /* cant write anything to a dead socket. */
153 /* Something wants us to not send anything currently */
157 /* try to flush later when the write event resets this */
161 #ifdef USE_IODEBUG_HOOKS
163 if(to
->localClient
->buf_sendq
.list
.head
)
164 hd
.arg1
= ((buf_line_t
*) to
->localClient
->buf_sendq
.list
.head
->data
)->buf
+
165 to
->localClient
->buf_sendq
.writeofs
;
168 if(rb_linebuf_len(&to
->localClient
->buf_sendq
))
171 rb_linebuf_flush(F
, &to
->localClient
->buf_sendq
)) > 0)
173 /* We have some data written .. update counters */
174 #ifdef USE_IODEBUG_HOOKS
176 call_hook(h_iosend_id
, &hd
);
178 if(to
->localClient
->buf_sendq
.list
.head
)
180 ((buf_line_t
*) to
->localClient
->buf_sendq
.list
.head
->
181 data
)->buf
+ to
->localClient
->buf_sendq
.writeofs
;
187 to
->localClient
->sendB
+= retlen
;
188 me
.localClient
->sendB
+= retlen
;
189 if(to
->localClient
->sendB
> 1023)
191 to
->localClient
->sendK
+= (to
->localClient
->sendB
>> 10);
192 to
->localClient
->sendB
&= 0x03ff; /* 2^10 = 1024, 3ff = 1023 */
194 else if(me
.localClient
->sendB
> 1023)
196 me
.localClient
->sendK
+= (me
.localClient
->sendB
>> 10);
197 me
.localClient
->sendB
&= 0x03ff;
201 if(retlen
== 0 || (retlen
< 0 && !rb_ignore_errno(errno
)))
208 if(rb_linebuf_len(&to
->localClient
->buf_sendq
))
211 rb_setselect(to
->localClient
->F
, RB_SELECT_WRITE
,
212 send_queued_write
, to
);
219 send_pop_queue(struct Client
*to
)
223 if(!MyConnect(to
) || IsIOError(to
))
225 if(rb_linebuf_len(&to
->localClient
->buf_sendq
) > 0)
229 /* send_queued_write()
231 * inputs - fd to have queue sent, client we're sending to
232 * outputs - contents of queue
233 * side effects - write is scheduled if queue isnt emptied
236 send_queued_write(rb_fde_t
*F
, void *data
)
238 struct Client
*to
= data
;
245 * inputs - client to send to, va_args
246 * outputs - client has message put into its queue
250 sendto_one(struct Client
*target_p
, const char *pattern
, ...)
255 /* send remote if to->from non NULL */
256 if(target_p
->from
!= NULL
)
257 target_p
= target_p
->from
;
259 if(IsIOError(target_p
))
262 rb_linebuf_newbuf(&linebuf
);
264 va_start(args
, pattern
);
265 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, NULL
);
268 _send_linebuf(target_p
, &linebuf
);
270 rb_linebuf_donebuf(&linebuf
);
274 /* sendto_one_prefix()
276 * inputs - client to send to, va_args
277 * outputs - client has message put into its queue
278 * side effects - source(us)/target is chosen based on TS6 capability
281 sendto_one_prefix(struct Client
*target_p
, struct Client
*source_p
,
282 const char *command
, const char *pattern
, ...)
284 struct Client
*dest_p
;
288 /* send remote if to->from non NULL */
289 if(target_p
->from
!= NULL
)
290 dest_p
= target_p
->from
;
294 if(IsIOError(dest_p
))
299 sendto_realops_snomask(SNO_GENERAL
, L_ALL
, "Trying to send to myself!");
303 rb_linebuf_newbuf(&linebuf
);
304 va_start(args
, pattern
);
305 rb_linebuf_putmsg(&linebuf
, pattern
, &args
,
307 get_id(source_p
, target_p
),
308 command
, get_id(target_p
, target_p
));
311 _send_linebuf(dest_p
, &linebuf
);
312 rb_linebuf_donebuf(&linebuf
);
315 /* sendto_one_notice()
317 * inputs - client to send to, va_args
318 * outputs - client has a NOTICE put into its queue
319 * side effects - source(us)/target is chosen based on TS6 capability
322 sendto_one_notice(struct Client
*target_p
, const char *pattern
, ...)
324 struct Client
*dest_p
;
329 /* send remote if to->from non NULL */
330 if(target_p
->from
!= NULL
)
331 dest_p
= target_p
->from
;
335 if(IsIOError(dest_p
))
340 sendto_realops_snomask(SNO_GENERAL
, L_ALL
, "Trying to send to myself!");
344 rb_linebuf_newbuf(&linebuf
);
345 va_start(args
, pattern
);
346 rb_linebuf_putmsg(&linebuf
, pattern
, &args
,
348 get_id(&me
, target_p
), *(to
= get_id(target_p
, target_p
)) != '\0' ? to
: "*");
351 _send_linebuf(dest_p
, &linebuf
);
352 rb_linebuf_donebuf(&linebuf
);
356 /* sendto_one_numeric()
358 * inputs - client to send to, va_args
359 * outputs - client has message put into its queue
360 * side effects - source/target is chosen based on TS6 capability
363 sendto_one_numeric(struct Client
*target_p
, int numeric
, const char *pattern
, ...)
365 struct Client
*dest_p
;
370 /* send remote if to->from non NULL */
371 if(target_p
->from
!= NULL
)
372 dest_p
= target_p
->from
;
376 if(IsIOError(dest_p
))
381 sendto_realops_snomask(SNO_GENERAL
, L_ALL
, "Trying to send to myself!");
385 rb_linebuf_newbuf(&linebuf
);
386 va_start(args
, pattern
);
387 rb_linebuf_putmsg(&linebuf
, pattern
, &args
,
389 get_id(&me
, target_p
),
390 numeric
, *(to
= get_id(target_p
, target_p
)) != '\0' ? to
: "*");
393 _send_linebuf(dest_p
, &linebuf
);
394 rb_linebuf_donebuf(&linebuf
);
400 * inputs - pointer to client to NOT send to
401 * - caps or'd together which must ALL be present
402 * - caps or'd together which must ALL NOT be present
403 * - printf style format string
404 * - args to format string
406 * side effects - Send a message to all connected servers, except the
407 * client 'one' (if non-NULL), as long as the servers
408 * support ALL capabs in 'caps', and NO capabs in 'nocaps'.
410 * This function was written in an attempt to merge together the other
411 * billion sendto_*serv*() functions, which sprung up with capabs, uids etc
415 sendto_server(struct Client
*one
, struct Channel
*chptr
, unsigned long caps
,
416 unsigned long nocaps
, const char *format
, ...)
419 struct Client
*target_p
;
421 rb_dlink_node
*next_ptr
;
424 /* noone to send to.. */
425 if(rb_dlink_list_length(&serv_list
) == 0)
428 if(chptr
!= NULL
&& *chptr
->chname
!= '#')
431 rb_linebuf_newbuf(&linebuf
);
432 va_start(args
, format
);
433 rb_linebuf_putmsg(&linebuf
, format
, &args
, NULL
);
436 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, serv_list
.head
)
438 target_p
= ptr
->data
;
440 /* check against 'one' */
441 if(one
!= NULL
&& (target_p
== one
->from
))
444 /* check we have required capabs */
445 if(!IsCapable(target_p
, caps
))
448 /* check we don't have any forbidden capabs */
449 if(!NotCapable(target_p
, nocaps
))
452 _send_linebuf(target_p
, &linebuf
);
455 rb_linebuf_donebuf(&linebuf
);
459 /* sendto_channel_flags()
461 * inputs - server not to send to, flags needed, source, channel, va_args
462 * outputs - message is sent to channel members
466 sendto_channel_flags(struct Client
*one
, int type
, struct Client
*source_p
,
467 struct Channel
*chptr
, const char *pattern
, ...)
469 static char buf
[BUFSIZE
];
471 buf_head_t rb_linebuf_local
;
472 buf_head_t rb_linebuf_id
;
473 struct Client
*target_p
;
474 struct membership
*msptr
;
476 rb_dlink_node
*next_ptr
;
478 rb_linebuf_newbuf(&rb_linebuf_local
);
479 rb_linebuf_newbuf(&rb_linebuf_id
);
483 va_start(args
, pattern
);
484 rb_vsnprintf(buf
, sizeof(buf
), pattern
, args
);
487 if(IsServer(source_p
))
488 rb_linebuf_putmsg(&rb_linebuf_local
, NULL
, NULL
,
489 ":%s %s", source_p
->name
, buf
);
491 rb_linebuf_putmsg(&rb_linebuf_local
, NULL
, NULL
,
493 source_p
->name
, source_p
->username
,
494 source_p
->host
, buf
);
496 rb_linebuf_putmsg(&rb_linebuf_id
, NULL
, NULL
, ":%s %s", use_id(source_p
), buf
);
498 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, chptr
->members
.head
)
501 target_p
= msptr
->client_p
;
503 if(IsIOError(target_p
->from
) || target_p
->from
== one
)
506 if(type
&& ((msptr
->flags
& type
) == 0))
512 if(!MyClient(target_p
))
514 /* if we've got a specific type, target must support
517 if(type
&& NotCapable(target_p
->from
, CAP_CHW
))
520 if(target_p
->from
->serial
!= current_serial
)
522 send_linebuf_remote(target_p
, source_p
, &rb_linebuf_id
);
523 target_p
->from
->serial
= current_serial
;
527 _send_linebuf(target_p
, &rb_linebuf_local
);
530 rb_linebuf_donebuf(&rb_linebuf_local
);
531 rb_linebuf_donebuf(&rb_linebuf_id
);
535 /* sendto_channel_local()
537 * inputs - flags to send to, channel to send to, va_args
538 * outputs - message to local channel members
542 sendto_channel_local(int type
, struct Channel
*chptr
, const char *pattern
, ...)
546 struct membership
*msptr
;
547 struct Client
*target_p
;
549 rb_dlink_node
*next_ptr
;
551 rb_linebuf_newbuf(&linebuf
);
553 va_start(args
, pattern
);
554 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, NULL
);
557 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, chptr
->locmembers
.head
)
560 target_p
= msptr
->client_p
;
562 if(IsIOError(target_p
))
565 if(type
&& ((msptr
->flags
& type
) == 0))
568 _send_linebuf(target_p
, &linebuf
);
571 rb_linebuf_donebuf(&linebuf
);
574 /* sendto_channel_local_butone()
576 * inputs - flags to send to, channel to send to, va_args
577 * - user to ignore when sending
578 * outputs - message to local channel members
582 sendto_channel_local_butone(struct Client
*one
, int type
, struct Channel
*chptr
, const char *pattern
, ...)
586 struct membership
*msptr
;
587 struct Client
*target_p
;
589 rb_dlink_node
*next_ptr
;
591 rb_linebuf_newbuf(&linebuf
);
593 va_start(args
, pattern
);
594 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, NULL
);
597 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, chptr
->locmembers
.head
)
600 target_p
= msptr
->client_p
;
605 if(IsIOError(target_p
))
608 if(type
&& ((msptr
->flags
& type
) == 0))
611 _send_linebuf(target_p
, &linebuf
);
614 rb_linebuf_donebuf(&linebuf
);
618 * sendto_common_channels_local()
620 * inputs - pointer to client
623 * side effects - Sends a message to all people on local server who are
624 * in same channel with user.
625 * used by m_nick.c and exit_one_client.
628 sendto_common_channels_local(struct Client
*user
, const char *pattern
, ...)
632 rb_dlink_node
*next_ptr
;
634 rb_dlink_node
*next_uptr
;
635 struct Channel
*chptr
;
636 struct Client
*target_p
;
637 struct membership
*msptr
;
638 struct membership
*mscptr
;
641 rb_linebuf_newbuf(&linebuf
);
642 va_start(args
, pattern
);
643 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, NULL
);
648 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, user
->user
->channel
.head
)
651 chptr
= mscptr
->chptr
;
653 RB_DLINK_FOREACH_SAFE(uptr
, next_uptr
, chptr
->locmembers
.head
)
656 target_p
= msptr
->client_p
;
658 if(IsIOError(target_p
) ||
659 target_p
->serial
== current_serial
)
662 target_p
->serial
= current_serial
;
663 send_linebuf(target_p
, &linebuf
);
667 /* this can happen when the user isnt in any channels, but we still
668 * need to send them the data, ie a nick change
670 if(MyConnect(user
) && (user
->serial
!= current_serial
))
671 send_linebuf(user
, &linebuf
);
673 rb_linebuf_donebuf(&linebuf
);
677 * sendto_common_channels_local_butone()
679 * inputs - pointer to client
682 * side effects - Sends a message to all people on local server who are
683 * in same channel with user, except for user itself.
686 sendto_common_channels_local_butone(struct Client
*user
, const char *pattern
, ...)
690 rb_dlink_node
*next_ptr
;
692 rb_dlink_node
*next_uptr
;
693 struct Channel
*chptr
;
694 struct Client
*target_p
;
695 struct membership
*msptr
;
696 struct membership
*mscptr
;
699 rb_linebuf_newbuf(&linebuf
);
700 va_start(args
, pattern
);
701 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, NULL
);
705 /* Skip them -- jilles */
706 user
->serial
= current_serial
;
708 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, user
->user
->channel
.head
)
711 chptr
= mscptr
->chptr
;
713 RB_DLINK_FOREACH_SAFE(uptr
, next_uptr
, chptr
->locmembers
.head
)
716 target_p
= msptr
->client_p
;
718 if(IsIOError(target_p
) ||
719 target_p
->serial
== current_serial
)
722 target_p
->serial
= current_serial
;
723 send_linebuf(target_p
, &linebuf
);
727 rb_linebuf_donebuf(&linebuf
);
730 /* sendto_match_butone()
732 * inputs - server not to send to, source, mask, type of mask, va_args
734 * side effects - message is sent to matching clients
737 sendto_match_butone(struct Client
*one
, struct Client
*source_p
,
738 const char *mask
, int what
, const char *pattern
, ...)
740 static char buf
[BUFSIZE
];
742 struct Client
*target_p
;
744 rb_dlink_node
*next_ptr
;
745 buf_head_t rb_linebuf_local
;
746 buf_head_t rb_linebuf_id
;
748 rb_linebuf_newbuf(&rb_linebuf_local
);
749 rb_linebuf_newbuf(&rb_linebuf_id
);
751 va_start(args
, pattern
);
752 rb_vsnprintf(buf
, sizeof(buf
), pattern
, args
);
755 if(IsServer(source_p
))
756 rb_linebuf_putmsg(&rb_linebuf_local
, NULL
, NULL
,
757 ":%s %s", source_p
->name
, buf
);
759 rb_linebuf_putmsg(&rb_linebuf_local
, NULL
, NULL
,
761 source_p
->name
, source_p
->username
,
762 source_p
->host
, buf
);
764 rb_linebuf_putmsg(&rb_linebuf_id
, NULL
, NULL
, ":%s %s", use_id(source_p
), buf
);
766 if(what
== MATCH_HOST
)
768 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, lclient_list
.head
)
770 target_p
= ptr
->data
;
772 if(match(mask
, target_p
->host
))
773 _send_linebuf(target_p
, &rb_linebuf_local
);
776 /* what = MATCH_SERVER, if it doesnt match us, just send remote */
777 else if(match(mask
, me
.name
))
779 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, lclient_list
.head
)
781 target_p
= ptr
->data
;
782 _send_linebuf(target_p
, &rb_linebuf_local
);
786 RB_DLINK_FOREACH(ptr
, serv_list
.head
)
788 target_p
= ptr
->data
;
793 send_linebuf_remote(target_p
, source_p
, &rb_linebuf_id
);
796 rb_linebuf_donebuf(&rb_linebuf_local
);
797 rb_linebuf_donebuf(&rb_linebuf_id
);
800 /* sendto_match_servs()
802 * inputs - source, mask to send to, caps needed, va_args
804 * side effects - message is sent to matching servers with caps.
807 sendto_match_servs(struct Client
*source_p
, const char *mask
, int cap
,
808 int nocap
, const char *pattern
, ...)
810 static char buf
[BUFSIZE
];
813 struct Client
*target_p
;
814 buf_head_t rb_linebuf_id
;
816 if(EmptyString(mask
))
819 rb_linebuf_newbuf(&rb_linebuf_id
);
821 va_start(args
, pattern
);
822 rb_vsnprintf(buf
, sizeof(buf
), pattern
, args
);
825 rb_linebuf_putmsg(&rb_linebuf_id
, NULL
, NULL
,
826 ":%s %s", use_id(source_p
), buf
);
830 RB_DLINK_FOREACH(ptr
, global_serv_list
.head
)
832 target_p
= ptr
->data
;
834 /* dont send to ourselves, or back to where it came from.. */
835 if(IsMe(target_p
) || target_p
->from
== source_p
->from
)
838 if(target_p
->from
->serial
== current_serial
)
841 if(match(mask
, target_p
->name
))
843 /* if we set the serial here, then we'll never do
844 * a match() again if !IsCapable()
846 target_p
->from
->serial
= current_serial
;
848 if(cap
&& !IsCapable(target_p
->from
, cap
))
851 if(nocap
&& !NotCapable(target_p
->from
, nocap
))
854 _send_linebuf(target_p
->from
, &rb_linebuf_id
);
858 rb_linebuf_donebuf(&rb_linebuf_id
);
863 * inputs - monitor nick to send to, format, va_args
864 * outputs - message to local users monitoring the given nick
868 sendto_monitor(struct monitor
*monptr
, const char *pattern
, ...)
872 struct Client
*target_p
;
874 rb_dlink_node
*next_ptr
;
876 rb_linebuf_newbuf(&linebuf
);
878 va_start(args
, pattern
);
879 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, NULL
);
882 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, monptr
->users
.head
)
884 target_p
= ptr
->data
;
886 if(IsIOError(target_p
))
889 _send_linebuf(target_p
, &linebuf
);
892 rb_linebuf_donebuf(&linebuf
);
897 * inputs - target, source, va_args
899 * side effects - client is sent message with correct prefix.
902 sendto_anywhere(struct Client
*target_p
, struct Client
*source_p
,
903 const char *command
, const char *pattern
, ...)
908 rb_linebuf_newbuf(&linebuf
);
910 va_start(args
, pattern
);
912 if(MyClient(target_p
))
914 if(IsServer(source_p
))
915 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, ":%s %s %s ",
916 source_p
->name
, command
,
919 rb_linebuf_putmsg(&linebuf
, pattern
, &args
,
921 source_p
->name
, source_p
->username
,
922 source_p
->host
, command
,
926 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, ":%s %s %s ",
927 get_id(source_p
, target_p
), command
,
928 get_id(target_p
, target_p
));
931 if(MyClient(target_p
))
932 _send_linebuf(target_p
, &linebuf
);
934 send_linebuf_remote(target_p
, source_p
, &linebuf
);
936 rb_linebuf_donebuf(&linebuf
);
939 /* sendto_realops_snomask()
941 * inputs - snomask needed, level (opers/admin), va_args
943 * side effects - message is sent to opers with matching snomasks
946 sendto_realops_snomask(int flags
, int level
, const char *pattern
, ...)
948 static char buf
[BUFSIZE
];
950 struct Client
*client_p
;
952 rb_dlink_node
*next_ptr
;
956 rb_linebuf_newbuf(&linebuf
);
958 /* Be very sure not to do things like "Trying to send to myself"
959 * L_NETWIDE, otherwise infinite recursion may result! -- jilles */
960 if (level
& L_NETWIDE
&& ConfigFileEntry
.global_snotices
)
962 /* rather a lot of copying around, oh well -- jilles */
963 va_start(args
, pattern
);
964 rb_vsnprintf(buf
, sizeof(buf
), pattern
, args
);
966 rb_linebuf_putmsg(&linebuf
, pattern
, NULL
,
967 ":%s NOTICE * :*** Notice -- %s", me
.name
, buf
);
968 snobuf
= construct_snobuf(flags
);
969 if (snobuf
[1] != '\0')
970 sendto_server(NULL
, NULL
, CAP_ENCAP
|CAP_TS6
, NOCAPS
,
971 ":%s ENCAP * SNOTE %c :%s",
972 me
.id
, snobuf
[1], buf
);
974 else if (remote_rehash_oper_p
!= NULL
)
976 /* rather a lot of copying around, oh well -- jilles */
977 va_start(args
, pattern
);
978 rb_vsnprintf(buf
, sizeof(buf
), pattern
, args
);
980 rb_linebuf_putmsg(&linebuf
, pattern
, NULL
,
981 ":%s NOTICE * :*** Notice -- %s", me
.name
, buf
);
982 sendto_one_notice(remote_rehash_oper_p
, ":*** Notice -- %s", buf
);
986 va_start(args
, pattern
);
987 rb_linebuf_putmsg(&linebuf
, pattern
, &args
,
988 ":%s NOTICE * :*** Notice -- ", me
.name
);
993 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, local_oper_list
.head
)
995 client_p
= ptr
->data
;
997 /* If we're sending it to opers and theyre an admin, skip.
998 * If we're sending it to admins, and theyre not, skip.
1000 if(((level
== L_ADMIN
) && !IsOperAdmin(client_p
)) ||
1001 ((level
== L_OPER
) && IsOperAdmin(client_p
)))
1004 if(client_p
->snomask
& flags
)
1005 _send_linebuf(client_p
, &linebuf
);
1008 rb_linebuf_donebuf(&linebuf
);
1010 /* sendto_realops_snomask_from()
1012 * inputs - snomask needed, level (opers/admin), source server, va_args
1014 * side effects - message is sent to opers with matching snomask
1017 sendto_realops_snomask_from(int flags
, int level
, struct Client
*source_p
,
1018 const char *pattern
, ...)
1020 struct Client
*client_p
;
1022 rb_dlink_node
*next_ptr
;
1026 rb_linebuf_newbuf(&linebuf
);
1028 va_start(args
, pattern
);
1029 rb_linebuf_putmsg(&linebuf
, pattern
, &args
,
1030 ":%s NOTICE * :*** Notice -- ", source_p
->name
);
1033 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, local_oper_list
.head
)
1035 client_p
= ptr
->data
;
1037 /* If we're sending it to opers and theyre an admin, skip.
1038 * If we're sending it to admins, and theyre not, skip.
1040 if(((level
== L_ADMIN
) && !IsOperAdmin(client_p
)) ||
1041 ((level
== L_OPER
) && IsOperAdmin(client_p
)))
1044 if(client_p
->snomask
& flags
)
1045 _send_linebuf(client_p
, &linebuf
);
1048 rb_linebuf_donebuf(&linebuf
);
1052 * sendto_wallops_flags
1054 * inputs - flag types of messages to show to real opers
1055 * - client sending request
1056 * - var args input message
1058 * side effects - Send a wallops to local opers
1061 sendto_wallops_flags(int flags
, struct Client
*source_p
, const char *pattern
, ...)
1063 struct Client
*client_p
;
1065 rb_dlink_node
*next_ptr
;
1069 rb_linebuf_newbuf(&linebuf
);
1071 va_start(args
, pattern
);
1073 if(IsPerson(source_p
))
1074 rb_linebuf_putmsg(&linebuf
, pattern
, &args
,
1075 ":%s!%s@%s WALLOPS :", source_p
->name
,
1076 source_p
->username
, source_p
->host
);
1078 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, ":%s WALLOPS :", source_p
->name
);
1082 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, IsPerson(source_p
) && flags
== UMODE_WALLOP
? lclient_list
.head
: local_oper_list
.head
)
1084 client_p
= ptr
->data
;
1086 if(client_p
->umodes
& flags
)
1087 _send_linebuf(client_p
, &linebuf
);
1090 rb_linebuf_donebuf(&linebuf
);
1095 * input - client to send kill to, client to kill, va_args
1097 * side effects - we issue a kill for the client
1100 kill_client(struct Client
*target_p
, struct Client
*diedie
, const char *pattern
, ...)
1105 rb_linebuf_newbuf(&linebuf
);
1107 va_start(args
, pattern
);
1108 rb_linebuf_putmsg(&linebuf
, pattern
, &args
, ":%s KILL %s :",
1109 get_id(&me
, target_p
), get_id(diedie
, target_p
));
1112 send_linebuf(target_p
, &linebuf
);
1113 rb_linebuf_donebuf(&linebuf
);
1118 * kill_client_serv_butone
1120 * inputs - pointer to client to not send to
1121 * - pointer to client to kill
1123 * side effects - Send a KILL for the given client
1124 * message to all connected servers
1125 * except the client 'one'. Also deal with
1126 * client being unknown to leaf, as in lazylink...
1129 kill_client_serv_butone(struct Client
*one
, struct Client
*target_p
, const char *pattern
, ...)
1131 static char buf
[BUFSIZE
];
1133 struct Client
*client_p
;
1135 rb_dlink_node
*next_ptr
;
1136 buf_head_t rb_linebuf_id
;
1138 rb_linebuf_newbuf(&rb_linebuf_id
);
1140 va_start(args
, pattern
);
1141 rb_vsnprintf(buf
, sizeof(buf
), pattern
, args
);
1144 rb_linebuf_putmsg(&rb_linebuf_id
, NULL
, NULL
, ":%s KILL %s :%s",
1145 use_id(&me
), use_id(target_p
), buf
);
1147 RB_DLINK_FOREACH_SAFE(ptr
, next_ptr
, serv_list
.head
)
1149 client_p
= ptr
->data
;
1151 /* ok, if the client we're supposed to not send to has an
1152 * ID, then we still want to issue the kill there..
1154 if(one
!= NULL
&& (client_p
== one
->from
) &&
1155 (!has_id(client_p
) || !has_id(target_p
)))
1158 _send_linebuf(client_p
, &rb_linebuf_id
);
1161 rb_linebuf_donebuf(&rb_linebuf_id
);