stoneage8.5/石器时代服务器端最新完整源代码/Serv/saac/main.c

1937 lines
49 KiB
C
Raw Normal View History

#define _MAIN_C_
#include "main.h"
#include "util.h"
#include "mail.h"
#include "db.h"
#include "saacproto_util.h"
#include "saacproto_serv.h"
// CoolFish: Family 2001/5/9
#include "acfamily.h"
#include "version.h"
#ifdef _SEND_EFFECT // WON ADD <20><><EFBFBD><EFBFBD>ѩ<EFBFBD><D1A9><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ч
#include "recv.h"
#endif
#include "md5.h"
#include "char.h"
#include "attestation.h"
#ifdef _SASQL
#include "sasql.h"
#endif
#include "longzoro.h"
#include <stdio.h>
#include <time.h>
#include <signal.h>
#include <sys/types.h>
#include <time.h>
#include <sys/time.h>
#include <errno.h>
#include <sys/wait.h>
#include <getopt.h>
#include <stdio.h>
#include <malloc.h>
#include <strings.h>
#include <string.h>
#include <unistd.h>
#include <netdb.h>
#include <errno.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <time.h>
#include <fcntl.h>
#include <linux/if.h>
#include <linux/sockios.h>
#include <linux/ioctl.h>
#include <netinet/tcp.h>
#include "lock.h"
#define BACKLOGNUM 5
int worksockfd;
static int findregBlankMemBuf( void );
static int unregMemBuf( int index );
static int findregBlankCon( void );
static int getFreeMem( void );
static int appendReadBuffer( int index, char *data, int len );
static int appendWriteBuffer( int index , char *data, int len );
static int appendMemBufList( int top, char *data, int len );
static int consumeMemBufList( int top, char *out, int len, int flag, int copyflag );
static int getLineReadBuffer( int index, char *buf, int len );
void logerr(char *token);
struct membuf
{
int use;
char buf[512];
// char buf[1024*128];
int len;
int next;
};
struct connection
{
int use;
int fd;
int mbtop_ri;
int mbtop_wi;
struct sockaddr_in remoteaddr;
int closed_by_remote;
};
struct membuf *mb;
int mbsize;
int mbuse ;
int cpuuse;
int mainsockfd; /* accept <20><> <20><>¦<EFBFBD>ѱ<EFBFBD><D1B1><EFBFBD>ľ<EFBFBD><C4BE> */
struct sockaddr_in localaddr; /* bind <20><><EFBFBD><EFBFBD>ʧ<EFBFBD><CAA7><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
struct connection *con; /* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
static int mb_finder=0; /* mb<6D><62><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><C3AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>׻<EFBFBD><D7BB><EFBFBD>
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD>ʢ<EFBFBD><EFBFBD> */
// WON FIX
//char tmpbuf[65536];
char tmpbuf[1024*1024];
//char tmpbuf[65536*3]; /* read<61><64> */
struct timeval select_timeout;
time_t sys_time =0; // Robin add
extern gmsv gs[MAXCONNECTION];
int tcpstruct_init( char *addr, int port, int timeout_ms, int mem_use, int deb);
int tcpstruct_accept1( void );
int tcpstruct_accept( int *tis , int ticount );
int tcpstruct_close( int ti );
int tcpstruct_read( int ti , char *buf , int len );
int tcpstruct_readline( int ti , char *buf , int len ,int k ,int r);
int tcpstruct_readline_chop( int ti , char *buf, int len );
int tcpstruct_write( int ti , char *buf , int len );
int tcpstruct_countmbuse( void );
int tcpstruct_connect( char *addr , int port );
void set_nodelay( int sock );
#define OK 0 /* <20><> */
#define TCPSTRUCT_ENOMEM -1 /* malloc <20><> */
#define TCPSTRUCT_ESOCK -2 /* socket <20><> */
#define TCPSTRUCT_EBIND -3 /* bind <20><> */
#define TCPSTRUCT_ELISTEN -4 /* listen <20><> */
#define TCPSTRUCT_EBUG -6 /* <20><><EFBFBD><EFBFBD>ƥؤ<C6A5><D8A4> */
#define TCPSTRUCT_EINVCIND -7 /* con<6F>߼<EFBFBD>index<65><78><EFBFBD>ƾ<EFBFBD><C6BE><EFBFBD><EFBFBD>з<EFBFBD> */
#define TCPSTRUCT_EREADFIN -8 /* read <20><><EFBFBD>·<EFBFBD><C2B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>ʻ<EFBFBD> closed by remote */
#define TCPSTRUCT_EHOST -9 /* gethostbyname <20><> */
#define TCPSTRUCT_ECONNECT -10 /* connect <20><> */
#define TCPSTRUCT_ECFULL -11 /* con <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
#define TCPSTRUCT_ETOOLONG -12 /* <20>滥ئ<E6BBA5><D8A6><EFBFBD>ʿ<EFBFBD> */
#define TCPSTRUCT_EMBFULL -13 /* mb <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
#define TCPSTRUCT_ECLOSEAGAIN -14 /* close <20><>2<EFBFBD>Խ<EFBFBD>ľ<EFBFBD><C4BE> */
int port; /* <20>ء<EFBFBD>ة<EFBFBD>ӡ<EFBFBD><D3A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD><C6BB><EFBFBD><EFBFBD>º̡<C2BA><CCA1><EFBFBD> */
int Total_Charlist;
int Expired_mail;
int Del_Family_or_Member;
int Write_Family;
#ifdef _IP_VIP
char myip[5][32];
#endif
#ifdef _SAVE_ZIP
int SAVEZIP = 0;
void savezipfile( void);
#endif
// Nuke start
char *chartime()
{
static char buf[80];
time_t t;
t=time(0);
strcpy(buf,ctime(&t));
buf[strlen(buf)-1]=0;
return(buf);
}
#ifdef _ANGEL_SUMMON
extern struct MissionTable missiontable[MAXMISSIONTABLE];
static int initMissionTable( void );
int saveMissionTable( void );
void checkMissionTimelimit( void);
#endif
/*
sigaction<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*/
void sighandle( int a )
{
if (a==SIGUSR1) log("sigusr1<EFBFBD>ź<EFBFBD>!\n");
log("<EFBFBD>õ<EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD>ź<EFBFBD>! <20><EFBFBD>ж<EFBFBD>......\n" );
writeFamily(familydir);
writeFMPoint(fmpointdir);
writeFMSMemo(fmsmemodir);
#ifdef _ANGEL_SUMMON
saveMissionTable();
#endif
exit(1);
}
// Arminius 7.20 memory unlock
void sigusr1(int a)
{
int i;
FILE *f;
char key[4096],buf[4096];
signal(SIGUSR1, sigusr1);
f = fopen("./unlock.arg", "r");
if (f) {
memset(key, 0, 4096);
fread(key, 4096, 1, f);
for (i=0; i<strlen(key); i++) if (key[i]=='\n') key[i]='\0';
switch (key[0]) {
case 'P': // unlock player
if (DeleteMemLock(getHash(&key[1]) & 0xff,&key[1],&i)) {
log("ADM: memunlock: %s success.\n", key);
} else {
log("ADM: memunlock: %s failed.\n", key);
}
break;
case 'S': // unlock server
DeleteMemLockServer(&key[1]);
log("ADM: memunlock: %s\n", key);
break;
case 'C': // check player lock
GetMemLockState(getHash(&key[1]) & 0xff, &key[1], buf);
sprintf(key, "echo \"%s\" > ./sigusr1.result", buf);
system(key);
break;
#ifdef _SEND_EFFECT // WON ADD <20><><EFBFBD><EFBFBD>ѩ<EFBFBD><D1A9><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ч
case 'E':
log("\nAC <20><> GS <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѩ<EFBFBD><D1A9>Ч!!\n");
SendEffect(&key[1]);
break;
#endif
case 'L': // Robin <20>г<EFBFBD><D0B3><EFBFBD><EFBFBD><EFBFBD>Server<65><72><EFBFBD><EFBFBD>
log("\nList All Server Conncet!!!!!\n");
for( i =0; i <MAXCONNECTION; i++)
if( gs[i].use)
log("\n gs[%d] fd:%d name:%s ", i, gs[i].fd, gs[i].name );
break;
}
log(" sigusr1_over_1 ");
fclose(f);
log(" sigusr1_over_2 ");
}
}
static int netWrite( int ti , char *buf , int len)
{
return tcpstruct_write( ti , buf, len );
}
gmsv gs[MAXCONNECTION];
#if _ATTESTAION_ID == 1
int login_game_server( int ti , int id, char *svname , char *svpas ,
char *result , int resultlen ,
char *retdata , int retdatalen )
#else
int login_game_server( int ti , char *svname , char *svpas ,
char *result , int resultlen ,
char *retdata , int retdatalen )
#endif
{
#if _ATTESTAION_ID == 1
if(id != _ATTESTAION_ID){
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˰汾<EFBFBD><EFBFBD><EFBFBD><EFBFBD>\n");
snprintf( result , resultlen , "ʧ<EFBFBD><EFBFBD>" );
snprintf( retdata , retdatalen , "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" );
return 0;
}
#endif
if( strcmp( svpas , svpass ) == 0 ){
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȷ %s\n" , svname );
} else {
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> %s\n" , svname );
snprintf( result , resultlen , "ʧ<EFBFBD><EFBFBD>" );
snprintf( retdata , retdatalen , "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" );
return 0;
}
{
int i;
for(i=0;i<MAXCONNECTION;i++){
if( gs[i].use &&
strcmp( gs[i].name , svname ) == 0 ){
snprintf( result, resultlen, "ʧ<EFBFBD><EFBFBD>" );
snprintf( retdata , retdatalen, "<EFBFBD>ظ<EFBFBD><EFBFBD><EFBFBD>½" );
return 0;
}
}
}
snprintf( gs[ti].name , sizeof(gs[ti].name), "%s" , svname );
gs[ti].fd = ti;
snprintf( result , resultlen ,SUCCESSFUL );
snprintf( retdata , retdatalen , "û<EFBFBD>пռ<EFBFBD>" );
DeleteMemLockServer(svname); // Arminius 7.31 unlock server
return 0;
}
int logout_game_server( int ti )
{
gs[ti].use = 0;
gs[ti].fd = -1;
gs[ti].name[0] = 0;
tcpstruct_close( ti );
printf("<EFBFBD>ڴ<EFBFBD>ʣ<EFBFBD><EFBFBD>%f\n", (float)(((float)getFreeMem()/(CHARDATASIZE * 16 * MAXCONNECTION))));
return 0;
}
int is_game_server_login( int ti )
{
if(strlen(gs[ti].name)==0){
return 0;
}else{
return gs[ti].use;
}
}
int servid;
static int readConfig( char *path )
{
char buf[2048];
FILE *fp;
fp = fopen( path , "r" );
if( fp == NULL ){ return -2; }
while( fgets( buf , sizeof( buf ) , fp )){
char command[128];
char param[128];
chop(buf);
easyGetTokenFromString( buf , 1 , command , sizeof( command ));
easyGetTokenFromString( buf , 2 , param , sizeof( param ));
if( strcmp( command , "port" ) == 0 ){
port = atoi( param );
log( "<EFBFBD>˿<EFBFBD>:%d\n",port );
} else if( strcmp( command , "logdir" ) == 0 ){
snprintf( logdir , sizeof( logdir) , param );
log( "<EFBFBD><EFBFBD>־Ŀ¼:%s\n",logdir );
} else if( strcmp( command , "chardir" ) == 0 ){
snprintf( chardir , sizeof( chardir) , param );
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼:%s\n",chardir );
#ifdef _SLEEP_CHAR
snprintf( sleepchardir , sizeof( sleepchardir), "%s_sleep", chardir);
log( "˯<EFBFBD><EFBFBD>Ŀ¼:%s\n",sleepchardir );
#endif
}
#ifdef _IP_VIP
else if( strcmp( command , "ip1" ) == 0 ){
snprintf( myip[0] , sizeof( myip[0] ) , param);
log( "IP1:%s\n",param );
}else if( strcmp( command , "ip2" ) == 0 ){
snprintf( myip[1] , sizeof( myip[1] ) , param);
log( "IP2:%s\n",param );
}else if( strcmp( command , "ip3" ) == 0 ){
snprintf( myip[2] , sizeof( myip[2] ) , param);
log( "IP3:%s\n",param );
}else if( strcmp( command , "ip4" ) == 0 ){
snprintf( myip[3] , sizeof( myip[3] ) , param);
log( "IP4:%s\n",param );
}else if( strcmp( command , "ip5" ) == 0 ){
snprintf( myip[4] , sizeof( myip[4] ) , param);
log( "IP5:%s\n",param );
}
#endif
else if( strcmp( command , "pass" ) == 0 ){
snprintf( svpass , sizeof( svpass ) , param);
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",param );
} else if( strcmp( command , "dbdir" ) == 0 ){
snprintf( dbdir , sizeof( dbdir) , param );
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼:%s\n",dbdir );
} else if( strcmp( command, "rotate_interval" ) == 0 ){
log_rotate_interval = atoi( param );
log( "<EFBFBD><EFBFBD>־ѭ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d\n",log_rotate_interval );
} else if( strcmp( command, "maildir" ) == 0 ){
snprintf( maildir, sizeof( maildir ), param );
log( "<EFBFBD>ʼ<EFBFBD>Ŀ¼:%s\n",maildir );
}
#ifdef _FAMILY
else if( strcmp( command, "familydir" ) == 0 ){
snprintf( familydir, sizeof( familydir ), param );
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼:%s\n",familydir );
} else if( strcmp( command, "fmpointdir" ) == 0 ){
snprintf( fmpointdir, sizeof( fmpointdir ), param );
log( "ׯ԰<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",fmpointdir );
} else if( strcmp( command, "fmsmemodir" ) == 0 ){
snprintf( fmsmemodir, sizeof( fmsmemodir ), param );
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",fmsmemodir );
}
#endif
else if( strcmp( command , "Total_Charlist" ) == 0 ){
Total_Charlist = atoi( param );
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d<><64>\n",Total_Charlist );
} else if( strcmp( command , "Expired_mail" ) == 0 ){
Expired_mail = atoi( param );
log( "<EFBFBD><EFBFBD><EFBFBD>¹<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʼ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d<><64>\n",Expired_mail );
} else if( strcmp( command , "Del_Family_or_Member" ) == 0 ){
Del_Family_or_Member = atoi( param );
log( "ɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ա<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d<><64>\n",Del_Family_or_Member );
} else if( strcmp( command , "Write_Family" ) == 0 ){
Write_Family = atoi( param );
log( "<EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d<><64>\n",Write_Family );
} else if( strcmp( command , "SameIpMun" ) == 0 ){
sameipmun = atoi( param );
if(sameipmun>0){
log( "ͬIP<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͬʱ<EFBFBD><EFBFBD>½:%d<><64>\n",sameipmun );
}else{
log( "ͬIP<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͬʱ<EFBFBD><EFBFBD>½:<3A><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>\n" );
}
} else if( strcmp( command , "CPUUSE" ) == 0 ){
cpuuse = atoi( param );
log( "CPUʹ<EFBFBD><EFBFBD>Ƶ<EFBFBD><EFBFBD>:%d<><64>\n",cpuuse );
}
#ifdef _OLDPS_TO_MD5PS
else if( strcmp( command , "USEMD5" ) == 0 ){
usemd5 = atoi( param );
log( "<EFBFBD>Ƿ<EFBFBD>ʹ<EFBFBD><EFBFBD>MD5<EFBFBD><EFBFBD><EFBFBD>룺%d\n",usemd5 );
}
#endif
#ifdef _AUTO_BACKUP
else if( strcmp( command , "AUTOBACKUPDAY" ) == 0 ){
autobackupday = atoi( param );
log( "ÿ<EFBFBD><EFBFBD>%d<><EFBFBD><ECB1B8>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD>ݣ<EFBFBD>\n",autobackupday );
}else if( strcmp( command , "AUTOBACKUPHOUR" ) == 0 ){
autobackuphour = atoi( param );
log( "ÿ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>%d<><64><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><D0B1>ݣ<EFBFBD>\n",autobackuphour );
}
#endif
#ifdef _LOTTERY_SYSTEM
else if( strcmp( command , "LOTTERYSYSTEM" ) == 0 ){
lotterysystem = atoi( param );
log( "ÿ<EFBFBD><EFBFBD>%d<>һ<ECBFAA>ν<EFBFBD><CEBD><EFBFBD>\n",lotterysystem );
}
#endif
#ifdef _SAVE_ZIP
else if( strcmp( command , "savezip" ) == 0 ){
SAVEZIP = atoi(param);
log( "<EFBFBD>Ƿ<EFBFBD><EFBFBD>Զ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",SAVEZIP>0?"<EFBFBD><EFBFBD>":"<EFBFBD><EFBFBD>");
}
#endif
else if( strcmp( command , "servid" ) == 0 ){
servid = atoi( param );
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ID<EFBFBD><EFBFBD>\n", servid );
}
}
fclose(fp);
return 0;
}
static void parseOpts( int argc, char **argv )
{
int c , option_index;
while(1){
static struct option long_options[] = {
{"nice" , 1 , 0 , 'n'},
{"buy" , 0 , 0 , 'b'},
{"cost" , 0 , 0 , 'c'},
{"help" , 0 , 0 , 'h' },
{"userinfo",0 , 0 , 'i'},
{"lockuser",0 , 0 , 'l'},
{"transmd5",0 , 0 , 'm'},
{"del" , 0 , 0 , 'd'},
{"trans" , 0 , 0 , 't'}
};
c = getopt_long( argc , argv , "n:bchilmdt" , long_options , &option_index );
if( c == -1 )break;
switch( c ){
case 'h':
fprintf( stderr ,
"ʹ<EFBFBD>÷<EFBFBD><EFBFBD><EFBFBD>: saac [-h] [-w port] [-w port] ... \n"
"-h : <20><>ʾsaac<61>İ<EFBFBD><C4B0><EFBFBD>\n"
"-w port : <20><><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>վ<EFBFBD><D5BE><EFBFBD>̶˿<CCB6>\n"
"Copyright 2006 <20><>zoro<72><6F><EFBFBD><EFBFBD><EFBFBD><EFBFBD> "
"( Longzoro System Supply )\n");
exit(0);
break;
case 'i':
{
int i;
char buf[256]="9088";
int len=strlen(buf);
char crypto_key[]={"aBcDeFgHiJkLmNoPqRsTuVwXyZ"};
for(i=0;i<len;i++){
buf[i]=buf[i]^crypto_key[26-i%26];
}
FILE * f12 = fopen("aaaa","w+");
fputs(buf,f12);
fclose(f12);
}
#ifdef _SASQL
sasql_init();
sasql_craete_userinfo();
sasql_close();
#endif
exit(0);
break;
case 'l':
#ifdef _SASQL
sasql_init();
sasql_craete_lock();
sasql_close();
#endif
exit(0);
break;
case 'b':
#ifdef _SQL_BUY_FUNC
{
int type = 0,num = 0;
char coststr[64];
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>(0Ϊ<30><CEAA><EFBFBD>1Ϊ<31><CEAA><EFBFBD>ߡ<EFBFBD>2Ϊʯ<CEAA><CAAF>)\n");
scanf("%d", &type);
if(type <= 0){
int id, vital, str, tough, dex;
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ID<EFBFBD><EFBFBD>");
scanf("%d", &id);
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
scanf("%d", &vital);
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
scanf("%d", &str);
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
scanf("%d", &tough);
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ݣ<EFBFBD>");
scanf("%d", &dex);
sprintf(coststr, "%d|%d|%d|%d|%d", id, vital, str, tough, dex);
}else if(type == 1){
int id;
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ʒ<EFBFBD><EFBFBD>ID<EFBFBD><EFBFBD>");
scanf("%d", &id);
sprintf(coststr, "%d", id);
}else if(type >= 2){
int gold;
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʯ<EFBFBD>ҵ<EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD><EFBFBD>");
scanf("%d", &gold);
sprintf(coststr, "%d", gold);
}
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ij<EFBFBD>ֵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
scanf("%d", &num);
sasql_init();
sasql_OnlineBuy_add(coststr, type, num);
sasql_close();
}
#endif
exit(0);
break;
case 'c':
#ifdef _ONLINE_COST
{
int cost = 0,num = 0,point = 0;
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ij<EFBFBD>ֵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD><EFBFBD>");
scanf("%d", &cost);
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ij<EFBFBD>ֵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
scanf("%d", &num);
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ij<EFBFBD>ֵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>֣<EFBFBD>");
scanf("%d", &point);
sasql_init();
sasql_OnlineCost_add(cost, num, point);
sasql_close();
}
#endif
exit(0);
break;
case 'm':
#ifdef _OLDPS_TO_MD5PS
sasql_init();
sasql_OldpsToMd5ps();
sasql_close();
#endif
exit(0);
break;
case 't':
{
sasql_init();
sasql_TransOnlineCost();
sasql_close();
exit(0);
break;
}
case 'd':
{
int date;
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD>:");
scanf("%d", &date);
sasql_init();
if(date >= 0){
sasql_CleanCdkey(date);
}else{
sasql_CleanLockCdkey();
}
sasql_close();
exit(0);
}
break;
case 'n':
nice(atoi( optarg ));
break;
default:
log( "<EFBFBD><EFBFBD><EFBFBD>ܶ<EFBFBD><EFBFBD><EFBFBD>ѡ<EFBFBD><EFBFBD> %c\n" , c );
exit(0);
}
}
}
double time_diff(struct timeval subtrahend, struct timeval subtractor);
int passwd = 0;
void dump()
{
void *array[10];
size_t size;
char **strings;
size_t i;
size = backtrace (array, 10);
strings = backtrace_symbols (array, size);
printf ("Obtained %zd stack frames.\n", size);
for (i = 0; i < size; i++){
logerr(strings[i]);
printf ("\n");
}
free (strings);
}
void sigshutdown( int number)
{
char buff[256];
if( number == 0 ){
printf( "\n\n\nGMSV<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ر<EFBFBD>\n" );
}else if( number == 2 ){
printf( "\n\n\nGMSV<EFBFBD><EFBFBD>CTRL+C<>ֶ<EFBFBD><D6B6>ж<EFBFBD>\n" );
}else{
sprintf( buff, "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ҫ<EFBFBD><EFBFBD><EFBFBD>󣬱<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ĵ<EFBFBD><EFBFBD><EFBFBD>\n");
logerr(buff);
dump();
}
signal(SIGINT , SIG_IGN );
signal(SIGQUIT, SIG_IGN );
signal(SIGILL, SIG_IGN );
signal(SIGTRAP, SIG_IGN );
signal(SIGIOT, SIG_IGN );
signal(SIGBUS, SIG_IGN );
signal(SIGFPE, SIG_IGN );
signal(SIGKILL, SIG_IGN );
signal(SIGSEGV, SIG_IGN );
signal(SIGPIPE, SIG_IGN );
signal(SIGTERM, SIG_IGN );
log("<EFBFBD>õ<EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD>ź<EFBFBD>! <20><EFBFBD>ж<EFBFBD>......\n" );
writeFamily(familydir);
writeFMPoint(fmpointdir);
writeFMSMemo(fmsmemodir);
#ifdef _ANGEL_SUMMON
saveMissionTable();
#endif
exit(1);
}
void signalset( void )
{
// CoolFish: Test Signal 2001/10/26
printf("\n<EFBFBD><EFBFBD>ʼ<EFBFBD><EFBFBD>ȡ<EFBFBD>ź<EFBFBD>..\n");
printf("SIGINT:%d\n", SIGINT);
printf("SIGQUIT:%d\n", SIGQUIT);
printf("SIGFPE:%d\n", SIGILL);
printf("SIGTRAP:%d\n", SIGTRAP);
printf("SIGIOT:%d\n", SIGIOT);
printf("SIGBUS:%d\n", SIGBUS);
printf("SIGFPE:%d\n", SIGFPE);
printf("SIGKILL:%d\n", SIGKILL);
printf("SIGSEGV:%d\n", SIGSEGV);
printf("SIGPIPE:%d\n", SIGPIPE);
printf("SIGTERM:%d\n", SIGTERM);
signal( SIGINT , sigshutdown );
signal( SIGQUIT, sigshutdown );
signal( SIGILL, sigshutdown );
signal( SIGTRAP, sigshutdown );
signal( SIGIOT, sigshutdown );
signal( SIGBUS, sigshutdown );
signal( SIGFPE, sigshutdown );
signal( SIGKILL, sigshutdown );
signal( SIGSEGV, sigshutdown );
signal( SIGPIPE, SIG_IGN );
signal( SIGTERM, sigshutdown );
}
int main( int argc , char **argv )
{
/*
#define cpuid(in,a,b,c,d)\
asm("cpuid": "=a" (a), "=b" (b), "=c" (c), "=d" (d) : "a" (in));
unsigned long eax,ebx,ecx,edx;
cpuid(0,eax,ebx,ecx,edx);
printf("%08x %08lx %08lx %08lx %08lx\n",0,eax,ebx,ecx,edx);
*/
srand((int)time(0));
parseOpts( argc, argv );
signalset();
// Nuke +1 1012: Loop counter
int counter1 = 0;
int counter2 = 0;
int counter3 = 0;
int counter4 = 0;
int counter5 = 0;
int counter6 = 0;
//signal(SIGUSR1, sigusr1);
log_rotate_interval = 3600 * 24 * 7;
Lock_Init(); // Arminius 7.17 memory lock
UNlockM_Init();
if(readConfig( "acserv.cf" )<0){
log( "<EFBFBD>޷<EFBFBD><EFBFBD>ڵ<EFBFBD>ǰĿ¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȡ acserv.cf .\n" );
exit(1);
}
#ifdef _SASQL
if(sasql_init()==FALSE){
exit(1);
}
#ifdef _SQL_BACKGROUND
sasql_online(NULL,NULL,NULL,NULL,3);
#endif
#endif
log( "<EFBFBD><EFBFBD>ȡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼\n" );
dbRead( dbdir );
#ifdef _FAMILY
log("<EFBFBD><EFBFBD>ȡ <20><><EFBFBD><EFBFBD>ׯ԰\n");
readFMSMemo(fmsmemodir);
log("<EFBFBD><EFBFBD>ȡ <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>\n");
readFMPoint(fmpointdir);
log("<EFBFBD><EFBFBD>ȡ <20><><EFBFBD><EFBFBD>Ŀ¼\n");
readFamily(familydir);
#endif
log( "׼<EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>Ŀ¼\n" );
prepareDirectories( chardir );
log( "׼<EFBFBD><EFBFBD> <20><>־Ŀ¼\n" );
prepareDirectories( logdir );
log( "׼<EFBFBD><EFBFBD> <20>ʼ<EFBFBD>Ŀ¼\n" );
prepareDirectories( maildir );
#ifdef _SLEEP_CHAR
prepareDirectories( sleepchardir );
log( "׼<EFBFBD><EFBFBD> ˯<>ߵ<EFBFBD><DFB5><EFBFBD>Ŀ¼\n" );
#endif
/* <20><><EFBFBD><EFBFBD><EFBFBD>Ȼ<EFBFBD><C8BB><EFBFBD><C2B6><EFBFBD><EFBFBD><EFBFBD>ë <20>ij<EFBFBD><C4B3><EFBFBD> */
if( readMail(maildir) < 0 ){
log( "<EFBFBD><EFBFBD><EFBFBD>ܳ<EFBFBD>ʼ<EFBFBD><EFBFBD><EFBFBD>ʼ<EFBFBD>\n" );
exit(1);
}
/* TCPSTRUCT ë<><C3AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
while( 1 ){
int tcpr;
if( ( tcpr = tcpstruct_init( NULL , port , 0 ,
CHARDATASIZE * 16 * MAXCONNECTION , 1 /* DEBUG */ ) ) < 0 ){
log( "<EFBFBD><EFBFBD><EFBFBD>ܼ<EFBFBD><EFBFBD><EFBFBD>TCP<EFBFBD>˿ڣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: %d, <20><><EFBFBD>Ե<EFBFBD>...\n", tcpr );
sleep( 10 );
}else{
break;
}
}
saacproto_InitServer( netWrite , CHARDATASIZE );
/*
{
struct sigaction s,os;
bzero( &s, sizeof(s));
s.sa_handler = sighandle;
s.sa_flags = SA_NOMASK;
sigaction( SIGTERM, &s, &os );
bzero( &s, sizeof(s));
s.sa_handler = sighandle;
s.sa_flags = SA_NOMASK;
sigaction( SIGINT, &s, &os );
bzero( &s, sizeof( s ));
s.sa_handler = SIG_IGN;
s.sa_flags = SA_NOMASK;
sigaction( SIGPIPE, &s, &os );
}
*/
#ifdef _AC_SEND_FM_PK // WON ADD ׯ԰<D7AF><D4B0>ս<EFBFBD>б<EFBFBD><D0B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>AC
load_fm_pk_list();
#endif
#ifdef _ACFMPK_LIST
FMPK_LoadList();
#endif
#ifdef _ALLDOMAN
LOAD_herolist(); // Syu ADD <20><><EFBFBD>а<EFBFBD>NPC
#endif
#ifdef _ANGEL_SUMMON
initMissionTable();
#endif
log( "\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˰汾: <%s>\n" , SERVER_VERSION );
printf( "ע: AllBlue's<>ڴ<EFBFBD>˵<EFBFBD><CBB5>.<2E><><EFBFBD>Ƿ<EFBFBD><C7B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѷ<EFBFBD><D1B7><EFBFBD><EFBFBD>ˡ<EFBFBD><CBA1>Ͻ<EFBFBD><CFBD><EFBFBD>ҵ<EFBFBD><D2B5>;<EFBFBD><CDBE>\n" );
log( "\n<EFBFBD><EFBFBD>ʼ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>...\n" );
// signal(SIGUSR1,sigusr1); // Arminius 7.20 memory lock
int itime=0;
while(1){
int newti,i;
static time_t main_loop_time;
sys_time = time(NULL);
#ifdef _LOTTERY_SYSTEM
char todayaward[256]="-1,-1,-1,-1,-1,-1,-1";
{
if(lotterysystem>0){
struct tm *p;
p=localtime(&sys_time); /*ȡ<>õ<EFBFBD><C3B5><EFBFBD>ʱ<EFBFBD><CAB1>*/
static BOOL lottery = FALSE;
if( lottery == FALSE){
if((p->tm_mday % lotterysystem) == 0){
if(p->tm_hour == 0){
int award[7];
int i,j;
for(i=0;i<7;i++){
award[i]=rand() % 36+1;
for(j=0;j<i;j++){
if(award[i]==award[j]){
award[i]=rand() % 36+1;
j=0;
}
}
}
sprintf(todayaward, "%d,%d,%d,%d,%d,%d,%d",award[0],
award[1],
award[2],
award[3],
award[4],
award[5],
award[6]);
FILE * f1 = fopen("todayaward.txt","w+");
fputs(todayaward,f1);
fclose(f1);
for( i=0; i<MAXCONNECTION; i++) {
if (gs[i].use && gs[i].name[0]) {
saacproto_LotterySystem_send(i,todayaward);
}
}
lottery = TRUE;
}
}
}else{
if(p->tm_hour != 0){
lottery = FALSE;
}
}
}
}
#endif
if( main_loop_time != sys_time){
main_loop_time = time(NULL);
counter1++;
counter2++;
counter3++;
counter4++;
counter5++;
counter6++;
if( counter6 > 600 ) // 300( -> 60)
{
readConfig( "acserv.cf" );
counter6 = 0;
}
//andy add 2002/06/20
UNlockM_UnlockPlayer();
#ifdef _ANGEL_SUMMON
checkMissionTimelimit();
#endif
// Nuke *1 1012
if( counter1 > Total_Charlist ){
counter1=0;
char *c = ctime( &main_loop_time );
if( c ){
struct timeval st,et;
log( "\nTIME:%s\n",c );
gettimeofday( &st,NULL);
dbFlush(dbdir);
gettimeofday( &et,NULL);
log( "Flushed db(%fsec)\n", time_diff(et,st) );
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d NG:%d\n",
total_ok_charlist, total_ng_charlist );
}
}
// Nuke **1 1012
//if( ( counter % 600 ) == 0 ){
if( counter2 > Expired_mail ){
counter2=0;
struct timeval st,et;
gettimeofday( &st,NULL);
expireMail();
gettimeofday( &et,NULL);
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʼ<EFBFBD>(%fsec)\n", time_diff(et,st) );
}
#ifdef _FAMILY
#ifdef _DEATH_FAMILY_LOGIN_CHECK
//if ((counter % 300) == 0) // 300( -> 60)
if ((counter4 % 1800) == 0) // 3hr( -> 1min)
{
counter4=0;
struct timeval st, et;
time_t t1;
gettimeofday(&st, NULL);
time(&t1);
delovertimeFMMem(t1);
gettimeofday(&et, NULL);
log("Del Family or Member (%fsec)\n", time_diff(et, st));
}
#endif
if( counter5 > Write_Family ) // 300( -> 60)
{
counter5=0;
struct timeval st, et;
gettimeofday(&st, NULL);
writeFamily(familydir);
writeFMPoint(fmpointdir);
writeFMSMemo(fmsmemodir);
gettimeofday(&et, NULL);
log("<EFBFBD><EFBFBD>¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD>(%fsec)\n", time_diff(et, st));
}
#endif
}
newti = tcpstruct_accept1();
if( newti >= 0 ){
log( "ͬ<EFBFBD><EFBFBD>: %d\n" , newti );
gs[newti].use = 1;
}
for(i=0;i<MAXCONNECTION;i++){
// char buf[CHARDATASIZE * 16;
char buf[CHARDATASIZE];
int l;
l = tcpstruct_readline_chop( i , buf , sizeof( buf )- 1);
{
if( !gs[i].use )continue;
if( l > 0 ){
char debugfun[256];
buf[l]=0;
if( saacproto_ServerDispatchMessage( i , buf, debugfun)<0){
printf("buf:%s;%d\n", buf, strlen(buf));
char token[256];
char tmp[256];
struct tm now;
time_t timep;
time(&timep);
memcpy(&now, localtime(&timep), sizeof(now));
sprintf(tmp, "%02d:%02d:%02d", now.tm_hour, now.tm_min, now.tm_sec);
sprintf(token, "[%s]GMSV(%s) <20><>Ϣ:%s\n", tmp, gs[i].name, debugfun);
logerr(token);
// Nuke start
//if(strlen(debugfun)>0){
//logout_game_server(i);// avoid the shutdown the gmsv ttom
//}
}
} else if( l == TCPSTRUCT_ETOOLONG ){
char token[256];
sprintf(token, "<EFBFBD>ܳ<EFBFBD>:%d <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n", i , gs[i].name );
logerr(token);
logout_game_server( i );
} else if( l < 0 ){
log( "<EFBFBD>ر<EFBFBD>:%d <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n", i , gs[i].name );
logout_game_server(i);
} else if( l == 0 ){
;
}
}
}
}
return 0;
}
double
time_diff(struct timeval subtrahend,
struct timeval subtractor)
{
return( (subtrahend.tv_sec - subtractor.tv_sec)
+ (subtrahend.tv_usec
- subtractor.tv_usec ) / (double)1E6 );
}
/*
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë <EFBFBD>£<EFBFBD>
<EFBFBD><EFBFBD>ئԪ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ּ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̻<EFBFBD><EFBFBD>ئԪ<EFBFBD><EFBFBD>ئ<EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>£<EFBFBD>
<EFBFBD>𼰿<EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>»<EFBFBD><EFBFBD><EFBFBD> ƥ<EFBFBD>̼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë <EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD><EFBFBD><EFBFBD>
<EFBFBD><EFBFBD>֣<EFBFBD>
*/
int get_rotate_count(void )
{
int a;
unsigned int t = (unsigned int ) time(NULL);
a = ( t / log_rotate_interval ) * log_rotate_interval;
return a;
}
int tcpstruct_init( char *addr , int p , int timeout_ms , int mem_use , int db )
{
mbsize = mem_use / sizeof( struct membuf );
mbuse =0;
mb_finder = 0;
mb = ( struct membuf * ) calloc( 1, mbsize * sizeof(struct membuf ));
if( mb == NULL ) return TCPSTRUCT_ENOMEM;
bzero( mb , mbsize * sizeof( struct membuf ));
con = ( struct connection *) calloc( 1, MAXCONNECTION * sizeof( struct connection ));
if( con == NULL ){
free( mb );
return TCPSTRUCT_ENOMEM;
} else {
int i;
for(i=0;i<MAXCONNECTION;i++){
con[i].use = 0;
con[i].fd = -1;
}
}
select_timeout.tv_sec = timeout_ms / 1000;
select_timeout.tv_usec = (timeout_ms - ( timeout_ms/1000)*1000)*1000;
/* socket */
mainsockfd = socket( AF_INET , SOCK_STREAM , 0 );
if( mainsockfd < 0 ) return TCPSTRUCT_ESOCK;
/* bind */
bzero( &localaddr ,sizeof( localaddr ));
localaddr.sin_family = AF_INET;
localaddr.sin_port = htons( p );
if( addr ){
localaddr.sin_addr.s_addr = inet_addr( addr );
} else {
localaddr.sin_addr.s_addr = htonl( INADDR_ANY );
}
if( bind( mainsockfd , (struct sockaddr*) &localaddr ,
sizeof( localaddr )) < 0 ) return TCPSTRUCT_EBIND;
/* listen */
if( listen( mainsockfd , BACKLOGNUM )<0) return TCPSTRUCT_ELISTEN;
return OK;
}
int tcpstruct_accept1( void )
{
int tis[BACKLOGNUM];
int ret;
ret = tcpstruct_accept( tis , 1 );
if( ret < 0 ){
return ret;
} else if( ret == 1 ){
return tis[0];
} else {
return TCPSTRUCT_EBUG ;
}
}
int tcpstruct_accept( int *tis , int ticount )
{
int i,k,num=0;
int sret = 0;
int accepted = 0;
struct timeval t;
fd_set rfds, wfds , efds;
FD_ZERO( & rfds );
FD_ZERO( & wfds );
FD_ZERO( & efds );
for(i=0;i<MAXCONNECTION;i++){
if( con[i].use &&
con[i].fd >= 0 && con[i].closed_by_remote ==0 ){
FD_SET( con[i].fd , & rfds );
FD_SET( con[i].fd , & wfds );
FD_SET( con[i].fd , & efds );
int j = 1,k;
if( (float)(((float)getFreeMem()/(CHARDATASIZE * 16 * MAXCONNECTION))) > 0.10 ){
t = select_timeout;
sret = select( con[i].fd+1, & rfds , (fd_set*)NULL, & efds , &t);
if( sret > 0 ) {
if( ( con[i].fd >= 0 ) && FD_ISSET( con[i].fd , &rfds ) ){
int fr = getFreeMem();
int rr , readsize ;
if( fr <= 0 ) continue;
memset( tmpbuf, 0, sizeof( tmpbuf));
if( fr > sizeof(tmpbuf ) ){
readsize = sizeof( tmpbuf);
} else {
readsize = fr - 1;
}
rr = read( con[i].fd , tmpbuf , readsize );
if( rr <= 0 ){
con[i].closed_by_remote = 1;
} else {
appendReadBuffer( i , tmpbuf , rr );
#ifdef _DEBUG
printf("<EFBFBD><EFBFBD>ȡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",tmpbuf);
#endif
}
}
}
if( (float)(((float)getFreeMem()/(CHARDATASIZE * 16 * MAXCONNECTION))) > 0.50 ){
j = 2;
}else if( (float)(((float)getFreeMem()/(CHARDATASIZE * 16 * MAXCONNECTION))) > 0.40 ){
j = 3;
}else if( (float)(((float)getFreeMem()/(CHARDATASIZE * 16 * MAXCONNECTION))) > 0.30 ){
j = 4;
}else if( (float)(((float)getFreeMem()/(CHARDATASIZE * 16 * MAXCONNECTION))) > 0.20 ){
j = 5;
}
}
for(k=0; k < j; k++){
t = select_timeout;
sret = select( con[i].fd+1, (fd_set*)NULL, &wfds, (fd_set*)NULL , &t);
if( sret > 0 ) {
if( ( con[i].fd >= 0 ) && FD_ISSET( con[i].fd , &wfds )){
char send_buf[4096];
memset( send_buf, 0, sizeof( send_buf));
int l = consumeMemBufList( con[i].mbtop_wi ,send_buf, sizeof(send_buf),0 , 1 );
if(l>0){
int rr = write( con[i].fd , send_buf , l );
if( rr < 0 ){
con[i].closed_by_remote = 1;
} else {
#ifdef _DEBUG
printf("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",send_buf);
#endif
consumeMemBufList( con[i].mbtop_wi , send_buf, l, 1 , 0 );
}
}
}
}
}
}
}
for( i=0; i<ticount; i++){
int asret;
struct timeval t;
t.tv_sec =0;
t.tv_usec =0;
FD_ZERO( & rfds );
FD_ZERO( & wfds );
FD_ZERO( & efds );
FD_SET( mainsockfd , & rfds );
FD_SET( mainsockfd , & wfds );
FD_SET( mainsockfd , & efds );
asret = select( mainsockfd+1, &rfds , &wfds , &efds, &t );
// Nuke 20040610: add asret>0 to avoid signal interrupt in select
if( (asret>0) && FD_ISSET( mainsockfd , & rfds )){
struct sockaddr_in c;
int len , newsockfd;
int newcon;
bzero( &c , sizeof( c ));
len = sizeof( c );
fprintf( stderr, "i can accept " );
newcon = findregBlankCon( );
if( newcon < 0 ) continue;
newsockfd = accept( mainsockfd, (struct sockaddr*)&c , &len );
#ifdef _IP_VIP
char tempIp[20];
strcpy(tempIp,inet_ntoa(c.sin_addr));
for (k=0;k<5;k++)
{
if (strcmp( tempIp, myip[i]) != 0) {
num++;
}
}
if(num >= 5){
log( "<EFBFBD>ܾ<EFBFBD>: %d IP:[%s] û<>еǼ<D0B5>\n" , newsockfd ,tempIp);
tcpstruct_close(mainsockfd);
continue;
}
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>: %d IP:[%s]\n" , newsockfd ,tempIp);
#else
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>: %d\n" , newsockfd);
#endif
if( newsockfd < 0 ){
unregMemBuf( newcon );
continue;
}
set_nodelay( newsockfd );
con[newcon].fd = newsockfd;
memcpy( &con[newcon].remoteaddr , &c ,sizeof(c));
tis[accepted] = newcon;
accepted ++;
}
}
return accepted;
}
int tcpstruct_close( int ti )
{
if( ti < 0 || ti >= MAXCONNECTION )return TCPSTRUCT_EINVCIND;
if( con[ti].use == 0 ){
return TCPSTRUCT_ECLOSEAGAIN;
}
close( con[ti].fd );
con[ti].use = 0;
con[ti].fd = -1;
/* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><C3AB><EFBFBD><EFBFBD><EFBFBD>Ȼ<EFBFBD><C8BB><EFBFBD> ë<><C3AB><EFBFBD><EFBFBD>ʧ<EFBFBD><CAA7><EFBFBD><EFBFBD> */
consumeMemBufList( con[ti].mbtop_ri , NULL,
mbsize * sizeof( mb[0].buf ), 1, 0 );
consumeMemBufList( con[ti].mbtop_wi , NULL,
mbsize * sizeof( mb[0].buf ), 1, 0 );
unregMemBuf( con[ti].mbtop_ri );
unregMemBuf( con[ti].mbtop_wi );
con[ti].mbtop_ri = -1;
con[ti].mbtop_wi = -1;
return OK;
}
/*
<EFBFBD>ij<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ּ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD>ئ<EFBFBD>ʻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƾ<EFBFBD><EFBFBD><EFBFBD> remoteclose <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> -1 ë<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*/
int tcpstruct_read( int ti , char *buf , int len )
{
int l;
if( ti < 0 || ti >= MAXCONNECTION || con[ti].use == 0 )
return TCPSTRUCT_EINVCIND;
l = consumeMemBufList( con[ti].mbtop_ri , buf , len , 1 , 1);
if( l == 0 && con[ti].closed_by_remote ) return TCPSTRUCT_EREADFIN;
return l;
}
/*
1<EFBFBD><EFBFBD>ë<EFBFBD><EFBFBD><EFBFBD>ij<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
int kend : 1ئ<EFBFBD>յ<EFBFBD> <EFBFBD><EFBFBD> \n ëڽ<EFBFBD><EFBFBD>
int kend_r : 1ئ<EFBFBD>յ<EFBFBD> <EFBFBD><EFBFBD> \r <EFBFBD><EFBFBD>ڽ<EFBFBD><EFBFBD>(ؤľ<EFBFBD><EFBFBD>)
<EFBFBD>ij<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ּ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD>ئ<EFBFBD>ʻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> remote closed <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>-1ë<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
// Nuke
Read 1 line
if kend==1 then delete \n at the tail
if kend_r== 1 then delete \r at the tail (if any)
if no data read, it means 'remote closed' then return -1
*/
int tcpstruct_readline( int ti , char *buf , int len , int kend , int kend_r )
{
int l;
int minus = 0;
if( ti < 0 || ti >= MAXCONNECTION || con[ti].use == 0 )
return TCPSTRUCT_EINVCIND;
l = getLineReadBuffer( ti , buf , len );
if( l == 0 ){
if( con[ti].closed_by_remote ){
return TCPSTRUCT_EREADFIN;
} else {
return 0;
}
}
if( kend ){
if( buf[l-1]=='\n' ){
buf[l-1] = 0; minus =-1;
}
}
if( kend_r ){
if( buf[l-1]=='\r' ){
buf[l-1] = 0; minus = -1;
}
if( buf[l-2]=='\r' ){
buf[l-2] = 0; minus = -2;
}
}
return l + minus;
}
int tcpstruct_readline_chop( int ti , char *buf, int len )
{
return tcpstruct_readline( ti , buf , len , 1,1);
}
int tcpstruct_write( int ti , char *buf , int len )
{
if( ti < 0 || ti >= MAXCONNECTION || con[ti].use == 0 )
return TCPSTRUCT_EINVCIND;
return appendWriteBuffer( ti , buf , len );
}
int tcpstruct_connect( char *addr , int port )
{
int newti ;
int s, r;
struct sockaddr_in svaddr;
struct hostent *he;
s = socket( AF_INET, SOCK_STREAM , 0 );
if(s<0)return -2;
bzero( &svaddr , sizeof( svaddr ));
svaddr.sin_family = AF_INET;
svaddr.sin_port = htons( port );
if( inet_aton( addr, &svaddr.sin_addr ) == 0 ){
he = gethostbyname( addr );
if( he == NULL ){
return TCPSTRUCT_EHOST;
}
memcpy( & svaddr.sin_addr.s_addr , he->h_addr ,
sizeof( struct in_addr));
}
r = connect( s , ( struct sockaddr*)&svaddr,sizeof(svaddr));
if( r < 0 ){
return TCPSTRUCT_ECONNECT;
}
set_nodelay( s );
newti = findregBlankCon( );
if( newti < 0 ){
fprintf( stderr , "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʧ<EFBFBD><EFBFBD>: newti:%d\n", newti );
return TCPSTRUCT_ECFULL;
}
con[newti].fd = s;
memcpy( & con[newti].remoteaddr , &svaddr ,
sizeof( struct sockaddr_in));
return newti;
}
static int appendReadBuffer( int index , char *data , int len )
{
int top;
top = con[index].mbtop_ri;
for(;;){
int nextind = mb[top].next;
if( nextind == -1 ) break;
top = nextind;
}
return appendMemBufList( top , data , len );
}
static int appendWriteBuffer( int index , char *data , int len )
{
int top;
top = con[index].mbtop_wi;
for(;;){
int nextind = mb[top].next;
if( nextind == -1 ) break;
top = nextind;
}
return appendMemBufList( top , data , len );
}
static int appendMemBufList( int top , char *data , int len )
{
int fr = getFreeMem( );
int rest = len;
int data_topaddr = 0;
if( len >= fr ){
/*
FILE *fp;
if( (fp=fopen( "badsysinfo.txt", "a+")) != NULL ){
fprintf( fp, "appendMemBufList() len:%d / fr:%d err !! \n", len, fr);
fclose( fp);
}
*/
//andy_log
log( "appendMemBufList() len:%d / fr:%d err !! \n", len, fr);
return -1;
}
data[len] = 0;
for(;;){
int blanksize = sizeof( mb[0].buf ) - mb[top].len;
int cpsize = ( rest <= blanksize ) ? rest : blanksize;
memcpy( mb[top].buf + mb[top].len ,
data + data_topaddr , cpsize );
mb[top].len += cpsize;
if( rest <= blanksize ){
return len;
} else {
int newmb;
rest -= cpsize;
data_topaddr += cpsize;
if( (newmb = findregBlankMemBuf( ) ) == TCPSTRUCT_EMBFULL ){
FILE *fp;
if( (fp=fopen( "badsysinfo.txt", "a+")) != NULL ){
fprintf( fp, "find newmb == TCPSTRUCT_EMBFULL err data:%s !!\n", data);
fclose( fp);
}
log( "find newmb == TCPSTRUCT_EMBFULL err data:%s !!\n", data);
}
mb[top].next = newmb;
top = mb[top].next;
}
}
return TCPSTRUCT_EBUG;
}
static int consumeMemBufList( int top , char *out , int len ,
int consumeflag , int copyflag )
{
int total = 0;
int top_store = top;
for(;;){
int cpsize;
if( top == -1 ) break;
cpsize = ( mb[top].len <= ( len - total) ) ?
mb[top].len : ( len - total );
if( copyflag ) memcpy( out + total , mb[top].buf , cpsize );
total += cpsize;
if( consumeflag ){
mb[top].len -= cpsize;
if( mb[top].len > 0 ){
/* <20><><EFBFBD><EFBFBD><EFBFBD>з<EFBFBD><D0B7><EFBFBD><EFBFBD>ƻ<EFBFBD>ئ<EFBFBD>м<EFBFBD>ƥmemmove */
memmove( mb[top].buf , mb[top].buf + cpsize ,
sizeof( mb[top].buf ) - cpsize );
}
}
top = mb[top].next;
if( total == len ){
break;
}
}
if( consumeflag ){
/* ئ<><D8A6><EFBFBD><EFBFBD><EFBFBD><EFBFBD>0<EFBFBD><30>ئ<EFBFBD>Ȼ<EFBFBD><C8BB><EFBFBD>ئ<EFBFBD><D8A6>ݩ <20><>ƥ<EFBFBD><C6A5> <20>ټ<EFBFBD>֧<EFBFBD><D6A7><EFBFBD><EFBFBD>ݩ <20><>ئ<EFBFBD><D8A6><EFBFBD><EFBFBD> */
top = mb[top_store].next;
for(;;){
if( top == -1 )break;
if( mb[top].len == 0 ){
int prev;
mb[top_store].next = mb[top].next;
prev = top;
top = mb[top].next;
unregMemBuf( prev );
} else {
top = mb[top].next;
}
}
}
return total;
}
static int getLineReadBuffer( int index , char *buf, int len )
{
int top = con[index].mbtop_ri;
int ti = 0 , breakflag = 0;
for(;;){
int i;
int l = mb[top].len;
if( top == -1 )break;
for( i=0 ; i < l ; i++){
if( mb[top].buf[i] == '\n' ){
breakflag = 1;
break;
}
ti ++;
}
if( breakflag )break;
top = mb[top].next;
}
if( ti > len ){
/* 1<>滥ئ<E6BBA5><D8A6><EFBFBD>ʿ<EFBFBD><CABF>£<EFBFBD> ئ<>޷¡<DEB7>ë<EFBFBD><C3AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
return TCPSTRUCT_ETOOLONG;
}
/* <20><EFBFBD><E6BBA5><EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD>ئ<EFBFBD><D8A6> */
if( breakflag == 0 ){
return 0;
}
return consumeMemBufList( con[index].mbtop_ri , buf , ti+1 , 1 , 1 );
}
/*
<EFBFBD>ij<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Ӯ<EFBFBD><EFBFBD>ë߯<EFBFBD><EFBFBD>
int index : con index
return:
<EFBFBD><EFBFBD><EFBFBD>޷¡<EFBFBD>
0<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> read <EFBFBD>ƻ<EFBFBD><EFBFBD>ַ<EFBFBD><EFBFBD><EFBFBD>Ӯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
mbsize <EFBFBD><EFBFBD><EFBFBD><EFBFBD>mbuse ë¦<EFBFBD>л<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ի<EFBFBD><EFBFBD><EFBFBD>з<EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>£۹<EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>ƾ<EFBFBD><EFBFBD>а<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ִ<EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>ʻ<EFBFBD><EFBFBD>ֵڣ<EFBFBD>
*/
static int getFreeMem( void )
{
return ( mbsize - mbuse ) * sizeof( mb[0].buf );
}
/*
membuf <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><EFBFBD><EFBFBD>Ʒ<EFBFBD><EFBFBD>ʣ<EFBFBD>
return : <EFBFBD>Ĺ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> >=0 ƥ index.
<EFBFBD>Ĺ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> mb_finder ë<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
<EFBFBD><EFBFBD>ľƥ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD>reg<EFBFBD><EFBFBD><EFBFBD>£<EFBFBD>
*/
static int findregBlankMemBuf( void )
{
int i;
for(i=0;i<mbsize;i++){
mb_finder ++;
if( mb_finder >= mbsize || mb_finder < 0 ) mb_finder = 0;
if( mb[mb_finder].use == 0 ){
mb[mb_finder].use = 1;
mb[mb_finder].len = 0;
mb[mb_finder].next = -1;
mbuse ++;
return mb_finder;
}
}
return TCPSTRUCT_EMBFULL;
}
/*
mb ëݩ <EFBFBD><EFBFBD><EFBFBD><EFBFBD>
*/
static int unregMemBuf( int index )
{
mb[index].use=0;
mb[index].next = -1;
mb[index].len = 0;
mbuse --;
return OK;
}
static int findregBlankCon( void )
{
int i;
// Nuke changed 0->1
//for(i=0;i<MAXCONNECTION;i++){
for(i=1;i<MAXCONNECTION;i++){
if( con[i].use == 0 ){
con[i].use = 1;
con[i].fd = -1;
con[i].mbtop_ri = findregBlankMemBuf();
if( con[i].mbtop_ri < 0 ){
fprintf( stderr , "EMBFULL\n" );
return TCPSTRUCT_EMBFULL;
}
con[i].mbtop_wi = findregBlankMemBuf();
if( con[i].mbtop_wi < 0 ){
unregMemBuf( con[i].mbtop_ri );
fprintf( stderr , "EMBFULL\n" );
return TCPSTRUCT_EMBFULL;
}
bzero( & con[i].remoteaddr , sizeof( struct sockaddr_in));
con[i].closed_by_remote = 0;
return i;
}
}
return TCPSTRUCT_ECFULL;
}
int tcpstruct_countmbuse( void )
{
int i,c=0;
for(i=0;i<mbsize;i++){
if( mb[i].use )c++;
}
return c;
}
char * getGSName( int i )
{
return gs[i].name;
}
void checkGSUCheck( char *id )
{
int i;
char gname[256];
if(!id[0]) return;
memset( gname, 0, sizeof( gname) );
if( LockNode_getGname( (getHash(id) & 0xff), id, gname) <= 0 ){
log("<EFBFBD>޷<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϸ<EFBFBD><EFBFBD><EFBFBD>ҵ<EFBFBD><EFBFBD>˺<EFBFBD>:%x/%s !!\n", getHash( id), id);
return;
}
log("\n");
for(i=0; i < MAXCONNECTION; i++ ){
if( gs[i].name[0] && strcmp( gs[i].name , gname )==0){
log("<EFBFBD><EFBFBD><EFBFBD>ͽ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>[%s] <20><> %d.%x/%s <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d !!\n", id, i, getHash( id), gname, gs[i].fd);
saacproto_ACUCheck_send( gs[i].fd , id );
return;
}
}
// log("Can't find gname:%s sending err !!\n", gname);
int ret = -1;
if( !isLocked( id) ) {
log( "ɾ<EFBFBD><EFBFBD><EFBFBD>ڴ<EFBFBD><EFBFBD><EFBFBD>Ϣ: <20>û<EFBFBD>:%x/%s û<><C3BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!!\n", getHash(id), id);
}
if( DeleteMemLock( getHash(id) & 0xff, id, &ret) ) {
} else {
log( "<EFBFBD><EFBFBD><EFBFBD>ܽ<EFBFBD><EFBFBD><EFBFBD> %x:%s !\n", getHash(id), id);
}
}
void set_nodelay( int sock )
{
int flag = 1;
int result = setsockopt( sock, IPPROTO_TCP, TCP_NODELAY,
(char*)&flag, sizeof(int));
if( result < 0 ){
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD>.\n" );
} else {
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD>: fd:%d\n", sock );
}
}
/*
<EFBFBD><EFBFBD><EFBFBD>ͻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ء<EFBFBD>ة<EFBFBD>ӡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ˪<EFBFBD><EFBFBD>
int flag : 1<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˪<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD><EFBFBD>
*/
void gmsvBroadcast( int fd, char *p1, char *p2, char *p3 , int flag )
{
int i,c=0;
for(i=0;i<MAXCONNECTION;i++){
if( ( flag == 1 ) && ( i == fd ) )continue;
if( gs[i].use && gs[i].name[0] ){
saacproto_Broadcast_send( i, p1,p2,p3);
c++;
}
}
/*
#if 1
{
char fn[1000];
FILE *fp;
snprintf( fn, sizeof(fn), "%s/broadcast.log" , logdir );
fp = fopen( fn,"a" );
if(fp){
fprintf( fp, "From %s(%d) Id:[%s] Char:[%s] Mesg:[%s]\n",
gs[fd].name, fd, p1,p2,p3 );
fclose(fp);
}
}
#endif
*/
}
#ifdef _ANGEL_SUMMON
#define MISSIONFILE "db/missiontable.txt"
static int initMissionTable( void )
{
FILE *fp;
char onedata[1024];
char buf[1024];
int index =0;
memset( missiontable, 0, sizeof(missiontable));
fp = fopen( MISSIONFILE, "r");
if( !fp ) {
log("\n<EFBFBD><EFBFBD><EFBFBD>ؾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!!!! \n");
//return false;
}
log("\n<EFBFBD><EFBFBD><EFBFBD>ؾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٻ<EFBFBD>...");
while(1) {
//
if( fgets( onedata, sizeof(onedata), fp) == NULL)
break;
if( onedata[0] == '\0' || onedata[0] == '#' )
continue;
//easyGetTokenFromBuf( onedata, ",", 1, buf, sizeof( buf));
//index = atoi( buf);
easyGetTokenFromBuf( onedata, ",", 1, buf, sizeof( buf));
if( buf[0] == '\0' ) continue;
strcpy( missiontable[index].angelinfo, buf);
easyGetTokenFromBuf( onedata, ",", 2, buf, sizeof( buf));
if( buf[0] == '\0' ) continue;
strcpy( missiontable[index].heroinfo, buf);
easyGetTokenFromBuf( onedata, ",", 3, buf, sizeof( buf));
if( buf[0] == '\0' ) continue;
missiontable[index].mission = atoi( buf);
easyGetTokenFromBuf( onedata, ",", 4, buf, sizeof( buf));
if( buf[0] == '\0' ) continue;
missiontable[index].flag = atoi( buf);
easyGetTokenFromBuf( onedata, ",", 5, buf, sizeof( buf));
if( buf[0] == '\0' ) continue;
missiontable[index].time = atoi( buf);
easyGetTokenFromBuf( onedata, ",", 6, buf, sizeof( buf));
if( buf[0] == '\0' ) continue;
missiontable[index].limittime = atoi( buf);
log("%d=%s,%s,%d,%d,%d,%d \n", index,
missiontable[index].angelinfo,
missiontable[index].heroinfo,
missiontable[index].mission,
missiontable[index].flag,
missiontable[index].time,
missiontable[index].limittime );
index++;
if( index >= MAXMISSIONTABLE) break;
}
fclose( fp);
log("..<2E>ɹ<EFBFBD>! \n");
return TRUE;
}
int saveMissionTable( void )
{
FILE *fp;
char onedata[1024];
int index =0;
fp = fopen( MISSIONFILE, "w");
if( !fp ) {
log("\n<EFBFBD>򿪾<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!!!! \n");
//return false;
}
log("\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٻ<EFBFBD>...");
for( index =0; index < MAXMISSIONTABLE; index++) {
if( missiontable[index].angelinfo[0] == '\0' )
continue;
sprintf( onedata, "%s,%s,%d,%d,%d,%d\n",
missiontable[index].angelinfo,
missiontable[index].heroinfo,
missiontable[index].mission,
missiontable[index].flag,
missiontable[index].time,
missiontable[index].limittime );
fputs( onedata, fp);
}
fclose( fp);
log("..<2E>ɹ<EFBFBD>! \n");
return TRUE;
}
void delMissionTableOnedata( int index)
{
int gi;
log("\nɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٻ<EFBFBD>:%d:%s:%s \n", index, missiontable[index].angelinfo, missiontable[index].heroinfo);
if( index <0 || index >=MAXMISSIONTABLE) return;
strcpy( missiontable[index].angelinfo, "");
strcpy( missiontable[index].heroinfo, "");
missiontable[index].mission = 0;
missiontable[index].flag = MISSION_NONE;
missiontable[index].time = 0;
missiontable[index].limittime = 0;
for( gi=0; gi<MAXCONNECTION; gi++) {
if (gs[gi].use && gs[gi].name[0]) {
saacproto_ACMissionTable_send( gi, index, 3, "", "");
}
}
}
#define ANSWERTIME 1 // <20>ȴ<EFBFBD><C8B4>ش<EFBFBD>ʱ<EFBFBD><CAB1>(Сʱ)
//#define DOINGTIME 3*24 // <20><><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1>(Сʱ)
#define BOUNDSTIME 1*24 // <20><><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1>(Сʱ)
void checkMissionTimelimit( void)
{
int index;
static time_t lastcheck =0;
if( sys_time < lastcheck + 5*60 )
return;
log("\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٻ<EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d \n", (int)sys_time);
for( index =0; index < MAXMISSIONTABLE; index++) {
if( missiontable[index].flag == MISSION_NONE) {
continue;
}
// <20>ȴ<EFBFBD>ʹ<EFBFBD>߻<EFBFBD>Ӧ1Сʱ
else if( missiontable[index].flag == MISSION_WAIT_ANSWER
&& sys_time > missiontable[index].time + ANSWERTIME*60*60 ) {
delMissionTableOnedata( index);// ɾ
}
// <20>ȴ<EFBFBD><C8B4><EFBFBD><ECBDB1><EFBFBD><EFBFBD> limittimeСʱ
else if( ( missiontable[index].flag == MISSION_DOING || missiontable[index].flag == MISSION_HERO_COMPLETE )
&& ( sys_time > (missiontable[index].time + missiontable[index].limittime*60*60)) ) {
char buf[1024];
int gi;
// <20><>TIMEOVER
log("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>콱ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d ", index);
missiontable[index].flag = MISSION_TIMEOVER;
missiontable[index].time = time(NULL);
missiontable[index].limittime = BOUNDSTIME;
sprintf( buf, "%d|%s|%s|%d|%d|%d|%d ", index,
missiontable[index].angelinfo,
missiontable[index].heroinfo,
missiontable[index].mission,
missiontable[index].flag,
missiontable[index].time,
missiontable[index].limittime );
for( gi=0; gi<MAXCONNECTION; gi++) {
if (gs[gi].use && gs[gi].name[0]) {
saacproto_ACMissionTable_send( gi, 1, 1, buf, "");
}
}
continue;
}
//else if( missiontable[index].flag == MISSION_HERO_COMPLETE
// && sys_time > missiontable[index].time + BOUNDSTIME*60*60 ) {
// log(" <20>콱ʱ<ECBDB1><CAB1><EFBFBD><EFBFBD>:%d ", index);
// delMissionTableOnedata( index);// ɾ
//}
// <20><><EFBFBD>ϱ<EFBFBD><CFB1><EFBFBD>ʱ<EFBFBD><CAB1>(BOUNDSTIMEСʱ)
else if( missiontable[index].flag == MISSION_TIMEOVER
&& sys_time > missiontable[index].time + BOUNDSTIME*60*60 ) {
log(" <20><><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD>:%d ", index);
delMissionTableOnedata( index);// ɾ
}
}
saveMissionTable();
#ifdef _SAVE_ZIP
if (SAVEZIP > 0) savezipfile();
#endif
lastcheck = sys_time;
}
#endif
void logerr(char *token)
{
char tmp[256];
struct tm now;
time_t timep;
time(&timep);
memcpy(&now, localtime(&timep), sizeof(now));
sprintf(tmp, "%04d-%02d-%02d.log", now.tm_year+1900, now.tm_mon+1, now.tm_mday);
FILE *fp=fopen(tmp,"a+");
fwrite(token, strlen(token), 1, fp);
fclose(fp);
printf( token );
}
#ifdef _SAVE_ZIP
void savezipfile( void )
{
time_t timep;
time(&timep);
struct tm * ptm;
int y,m,d;
timep = time(NULL);
ptm = localtime(&timep);
y = ptm->tm_year +1900;
m = ptm->tm_mon+1;
d = ptm->tm_mday;
char buf[256];
sprintf( buf, "%d-%d-%d.zip",y,m,d);
if (access(buf,W_OK) == 0) return;//<2F>ļ<EFBFBD><C4BC><EFBFBD><EFBFBD><EFBFBD>
sprintf( buf, "zip -q -r %d-%d-%d.zip char char_sleep data db lock log mail pklist race&",y,m,d);
log("<EFBFBD><EFBFBD><EFBFBD>ݵ<EFBFBD><EFBFBD><EFBFBD>...");
system(buf);
log("<EFBFBD>ɹ<EFBFBD>!\n");
return;
}
#endif