/************************************************************************
* IRC - Internet Relay Chat, modules/m_error.c
*
* Copyright (C) 2000-2003 TR-IRCD Development
*
* Copyright (C) 1990 Jarkko Oikarinen and
* University of Oulu, Co Center
*
* 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 2, 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.
*/
/*
* $Id: m_error.c,v 1.3 2003/06/14 13:55:51 tr-ircd Exp $
*/
#include "struct.h"
#include "common.h"
#include "sys.h"
#include "numeric.h"
#include "msg.h"
#include "channel.h"
#include "h.h"
static struct Message _msgtab[] = {
{MSG_ERROR, 0, MAXPARA, M_SLOW, 0L,
m_ignore, m_ignore, m_ignore, m_error, m_error}
};
static char *token = TOK1_ERROR;
static int log_error = -1;
#ifndef STATIC_MODULES
char *_version = "$Revision: 1.3 $";
void _modinit(void)
{
mod_add_cmd(_msgtab);
tok1_msgtab[(u_char) *token].msg = _msgtab;
log_error = logevent_register("ERROR", LOG_ON_LOG, LOG_ERRORLOG, LOG_ERROR,
"Received ERROR message from %s: %s");
}
void _moddeinit(void)
{
mod_del_cmd(_msgtab);
tok1_msgtab[(u_char) *token].msg = NULL;
logevent_unregister(log_error);
}
#else
void m_error_init(void)
{
mod_add_cmd(_msgtab);
tok1_msgtab[(u_char) *token].msg = _msgtab;
log_error = logevent_register("ERROR", LOG_ON_LOG, LOG_ERRORLOG, LOG_ERROR,
"Received ERROR message from %s: %s");
}
#endif
/*
* * Note: At least at protocol level ERROR has only one parameter,
* although this is called internally from other functions --msa
*
* parv[0] = sender prefix
* parv[*] = parameters
*/
int m_error(aClient *cptr, aClient *sptr, int parc, char *parv[])
{
char *para;
para = (parc > 1 && *parv[1] != '\0') ? parv[1] : "<>";
logevent_call(log_error, sptr->name, para);
if (cptr == sptr)
sendto_operators(0, "Error", "from %C: %s", cptr, para);
else
sendto_operators(0, "Error", "from %C via %C: %s", sptr, cptr, para);
return 0;
}
syntax highlighted by Code2HTML, v. 0.9.1