📄 lssproto_serv.c
字号:
#include "version.h"#include "autil.h"#include "lssproto_serv.h"#include "common.h" // for StoneAge#include "log.h" // for StoneAge#include "char.h"#include <stdio.h>#include <time.h>#include <net.h>void lssproto_SetServerLogFiles( char *r , char *w ){ lssproto_strcpysafe( lssproto_writelogfilename , w , sizeof(lssproto_writelogfilename )); lssproto_strcpysafe( lssproto_readlogfilename , r , sizeof(lssproto_readlogfilename ));}int lssproto_InitServer( int (*writefunc)(int,char*,int) , int worksiz ){ int i; if( (void*)writefunc == NULL) { lssproto.write_func = lssproto_default_write_wrap; } else { lssproto.write_func = writefunc; } lssproto_AllocateCommonWork(worksiz); lssproto_stringwrapper = (char**)calloc( 1,sizeof(char*) * MAXLSRPCARGS); if(lssproto_stringwrapper ==NULL) return -1; memset( lssproto_stringwrapper , 0, sizeof(char*)*MAXLSRPCARGS); for(i=0;i<MAXLSRPCARGS;i++) { lssproto_stringwrapper[i] = (char*)calloc( 1, worksiz ); if( lssproto_stringwrapper[i] == NULL) { for(i=0;i<MAXLSRPCARGS;i++) { free( lssproto_stringwrapper[i]); return -1; } } } lssproto.ret_work = (char*)calloc( 1,sizeof( worksiz )); if( lssproto.ret_work == NULL ) { return -1; } return 0;}void lssproto_CleanupServer( void ){ int i; free( lssproto.work ); free( lssproto.arraywork); free( lssproto.escapework ); free( lssproto.val_str); free( lssproto.token_list ); for(i=0;i<MAXLSRPCARGS;i++) { free( lssproto_stringwrapper[i]); } free( lssproto_stringwrapper ); free( lssproto.ret_work );}#define DME() print("<DME(%d)%d:%d>",fd,__LINE__,func)int lssproto_ServerDispatchMessage(int fd, char *encoded){ int func,fieldcount; char raw[1024 * 64]; CONNECT_getCdkey( fd, PersonalKey, 4096); strcat(PersonalKey, _RUNNING_KEY); util_DecodeMessage(raw,encoded);#ifdef _DEBUG_RET print("\nraw=%s\n",raw);#endif if( !util_SplitMessage(raw,SEPARATOR) ){ print("\nDME1:package=%s\n",raw); DME(); return -1; } if (!util_GetFunctionFromSlice(&func, &fieldcount)) { logHack(fd,HACK_GETFUNCFAIL); DME(); return -1; }#ifdef _DEBUG_RET printf("\n客户端接口=%d\n",func);#endif if (func==LSSPROTO_W_RECV) { int checksum=0, checksumrecv; int x; int y; char direction[1024 * 64]; checksum += util_deint(2, &x); checksum += util_deint(3, &y); checksum += util_destring(4, direction); util_deint(5, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_W_RECV-x:%d,y:%d,direction:%s\n", x, y, direction);#endif lssproto_W_recv(fd, x, y, direction); util_DiscardMessage(); return 0; } if (func==LSSPROTO_W2_RECV) { int checksum=0, checksumrecv; int x; int y; char direction[1024 * 64]; checksum += util_deint(2, &x); checksum += util_deint(3, &y); checksum += util_destring(4, direction); util_deint(5, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_W2_RECV-x:%d,y:%d,direction:%s\n", x, y, direction);#endif lssproto_W2_recv(fd, x, y, direction); util_DiscardMessage(); return 0; } if (func==LSSPROTO_EV_RECV) { int checksum=0, checksumrecv; int event; int seqno; int x; int y; int dir; checksum += util_deint(2, &event); checksum += util_deint(3, &seqno); checksum += util_deint(4, &x); checksum += util_deint(5, &y); checksum += util_deint(6, &dir); util_deint(7, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_EV_RECV-event:%d,seqno:%d,x:%d,y:%d,dir:%d\n", event, seqno, x, y, dir);#endif lssproto_EV_recv(fd, event, seqno, x, y, dir); util_DiscardMessage(); return 0; } if (func==LSSPROTO_DU_RECV) { int checksum=0, checksumrecv; int x; int y; checksum += util_deint(2, &x); checksum += util_deint(3, &y); util_deint(4, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_DU_RECV-x:%d,y:%d\n", x, y);#endif lssproto_DU_recv(fd, x, y); util_DiscardMessage(); return 0; } if (func==LSSPROTO_EO_RECV) { int checksum=0, checksumrecv; int dummy; checksum += util_deint(2, &dummy); util_deint(3, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_EO_RECV-dummy:%d\n", dummy);#endif lssproto_EO_recv(fd, dummy); util_DiscardMessage(); return 0; } if (func==LSSPROTO_BU_RECV) { int checksum=0, checksumrecv; int dummy; checksum += util_deint(2, &dummy); util_deint(3, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_BU_RECV-dummy:%d\n", dummy);#endif lssproto_BU_recv(fd, dummy); util_DiscardMessage(); return 0; } if (func==LSSPROTO_JB_RECV) { int checksum=0, checksumrecv; int x; int y; checksum += util_deint(2, &x); checksum += util_deint(3, &y); util_deint(4, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_JB_RECV-x:%d,y:%d\n", x, y);#endif lssproto_JB_recv(fd, x, y); util_DiscardMessage(); return 0; } if (func==LSSPROTO_LB_RECV) { int checksum=0, checksumrecv; int x; int y; checksum += util_deint(2, &x); checksum += util_deint(3, &y); util_deint(4, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_LB_RECV-x:%d,y:%d\n", x, y);#endif lssproto_LB_recv(fd, x, y); util_DiscardMessage(); return 0; } if (func==LSSPROTO_B_RECV) { int checksum=0, checksumrecv; char command[1024 * 64]; checksum += util_destring(2, command); util_deint(3, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; } #ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_B_RECV-command:%d\n", command);#endif lssproto_B_recv(fd, command); util_DiscardMessage(); return 0; } if (func==LSSPROTO_SKD_RECV) { int checksum=0, checksumrecv; int dir; int index; checksum += util_deint(2, &dir); checksum += util_deint(3, &index); util_deint(4, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_SKD_RECV-dir:%d,index:%d\n", dir, index);#endif lssproto_SKD_recv(fd, dir, index); util_DiscardMessage(); return 0; } if (func==LSSPROTO_ID_RECV) { int checksum=0, checksumrecv; int x; int y; int haveitemindex; int toindex; checksum += util_deint(2, &x); checksum += util_deint(3, &y); checksum += util_deint(4, &haveitemindex); checksum += util_deint(5, &toindex); util_deint(6, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_ID_RECV-x:%d,y:%d,haveitemindex:%d,toindex:%d\n", x, y, haveitemindex, toindex);#endif lssproto_ID_recv(fd, x, y, haveitemindex, toindex); util_DiscardMessage(); return 0; } if (func==LSSPROTO_PI_RECV) { int checksum=0, checksumrecv; int x; int y; int dir; checksum += util_deint(2, &x); checksum += util_deint(3, &y); checksum += util_deint(4, &dir); util_deint(5, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_PI_RECV-x:%d,y:%d,dir:%d\n", x, y, dir);#endif lssproto_PI_recv(fd, x, y, dir); util_DiscardMessage(); return 0; } if (func==LSSPROTO_DI_RECV) { int checksum=0, checksumrecv; int x; int y; int itemindex; checksum += util_deint(2, &x); checksum += util_deint(3, &y); checksum += util_deint(4, &itemindex); util_deint(5, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_DI_RECV-x:%d,y:%d,itemindex:%d\n", x, y, itemindex);#endif lssproto_DI_recv(fd, x, y, itemindex); util_DiscardMessage(); return 0; } if (func==LSSPROTO_DG_RECV) { int checksum=0, checksumrecv; int x; int y; int amount; checksum += util_deint(2, &x); checksum += util_deint(3, &y); checksum += util_deint(4, &amount); util_deint(5, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_DG_RECV-x:%d,y:%d,amount:%d\n", x, y, amount);#endif lssproto_DG_recv(fd, x, y, amount); util_DiscardMessage(); return 0; } if (func==LSSPROTO_DP_RECV) { int checksum=0, checksumrecv; int x; int y; int petindex; checksum += util_deint(2, &x); checksum += util_deint(3, &y); checksum += util_deint(4, &petindex); util_deint(5, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_DP_RECV-x:%d,y:%d,petindex:%d\n", x, y, petindex);#endif lssproto_DP_recv(fd, x, y, petindex); util_DiscardMessage(); return 0; } if (func==LSSPROTO_MI_RECV) { int checksum=0, checksumrecv; int fromindex; int toindex; checksum += util_deint(2, &fromindex); checksum += util_deint(3, &toindex); util_deint(4, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_MI_RECV-fromindex:%d,toindex:%d\n", fromindex, toindex);#endif lssproto_MI_recv(fd, fromindex, toindex); util_DiscardMessage(); return 0; } if (func==LSSPROTO_MSG_RECV) { int checksum=0, checksumrecv; int index; char message[1024 * 64]; int color; checksum += util_deint(2, &index); checksum += util_destring(3, message); checksum += util_deint(4, &color); util_deint(5, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_MSG_RECV-index:%d,message:%s,color:%d\n", index, message, color);#endif lssproto_MSG_recv(fd, index, message, color); util_DiscardMessage(); return 0; } if (func==LSSPROTO_PMSG_RECV) { int checksum=0, checksumrecv; int index; int petindex; int itemindex; char message[1024 * 64]; int color; checksum += util_deint(2, &index); checksum += util_deint(3, &petindex); checksum += util_deint(4, &itemindex); checksum += util_destring(5, message); checksum += util_deint(6, &color); util_deint(7, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_PMSG_RECV-index:%d,petindex:%d,itemindex:%d,message:%s,color:%d\n", index, petindex, itemindex, message, color);#endif lssproto_PMSG_recv(fd, index, petindex, itemindex, message, color); util_DiscardMessage(); return 0; } if (func==LSSPROTO_AB_RECV) { int checksum=0, checksumrecv; util_deint(2, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_AB_RECV\n");#endif lssproto_AB_recv(fd); util_DiscardMessage(); return 0; } if (func==LSSPROTO_DAB_RECV) { int checksum=0, checksumrecv; int index; checksum += util_deint(2, &index); util_deint(3, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_DAB_RECV-index:%d\n", index);#endif lssproto_DAB_recv(fd, index); util_DiscardMessage(); return 0; } if (func==LSSPROTO_AAB_RECV) { int checksum=0, checksumrecv; int x; int y; checksum += util_deint(2, &x); checksum += util_deint(3, &y); util_deint(4, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_AAB_RECV-x:%d,y:%d\n", x, y);#endif lssproto_AAB_recv(fd, x, y); util_DiscardMessage(); return 0; } if (func==LSSPROTO_L_RECV) { int checksum=0, checksumrecv; int dir; checksum += util_deint(2, &dir); util_deint(3, &checksumrecv); if (checksum!=checksumrecv) { util_DiscardMessage(); logHack(fd, HACK_CHECKSUMERROR); DME(); return -1; }#ifdef _DEBUG_RET_CLI printf("[接收]LSSPROTO_L_RECV-dir:%d\n", dir);#endif lssproto_L_recv(fd, dir); util_DiscardMessage(); return 0;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -