⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 m_connect.c

📁 Unreal irc 服务器源代码
💻 C
字号:
/* *   IRC - Internet Relay Chat, src/modules/out.c *   (C) 2004 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 "config.h"#include "struct.h"#include "common.h"#include "sys.h"#include "numeric.h"#include "msg.h"#include "proto.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"#ifdef STRIPBADWORDS#include "badwords.h"#endif#ifdef _WIN32#include "version.h"#endifDLLFUNC int m_connect(aClient *cptr, aClient *sptr, int parc, char *parv[]);#define MSG_CONNECT 	"CONNECT"	#define TOK_CONNECT 	"7"	ModuleHeader MOD_HEADER(m_connect)  = {	"m_connect",	"$Id: m_connect.c,v 1.1.6.8 2006/12/22 21:10:33 syzop Exp $",	"command /connect", 	"3.2-b8-1",	NULL     };DLLFUNC int MOD_INIT(m_connect)(ModuleInfo *modinfo){	add_Command(MSG_CONNECT, TOK_CONNECT, m_connect, MAXPARA);	MARK_AS_OFFICIAL_MODULE(modinfo);	return MOD_SUCCESS;}DLLFUNC int MOD_LOAD(m_connect)(int module_load){	return MOD_SUCCESS;}DLLFUNC int MOD_UNLOAD(m_connect)(int module_unload){	if (del_Command(MSG_CONNECT, TOK_CONNECT, m_connect) < 0)	{		sendto_realops("Failed to delete commands when unloading %s",			MOD_HEADER(m_connect).name);	}	return MOD_SUCCESS;}/*********************************************************************** * m_connect() - Added by Jto 11 Feb 1989 ***********************************************************************//*   ** m_connect   **  parv[0] = sender prefix   **  parv[1] = servername   **  parv[2] = port number   **  parv[3] = remote server */DLLFUNC CMD_FUNC(m_connect){	int  port, tmpport, retval;	ConfigItem_link	*aconf;	ConfigItem_deny_link *deny;	aClient *acptr;	if (!IsPrivileged(sptr))	{		sendto_one(sptr, err_str(ERR_NOPRIVILEGES), me.name, parv[0]);		return -1;	}	if (MyClient(sptr) && !OPCanGRoute(sptr) && parc > 3)	{			/* Only allow LocOps to make */		/* local CONNECTS --SRB      */		sendto_one(sptr, err_str(ERR_NOPRIVILEGES), me.name, parv[0]);		return 0;	}	if (MyClient(sptr) && !OPCanLRoute(sptr) && parc <= 3)	{		sendto_one(sptr, err_str(ERR_NOPRIVILEGES), me.name, parv[0]);		return 0;	}	if (hunt_server_token(cptr, sptr, MSG_CONNECT, TOK_CONNECT, "%s %s :%s",	    3, parc, parv) != HUNTED_ISME)		return 0;	if (parc < 2 || *parv[1] == '\0')	{		sendto_one(sptr, err_str(ERR_NEEDMOREPARAMS),		    me.name, parv[0], "CONNECT");		return -1;	}	if ((acptr = find_server_quick(parv[1])))	{		sendto_one(sptr, ":%s %s %s :*** Connect: Server %s %s %s.",		    me.name, IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0], parv[1], "already exists from",		    acptr->from->name);		return 0;	}	for (aconf = conf_link; aconf; aconf = (ConfigItem_link *) aconf->next)		if (!match(parv[1], aconf->servername))			break;	/* Checked first servernames, then try hostnames. */	if (!aconf)	{		sendto_one(sptr,		    ":%s %s %s :*** Connect: Server %s is not configured for linking", me.name,		    IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0], parv[1]);		return 0;	}	/*	   ** Get port number from user, if given. If not specified,	   ** use the default form configuration structure. If missing	   ** from there, then use the precompiled default.	 */	tmpport = port = aconf->port;	if (parc > 2 && !BadPtr(parv[2]))	{		if ((port = atoi(parv[2])) <= 0)		{			sendto_one(sptr,			    ":%s %s %s :*** Connect: Illegal port number", me.name,			    IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0]);			return 0;		}	}	else if (port <= 0 && (port = PORTNUM) <= 0)	{		sendto_one(sptr, ":%s %s %s :*** Connect: missing port number",		    me.name, IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0]);		return 0;	}/* Evaluate deny link */	for (deny = conf_deny_link; deny; deny = (ConfigItem_deny_link *) deny->next) {		if (deny->flag.type == CRULE_ALL && !match(deny->mask, aconf->servername)			&& crule_eval(deny->rule)) {			sendto_one(sptr,				":%s %s %s :Connect: Disallowed by connection rule",				me.name, IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0]);			return 0;		}	}	/*	   ** Notify all operators about remote connect requests	 */	if (!IsAnOper(cptr))	{		sendto_serv_butone(&me,		    ":%s GLOBOPS :Remote CONNECT %s %s from %s",		    me.name, parv[1], parv[2] ? parv[2] : "",		    get_client_name(sptr, FALSE));	}	/* Interesting */	aconf->port = port;	switch (retval = connect_server(aconf, sptr, NULL))	{	  case 0:		  sendto_one(sptr,		      ":%s %s %s :*** Connecting to %s[%s].",		      me.name, IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0], aconf->servername, aconf->hostname);		  break;	  case -1:		  sendto_one(sptr, ":%s %s %s :*** Couldn't connect to %s.",		      me.name, IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0], aconf->servername);		  break;	  case -2:		  sendto_one(sptr, ":%s %s %s :*** Resolving hostname '%s'...",		      me.name, IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0], aconf->hostname);		  break;	  default:		  sendto_one(sptr,		      ":%s %s %s :*** Connection to %s failed: %s",		      me.name, IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0], aconf->servername, STRERROR(retval));	}	aconf->port = tmpport;	return 0;}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -