mirror of
https://github.com/unrealircd/unrealircd.git
synced 2026-06-29 02:36:37 +02:00
7f903b422c
of each module to 5.0 (or the ones that previously were 4.2, anyway).
120 lines
2.7 KiB
C
120 lines
2.7 KiB
C
/*
|
|
* IRC - Internet Relay Chat, src/modules/batch.c
|
|
* (C) 2019 Syzop & The UnrealIRCd Team
|
|
*
|
|
* See file AUTHORS in IRC package for additional names of
|
|
* the programmers.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 1, or (at your option)
|
|
* any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
*/
|
|
|
|
#include "unrealircd.h"
|
|
|
|
ModuleHeader MOD_HEADER(batch)
|
|
= {
|
|
"batch",
|
|
"5.0",
|
|
"Batch CAP",
|
|
"3.2-b8-1",
|
|
NULL
|
|
};
|
|
|
|
/* Forward declarations */
|
|
CMD_FUNC(m_batch);
|
|
|
|
/* Variables */
|
|
long CAP_BATCH = 0L;
|
|
|
|
int batch_mtag_is_ok(aClient *acptr, char *name, char *value);
|
|
|
|
MOD_INIT(batch)
|
|
{
|
|
ClientCapabilityInfo cap;
|
|
ClientCapability *c;
|
|
MessageTagHandlerInfo mtag;
|
|
|
|
MARK_AS_OFFICIAL_MODULE(modinfo);
|
|
|
|
memset(&cap, 0, sizeof(cap));
|
|
cap.name = "batch";
|
|
c = ClientCapabilityAdd(modinfo->handle, &cap, &CAP_BATCH);
|
|
|
|
memset(&mtag, 0, sizeof(mtag));
|
|
mtag.name = "batch";
|
|
mtag.is_ok = batch_mtag_is_ok;
|
|
mtag.clicap_handler = c;
|
|
MessageTagHandlerAdd(modinfo->handle, &mtag);
|
|
|
|
CommandAdd(modinfo->handle, "BATCH", m_batch, MAXPARA, M_USER|M_SERVER);
|
|
return MOD_SUCCESS;
|
|
}
|
|
|
|
MOD_LOAD(batch)
|
|
{
|
|
return MOD_SUCCESS;
|
|
}
|
|
|
|
MOD_UNLOAD(batch)
|
|
{
|
|
return MOD_SUCCESS;
|
|
}
|
|
|
|
/* BATCH:
|
|
* As an intra-server command:
|
|
* :sender BATCH target +xxxxx [etc etc etc]
|
|
*/
|
|
CMD_FUNC(m_batch)
|
|
{
|
|
aClient *acptr;
|
|
char buf[512];
|
|
|
|
if (!IsServer(cptr) || (parc < 3))
|
|
return 0;
|
|
|
|
acptr = find_client(parv[1], NULL);
|
|
if (!acptr)
|
|
return 0; /* race condition */
|
|
|
|
/* If the recipient does not support message tags or
|
|
* does not support batch, then don't do anything.
|
|
*/
|
|
if (MyConnect(acptr) && !IsServer(acptr) &&
|
|
!(HasCapability(acptr, "message-tags") &&
|
|
HasCapability(acptr, "batch")))
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
/* Relay the batch message to the client (or server) */
|
|
parv[1] = "BATCH";
|
|
concat_params(buf, sizeof(buf), parc, parv);
|
|
sendto_prefix_one(acptr, sptr, recv_mtags, "%s", buf);
|
|
|
|
return 0;
|
|
}
|
|
|
|
/** This function verifies if the client sending
|
|
* 'batch' is permitted to do so and uses a permitted
|
|
* syntax.
|
|
* We simply allow batch ONLY from servers and with any syntax.
|
|
*/
|
|
int batch_mtag_is_ok(aClient *acptr, char *name, char *value)
|
|
{
|
|
if (IsServer(acptr))
|
|
return 1;
|
|
|
|
return 0;
|
|
}
|