/************************************************************************ * IRC - Internet Relay Chat, modules/m_accept.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 softwmare; 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. */ #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_ACCEPT, 0, 1, M_SLOW, 0L, m_unregistered, m_accept, m_accept, m_ignore, m_ignore} }; #ifndef STATIC_MODULES char *_version = "$Revision: 1.3 $"; void _modinit(void) { mod_add_cmd(_msgtab); } void _moddeinit(void) { mod_del_cmd(_msgtab); } #else void m_accept_init(void) { mod_add_cmd(_msgtab); } #endif int m_accept(aClient *cptr, aClient *sptr, int parc, char *parv[]) { dlink_node *lp, *next_lp; char *p, *s; char *cn; aClient *acptr; if (!MyClient(sptr)) return 0; if (parc < 2) { send_me_notice(sptr, ":No command specified for ACCEPT. Type /quote help accept for more information."); return 0; } for (p = NULL, s = strtoken(&p, parv[1], ", "); s; s = strtoken(&p, NULL, ", ")) { if (*s == '+') { cn = s + 1; if (*cn == '\0') continue; acptr = find_person(cn); if (!acptr) { send_me_numeric(sptr, ERR_NOSUCHNICK, cn); continue; } if (acptr == sptr) continue; accept_client(sptr, acptr); } else if (*s == '-') { cn = s + 1; if (*cn == '\0') continue; acptr = find_person(cn); if (!acptr) { send_me_numeric(sptr, ERR_NOSUCHNICK, cn); continue; } if (acptr == sptr) continue; deny_client(sptr, acptr); } else { if (irc_strncmp(s, "list", 4) == 0) { sendto_one(sptr, ":%C %N %s :The following users are on your accept list:", &me, RPL_ACCEPTINFO, sptr->name); for (lp = sptr->user->accepted.head; lp; lp = next_lp) { next_lp = lp->next; acptr = lp->data; if (!acptr || !IsPerson(acptr)) { deny_client(sptr, acptr); continue; } sendto_one(sptr, ":%C %N %s :%s (%s@%s)", &me, RPL_ACCEPTLIST, sptr->name, acptr->name, acptr->user->username, IsFake(acptr) ? acptr->user->fakehost : acptr->user->host); } send_me_numeric(sptr, RPL_ENDOFACCEPTLIST); } } } return 0; }