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

📄 m_mkpasswd.c

📁 Unreal irc 服务器源代码
💻 C
字号:
/* *   IRC - Internet Relay Chat, src/modules/m_mkpasswd.c *   (C) 2001 The UnrealIRCd Team * *   mkpasswd command * *   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 "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_mkpasswd(aClient *cptr, aClient *sptr, int parc, char *parv[]);#define MSG_MKPASSWD 	"MKPASSWD"	#define TOK_MKPASSWD 	"y"	ModuleHeader MOD_HEADER(m_mkpasswd)  = {	"m_mkpasswd",	"$Id: m_mkpasswd.c,v 1.1.6.10 2006/12/22 21:10:33 syzop Exp $",	"command /mkpasswd", 	"3.2-b8-1",	NULL     };DLLFUNC int MOD_INIT(m_mkpasswd)(ModuleInfo *modinfo){	add_Command(MSG_MKPASSWD, TOK_MKPASSWD, m_mkpasswd, MAXPARA);	MARK_AS_OFFICIAL_MODULE(modinfo);	return MOD_SUCCESS;}DLLFUNC int MOD_LOAD(m_mkpasswd)(int module_load){	return MOD_SUCCESS;}DLLFUNC int MOD_UNLOAD(m_mkpasswd)(int module_unload){	if (del_Command(MSG_MKPASSWD, TOK_MKPASSWD, m_mkpasswd) < 0)	{		sendto_realops("Failed to delete commands when unloading %s",				MOD_HEADER(m_mkpasswd).name);	}	return MOD_SUCCESS;}/*** m_mkpasswd**      parv[0] = sender prefix**      parv[1] = password to encrypt*/int  m_mkpasswd(aClient *cptr, aClient *sptr, int parc, char *parv[]){	short	type;	char	*result = NULL;	if (!MKPASSWD_FOR_EVERYONE && !IsAnOper(sptr))	{		sendto_one(sptr, err_str(ERR_NOPRIVILEGES), me.name, sptr->name);		return -1;	}	if (!IsAnOper(sptr))	{		/* Non-opers /mkpasswd usage: lag them up, and send a notice to eyes snomask.		 * This notice is always sent, even in case of bad usage/bad auth methods/etc.		 */		sptr->since += 7;		sendto_snomask(SNO_EYES, "*** /mkpasswd used by %s (%s@%s)",			sptr->name, sptr->user->username, GetHost(sptr));	}	if ((parc < 3) || BadPtr(parv[2]))	{		sendto_one(sptr, ":%s NOTICE %s :*** Syntax: /mkpasswd <authmethod> :parameter",			me.name, sptr->name);		return 0;	}	/* Don't want to take any risk ;p. -- Syzop */	if (strlen(parv[2]) > 64)	{		sendto_one(sptr, ":%s NOTICE %s :*** Your parameter (text-to-hash) is too long.",			me.name, sptr->name);		return 0;	}	if ((type = Auth_FindType(parv[1])) == -1)	{		sendto_one(sptr, 			":%s NOTICE %s :*** %s is not an enabled authentication method",				me.name, sptr->name, parv[1]);		return 0;	}#ifdef AUTHENABLE_UNIXCRYPT	if ((type == AUTHTYPE_UNIXCRYPT) && (strlen(parv[2]) > 8))	{		sendnotice(sptr, "WARNING: Password truncated to 8 characters due to 'crypt' algorithm. "		                 "You are suggested to use the 'md5' algorithm instead.");		parv[2][8] = '\0';	}#endif	if (!(result = Auth_Make(type, parv[2])))	{		sendto_one(sptr, 			":%s NOTICE %s :*** Authentication method %s failed",				me.name, sptr->name, parv[1]);		return 0;	}	sendto_one(sptr, ":%s %s %s :*** Authentication phrase (method=%s, para=%s) is: %s",		me.name, IsWebTV(sptr) ? "PRIVMSG" : "NOTICE", parv[0], parv[1], parv[2], result);	return 0;}

⌨️ 快捷键说明

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