亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? handle_bot.c

?? 打魔獸戰網的都知道他是什么
?? C
字號:
/* * Copyright (C) 1999,2000,2001  Ross Combs (rocombs@cs.nmsu.edu) * Copyright (C) 1999  Rob Crittenden (rcrit@greyoak.com) * * 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 * of the License, 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., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. */#include "common/setup_before.h"#ifdef HAVE_STDDEF_H# include <stddef.h>#else# ifndef NULL#  define NULL ((void *)0)# endif#endif#ifdef STDC_HEADERS# include <stdlib.h>#endif#ifdef HAVE_STRING_H# include <string.h>#else# ifdef HAVE_STRINGS_H#  include <strings.h># endif# ifdef HAVE_MEMORY_H#  include <memory.h># endif#endif#include "compat/strdup.h"#include <ctype.h>#include "common/packet.h"#include "common/bot_protocol.h"#include "common/tag.h"#include "message.h"#include "common/eventlog.h"#include "command.h"#include "account.h"#include "account_wrap.h"#include "connection.h"#include "channel.h"#include "common/queue.h"#include "common/bnethash.h"#include "common/bnethashconv.h"#include "common/bn_type.h"#include "common/field_sizes.h"#include "common/list.h"#include "common/xalloc.h"#include "handle_bot.h"#include "common/setup_after.h"extern int handle_bot_packet(t_connection * c, t_packet const * const packet){    t_packet * rpacket;        if (!c)    {	eventlog(eventlog_level_error,__FUNCTION__,"[%d] got NULL connection",conn_get_socket(c));	return -1;    }    if (!packet)    {	eventlog(eventlog_level_error,__FUNCTION__,"[%d] got NULL packet",conn_get_socket(c));	return -1;    }    if (packet_get_class(packet)!=packet_class_raw)    {        eventlog(eventlog_level_error,__FUNCTION__,"[%d] got bad packet (class %d)",conn_get_socket(c),(int)packet_get_class(packet));        return -1;    }        {	char const * const linestr=packet_get_str_const(packet,0,MAX_MESSAGE_LEN);		if (packet_get_size(packet)<2) /* empty line */	    return 0;	if (!linestr)	{	    eventlog(eventlog_level_warn,__FUNCTION__,"[%d] line too long",conn_get_socket(c));	    return 0;	}		switch (conn_get_state(c))	{	case conn_state_connected:	    conn_add_flags(c,MF_PLUG);	    conn_set_clienttag(c,CLIENTTAG_BNCHATBOT_UINT);	    	    {		char const * temp=linestr;				if (temp[0]=='\004') /* FIXME: no echo, ignore for now (we always do no echo) */		    temp = &temp[1];				if (temp[0]=='\0') /* empty line */		{		    conn_set_state(c,conn_state_bot_username); /* don't look for ^D or reset tag and flags */		    break;		}				conn_set_state(c,conn_state_bot_password);				if (conn_set_loggeduser(c,temp)<0)		    eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not set username to \"%s\"",conn_get_socket(c),temp);				{		    char const * const msg="\r\nPassword: ";		    		    if (!(rpacket = packet_create(packet_class_raw)))		    {			eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			break;		    }#if 1 /* don't echo */		    packet_append_ntstring(rpacket,conn_get_loggeduser(c));#endif		    packet_append_ntstring(rpacket,msg);		    conn_push_outqueue(c,rpacket);		    packet_del_ref(rpacket);		}	    }	    break;	    	case conn_state_bot_username:	    conn_set_state(c,conn_state_bot_password);	    	    if (conn_set_loggeduser(c,linestr)<0)		eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not set username to \"%s\"",conn_get_socket(c),linestr);	    	    {		char const * const temp="\r\nPassword: ";	    			if (!(rpacket = packet_create(packet_class_raw)))		{		    eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));		    break;		}#if 1 /* don't echo */		packet_append_ntstring(rpacket,linestr);#endif		packet_append_ntstring(rpacket,temp);		conn_push_outqueue(c,rpacket);		packet_del_ref(rpacket);	    }	    break;	    	case conn_state_bot_password:	    {		char const * const tempa="\r\nLogin failed.\r\n\r\nUsername: ";		char const * const tempb="\r\nAccount has no bot access.\r\n\r\nUsername: ";		char const * loggeduser=conn_get_loggeduser(c);		t_account *        account;		char const *       oldstrhash1;		t_hash             trypasshash1;		t_hash             oldpasshash1;		char *             testpass;				if (!loggeduser) /* error earlier in login */		{		    /* no log message... */		    conn_set_state(c,conn_state_bot_username);		    		    if (!(rpacket = packet_create(packet_class_raw)))		    {			eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			break;		    }		    		    packet_append_ntstring(rpacket,tempa);		    conn_push_outqueue(c,rpacket);		    packet_del_ref(rpacket);		    break;		}		if (connlist_find_connection_by_accountname(loggeduser))		{		    eventlog(eventlog_level_info,__FUNCTION__,"[%d] bot login for \"%s\" refused (already logged in)",conn_get_socket(c),loggeduser);		    conn_set_state(c,conn_state_bot_username);		    		    if (!(rpacket = packet_create(packet_class_raw)))		    {			eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			break;		    }		    		    packet_append_ntstring(rpacket,tempa);		    conn_push_outqueue(c,rpacket);		    packet_del_ref(rpacket);		    break;		}		if (!(account = accountlist_find_account(loggeduser)))		{			eventlog(eventlog_level_info,__FUNCTION__,"[%d] bot login for \"%s\" refused (bad account)",conn_get_socket(c),loggeduser);			conn_set_state(c,conn_state_bot_username);						if (!(rpacket = packet_create(packet_class_raw)))			{			    eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			    break;			}						packet_append_ntstring(rpacket,tempa);			conn_push_outqueue(c,rpacket);			packet_del_ref(rpacket);		    break;		}		if ((oldstrhash1 = account_get_pass(account)))		{		    if (hash_set_str(&oldpasshash1,oldstrhash1)<0)		    {			eventlog(eventlog_level_info,__FUNCTION__,"[%d] bot login for \"%s\" refused (corrupted passhash1?)",conn_get_socket(c),loggeduser);			conn_set_state(c,conn_state_bot_username);						if (!(rpacket = packet_create(packet_class_raw)))			{			    eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			    break;			}						packet_append_ntstring(rpacket,tempa);			conn_push_outqueue(c,rpacket);			packet_del_ref(rpacket);			break;		    }                    testpass = xstrdup(linestr);		    {			unsigned int i;						for (i=0; i<strlen(testpass); i++)			    if (isupper((int)testpass[i]))				testpass[i] = tolower((int)testpass[i]);		    }		    if (bnet_hash(&trypasshash1,strlen(testpass),testpass)<0) /* FIXME: force to lowercase */		    {			eventlog(eventlog_level_info,__FUNCTION__,"[%d] bot login for \"%s\" refused (unable to hash password)",conn_get_socket(c), loggeduser);			conn_set_state(c,conn_state_bot_username);			xfree((void *)testpass);						if (!(rpacket = packet_create(packet_class_raw)))			{			    eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			    break;			}						packet_append_ntstring(rpacket,tempa);			conn_push_outqueue(c,rpacket);			packet_del_ref(rpacket);			break;		    }		    xfree((void *)testpass);		    if (hash_eq(trypasshash1,oldpasshash1)!=1)		    {			eventlog(eventlog_level_info,__FUNCTION__,"[%d] bot login for \"%s\" refused (wrong password)",conn_get_socket(c), loggeduser);			conn_set_state(c,conn_state_bot_username);						if (!(rpacket = packet_create(packet_class_raw)))			{			    eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			    break;			}						packet_append_ntstring(rpacket,tempa);			conn_push_outqueue(c,rpacket);			packet_del_ref(rpacket);			break;		    }		    		    		    if (account_get_auth_botlogin(account)!=1) /* default to false */		    {			eventlog(eventlog_level_info,__FUNCTION__,"[%d] bot login for \"%s\" refused (no bot access)",conn_get_socket(c), loggeduser);			conn_set_state(c,conn_state_bot_username);						if (!(rpacket = packet_create(packet_class_raw)))			{			    eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			    break;			}						packet_append_ntstring(rpacket,tempb);			conn_push_outqueue(c,rpacket);			packet_del_ref(rpacket);			break;		    }		    else if (account_get_auth_lock(account)==1) /* default to false */		    {			eventlog(eventlog_level_info,__FUNCTION__,"[%d] bot login for \"%s\" refused (this account is locked)",conn_get_socket(c), loggeduser);			conn_set_state(c,conn_state_bot_username);						if (!(rpacket = packet_create(packet_class_raw)))			{			    eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));			    break;			}						packet_append_ntstring(rpacket,tempb);			conn_push_outqueue(c,rpacket);			packet_del_ref(rpacket);			break;		    }		    		    eventlog(eventlog_level_info,__FUNCTION__,"[%d] \"%s\" bot logged in (correct password)",conn_get_socket(c), loggeduser);		}		else		{		    eventlog(eventlog_level_info,__FUNCTION__,"[%d] \"%s\" bot logged in (no password)",conn_get_socket(c), loggeduser);		}		    if (!(rpacket = packet_create(packet_class_raw))) /* if we got this far, let them log in even if this fails */			eventlog(eventlog_level_error,__FUNCTION__,"[%d] could not create rpacket",conn_get_socket(c));		    else		    {			packet_append_ntstring(rpacket,"\r\n");			conn_push_outqueue(c,rpacket);			packet_del_ref(rpacket);		    }		    conn_login(c,account,loggeduser);		    message_send_text(c,message_type_uniqueid,c,loggeduser);		    		    		    if (conn_set_channel(c,CHANNEL_NAME_CHAT)<0)			conn_set_channel(c,CHANNEL_NAME_BANNED); /* should not fail */	    }	    break;	    	case conn_state_loggedin:	    {		t_channel const * channel;				conn_set_idletime(c);				if ((channel = conn_get_channel(c)))		    channel_message_log(channel,c,1,linestr);		/* we don't log game commands currently */				if (linestr[0]=='/')		    handle_command(c,linestr);		else		    if (channel && !conn_quota_exceeded(c,linestr))			channel_message_send(channel,message_type_talk,c,linestr);		    /* else discard */	    }	    break;	    	default:	    eventlog(eventlog_level_error,__FUNCTION__,"[%d] unknown bot connection state %d",conn_get_socket(c),(int)conn_get_state(c));	}    }        return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一卡二卡在线| 婷婷开心激情综合| 日产国产高清一区二区三区 | 欧美日韩国产三级| 久久久.com| 亚洲福利一区二区| 99视频超级精品| 欧美变态tickling挠脚心| 亚洲免费高清视频在线| 高清国产一区二区| 久久精品人人爽人人爽| 麻豆91免费观看| 欧美日韩亚洲综合一区二区三区| 精品99一区二区三区| 五月激情综合网| 欧美亚洲国产一区在线观看网站| 国产午夜精品理论片a级大结局 | 精品国产麻豆免费人成网站| 一区二区免费看| 972aa.com艺术欧美| 国产婷婷一区二区| 精品亚洲国内自在自线福利| 91精品欧美综合在线观看最新| 亚洲精品日产精品乱码不卡| 不卡的av电影| 国产精品日韩成人| 成人精品视频.| 日本一区二区综合亚洲| 国产999精品久久久久久| 精品欧美一区二区三区精品久久| 麻豆传媒一区二区三区| 日韩欧美电影一二三| 久久精品国产亚洲一区二区三区| 5858s免费视频成人| 奇米影视一区二区三区| 欧美剧情电影在线观看完整版免费励志电影| 亚洲欧美欧美一区二区三区| av电影天堂一区二区在线| 亚洲图片另类小说| 欧美在线小视频| 日日摸夜夜添夜夜添国产精品| 7777精品伊人久久久大香线蕉 | 欧美国产日产图区| 99久久婷婷国产| 亚洲欧洲制服丝袜| 91成人免费网站| 亚洲成人av在线电影| 3atv在线一区二区三区| 麻豆精品精品国产自在97香蕉| 久久免费视频一区| 99久久久免费精品国产一区二区| 国产精品久久久久一区| 欧美最猛黑人xxxxx猛交| 日本不卡一区二区三区| 久久午夜老司机| 97超碰欧美中文字幕| 日韩电影一区二区三区| 国产清纯美女被跳蛋高潮一区二区久久w| 国产91色综合久久免费分享| 亚洲欧美激情插| 欧美一区二区三区在线观看视频 | 欧美日韩一二三区| 久久精品999| 中文字幕一区三区| 日韩天堂在线观看| 99免费精品视频| 日韩高清不卡一区二区三区| 国产亚洲欧美日韩日本| 欧美三区在线视频| 成人性生交大片| 五月婷婷欧美视频| 国产精品免费视频网站| 欧美精品777| 成人av电影在线网| 日韩电影在线观看电影| 亚洲视频免费观看| 久久综合九色综合欧美就去吻| 91免费国产视频网站| 美女视频网站久久| 尤物视频一区二区| 亚洲国产高清在线| 精品国产一区二区三区不卡| 色综合 综合色| 国产精品一区二区在线看| 亚洲国产精品欧美一二99| 国产欧美日韩中文久久| 欧美日韩免费观看一区二区三区 | 在线播放国产精品二区一二区四区 | 成人亚洲一区二区一| 视频一区免费在线观看| 亚洲另类在线制服丝袜| 国产精品理伦片| 国产日韩视频一区二区三区| 欧美zozo另类异族| 3atv在线一区二区三区| 欧美图片一区二区三区| av成人免费在线| 不卡一区中文字幕| 国产成人在线视频网站| 久久99精品国产91久久来源| 亚洲午夜精品在线| 亚洲一区二区三区不卡国产欧美| 国产精品电影一区二区| 欧美激情一二三区| 中文字幕不卡在线播放| 国产欧美久久久精品影院| 久久香蕉国产线看观看99| 久久综合九色综合欧美就去吻 | 337p亚洲精品色噜噜| 色94色欧美sute亚洲线路一ni | 精品区一区二区| 日韩午夜激情电影| 久久综合狠狠综合久久综合88| 欧美成人女星排名| 26uuu国产电影一区二区| 欧美精品一区二区三区蜜桃| 久久综合九色综合97_久久久| 欧美videos大乳护士334| 精品国产电影一区二区| 精品国产伦一区二区三区免费| 2024国产精品| 日本一区二区视频在线| 中文字幕日韩欧美一区二区三区| 国产精品人人做人人爽人人添| 中文字幕一区二区三区视频| 亚洲免费在线观看| 亚洲成年人网站在线观看| 麻豆精品久久久| 成人免费福利片| 欧美这里有精品| 欧美成va人片在线观看| 国产欧美va欧美不卡在线| 亚洲乱码国产乱码精品精的特点 | av高清久久久| 欧美日韩一区二区三区四区五区| 欧美日韩一区二区在线观看视频 | 91麻豆精品国产91久久久久久 | 不卡视频一二三四| 色狠狠一区二区| 欧美一级理论片| 国产女主播在线一区二区| 亚洲最新在线观看| 韩国精品在线观看| caoporen国产精品视频| 欧洲av一区二区嗯嗯嗯啊| 欧美成人一区二区三区片免费| 自拍偷拍亚洲综合| 日韩高清不卡在线| eeuss国产一区二区三区| 欧美视频一区二区| 精品日韩在线一区| 亚洲欧美日韩国产综合| 黄色成人免费在线| 色又黄又爽网站www久久| 日韩一区二区在线观看| 亚洲欧洲美洲综合色网| 免费观看在线综合色| 99久久99精品久久久久久| 日韩欧美专区在线| 亚洲天堂精品视频| 久久99久久久欧美国产| 在线欧美日韩精品| 国产人久久人人人人爽| 麻豆精品在线播放| 欧美亚一区二区| 国产精品久久久久影视| 久久se精品一区精品二区| 欧美日韩一区成人| 亚洲欧美乱综合| 丰满少妇久久久久久久| 91精品国产色综合久久| 一区二区三区影院| 处破女av一区二区| 精品国产sm最大网站免费看| 亚洲国产一区视频| 91色.com| 国产精品国模大尺度视频| 狠狠色2019综合网| 在线不卡免费av| 天天综合色天天综合| 色婷婷久久一区二区三区麻豆| 久久综合色天天久久综合图片| 天天操天天干天天综合网| 欧美在线短视频| 亚洲在线观看免费| 91麻豆国产香蕉久久精品| 国产精品乱码久久久久久| 国产在线视频不卡二| 欧美一级生活片| 免费观看一级欧美片| 欧美v国产在线一区二区三区| 蜜桃av一区二区| 日韩欧美国产成人一区二区| 蜜桃av噜噜一区| 久久伊人蜜桃av一区二区| 精品亚洲国产成人av制服丝袜| www欧美成人18+| 国产经典欧美精品| 欧美国产精品一区二区| 成人综合日日夜夜|