📄 m_sethost.c
字号:
/* * IRC - Internet Relay Chat, src/modules/m_sethost.c * (C) 1999-2001 Carsten Munk (Techie/Stskeeps) <stskeeps@tspre.org> * * 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 "macros.h"#include "config.h"#include "struct.h"#include "common.h"#include "sys.h"#include "numeric.h"#include "msg.h"#include "channel.h"#include <time.h>#include <sys/stat.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#ifdef _WIN32#include <io.h>#endif#include <fcntl.h>#include "h.h"#include "proto.h"#ifdef STRIPBADWORDS#include "badwords.h"#endif#ifdef _WIN32#include "version.h"#endifDLLFUNC int m_sethost(aClient *cptr, aClient *sptr, int parc, char *parv[]);/* Place includes here */#define MSG_SETHOST "SETHOST" /* sethost */#define TOK_SETHOST "AA" /* 127 4ever !;) */ModuleHeader MOD_HEADER(m_sethost) = { "sethost", /* Name of module */ "$Id: m_sethost.c,v 1.1.6.10 2006/12/22 21:10:33 syzop Exp $", /* Version */ "command /sethost", /* Short description of module */ "3.2-b8-1", NULL };DLLFUNC int MOD_INIT(m_sethost)(ModuleInfo *modinfo){ /* * We call our add_Command crap here */ add_Command(MSG_SETHOST, TOK_SETHOST, m_sethost, MAXPARA); MARK_AS_OFFICIAL_MODULE(modinfo); return MOD_SUCCESS;}DLLFUNC int MOD_LOAD(m_sethost)(int module_load){ return MOD_SUCCESS;}DLLFUNC int MOD_UNLOAD(m_sethost)(int module_unload){ if (del_Command(MSG_SETHOST, TOK_SETHOST, m_sethost) < 0) { sendto_realops("Failed to delete commands when unloading %s", MOD_HEADER(m_sethost).name); } return MOD_SUCCESS;}/* m_sethost() added by Stskeeps (30/04/1999) (modified at 15/05/1999) by Stskeeps | Potvin :prefix SETHOST newhost parv[0] - sender parv[1] - newhost*/DLLFUNC int m_sethost(aClient *cptr, aClient *sptr, int parc, char *parv[]){ char *vhost;#ifndef DISABLE_USERMOD int permit = 0; /* 0 = opers(glob/locop) 1 = global oper 2 = not MY clients.. */#else int permit = 2;#endif if (!MyConnect(sptr)) goto have_permit1; switch (permit) { case 0: if (!IsAnOper(sptr)) { sendto_one(sptr, err_str(ERR_NOPRIVILEGES), me.name, parv[0]); return 0; } break; case 1: if (!IsOper(sptr)) { sendto_one(sptr, err_str(ERR_NOPRIVILEGES), me.name, parv[0]); return 0; } break; case 2: if (MyConnect(sptr)) { sendto_one(sptr, err_str(ERR_NOPRIVILEGES), me.name, parv[0]); return 0; } default: sendto_ops_butone(IsServer(cptr) ? cptr : NULL, sptr, ":%s WALLOPS :[SETHOST] Somebody fixing this corrupted server? !(0|1) !!!", me.name); break; } have_permit1: if (parc < 2) vhost = NULL; else vhost = parv[1]; /* bad bad bad boys .. ;p */ if (vhost == NULL) { if (MyConnect(sptr)) { sendto_one(sptr, ":%s NOTICE %s :*** Syntax: /SetHost <new host>", me.name, parv[0]); } return 0; } if (strlen(parv[1]) < 1) { if (MyConnect(sptr)) sendto_one(sptr, ":%s NOTICE %s :*** /SetHost Error: Atleast write SOMETHING that makes sense (':' string)", me.name, sptr->name); return 0; } /* too large huh? */ if (strlen(parv[1]) > (HOSTLEN)) { /* ignore us as well if we're not a child of 3k */ if (MyConnect(sptr)) sendto_one(sptr, ":%s NOTICE %s :*** /SetHost Error: Hostnames are limited to %i characters.", me.name, sptr->name, HOSTLEN); return 0; } if (!valid_host(vhost)) { sendto_one(sptr, ":%s NOTICE %s :*** /SetHost Error: A hostname may contain a-z, A-Z, 0-9, '-' & '.' - Please only use them", me.name, parv[0]); return 0; } if (vhost[0] == ':') { sendto_one(sptr, ":%s NOTICE %s :*** A hostname cannot start with ':'", me.name, sptr->name); return 0; } if (MyClient(sptr) && !strcmp(GetHost(sptr), vhost)) { sendto_one(sptr, ":%s NOTICE %s :*** /SetHost Error: requested host is same as current host.", me.name, parv[0]); return 0; } { DYN_LOCAL(char, did_parts, sptr->user->joined); switch (UHOST_ALLOWED) { case UHALLOW_NEVER: if (MyClient(sptr)) { sendto_one(sptr, ":%s NOTICE %s :*** /SetHost is disabled", me.name, sptr->name); DYN_FREE(did_parts); return 0; } break; case UHALLOW_ALWAYS: break; case UHALLOW_NOCHANS: if (MyClient(sptr) && sptr->user->joined) { sendto_one(sptr, ":%s NOTICE %s :*** /SetHost can not be used while you are on a channel", me.name, sptr->name); DYN_FREE(did_parts); return 0; } break; case UHALLOW_REJOIN: rejoin_doparts(sptr, did_parts); /* join sent later when the host has been changed */ break; } /* hide it */ sptr->umodes |= UMODE_HIDE; sptr->umodes |= UMODE_SETHOST; /* get it in */ if (sptr->user->virthost) { MyFree(sptr->user->virthost); sptr->user->virthost = NULL; } sptr->user->virthost = strdup(vhost); /* spread it out */ sendto_serv_butone_token(cptr, sptr->name, MSG_SETHOST, TOK_SETHOST, "%s", parv[1]); if (UHOST_ALLOWED == UHALLOW_REJOIN) rejoin_dojoinandmode(sptr, did_parts); DYN_FREE(did_parts); } if (MyConnect(sptr)) { sendto_one(sptr, ":%s MODE %s :+xt", sptr->name, sptr->name); sendto_one(sptr, ":%s NOTICE %s :Your nick!user@host-mask is now (%s!%s@%s) - To disable it type /mode %s -x", me.name, parv[0], parv[0], sptr->user->username, vhost, parv[0]); } return 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -