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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? handle_telnet.c

?? 打魔獸戰(zhàn)網(wǎng)的都知道他是什么
?? C
字號:
/* * Copyright (C) 2001  Ross Combs (rocombs@cs.nmsu.edu) * * 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/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_telnet.h"#include "common/setup_after.h"extern int handle_telnet_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 0 /* 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 0 /* 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 * 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),account_get_name(account));			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),account_get_name(account));			xfree(testpass);			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;		    }		    xfree(testpass);		    if (hash_eq(trypasshash1,oldpasshash1)!=1)		    {			eventlog(eventlog_level_info,__FUNCTION__,"[%d] bot login for \"%s\" refused (wrong password)",conn_get_socket(c),account_get_name(account));			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),account_get_name(account));			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),account_get_name(account));			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),account_get_name(account));		}		else		    eventlog(eventlog_level_info,__FUNCTION__,"[%d] \"%s\" bot logged in (no password)",conn_get_socket(c),account_get_name(account));		    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);		    }		    message_send_text(c,message_type_uniqueid,c,account_get_name(account));		    conn_login(c,account,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 telnet connection state %d",conn_get_socket(c),(int)conn_get_state(c));	}    }        return 0;}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩理论电影院| 久久女同互慰一区二区三区| 亚洲激情在线播放| 91视频在线观看免费| 亚洲四区在线观看| 色婷婷久久99综合精品jk白丝| 亚洲天堂2016| 欧美精品黑人性xxxx| 日韩中文字幕亚洲一区二区va在线| 欧美日韩成人综合在线一区二区| 午夜精品一区二区三区三上悠亚| 7777精品伊人久久久大香线蕉最新版| 亚洲va韩国va欧美va精品| 欧美一区二区三区在线视频 | 99re这里只有精品首页| 亚洲天堂免费在线观看视频| 色综合色狠狠天天综合色| 亚洲精品久久7777| 欧美日韩高清影院| 精品在线免费观看| 国产精品女同互慰在线看| 91农村精品一区二区在线| 亚洲美女在线一区| 欧美一卡2卡三卡4卡5免费| 国产一区二区三区在线观看免费视频| 日本一区免费视频| 欧美婷婷六月丁香综合色| 麻豆91精品91久久久的内涵| 久久久久88色偷偷免费| 色偷偷久久人人79超碰人人澡| 日韩高清欧美激情| 国产日本欧美一区二区| 91精品1区2区| 极品销魂美女一区二区三区| 中文字幕一区二区三区乱码在线| 精品视频在线免费观看| 国产原创一区二区三区| 一区二区三区四区在线| 精品久久久久久久久久久久久久久久久| 国产成人一区二区精品非洲| 亚洲一区二区在线观看视频 | 欧美精品久久天天躁| 风间由美性色一区二区三区| 亚洲午夜成aⅴ人片| 国产视频视频一区| 欧美高清你懂得| 成人av影视在线观看| 日韩影院在线观看| 中文字幕在线观看不卡| 欧美大白屁股肥臀xxxxxx| 91女厕偷拍女厕偷拍高清| 美女mm1313爽爽久久久蜜臀| 一区二区三区欧美| 一区二区中文字幕在线| www久久精品| 日韩一区二区三区在线观看| 91成人在线精品| caoporm超碰国产精品| 国产在线视频一区二区三区| 亚洲成人福利片| 亚洲综合一二三区| 国产精品麻豆久久久| 久久亚洲捆绑美女| 日韩写真欧美这视频| 欧美欧美欧美欧美| 欧美中文字幕一区二区三区亚洲| 不卡在线观看av| 国产福利精品一区二区| 久久精品999| 久久精品国产亚洲高清剧情介绍| 玉足女爽爽91| 国产精品色在线| 日韩一级精品视频在线观看| 精品视频一区三区九区| jizzjizzjizz欧美| 国产美女一区二区三区| 美女视频免费一区| 午夜精品久久久久久久99水蜜桃| 国产精品久久免费看| 久久久久久久一区| 色欧美乱欧美15图片| 国产成+人+日韩+欧美+亚洲| 美女国产一区二区三区| 亚洲成人动漫在线观看| 一区二区三区精品久久久| 国产精品女人毛片| 亚洲国产高清在线| 国产视频911| 久久精品一区二区三区不卡牛牛 | 中文字幕欧美区| 久久久影视传媒| 26uuu亚洲婷婷狠狠天堂| 欧美日韩小视频| 欧美日韩午夜在线视频| 在线免费观看日本欧美| 91浏览器入口在线观看| 91在线精品秘密一区二区| 韩日精品视频一区| 国产成人综合网站| 国产.欧美.日韩| 成人美女视频在线观看| 成人午夜在线播放| av成人动漫在线观看| 成人免费va视频| 99久久综合精品| 精品视频全国免费看| 欧美午夜在线观看| 91精品国产麻豆| 精品国偷自产国产一区| 精品国产乱码久久久久久老虎 | 日韩av高清在线观看| 国产精品久久久久久亚洲毛片 | 3751色影院一区二区三区| 欧美精选一区二区| 日韩视频一区在线观看| 精品少妇一区二区三区免费观看| 2017欧美狠狠色| 国产精品色眯眯| 亚洲蜜臀av乱码久久精品| 亚洲高清免费观看| 美女www一区二区| 91蝌蚪国产九色| 欧美男同性恋视频网站| 欧美一区二区三区不卡| ww久久中文字幕| 亚洲欧美日韩国产成人精品影院| 亚洲综合久久av| 蜜桃精品视频在线观看| 国产超碰在线一区| 欧美特级限制片免费在线观看| 日韩欧美国产一区在线观看| 久久久久久**毛片大全| 亚洲免费在线视频| 丝袜脚交一区二区| 成人午夜免费av| 欧美色手机在线观看| 精品日韩99亚洲| 亚洲精品国产无天堂网2021 | 欧美电视剧在线看免费| 亚洲欧洲制服丝袜| 久久99精品视频| 在线视频综合导航| 精品999在线播放| 一区二区三区精品视频在线| 久久9热精品视频| 99国产欧美另类久久久精品| 久久综合九色综合97婷婷女人 | 欧美日韩精品系列| 国产欧美日韩精品一区| 亚洲成人黄色小说| www.一区二区| 精品国产区一区| 国产精品久久久久久久岛一牛影视 | 欧美老女人在线| 中文字幕av一区二区三区| 日韩国产一二三区| 99这里都是精品| 精品福利一区二区三区 | 日韩一区二区三区三四区视频在线观看| 国产精品素人视频| 久久国产精品99精品国产| 欧美亚洲动漫精品| 18涩涩午夜精品.www| 国内外成人在线| 日韩三级高清在线| 亚洲成av人在线观看| 91性感美女视频| 久久精品一二三| 亚洲与欧洲av电影| 欧美午夜免费电影| 亚洲青青青在线视频| 岛国精品一区二区| 久久久蜜桃精品| 美女视频免费一区| 88在线观看91蜜桃国自产| 亚洲欧美电影院| 日本精品一级二级| |精品福利一区二区三区| 丰满少妇在线播放bd日韩电影| 精品久久国产老人久久综合| 日韩国产精品91| 欧美一区二区性放荡片| 国产精品久久久久久福利一牛影视 | 成人小视频免费在线观看| 国产精品欧美一区二区三区| 国产精品一区二区在线观看不卡 | 日韩精品一区在线| 美腿丝袜亚洲综合| 日韩三级高清在线| 久久综合综合久久综合| 欧美一级理论性理论a| 精品无人区卡一卡二卡三乱码免费卡 | 亚洲一卡二卡三卡四卡| 欧美在线制服丝袜| 亚洲第一主播视频| 26uuu欧美| 成人黄色网址在线观看| 中文字幕一区二区在线观看| www.欧美亚洲| 亚洲国产一区二区三区青草影视 |