2 * ircd-ratbox: A slightly useful ircd.
3 * m_wallops.c: Sends a message to all operators.
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: m_wallops.c 1377 2006-05-20 13:48:37Z jilles $
30 #include "irc_string.h"
35 #include "s_newconf.h"
41 static int mo_operwall(struct Client
*, struct Client
*, int, const char **);
42 static int ms_operwall(struct Client
*, struct Client
*, int, const char **);
43 static int ms_wallops(struct Client
*, struct Client
*, int, const char **);
45 struct Message wallops_msgtab
= {
46 "WALLOPS", 0, 0, 0, MFLG_SLOW
,
47 {mg_unreg
, mg_not_oper
, {ms_wallops
, 2}, {ms_wallops
, 2}, mg_ignore
, {ms_wallops
, 2}}
49 struct Message operwall_msgtab
= {
50 "OPERWALL", 0, 0, 0, MFLG_SLOW
,
51 {mg_unreg
, mg_not_oper
, {ms_operwall
, 2}, mg_ignore
, mg_ignore
, {mo_operwall
, 2}}
54 mapi_clist_av1 wallops_clist
[] = { &wallops_msgtab
, &operwall_msgtab
, NULL
};
55 DECLARE_MODULE_AV1(wallops
, NULL
, NULL
, wallops_clist
, NULL
, NULL
, "$Revision: 1377 $");
58 * mo_operwall (write to *all* opers currently online)
59 * parv[1] = message text
62 mo_operwall(struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
64 if(!IsOperOperwall(source_p
))
66 sendto_one(source_p
, form_str(ERR_NOPRIVS
),
67 me
.name
, source_p
->name
, "operwall");
71 sendto_wallops_flags(UMODE_OPERWALL
, source_p
, "OPERWALL - %s", parv
[1]);
72 sendto_server(client_p
, NULL
, CAP_TS6
, NOCAPS
, ":%s OPERWALL :%s",
73 use_id(source_p
), parv
[1]);
74 sendto_server(client_p
, NULL
, NOCAPS
, CAP_TS6
, ":%s OPERWALL :%s",
75 source_p
->name
, parv
[1]);
81 * ms_operwall - OPERWALL message handler
82 * (write to *all* local opers currently online)
83 * parv[0] = sender prefix
84 * parv[1] = message text
87 ms_operwall(struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
89 sendto_server(client_p
, NULL
, CAP_TS6
, NOCAPS
, ":%s OPERWALL :%s",
90 use_id(source_p
), parv
[1]);
91 sendto_server(client_p
, NULL
, NOCAPS
, CAP_TS6
, ":%s OPERWALL :%s",
92 source_p
->name
, parv
[1]);
93 sendto_wallops_flags(UMODE_OPERWALL
, source_p
, "OPERWALL - %s", parv
[1]);
99 * ms_wallops (write to *all* opers currently online)
100 * parv[1] = message text
103 ms_wallops(struct Client
*client_p
, struct Client
*source_p
, int parc
, const char *parv
[])
105 const char *prefix
= "";
107 if (IsPerson(source_p
))
109 if (!strncmp(parv
[1], "OPERWALL - ", 11) ||
110 !strncmp(parv
[1], "LOCOPS - ", 9) ||
111 !strncmp(parv
[1], "SLOCOPS - ", 10) ||
112 !strncmp(parv
[1], "ADMINWALL - ", 12))
113 prefix
= "WALLOPS - ";
116 sendto_wallops_flags(UMODE_WALLOP
, source_p
, "%s%s", prefix
, parv
[1]);
118 sendto_server(client_p
, NULL
, CAP_TS6
, NOCAPS
, ":%s WALLOPS :%s",
119 use_id(source_p
), parv
[1]);
120 sendto_server(client_p
, NULL
, NOCAPS
, CAP_TS6
, ":%s WALLOPS :%s",
121 source_p
->name
, parv
[1]);