]> jfr.im git - irc/rqf/shadowircd.git/blob - src/send.c
Note that blacklist{} only accepts host/reason pairs, no host+host+reason.
[irc/rqf/shadowircd.git] / src / send.c
1 /*
2 * ircd-ratbox: A slightly useful ircd.
3 * send.c: Functions for sending messages.
4 *
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
8 *
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.
13 *
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.
18 *
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
22 * USA
23 *
24 * $Id: send.c 3520 2007-06-30 22:15:35Z jilles $
25 */
26
27 #include "stdinc.h"
28 #include "send.h"
29 #include "channel.h"
30 #include "class.h"
31 #include "client.h"
32 #include "common.h"
33 #include "match.h"
34 #include "ircd.h"
35 #include "numeric.h"
36 #include "s_serv.h"
37 #include "s_conf.h"
38 #include "s_newconf.h"
39 #include "logger.h"
40 #include "hook.h"
41 #include "monitor.h"
42
43 #define LOG_BUFSIZE 2048
44
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)
47
48 static void send_queued_write(rb_fde_t *F, void *data);
49
50 unsigned long current_serial = 0L;
51
52 struct Client *remote_rehash_oper_p;
53
54 /* send_linebuf()
55 *
56 * inputs - client to send to, linebuf to attach
57 * outputs -
58 * side effects - linebuf is attached to client
59 */
60 static int
61 _send_linebuf(struct Client *to, buf_head_t *linebuf)
62 {
63 if(IsMe(to))
64 {
65 sendto_realops_snomask(SNO_GENERAL, L_ALL, "Trying to send message to myself!");
66 return 0;
67 }
68
69 if(!MyConnect(to) || IsIOError(to))
70 return 0;
71
72 if(rb_linebuf_len(&to->localClient->buf_sendq) > get_sendq(to))
73 {
74 if(IsServer(to))
75 {
76 sendto_realops_snomask(SNO_GENERAL, L_ALL,
77 "Max SendQ limit exceeded for %s: %u > %lu",
78 to->name,
79 rb_linebuf_len(&to->localClient->buf_sendq),
80 get_sendq(to));
81
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),
85 get_sendq(to));
86 }
87
88 if(IsClient(to))
89 to->flags |= FLAGS_SENDQEX;
90
91 dead_link(to);
92 return -1;
93 }
94 else
95 {
96 /* just attach the linebuf to the sendq instead of
97 * generating a new one
98 */
99 rb_linebuf_attach(&to->localClient->buf_sendq, linebuf);
100 }
101
102 /*
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.
106 */
107 to->localClient->sendM += 1;
108 me.localClient->sendM += 1;
109 if(rb_linebuf_len(&to->localClient->buf_sendq) > 0)
110 send_queued(to);
111 return 0;
112 }
113
114 /* send_linebuf_remote()
115 *
116 * inputs - client to attach to, sender, linebuf
117 * outputs -
118 * side effects - client has linebuf attached
119 */
120 static void
121 send_linebuf_remote(struct Client *to, struct Client *from, buf_head_t *linebuf)
122 {
123 if(to->from)
124 to = to->from;
125
126 /* we assume the caller has already tested for fake direction */
127
128 _send_linebuf(to, linebuf);
129 return;
130 }
131
132 /* send_queued_write()
133 *
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
137 */
138 void
139 send_queued(struct Client *to)
140 {
141 int retlen;
142 #ifdef USE_IODEBUG_HOOKS
143 hook_data_int hd;
144 #endif
145 rb_fde_t *F = to->localClient->F;
146 if (!F)
147 return;
148
149 /* cant write anything to a dead socket. */
150 if(IsIOError(to))
151 return;
152
153 /* Something wants us to not send anything currently */
154 /* if(IsCork(to))
155 return; */
156
157 /* try to flush later when the write event resets this */
158 if(IsFlush(to))
159 return;
160
161 #ifdef USE_IODEBUG_HOOKS
162 hd.client = to;
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;
166 #endif
167
168 if(rb_linebuf_len(&to->localClient->buf_sendq))
169 {
170 while ((retlen =
171 rb_linebuf_flush(F, &to->localClient->buf_sendq)) > 0)
172 {
173 /* We have some data written .. update counters */
174 #ifdef USE_IODEBUG_HOOKS
175 hd.arg2 = retlen;
176 call_hook(h_iosend_id, &hd);
177
178 if(to->localClient->buf_sendq.list.head)
179 hd.arg1 =
180 ((buf_line_t *) to->localClient->buf_sendq.list.head->
181 data)->buf + to->localClient->buf_sendq.writeofs;
182 #endif
183
184
185 ClearFlush(to);
186
187 to->localClient->sendB += retlen;
188 me.localClient->sendB += retlen;
189 if(to->localClient->sendB > 1023)
190 {
191 to->localClient->sendK += (to->localClient->sendB >> 10);
192 to->localClient->sendB &= 0x03ff; /* 2^10 = 1024, 3ff = 1023 */
193 }
194 else if(me.localClient->sendB > 1023)
195 {
196 me.localClient->sendK += (me.localClient->sendB >> 10);
197 me.localClient->sendB &= 0x03ff;
198 }
199 }
200
201 if(retlen == 0 || (retlen < 0 && !rb_ignore_errno(errno)))
202 {
203 dead_link(to);
204 return;
205 }
206 }
207
208 if(rb_linebuf_len(&to->localClient->buf_sendq))
209 {
210 SetFlush(to);
211 rb_setselect(to->localClient->F, RB_SELECT_WRITE,
212 send_queued_write, to);
213 }
214 else
215 ClearFlush(to);
216 }
217
218 void
219 send_pop_queue(struct Client *to)
220 {
221 if(to->from != NULL)
222 to = to->from;
223 if(!MyConnect(to) || IsIOError(to))
224 return;
225 if(rb_linebuf_len(&to->localClient->buf_sendq) > 0)
226 send_queued(to);
227 }
228
229 /* send_queued_write()
230 *
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
234 */
235 static void
236 send_queued_write(rb_fde_t *F, void *data)
237 {
238 struct Client *to = data;
239 ClearFlush(to);
240 send_queued(to);
241 }
242
243 /* sendto_one()
244 *
245 * inputs - client to send to, va_args
246 * outputs - client has message put into its queue
247 * side effects -
248 */
249 void
250 sendto_one(struct Client *target_p, const char *pattern, ...)
251 {
252 va_list args;
253 buf_head_t linebuf;
254
255 /* send remote if to->from non NULL */
256 if(target_p->from != NULL)
257 target_p = target_p->from;
258
259 if(IsIOError(target_p))
260 return;
261
262 rb_linebuf_newbuf(&linebuf);
263
264 va_start(args, pattern);
265 rb_linebuf_putmsg(&linebuf, pattern, &args, NULL);
266 va_end(args);
267
268 _send_linebuf(target_p, &linebuf);
269
270 rb_linebuf_donebuf(&linebuf);
271
272 }
273
274 /* sendto_one_prefix()
275 *
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
279 */
280 void
281 sendto_one_prefix(struct Client *target_p, struct Client *source_p,
282 const char *command, const char *pattern, ...)
283 {
284 struct Client *dest_p;
285 va_list args;
286 buf_head_t linebuf;
287
288 /* send remote if to->from non NULL */
289 if(target_p->from != NULL)
290 dest_p = target_p->from;
291 else
292 dest_p = target_p;
293
294 if(IsIOError(dest_p))
295 return;
296
297 if(IsMe(dest_p))
298 {
299 sendto_realops_snomask(SNO_GENERAL, L_ALL, "Trying to send to myself!");
300 return;
301 }
302
303 rb_linebuf_newbuf(&linebuf);
304 va_start(args, pattern);
305 rb_linebuf_putmsg(&linebuf, pattern, &args,
306 ":%s %s %s ",
307 get_id(source_p, target_p),
308 command, get_id(target_p, target_p));
309 va_end(args);
310
311 _send_linebuf(dest_p, &linebuf);
312 rb_linebuf_donebuf(&linebuf);
313 }
314
315 /* sendto_one_notice()
316 *
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
320 */
321 void
322 sendto_one_notice(struct Client *target_p, const char *pattern, ...)
323 {
324 struct Client *dest_p;
325 va_list args;
326 buf_head_t linebuf;
327 char *to;
328
329 /* send remote if to->from non NULL */
330 if(target_p->from != NULL)
331 dest_p = target_p->from;
332 else
333 dest_p = target_p;
334
335 if(IsIOError(dest_p))
336 return;
337
338 if(IsMe(dest_p))
339 {
340 sendto_realops_snomask(SNO_GENERAL, L_ALL, "Trying to send to myself!");
341 return;
342 }
343
344 rb_linebuf_newbuf(&linebuf);
345 va_start(args, pattern);
346 rb_linebuf_putmsg(&linebuf, pattern, &args,
347 ":%s NOTICE %s ",
348 get_id(&me, target_p), *(to = get_id(target_p, target_p)) != '\0' ? to : "*");
349 va_end(args);
350
351 _send_linebuf(dest_p, &linebuf);
352 rb_linebuf_donebuf(&linebuf);
353 }
354
355
356 /* sendto_one_numeric()
357 *
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
361 */
362 void
363 sendto_one_numeric(struct Client *target_p, int numeric, const char *pattern, ...)
364 {
365 struct Client *dest_p;
366 va_list args;
367 buf_head_t linebuf;
368 char *to;
369
370 /* send remote if to->from non NULL */
371 if(target_p->from != NULL)
372 dest_p = target_p->from;
373 else
374 dest_p = target_p;
375
376 if(IsIOError(dest_p))
377 return;
378
379 if(IsMe(dest_p))
380 {
381 sendto_realops_snomask(SNO_GENERAL, L_ALL, "Trying to send to myself!");
382 return;
383 }
384
385 rb_linebuf_newbuf(&linebuf);
386 va_start(args, pattern);
387 rb_linebuf_putmsg(&linebuf, pattern, &args,
388 ":%s %03d %s ",
389 get_id(&me, target_p),
390 numeric, *(to = get_id(target_p, target_p)) != '\0' ? to : "*");
391 va_end(args);
392
393 _send_linebuf(dest_p, &linebuf);
394 rb_linebuf_donebuf(&linebuf);
395 }
396
397 /*
398 * sendto_server
399 *
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
405 * output - NONE
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'.
409 *
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
412 * -davidt
413 */
414 void
415 sendto_server(struct Client *one, struct Channel *chptr, unsigned long caps,
416 unsigned long nocaps, const char *format, ...)
417 {
418 va_list args;
419 struct Client *target_p;
420 rb_dlink_node *ptr;
421 rb_dlink_node *next_ptr;
422 buf_head_t linebuf;
423
424 /* noone to send to.. */
425 if(rb_dlink_list_length(&serv_list) == 0)
426 return;
427
428 if(chptr != NULL && *chptr->chname != '#')
429 return;
430
431 rb_linebuf_newbuf(&linebuf);
432 va_start(args, format);
433 rb_linebuf_putmsg(&linebuf, format, &args, NULL);
434 va_end(args);
435
436 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, serv_list.head)
437 {
438 target_p = ptr->data;
439
440 /* check against 'one' */
441 if(one != NULL && (target_p == one->from))
442 continue;
443
444 /* check we have required capabs */
445 if(!IsCapable(target_p, caps))
446 continue;
447
448 /* check we don't have any forbidden capabs */
449 if(!NotCapable(target_p, nocaps))
450 continue;
451
452 _send_linebuf(target_p, &linebuf);
453 }
454
455 rb_linebuf_donebuf(&linebuf);
456
457 }
458
459 /* sendto_channel_flags()
460 *
461 * inputs - server not to send to, flags needed, source, channel, va_args
462 * outputs - message is sent to channel members
463 * side effects -
464 */
465 void
466 sendto_channel_flags(struct Client *one, int type, struct Client *source_p,
467 struct Channel *chptr, const char *pattern, ...)
468 {
469 static char buf[BUFSIZE];
470 va_list args;
471 buf_head_t rb_linebuf_local;
472 buf_head_t rb_linebuf_id;
473 struct Client *target_p;
474 struct membership *msptr;
475 rb_dlink_node *ptr;
476 rb_dlink_node *next_ptr;
477
478 rb_linebuf_newbuf(&rb_linebuf_local);
479 rb_linebuf_newbuf(&rb_linebuf_id);
480
481 current_serial++;
482
483 va_start(args, pattern);
484 rb_vsnprintf(buf, sizeof(buf), pattern, args);
485 va_end(args);
486
487 if(IsServer(source_p))
488 rb_linebuf_putmsg(&rb_linebuf_local, NULL, NULL,
489 ":%s %s", source_p->name, buf);
490 else
491 rb_linebuf_putmsg(&rb_linebuf_local, NULL, NULL,
492 ":%s!%s@%s %s",
493 source_p->name, source_p->username,
494 source_p->host, buf);
495
496 rb_linebuf_putmsg(&rb_linebuf_id, NULL, NULL, ":%s %s", use_id(source_p), buf);
497
498 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, chptr->members.head)
499 {
500 msptr = ptr->data;
501 target_p = msptr->client_p;
502
503 if(IsIOError(target_p->from) || target_p->from == one)
504 continue;
505
506 if(type && ((msptr->flags & type) == 0))
507 continue;
508
509 if(IsDeaf(target_p))
510 continue;
511
512 if(!MyClient(target_p))
513 {
514 /* if we've got a specific type, target must support
515 * CHW.. --fl
516 */
517 if(type && NotCapable(target_p->from, CAP_CHW))
518 continue;
519
520 if(target_p->from->serial != current_serial)
521 {
522 send_linebuf_remote(target_p, source_p, &rb_linebuf_id);
523 target_p->from->serial = current_serial;
524 }
525 }
526 else
527 _send_linebuf(target_p, &rb_linebuf_local);
528 }
529
530 rb_linebuf_donebuf(&rb_linebuf_local);
531 rb_linebuf_donebuf(&rb_linebuf_id);
532 }
533
534 /* sendto_channel_flags()
535 *
536 * inputs - server not to send to, flags needed, source, channel, va_args
537 * outputs - message is sent to channel members
538 * side effects -
539 */
540 void
541 sendto_channel_opmod(struct Client *one, struct Client *source_p,
542 struct Channel *chptr, const char *command,
543 const char *text)
544 {
545 buf_head_t rb_linebuf_local;
546 buf_head_t rb_linebuf_old;
547 buf_head_t rb_linebuf_new;
548 struct Client *target_p;
549 struct membership *msptr;
550 rb_dlink_node *ptr;
551 rb_dlink_node *next_ptr;
552
553 rb_linebuf_newbuf(&rb_linebuf_local);
554 rb_linebuf_newbuf(&rb_linebuf_old);
555 rb_linebuf_newbuf(&rb_linebuf_new);
556
557 current_serial++;
558
559 if(IsServer(source_p))
560 rb_linebuf_putmsg(&rb_linebuf_local, NULL, NULL,
561 ":%s %s %s :%s",
562 source_p->name, command, chptr->chname, text);
563 else
564 rb_linebuf_putmsg(&rb_linebuf_local, NULL, NULL,
565 ":%s!%s@%s %s %s :%s",
566 source_p->name, source_p->username,
567 source_p->host, command, chptr->chname, text);
568
569 if (chptr->mode.mode & MODE_MODERATED)
570 rb_linebuf_putmsg(&rb_linebuf_old, NULL, NULL,
571 ":%s %s %s :%s",
572 use_id(source_p), command, chptr->chname, text);
573 else
574 rb_linebuf_putmsg(&rb_linebuf_old, NULL, NULL,
575 ":%s NOTICE @%s :<%s:%s> %s",
576 use_id(source_p->servptr), chptr->chname,
577 source_p->name, chptr->chname, text);
578 rb_linebuf_putmsg(&rb_linebuf_new, NULL, NULL,
579 ":%s %s =%s :%s",
580 use_id(source_p), command, chptr->chname, text);
581
582 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, chptr->members.head)
583 {
584 msptr = ptr->data;
585 target_p = msptr->client_p;
586
587 if(IsIOError(target_p->from) || target_p->from == one)
588 continue;
589
590 if((msptr->flags & CHFL_CHANOP) == 0)
591 continue;
592
593 if(IsDeaf(target_p))
594 continue;
595
596 if(!MyClient(target_p))
597 {
598 /* if we've got a specific type, target must support
599 * CHW.. --fl
600 */
601 if(NotCapable(target_p->from, CAP_CHW))
602 continue;
603
604 if(target_p->from->serial != current_serial)
605 {
606 if (IsCapable(target_p->from, CAP_EOPMOD))
607 send_linebuf_remote(target_p, source_p, &rb_linebuf_new);
608 else
609 send_linebuf_remote(target_p, source_p, &rb_linebuf_old);
610 target_p->from->serial = current_serial;
611 }
612 }
613 else
614 _send_linebuf(target_p, &rb_linebuf_local);
615 }
616
617 rb_linebuf_donebuf(&rb_linebuf_local);
618 rb_linebuf_donebuf(&rb_linebuf_old);
619 rb_linebuf_donebuf(&rb_linebuf_new);
620 }
621
622 /* sendto_channel_local()
623 *
624 * inputs - flags to send to, channel to send to, va_args
625 * outputs - message to local channel members
626 * side effects -
627 */
628 void
629 sendto_channel_local(int type, struct Channel *chptr, const char *pattern, ...)
630 {
631 va_list args;
632 buf_head_t linebuf;
633 struct membership *msptr;
634 struct Client *target_p;
635 rb_dlink_node *ptr;
636 rb_dlink_node *next_ptr;
637
638 rb_linebuf_newbuf(&linebuf);
639
640 va_start(args, pattern);
641 rb_linebuf_putmsg(&linebuf, pattern, &args, NULL);
642 va_end(args);
643
644 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, chptr->locmembers.head)
645 {
646 msptr = ptr->data;
647 target_p = msptr->client_p;
648
649 if(IsIOError(target_p))
650 continue;
651
652 if(type && ((msptr->flags & type) == 0))
653 continue;
654
655 _send_linebuf(target_p, &linebuf);
656 }
657
658 rb_linebuf_donebuf(&linebuf);
659 }
660
661 /* sendto_channel_local_butone()
662 *
663 * inputs - flags to send to, channel to send to, va_args
664 * - user to ignore when sending
665 * outputs - message to local channel members
666 * side effects -
667 */
668 void
669 sendto_channel_local_butone(struct Client *one, int type, struct Channel *chptr, const char *pattern, ...)
670 {
671 va_list args;
672 buf_head_t linebuf;
673 struct membership *msptr;
674 struct Client *target_p;
675 rb_dlink_node *ptr;
676 rb_dlink_node *next_ptr;
677
678 rb_linebuf_newbuf(&linebuf);
679
680 va_start(args, pattern);
681 rb_linebuf_putmsg(&linebuf, pattern, &args, NULL);
682 va_end(args);
683
684 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, chptr->locmembers.head)
685 {
686 msptr = ptr->data;
687 target_p = msptr->client_p;
688
689 if(target_p == one)
690 continue;
691
692 if(IsIOError(target_p))
693 continue;
694
695 if(type && ((msptr->flags & type) == 0))
696 continue;
697
698 _send_linebuf(target_p, &linebuf);
699 }
700
701 rb_linebuf_donebuf(&linebuf);
702 }
703
704 /*
705 * sendto_common_channels_local()
706 *
707 * inputs - pointer to client
708 * - pattern to send
709 * output - NONE
710 * side effects - Sends a message to all people on local server who are
711 * in same channel with user.
712 * used by m_nick.c and exit_one_client.
713 */
714 void
715 sendto_common_channels_local(struct Client *user, const char *pattern, ...)
716 {
717 va_list args;
718 rb_dlink_node *ptr;
719 rb_dlink_node *next_ptr;
720 rb_dlink_node *uptr;
721 rb_dlink_node *next_uptr;
722 struct Channel *chptr;
723 struct Client *target_p;
724 struct membership *msptr;
725 struct membership *mscptr;
726 buf_head_t linebuf;
727
728 rb_linebuf_newbuf(&linebuf);
729 va_start(args, pattern);
730 rb_linebuf_putmsg(&linebuf, pattern, &args, NULL);
731 va_end(args);
732
733 ++current_serial;
734
735 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, user->user->channel.head)
736 {
737 mscptr = ptr->data;
738 chptr = mscptr->chptr;
739
740 RB_DLINK_FOREACH_SAFE(uptr, next_uptr, chptr->locmembers.head)
741 {
742 msptr = uptr->data;
743 target_p = msptr->client_p;
744
745 if(IsIOError(target_p) ||
746 target_p->serial == current_serial)
747 continue;
748
749 target_p->serial = current_serial;
750 send_linebuf(target_p, &linebuf);
751 }
752 }
753
754 /* this can happen when the user isnt in any channels, but we still
755 * need to send them the data, ie a nick change
756 */
757 if(MyConnect(user) && (user->serial != current_serial))
758 send_linebuf(user, &linebuf);
759
760 rb_linebuf_donebuf(&linebuf);
761 }
762
763 /*
764 * sendto_common_channels_local_with_capability()
765 *
766 * inputs - pointer to client
767 * - capability
768 * - pattern to send
769 * output - NONE
770 * side effects - Sends a message to all people on local server who are
771 * in same channel with user.
772 * used by m_nick.c and exit_one_client.
773 */
774 void
775 sendto_common_channels_local_with_capability(struct Client *user, int capability, const char *pattern, ...)
776 {
777 va_list args;
778 rb_dlink_node *ptr;
779 rb_dlink_node *next_ptr;
780 rb_dlink_node *uptr;
781 rb_dlink_node *next_uptr;
782 struct Channel *chptr;
783 struct Client *target_p;
784 struct membership *msptr;
785 struct membership *mscptr;
786 buf_head_t linebuf;
787
788 rb_linebuf_newbuf(&linebuf);
789 va_start(args, pattern);
790 rb_linebuf_putmsg(&linebuf, pattern, &args, NULL);
791 va_end(args);
792
793 ++current_serial;
794
795 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, user->user->channel.head)
796 {
797 mscptr = ptr->data;
798 chptr = mscptr->chptr;
799
800 RB_DLINK_FOREACH_SAFE(uptr, next_uptr, chptr->locmembers.head)
801 {
802 msptr = uptr->data;
803 target_p = msptr->client_p;
804
805 if(!IsCapable(target_p, capability))
806 continue;
807
808 if(IsIOError(target_p) ||
809 target_p->serial == current_serial)
810 continue;
811
812 target_p->serial = current_serial;
813 send_linebuf(target_p, &linebuf);
814 }
815 }
816
817 /* this can happen when the user isnt in any channels, but we still
818 * need to send them the data, ie a nick change
819 */
820 if(MyConnect(user) && (user->serial != current_serial) && IsCapable(user, capability))
821 send_linebuf(user, &linebuf);
822
823 rb_linebuf_donebuf(&linebuf);
824 }
825
826 /*
827 * sendto_common_channels_local_butone()
828 *
829 * inputs - pointer to client
830 * - pattern to send
831 * output - NONE
832 * side effects - Sends a message to all people on local server who are
833 * in same channel with user, except for user itself.
834 */
835 void
836 sendto_common_channels_local_butone(struct Client *user, const char *pattern, ...)
837 {
838 va_list args;
839 rb_dlink_node *ptr;
840 rb_dlink_node *next_ptr;
841 rb_dlink_node *uptr;
842 rb_dlink_node *next_uptr;
843 struct Channel *chptr;
844 struct Client *target_p;
845 struct membership *msptr;
846 struct membership *mscptr;
847 buf_head_t linebuf;
848
849 rb_linebuf_newbuf(&linebuf);
850 va_start(args, pattern);
851 rb_linebuf_putmsg(&linebuf, pattern, &args, NULL);
852 va_end(args);
853
854 ++current_serial;
855 /* Skip them -- jilles */
856 user->serial = current_serial;
857
858 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, user->user->channel.head)
859 {
860 mscptr = ptr->data;
861 chptr = mscptr->chptr;
862
863 RB_DLINK_FOREACH_SAFE(uptr, next_uptr, chptr->locmembers.head)
864 {
865 msptr = uptr->data;
866 target_p = msptr->client_p;
867
868 if(IsIOError(target_p) ||
869 target_p->serial == current_serial)
870 continue;
871
872 target_p->serial = current_serial;
873 send_linebuf(target_p, &linebuf);
874 }
875 }
876
877 rb_linebuf_donebuf(&linebuf);
878 }
879
880 /*
881 * sendto_common_channels_local_with_capability_butone()
882 *
883 * inputs - pointer to client
884 * - capability
885 * - pattern to send
886 * output - NONE
887 * side effects - Sends a message to all people on local server who are
888 * in same channel with user, except the user themselves.
889 * used by m_nick.c and exit_one_client.
890 */
891 void
892 sendto_common_channels_local_with_capability_butone(struct Client *user, int capability, const char *pattern, ...)
893 {
894 va_list args;
895 rb_dlink_node *ptr;
896 rb_dlink_node *next_ptr;
897 rb_dlink_node *uptr;
898 rb_dlink_node *next_uptr;
899 struct Channel *chptr;
900 struct Client *target_p;
901 struct membership *msptr;
902 struct membership *mscptr;
903 buf_head_t linebuf;
904
905 rb_linebuf_newbuf(&linebuf);
906 va_start(args, pattern);
907 rb_linebuf_putmsg(&linebuf, pattern, &args, NULL);
908 va_end(args);
909
910 ++current_serial;
911 /* Skip them -- jilles */
912 user->serial = current_serial;
913
914 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, user->user->channel.head)
915 {
916 mscptr = ptr->data;
917 chptr = mscptr->chptr;
918
919 RB_DLINK_FOREACH_SAFE(uptr, next_uptr, chptr->locmembers.head)
920 {
921 msptr = uptr->data;
922 target_p = msptr->client_p;
923
924 if(!IsCapable(target_p, capability))
925 continue;
926
927 if(IsIOError(target_p) ||
928 target_p->serial == current_serial)
929 continue;
930
931 target_p->serial = current_serial;
932 send_linebuf(target_p, &linebuf);
933 }
934 }
935
936 /* this can happen when the user isnt in any channels, but we still
937 * need to send them the data, ie a nick change
938 */
939 if(MyConnect(user) && (user->serial != current_serial) && IsCapable(user, capability))
940 send_linebuf(user, &linebuf);
941
942 rb_linebuf_donebuf(&linebuf);
943 }
944
945
946 /* sendto_match_butone()
947 *
948 * inputs - server not to send to, source, mask, type of mask, va_args
949 * output -
950 * side effects - message is sent to matching clients
951 */
952 void
953 sendto_match_butone(struct Client *one, struct Client *source_p,
954 const char *mask, int what, const char *pattern, ...)
955 {
956 static char buf[BUFSIZE];
957 va_list args;
958 struct Client *target_p;
959 rb_dlink_node *ptr;
960 rb_dlink_node *next_ptr;
961 buf_head_t rb_linebuf_local;
962 buf_head_t rb_linebuf_id;
963
964 rb_linebuf_newbuf(&rb_linebuf_local);
965 rb_linebuf_newbuf(&rb_linebuf_id);
966
967 va_start(args, pattern);
968 rb_vsnprintf(buf, sizeof(buf), pattern, args);
969 va_end(args);
970
971 if(IsServer(source_p))
972 rb_linebuf_putmsg(&rb_linebuf_local, NULL, NULL,
973 ":%s %s", source_p->name, buf);
974 else
975 rb_linebuf_putmsg(&rb_linebuf_local, NULL, NULL,
976 ":%s!%s@%s %s",
977 source_p->name, source_p->username,
978 source_p->host, buf);
979
980 rb_linebuf_putmsg(&rb_linebuf_id, NULL, NULL, ":%s %s", use_id(source_p), buf);
981
982 if(what == MATCH_HOST)
983 {
984 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, lclient_list.head)
985 {
986 target_p = ptr->data;
987
988 if(match(mask, target_p->host))
989 _send_linebuf(target_p, &rb_linebuf_local);
990 }
991 }
992 /* what = MATCH_SERVER, if it doesnt match us, just send remote */
993 else if(match(mask, me.name))
994 {
995 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, lclient_list.head)
996 {
997 target_p = ptr->data;
998 _send_linebuf(target_p, &rb_linebuf_local);
999 }
1000 }
1001
1002 RB_DLINK_FOREACH(ptr, serv_list.head)
1003 {
1004 target_p = ptr->data;
1005
1006 if(target_p == one)
1007 continue;
1008
1009 send_linebuf_remote(target_p, source_p, &rb_linebuf_id);
1010 }
1011
1012 rb_linebuf_donebuf(&rb_linebuf_local);
1013 rb_linebuf_donebuf(&rb_linebuf_id);
1014 }
1015
1016 /* sendto_match_servs()
1017 *
1018 * inputs - source, mask to send to, caps needed, va_args
1019 * outputs -
1020 * side effects - message is sent to matching servers with caps.
1021 */
1022 void
1023 sendto_match_servs(struct Client *source_p, const char *mask, int cap,
1024 int nocap, const char *pattern, ...)
1025 {
1026 static char buf[BUFSIZE];
1027 va_list args;
1028 rb_dlink_node *ptr;
1029 struct Client *target_p;
1030 buf_head_t rb_linebuf_id;
1031
1032 if(EmptyString(mask))
1033 return;
1034
1035 rb_linebuf_newbuf(&rb_linebuf_id);
1036
1037 va_start(args, pattern);
1038 rb_vsnprintf(buf, sizeof(buf), pattern, args);
1039 va_end(args);
1040
1041 rb_linebuf_putmsg(&rb_linebuf_id, NULL, NULL,
1042 ":%s %s", use_id(source_p), buf);
1043
1044 current_serial++;
1045
1046 RB_DLINK_FOREACH(ptr, global_serv_list.head)
1047 {
1048 target_p = ptr->data;
1049
1050 /* dont send to ourselves, or back to where it came from.. */
1051 if(IsMe(target_p) || target_p->from == source_p->from)
1052 continue;
1053
1054 if(target_p->from->serial == current_serial)
1055 continue;
1056
1057 if(match(mask, target_p->name))
1058 {
1059 /* if we set the serial here, then we'll never do
1060 * a match() again if !IsCapable()
1061 */
1062 target_p->from->serial = current_serial;
1063
1064 if(cap && !IsCapable(target_p->from, cap))
1065 continue;
1066
1067 if(nocap && !NotCapable(target_p->from, nocap))
1068 continue;
1069
1070 _send_linebuf(target_p->from, &rb_linebuf_id);
1071 }
1072 }
1073
1074 rb_linebuf_donebuf(&rb_linebuf_id);
1075 }
1076
1077 /* sendto_monitor()
1078 *
1079 * inputs - monitor nick to send to, format, va_args
1080 * outputs - message to local users monitoring the given nick
1081 * side effects -
1082 */
1083 void
1084 sendto_monitor(struct monitor *monptr, const char *pattern, ...)
1085 {
1086 va_list args;
1087 buf_head_t linebuf;
1088 struct Client *target_p;
1089 rb_dlink_node *ptr;
1090 rb_dlink_node *next_ptr;
1091
1092 rb_linebuf_newbuf(&linebuf);
1093
1094 va_start(args, pattern);
1095 rb_linebuf_putmsg(&linebuf, pattern, &args, NULL);
1096 va_end(args);
1097
1098 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, monptr->users.head)
1099 {
1100 target_p = ptr->data;
1101
1102 if(IsIOError(target_p))
1103 continue;
1104
1105 _send_linebuf(target_p, &linebuf);
1106 }
1107
1108 rb_linebuf_donebuf(&linebuf);
1109 }
1110
1111 /* sendto_anywhere()
1112 *
1113 * inputs - target, source, va_args
1114 * outputs -
1115 * side effects - client is sent message with correct prefix.
1116 */
1117 void
1118 sendto_anywhere(struct Client *target_p, struct Client *source_p,
1119 const char *command, const char *pattern, ...)
1120 {
1121 va_list args;
1122 buf_head_t linebuf;
1123
1124 rb_linebuf_newbuf(&linebuf);
1125
1126 va_start(args, pattern);
1127
1128 if(MyClient(target_p))
1129 {
1130 if(IsServer(source_p))
1131 rb_linebuf_putmsg(&linebuf, pattern, &args, ":%s %s %s ",
1132 source_p->name, command,
1133 target_p->name);
1134 else
1135 rb_linebuf_putmsg(&linebuf, pattern, &args,
1136 ":%s!%s@%s %s %s ",
1137 source_p->name, source_p->username,
1138 source_p->host, command,
1139 target_p->name);
1140 }
1141 else
1142 rb_linebuf_putmsg(&linebuf, pattern, &args, ":%s %s %s ",
1143 get_id(source_p, target_p), command,
1144 get_id(target_p, target_p));
1145 va_end(args);
1146
1147 if(MyClient(target_p))
1148 _send_linebuf(target_p, &linebuf);
1149 else
1150 send_linebuf_remote(target_p, source_p, &linebuf);
1151
1152 rb_linebuf_donebuf(&linebuf);
1153 }
1154
1155 /* sendto_realops_snomask()
1156 *
1157 * inputs - snomask needed, level (opers/admin), va_args
1158 * output -
1159 * side effects - message is sent to opers with matching snomasks
1160 */
1161 void
1162 sendto_realops_snomask(int flags, int level, const char *pattern, ...)
1163 {
1164 static char buf[BUFSIZE];
1165 char *snobuf;
1166 struct Client *client_p;
1167 rb_dlink_node *ptr;
1168 rb_dlink_node *next_ptr;
1169 va_list args;
1170 buf_head_t linebuf;
1171
1172 rb_linebuf_newbuf(&linebuf);
1173
1174 /* Be very sure not to do things like "Trying to send to myself"
1175 * L_NETWIDE, otherwise infinite recursion may result! -- jilles */
1176 if (level & L_NETWIDE && ConfigFileEntry.global_snotices)
1177 {
1178 /* rather a lot of copying around, oh well -- jilles */
1179 va_start(args, pattern);
1180 rb_vsnprintf(buf, sizeof(buf), pattern, args);
1181 va_end(args);
1182 rb_linebuf_putmsg(&linebuf, pattern, NULL,
1183 ":%s NOTICE * :*** Notice -- %s", me.name, buf);
1184 snobuf = construct_snobuf(flags);
1185 if (snobuf[1] != '\0')
1186 sendto_server(NULL, NULL, CAP_ENCAP|CAP_TS6, NOCAPS,
1187 ":%s ENCAP * SNOTE %c :%s",
1188 me.id, snobuf[1], buf);
1189 }
1190 else if (remote_rehash_oper_p != NULL)
1191 {
1192 /* rather a lot of copying around, oh well -- jilles */
1193 va_start(args, pattern);
1194 rb_vsnprintf(buf, sizeof(buf), pattern, args);
1195 va_end(args);
1196 rb_linebuf_putmsg(&linebuf, pattern, NULL,
1197 ":%s NOTICE * :*** Notice -- %s", me.name, buf);
1198 sendto_one_notice(remote_rehash_oper_p, ":*** Notice -- %s", buf);
1199 }
1200 else
1201 {
1202 va_start(args, pattern);
1203 rb_linebuf_putmsg(&linebuf, pattern, &args,
1204 ":%s NOTICE * :*** Notice -- ", me.name);
1205 va_end(args);
1206 }
1207 level &= ~L_NETWIDE;
1208
1209 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, local_oper_list.head)
1210 {
1211 client_p = ptr->data;
1212
1213 /* If we're sending it to opers and theyre an admin, skip.
1214 * If we're sending it to admins, and theyre not, skip.
1215 */
1216 if(((level == L_ADMIN) && !IsOperAdmin(client_p)) ||
1217 ((level == L_OPER) && IsOperAdmin(client_p)))
1218 continue;
1219
1220 if(client_p->snomask & flags)
1221 _send_linebuf(client_p, &linebuf);
1222 }
1223
1224 rb_linebuf_donebuf(&linebuf);
1225 }
1226 /* sendto_realops_snomask_from()
1227 *
1228 * inputs - snomask needed, level (opers/admin), source server, va_args
1229 * output -
1230 * side effects - message is sent to opers with matching snomask
1231 */
1232 void
1233 sendto_realops_snomask_from(int flags, int level, struct Client *source_p,
1234 const char *pattern, ...)
1235 {
1236 struct Client *client_p;
1237 rb_dlink_node *ptr;
1238 rb_dlink_node *next_ptr;
1239 va_list args;
1240 buf_head_t linebuf;
1241
1242 rb_linebuf_newbuf(&linebuf);
1243
1244 va_start(args, pattern);
1245 rb_linebuf_putmsg(&linebuf, pattern, &args,
1246 ":%s NOTICE * :*** Notice -- ", source_p->name);
1247 va_end(args);
1248
1249 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, local_oper_list.head)
1250 {
1251 client_p = ptr->data;
1252
1253 /* If we're sending it to opers and theyre an admin, skip.
1254 * If we're sending it to admins, and theyre not, skip.
1255 */
1256 if(((level == L_ADMIN) && !IsOperAdmin(client_p)) ||
1257 ((level == L_OPER) && IsOperAdmin(client_p)))
1258 continue;
1259
1260 if(client_p->snomask & flags)
1261 _send_linebuf(client_p, &linebuf);
1262 }
1263
1264 rb_linebuf_donebuf(&linebuf);
1265 }
1266
1267 /*
1268 * sendto_wallops_flags
1269 *
1270 * inputs - flag types of messages to show to real opers
1271 * - client sending request
1272 * - var args input message
1273 * output - NONE
1274 * side effects - Send a wallops to local opers
1275 */
1276 void
1277 sendto_wallops_flags(int flags, struct Client *source_p, const char *pattern, ...)
1278 {
1279 struct Client *client_p;
1280 rb_dlink_node *ptr;
1281 rb_dlink_node *next_ptr;
1282 va_list args;
1283 buf_head_t linebuf;
1284
1285 rb_linebuf_newbuf(&linebuf);
1286
1287 va_start(args, pattern);
1288
1289 if(IsPerson(source_p))
1290 rb_linebuf_putmsg(&linebuf, pattern, &args,
1291 ":%s!%s@%s WALLOPS :", source_p->name,
1292 source_p->username, source_p->host);
1293 else
1294 rb_linebuf_putmsg(&linebuf, pattern, &args, ":%s WALLOPS :", source_p->name);
1295
1296 va_end(args);
1297
1298 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, IsPerson(source_p) && flags == UMODE_WALLOP ? lclient_list.head : local_oper_list.head)
1299 {
1300 client_p = ptr->data;
1301
1302 if(client_p->umodes & flags)
1303 _send_linebuf(client_p, &linebuf);
1304 }
1305
1306 rb_linebuf_donebuf(&linebuf);
1307 }
1308
1309 /* kill_client()
1310 *
1311 * input - client to send kill to, client to kill, va_args
1312 * output -
1313 * side effects - we issue a kill for the client
1314 */
1315 void
1316 kill_client(struct Client *target_p, struct Client *diedie, const char *pattern, ...)
1317 {
1318 va_list args;
1319 buf_head_t linebuf;
1320
1321 rb_linebuf_newbuf(&linebuf);
1322
1323 va_start(args, pattern);
1324 rb_linebuf_putmsg(&linebuf, pattern, &args, ":%s KILL %s :",
1325 get_id(&me, target_p), get_id(diedie, target_p));
1326 va_end(args);
1327
1328 send_linebuf(target_p, &linebuf);
1329 rb_linebuf_donebuf(&linebuf);
1330 }
1331
1332
1333 /*
1334 * kill_client_serv_butone
1335 *
1336 * inputs - pointer to client to not send to
1337 * - pointer to client to kill
1338 * output - NONE
1339 * side effects - Send a KILL for the given client
1340 * message to all connected servers
1341 * except the client 'one'. Also deal with
1342 * client being unknown to leaf, as in lazylink...
1343 */
1344 void
1345 kill_client_serv_butone(struct Client *one, struct Client *target_p, const char *pattern, ...)
1346 {
1347 static char buf[BUFSIZE];
1348 va_list args;
1349 struct Client *client_p;
1350 rb_dlink_node *ptr;
1351 rb_dlink_node *next_ptr;
1352 buf_head_t rb_linebuf_id;
1353
1354 rb_linebuf_newbuf(&rb_linebuf_id);
1355
1356 va_start(args, pattern);
1357 rb_vsnprintf(buf, sizeof(buf), pattern, args);
1358 va_end(args);
1359
1360 rb_linebuf_putmsg(&rb_linebuf_id, NULL, NULL, ":%s KILL %s :%s",
1361 use_id(&me), use_id(target_p), buf);
1362
1363 RB_DLINK_FOREACH_SAFE(ptr, next_ptr, serv_list.head)
1364 {
1365 client_p = ptr->data;
1366
1367 /* ok, if the client we're supposed to not send to has an
1368 * ID, then we still want to issue the kill there..
1369 */
1370 if(one != NULL && (client_p == one->from) &&
1371 (!has_id(client_p) || !has_id(target_p)))
1372 continue;
1373
1374 _send_linebuf(client_p, &rb_linebuf_id);
1375 }
1376
1377 rb_linebuf_donebuf(&rb_linebuf_id);
1378 }