StoneAge/saac/char.c

1351 lines
30 KiB
C
Raw Normal View History

2018-08-07 15:51:35 +08:00
#define _CHAR_C_
// Spock +1 2000/12/6
#include <time.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include "main.h"
#include "char.h"
#include "saacproto_serv.h"
#include "util.h"
#include "saacproto_lserver.h"
// CoolFish: Family 2001/6/12
#include "acfamily.h"
#include "version.h"
// Arminius 7.17 memory lock
#include "lock.h"
#include "recv.h"
#ifdef _SASQL1
#include "sasql.h"
#endif
static void getCharNameFromString(char*str ,char *out );
static void getCharOptionFromString( char *str , char *out );
static void getCharNameFromString(char*str ,char *out );
static void makeCharFileName( char *idstring ,char *output, int outlen,int num);
// Nuke *1*1
static int makeSaveCharString( char *out , int outlen ,
char *nm , char *opt , char *info );
static int findBlankCharIndex( char *id );
static int unlinkCharFile( char *id , int num );
#ifdef _SLEEP_CHAR // ȡ<>÷ǻ<C3B7>Ծ<EFBFBD><D4BE><EFBFBD><EFBFBD><EFB5B5>
static void makeSleepCharFileName( char *id,char *output, int outlen, int num);
static void makeSleepCharPoolItemFileName( char *id,char *output, int outlen);
#endif
#ifdef _CHAR_POOLITEM
static void makeCharPoolItemFileName( char *id,char *output, int outlen);
#endif
#define SPACE '|'
#define SPACESTRING "|"
#define IS_2BYTEWORD( _a_ ) ( (char)(0x80) <= (_a_) && (_a_) <= (char)(0xFF) )
#define USERLOG( id , format, args...) \
{\
char body[1000];\
char fn[1000];\
if(id[0]){\
snprintf( body ,sizeof(body), "%s.log.%d" , id ,get_rotate_count() );\
makeDirFilename( fn , sizeof(fn),logdir, getHash(id), body);\
LOGBASE( fn , "%u " , (unsigned int ) time(NULL) );\
LOGBASE( fn , format , ## args );\
}\
}
#ifdef _ANGEL_SUMMON
struct MissionTable missiontable[MAXMISSIONTABLE];
#endif
/*
<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>
char *c0 : ID
char *c1 : Passwd <EFBFBD>ֵ<EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƥ<EFBFBD>¾<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD><EFBFBD>
char *c2 : Charname
char *c3 : opt
Spock fixed, opt change to process
char *c3 : process
char *c4 : <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
int i0 : lock
int i1 : mesgid
*/
void charLoadCallback( int ti , int auth , char *c0, char* c1 ,
char *c2 , char *c3, char *c4, int i0 , int i1 )
{
// Spock deleted 2000/11/2
//static int process_id = 0;
// CoolFish: Init charindex 2001/10/16
#ifdef _NewSave
int charindex = -1;
#else
int charindex;
#endif
#ifndef _LOCK_SERVER
char loadbuf[CHARDATASIZE];
char infobuf[CHARDATASIZE];
int lock = i0;
#endif
char *process = c3;
char *id = c0;
char *passwd = c1;
char *charname = c2;
int mesgid = i1;
char *deadline = c4;
// Spock deleted 2000/11/2
//process_id++;
if( auth != 0 ){
char data[100];
snprintf( data, sizeof( data ), "%d" , auth );
#ifdef _NewSave
saacproto_ACCharLoad_send( ti , FAILED , data, mesgid, charindex );
#else
saacproto_ACCharLoad_send( ti , FAILED , data, mesgid );
#endif
#ifdef _FIX_MESSAGE // WON ADD <20>޸<EFBFBD>WORKER<45><52><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
// ͬһ<CDAC><D2BB>ϵ<EFBFBD>ظ<EFBFBD><D8B8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> game end
if( auth == 204 ){
#ifdef _WAEI_KICK
log("\n (%s) APͬһ<CDAC><D2BB>ϵ<EFBFBD>ظ<EFBFBD><D8B8><EFBFBD><EFBFBD><EFBFBD><EBA3AC><EFBFBD><EFBFBD>!! ", id );
saacproto_ACKick_recv( ti, id, 7, -1); //<2F><><EFBFBD><EFBFBD>
#ifdef _UNLOCKPOOL
addUnlockPool( ti, id, "", process, ""); // AP<41><50><EFBFBD><EFBFBD>
#else
addWorkerTask( id , "dummy" , "3" , dummyCallback , ti ,
id , "dummy" , charname , process ,"", mesgid , 0 );
#endif
#endif
}else
log("\n (%s) <20><><EFBFBD><EFBFBD><EFBFBD>쳣!!:%d ", id, auth );
#endif
return;
}
#ifdef _DELAY_UNLOCK
if( UNlockM_isBe( id ) ){
saacproto_ACCharLoad_send( ti , FAILED , "locked" , mesgid, charindex );
return;
}else
#endif
if( isLocked( id ) ){
//int process;
#ifdef _NewSave
saacproto_ACCharLoad_send( ti , FAILED , "locked" , mesgid, charindex );
#else
saacproto_ACCharLoad_send( ti , FAILED , "locked" , mesgid );
#endif
//DeleteMemLock(getHash(id) & 0xff, id, &process); // <20><><EFBFBD><EFBFBD>AP<41><50><EFBFBD><EFBFBD><EFBFBD><EFBFBD>AC<41><43><EFBFBD><EFBFBD>
log("\n (%s) ACͬһ<CDAC><D2BB>ϵ<EFBFBD>ظ<EFBFBD><D8B8><EFBFBD><EFBFBD><EFBFBD><EBA3AC><EFBFBD><EFBFBD>!! ", id );
saacproto_ACKick_recv( ti, id, 7, -1); //<2F><><EFBFBD><EFBFBD>
// checkGSUCheck( id);
return;
}
#ifdef _LOCK_SERVER
if( CHECK_LS_BEUSE() == TRUE ) {
LServer_SACheckLock2_send( ti, id, mesgid, charname, 1, process);//process
return;
}else {
saacproto_ACCharLoad_send( ti , FAILED , "locked" , mesgid, charindex );
}
#else
charindex = getCharIndexByName( id , charname );
#ifdef _NewSave
//log("\n<><6E><EFBFBD><EFBFBD>װ<EFBFBD><D7B0><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d <20>˺<EFBFBD>:%s <20><><EFBFBD><EFBFBD>:%s\n", charindex, id, charname);
#endif
#ifdef _SQL_BACKGROUND
sasql_online(id,charname);
#endif
if( charindex < 0 ){
/* ƽ<>ҷ»<D2B7><C2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>м<EFBFBD>ƥ<EFBFBD>޷¡<DEB7>ئ<EFBFBD><D8A6><EFBFBD><EFBFBD> */
#ifdef _NewSave
saacproto_ACCharLoad_send( ti , FAILED ,
"char nonexistent" , mesgid , charindex );
#else
saacproto_ACCharLoad_send( ti , FAILED ,
"char nonexistent" , mesgid );
#endif
return;
}
// log( "loadCharOne: id:[%s] char:[%s]\n", id, charname );
if( loadCharOne( id , charindex , loadbuf ,sizeof( loadbuf ))<0){
#ifdef _NewSave
saacproto_ACCharLoad_send( ti , FAILED ,
"cannot load ( disk i/o error?)", mesgid, charindex );
#else
saacproto_ACCharLoad_send( ti , FAILED ,
"cannot load ( disk i/o error?)", mesgid );
#endif
return;
}else{
#ifdef _CHAR_POOLITEM
checkCharPoolItem( id);
#endif
#ifdef _CHAR_POOLITEM
checkCharPoolPet( id);
#endif
}
{//ttom
char *c_ptr;
c_ptr=loadbuf;
while(*c_ptr!='\0'){
if( IS_2BYTEWORD(*c_ptr) ){
if(*(c_ptr+1)==' '){
*(c_ptr+1)=0x41;
}
c_ptr++;
if(*c_ptr=='\0') break;
}
c_ptr++;
}
}//ttom
if( lock ){
char result[100];
char retdata[100];
#ifdef _LOCK_ADD_NAME
if( lockUser( getGSName(ti) , id , charname, passwd , 1 , result , sizeof( result ) ,
retdata , sizeof( retdata ) , process , deadline) <0 ){
#else
// Spock 2000/11/2
if( lockUser( getGSName(ti) , id , passwd , 1 , result , sizeof( result ) ,
retdata , sizeof( retdata ) , process , deadline) <0 ){
#endif
saacproto_ACCharLoad_send( ti , FAILED, "lock FAIL!!" , mesgid , charindex );
return;
}else {
#ifdef _TIMEOUTKICK
//
#endif
}
}
memset( infobuf , 0 , sizeof( infobuf ));
getCharInfoFromString( loadbuf , infobuf );
makeStringFromEscaped( infobuf );
#ifdef _BAD_PLAYER // WON ADD <20>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD><EFBFBD>ȥ<EFBFBD><C8A5>
{
extern int MAX_BAD_PLAYER;
extern char BadPlayerList[500][20]; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 500 <20><>
int i;
for( i=0; i<=MAX_BAD_PLAYER; i++){
if( strcmp( id, BadPlayerList[i] ) == 0){
saacproto_ACCharLoad_send( ti , BADPLAYER , infobuf , mesgid, charindex );
#ifdef _WAEI_KICK
saacproto_ACKick_recv( ti, id, 10, -1);
#endif
return;
}
}
}
#endif
#ifdef _NewSave
saacproto_ACCharLoad_send( ti , SUCCESSFUL , infobuf , mesgid, charindex );
#else
saacproto_ACCharLoad_send( ti , SUCCESSFUL , infobuf , mesgid);
#endif
#ifdef _WAEI_KICK
saacproto_ACKick_recv( ti, id, 10, -1); //<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵ
#endif
#endif
}
#ifdef _NewSave
int charSave( int ti , char *id ,
char *charname , char *opt , char *charinfo,
int unlock , int mesgid , int charindex)
#else
int charSave( int ti , char *id ,
char *charname , char *opt , char *charinfo,
int unlock , int mesgid )
#endif
{
#ifdef _NewSave
#else
int charindex;
#endif
char savebuf[CHARDATASIZE];
int ret = -1;
memset(savebuf, 0, sizeof(savebuf));
//andy_log
if( strstr( charinfo, "DATAEND=") == NULL ){
FILE *fp;
if( (fp=fopen( "badpetstring.txt", "a+")) != NULL ){
fprintf( fp, "%s\n", charinfo);
fclose( fp);
}
log( "err add batpetstring.txt:%s[%s] !\n", id, charname);
}
if( unlock ){
char result[100];
char retdata[100];
#ifdef _LOCK_ADD_NAME
if( (ret = lockUser( getGSName(ti), id , "" , "0" , 0 , result , sizeof( result ) ,
retdata , sizeof( retdata ) , "0" , "0")) < 0 ){
#else
if( (ret = lockUser( getGSName(ti), id , "0" , 0 , result , sizeof( result ) ,
retdata , sizeof( retdata ) , "0" , "0")) < 0 ){
#endif
log( "Unlock:%s FAILED err!!\n", id);
}
#ifdef _LOCK_SERVER
if( CHECK_LS_BEUSE() == TRUE ) {
LServer_SAUNLock_send( ti, id, mesgid, 1);
}
#endif
}
// Nuke *1 add escape
if( makeSaveCharString( savebuf , sizeof( savebuf ) ,
charname, opt , charinfo )<0){
log("\n ACCharSave:too long ");
saacproto_ACCharSave_send( ti , FAILED , "too long" , mesgid );
// Spock fixed 2000/11/1
return ret;
}
#ifdef _NewSave
if (charindex == -1)
charindex = getCharIndexByName( id , charname );
#else
// Nuke *1-
charindex = getCharIndexByName( id , charname );
#endif
if( charindex < 0 ){
int blankind = findBlankCharIndex( id );
if( blankind < 0 ){
log("\n ACCharSave:char full ");
saacproto_ACCharSave_send( ti , FAILED , "char full" ,mesgid);
return ret;
} else {
charindex = blankind;
}
}
log( "<EFBFBD>˺<EFBFBD>:[%s] <20><><EFBFBD><EFBFBD>:[%s]\n", id, charname );
if( saveCharOne( id , charindex , savebuf ) < 0 ){
log("\n ACCharSave:disk I/O error or a bug ");
saacproto_ACCharSave_send( ti , FAILED , "disk I/O error or a bug", mesgid );
return ret;
}
else
{
#ifdef _SASQL
sasql_save_nm( charindex, id, charname );
sasql_save_opt( charindex, id, opt );
sasql_save_int_info( charindex, id, charinfo );
sasql_save_char_info( charindex, id, charinfo );
#endif
}
saacproto_ACCharSave_send( ti , SUCCESSFUL , "" , mesgid);
return ret;
}
void charListCallback( int ti , int auth , char *c0 , char *c1 ,
char *c2 , char *c3 , char *c4 , int i0 , int i1 )
{
#ifndef _LOCK_SERVER
char listbuf[CHARDATASIZE];
#endif
char *id = c0;
int mesgid = i0;
//log(" <20><><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><D0B1><EFBFBD><EFBFBD><EFBFBD>:%s:%d \n", id, auth);
if( auth != 0 ){
char data[100];
snprintf( data, sizeof( data ) , "%d" , auth );
saacproto_ACCharList_send( ti , FAILED , data , mesgid );
total_ng_charlist++;
return;
}
if (!sasql_query(c0,c1)){
#ifdef _SQL_REGISTER
if(!sasql_register(c0,c1))
#endif
{
log("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>û<EFBFBD><EFBFBD>ע<EFBFBD><EFBFBD>\n");
saacproto_ACCharList_send( ti , FAILED , "Password error" , mesgid);
return;}}
// ȡ<><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD> unlock <20><><EFBFBD><EFBFBD>
#ifndef _FIX_MESSAGE // WON ADD <20>޸<EFBFBD>WORKER<45><52><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
#ifdef _DELAY_UNLOCK
if( UNlockM_isBe( id ) ){
saacproto_ACCharList_send( ti , FAILED , "locked" , mesgid );
return;
}else
#endif
if( isLocked( id ) ){
saacproto_ACCharList_send( ti , FAILED , "locked" , mesgid );
checkGSUCheck( id );
total_ng_charlist++;
return;
}
#endif // end FIX_MESSAGE
#ifdef _LOCK_SERVER
if( CHECK_LS_BEUSE() == TRUE ) {
LServer_SACheckLock1_send( ti, id, mesgid, 1);
}else {
saacproto_ACCharList_send( ti , FAILED , "locked" , mesgid );
total_ng_charlist++;
}
#else
#ifdef _SLEEP_CHAR // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>µ<EFBFBD>, <20><><EFBFBD>ɵ<EFBFBD><C9B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD>µ<EFBFBD>
{
char fn_old[256], fn_new[256];
FILE *fp_old, *fp_new;
int i;
// <20><><EFBFBD><EFBFBD><EFBFBD>
for( i=0; i<MAXCHAR_PER_USER; i++) {
makeCharFileName( id, fn_new, sizeof(fn_new), i);
fp_new = fopen( fn_new, "r");
if( fp_new == NULL ) {
makeSleepCharFileName( id, fn_old, sizeof(fn_old), i);
fp_old = fopen( fn_old, "r");
if( fp_old != NULL ) {
fclose( fp_old);
rename( fn_old, fn_new); // <20><><EFBFBD><EFBFBD>
//filecopy( fn_old, fn_new); // <20><><EFBFBD><EFBFBD>
log(" <20>Ƶ<EFBFBD>_%s ", fn_new);
}
}
else {
fclose( fp_new);
}
}
// <20>Ʋֿ⵵
makeCharPoolItemFileName( id, fn_new, sizeof(fn_new));
fp_new = fopen( fn_new, "r");
if( fp_new == NULL ) {
makeSleepCharPoolItemFileName( id, fn_old, sizeof(fn_old));
fp_old = fopen( fn_old, "r");
if( fp_old != NULL ) {
fclose( fp_old);
rename( fn_old, fn_new); // <20><><EFBFBD><EFBFBD>
//filecopy( fn_old, fn_new); // <20><><EFBFBD><EFBFBD>
log(" <20>Ƶ<EFBFBD>_%s ", fn_new);
}
}
else {
fclose( fp_new);
}
}
#endif
#ifdef _DEATH_FAMILY_LOGIN_CHECK//<2F>޷<EFBFBD><DEB7><EFBFBD>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if( loadCharNameAndOption( id , listbuf,sizeof(listbuf)) == 0 ){
saacproto_ACCharList_send( ti , FAILED , "locked" , mesgid );
return;
}
#endif
#ifdef _DEATH_CONTEND //<2F>޷<EFBFBD><DEB7><EFBFBD>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if( loadCharNameAndOption( id , listbuf,sizeof(listbuf)) == 0 ){
saacproto_ACCharList_send( ti , FAILED , "locked" , mesgid );
return;
}
#else
loadCharNameAndOption( id , listbuf,sizeof(listbuf));
#endif
// Arminius
saacproto_ACCharList_send( ti , SUCCESSFUL , listbuf , mesgid);
total_ok_charlist++;
#endif
}
void charDeleteCallback( int ti , int auth ,
char *c0 , char *c1 , char *c2 , char *c3 ,
char *c4 , int i0 , int i1 )
{
int charindex;
char *id = c0;
char *charname = c2;
int mesgid = i0;
struct tm *now;
time_t timenow;
char logfile[128];
if( auth != 0 ){
char data[100];
snprintf( data, sizeof( data ) , "%d" , auth );
saacproto_ACCharDelete_send( ti , FAILED , data, mesgid );
return;
}
charindex = getCharIndexByName( id , charname );
if( charindex < 0 ){
saacproto_ACCharDelete_send( ti , FAILED , "nochar", mesgid );
return;
}
if( unlinkCharFile( id , charindex ) < 0 ){
saacproto_ACCharDelete_send( ti , FAILED , "fileI/O" , mesgid);
return;
}
#ifdef __FAMILY
// CoolFish: Family 2001/6/12
{
int index = 0, fmindex = 0, fmcharindex = 0;
char fmname[32];
index = ACgetFMInfoFromChar(fmname, &fmindex, charname, id, &fmcharindex);
if (index != -1)
{
if (fmcharindex == 0)
{
#ifdef _FMVER21
if (ChangeFMLeader(index, fmname, fmindex) >= 0)
{
if (ACDelFM(index, fmname, fmindex) >= 0)
log("ACDelFM index:%d fmname:%s fmindex:%d charname:%s, charid:%s, charindex:%d\n",
index, fmname, fmindex, charname, id, fmcharindex);
}
log("ChangeFMLeader_3 index:%d fmname:%s fmindex:%d\n", index, fmname, fmindex);
#else
if (ACDelFM(index, fmname, fmindex) >= 0)
log("ACDelFM index:%d fmname:%s fmindex:%d charname:%s, charid:%s, charindex:%d\n",
index, fmname, fmindex, charname, id, fmcharindex);
#endif
}
else
{
#ifdef _FMVER21
if (ACMemberLeaveFM(index, fmname, fmindex, charname, 0, 0, fmcharindex) >= 0)
log("ACMemberLeaveFM index:%d fmname:%s fmindex:%d charname:%s, charid:%s, charindex:%d\n",
index, fmname, fmindex, charname, id, fmcharindex);
#else
if (ACMemberLeaveFM(index, fmname, fmindex, charname, 0, fmcharindex) >= 0)
log("ACMemberLeaveFM index:%d fmname:%s fmindex:%d charname:%s, charid:%s, charindex:%d\n",
index, fmname, fmindex, charname, id, fmcharindex);
#endif
}
}
}
#endif
// Spock 2000/12/6
time( &timenow );
now = localtime( &timenow );
sprintf( logfile , "log/chardel/%04d%02d%02d.log" ,
now->tm_year + 1900 , now->tm_mon + 1 , now->tm_mday );
LOGBASE( logfile , "%04d/%02d/%02d %02d:%02d:%02d id:[%s] char:[%s] index:[%d]\n" ,
now->tm_year + 1900 , now->tm_mon + 1 , now->tm_mday ,
now->tm_hour , now->tm_min , now->tm_sec ,
id , charname , charindex );
// Spock end
USERLOG( id , "chardelete: successful\n" );
saacproto_ACCharDelete_send( ti , SUCCESSFUL , "ok" , mesgid);
}
void dummyCallback( int ti , int auth ,
char *c0 , char *c1 , char *c2 , char *c3 ,
char *c4 , int i0 , int i1 )
{
return;
}
static void getCharNameFromString(char*str ,char *out )
{
int c;
out[0]='\0';
for(c=0;;c++){
if( IS_2BYTEWORD( str[c] ) ){
out[c] = str[c];
c ++ ; // <20>ݼ<EFBFBD> ٯ<><D9AF>
out[c] = str[c];
continue;
}
out[c] = str[c];
if( str[c] == '\0' )break;
if( str[c] == SPACE ){
out[c] = '\0';
break;
}
}
}
static void getCharOptionFromString( char *str , char *out )
{
int c;
int outc = 0;
out[outc] = '\0';
for(c=0;;c++){
if( str[c]=='\0')break;
if( IS_2BYTEWORD( str[c] ) ){
c++;
if( str[c] == '\0' )break; // <20><><EFBFBD><EFBFBD> ٯ<><D9AF><EFBFBD><EFBFBD>ƥ<EFBFBD><C6A5>NULLئ<4C>ձ<EFBFBD>
continue;
}
if( str[c]== SPACE ){
c++;
for(;;c++){
if( str[c] == '\0' ){ // <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> NULL ľ<><C4BE><EFBFBD>δ<EFBFBD><CEB4><EFBFBD>
out[outc] = '\0';
break;
}
// <20><><EFBFBD><EFBFBD><EFBFBD>֨<EFBFBD><D6A8><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ٯ<><D9AF><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ئ<><D8A6><EFBFBD>ֵ<EFBFBD><D6B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
//---- For 2Byte Code ----
if( IS_2BYTEWORD( str[c] ) ){
out[outc++] = str[c++]; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
out[outc++] = str[c]; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if( str[c] == '\0' )break; // <20><><EFBFBD><EFBFBD> ٯ<><D9AF><EFBFBD><EFBFBD>ƥ<EFBFBD><C6A5>NULLئ<4C>ձ<EFBFBD>
continue;
}
// ɧ<><C9A7> ٯ<><D9AF><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
out[outc] = str[c]; // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if( str[c] == '\0' )break; // <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ձδ<D5B1><CEB4><EFBFBD>
if( str[c] == SPACE ){
out[outc] = '\0';
break;
}
outc++;
}
return;
}
}
}
void getCharInfoFromString( char *str , char *out )
{
int c=0,outc=0;
int space_counter=0;
out[outc] = '\0';
for(c=0;;c++){
if( str[c]=='\0')break;
if( IS_2BYTEWORD( str[c] ) ){
c++;
continue;
}else
if( str[c]== SPACE ){
space_counter++;
}
if( space_counter==2 && str[c]== SPACE ){
c++;
for(;;c++){
if( IS_2BYTEWORD( str[c] ) ){
out[outc++] = str[c++];
out[outc++] = str[c];
if( str[c] == '\0' ){
out[outc] = '\0';
break;
}
continue;
}
out[outc] = str[c];
if( str[c] == '\0' )break;
if( str[c] == SPACE ){
out[outc] = '\0';
break;
}
outc++;
}
return;
}
}
}
static void makeCharFileName( char *id,char *output, int outlen, int num)
{
char body[1024];
if ( strlen( id) < 1)return;
snprintf(body , sizeof(body ) , "%s.%d.char" , id , num );
makeDirFilename(output , outlen, chardir , getHash(id) ,body);
}
#ifdef _SLEEP_CHAR // ȡ<>÷ǻ<C3B7>Ծ<EFBFBD><D4BE><EFBFBD><EFBFBD><EFB5B5>
static void makeSleepCharFileName( char *id,char *output, int outlen, int num)
{
char body[1024];
if ( strlen( id) < 1)return;
snprintf(body , sizeof(body ) , "%s.%d.char" , id , num );
makeDirFilename(output , outlen, sleepchardir , getHash(id) ,body);
}
#endif
int loadCharNameAndOption( char *id , char *output , int outlen)
{
char chbuf[MAXCHAR_PER_USER][CHARDATASIZE];
char namework[CHARDATASIZE];
char optionwork[CHARDATASIZE];
char nm_work[CHARDATASIZE];
int i,count=0;
int so_far_bytes = 0;
output[0] = 0;
for(i=0;i<MAXCHAR_PER_USER;i++){
int l;
char delim[2];
chbuf[i][0] = 0;
loadCharOne( id , i , chbuf[i] , sizeof( chbuf[i] ));
getCharNameFromString( chbuf[i] , namework );
getCharOptionFromString( chbuf[i] , optionwork );
if( chbuf[i][0] == 0 )continue;
if( strlen( output ) > 0 ){
delim[0] = SPACE;
delim[1] = 0;
} else {
delim[0] = 0;
}
snprintf( nm_work , sizeof( nm_work ),
"%s%s|%s" , delim,namework , optionwork );
l = strlen( nm_work );
if( ( so_far_bytes + l ) < outlen ){
strcat( output , nm_work );
so_far_bytes += l;
count++;
}
}
return count;
}
#ifdef _CHECK_BADFILES
int backupBadcharfile( char *filename, char *cdkey, int num)
{
char file1[256],file2[256];
char userpath[256];
FILE *fp;
log("backupBadcharfile( %s) -%s.%d-%s\n", filename, cdkey, num, userpath);
sprintf( userpath , "%s.%d.char" , cdkey , num );
sprintf( file1, "char/0x%x/%s", getHash(cdkey) & 0xff, userpath);
sprintf( file2, "badchar/%s", userpath);
{
char buf[1024];
int f;
bzero(buf,sizeof(buf));
f=open( file1, O_RDONLY);
if ( f <= 0 ){
log( "Can't open %s..\n", file1);
return 1;
}
lseek( f, -4, SEEK_END);
read(f,buf,4);
close(f);
if ((buf[2]=='\\')&&(buf[3]=='n')&&
(buf[0]=='\\')&&(buf[1]=='z')){
return 1;
}
}
if (mkdir("badchar", 0755) == 0)
log("create %s\n", "badchar");
sprintf( file2, "./badchar/%s", filename);
fp = fopen( file2, "a+");
if( fp == NULL ){
log("create file:%s error !!\n", file1);
return -1;
}
fprintf( fp, "%s %s\n", cdkey, file1);
fclose( fp);
log("backup badcharfile:%s..\n", userpath);
return -1;
}
#endif
int loadCharOne( char *id , int num, char *output , int outlen )
{
char fn[1024];
FILE *fp;
char c_temp,*c_ptr;
c_ptr=output;
makeCharFileName( id , fn , sizeof(fn),num );
fp = fopen( fn , "r" );
if( fp == NULL ){
return -1;
}
do{
c_temp = fgetc(fp);
*c_ptr=c_temp;
c_ptr++;
}while(c_temp != EOF);
*c_ptr='\0';
if( output[0]=='|' && output[1]=='|' ){
return -1;
}
fclose(fp);
#ifdef _CHECK_BADFILES
if( backupBadcharfile( "badfilelist.txt", id, num) < 0 ){
return -1;
}
#endif
return 0;
}
int saveCharOne( char *id , int num , char *input )
{
char fn[1024];
FILE *fp;
char *strp;
char *strp1; // Won <20><><EFBFBD><EFBFBD> hp Ϊ<><CEAA><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
makeCharFileName( id , fn , sizeof(fn),num );
fp= fopen( fn , "w" );
if( fp == NULL ) {
log( "save error 01: %d",errno );//Change add errno
return -1;
}
// Won <20><><EFBFBD><EFBFBD> hp Ϊ<><CEAA><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
if ((strp=strstr(input,"\\nhp=-"))!=NULL) {
strp1=strstr(input,"\\nmp=");
*(strp+5)='1';
strcpy((strp+6), strp1);
}
// Arminius
if ((strp=strstr(input,"\\nhp=0\\n"))!=NULL) *(strp+5)='1';
fprintf( fp , "%s" , input );
fclose(fp);
#if 0 //_SLEEP_CHAR // <20>ɵ<EFBFBD>Ҳ<EFBFBD><D2B2>
{
char fn1[1024], fn2[1024];
makeSleepCharFileName( id , fn1 , sizeof(fn1),num );
fp = fopen( fn1 , "w" );
if( fp != NULL ) {
fprintf( fp , "%s" , input );
fclose(fp);
}
// <20><><EFBFBD><EFBFBD><EFBFBD>²ֿ⵵<D6BF><E2B5B5><EFBFBD>ɵ<EFBFBD>
makeCharPoolItemFileName( id, fn1, sizeof(fn));
makeSleepCharPoolItemFileName( id, fn2, sizeof(fn));
filecopy( fn1, fn2);
}
#endif
#ifdef _SQL_BACKGROUND
sasql_update(id,fn);
sasql_online(id,NULL);
#endif
log( "д<EFBFBD><EFBFBD> %s <20><><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>:%s\n",id , fn );
return 0;
}
static int makeSaveCharString( char *out , int outlen ,
char *nm , char *opt , char *info )
{
char nmwork[CHARDATASIZE];
char optwork[CHARDATASIZE];
char infowork[CHARDATASIZE];
char outwork[CHARDATASIZE];
char *nmwork_p , *optwork_p , *infowork_p;
int l;
/* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD> */
strncpy( nmwork , nm , sizeof( nmwork ));
nmwork[strlen( nm)]=0;
strncpy( optwork , opt , sizeof( optwork ));
optwork[strlen(opt)]=0;
strncpy( infowork , info , sizeof( infowork ));
infowork[strlen(info)]=0;
/* <20>޵<EFBFBD><DEB5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
/* if ( esc ) {
nmwork_p = makeEscapeString1( nm , nmwork ,sizeof( nmwork ));
optwork_p = makeEscapeString1( opt , optwork , sizeof( optwork ));
infowork_p = makeEscapeString1( info , infowork , sizeof( infowork ));
} else {*/
nmwork_p = makeEscapeString( nm , nmwork ,sizeof( nmwork ));
optwork_p = makeEscapeString( opt , optwork , sizeof( optwork ));
infowork_p = makeEscapeString( info , infowork , sizeof( infowork ));
#ifdef _SASQL
{
FILE *f;
f=fopen("nmkill.txt","w");
if( f )
{
fprintf(f,"%s",nmwork_p);
fclose( f );
}
f=fopen("optkill.txt","w");
if( f )
{
fprintf(f,"%s",optwork_p);
fclose( f );
}
f=fopen("infokill.txt","w");
if( f )
{
fprintf(f,"%s",infowork_p);
fclose( f );
}
}
#endif
// }
/* <20><>ئ<EFBFBD><D8A6><EFBFBD>£<EFBFBD><C2A3><EFBFBD><EFBFBD>л<EFBFBD><D0BB>޷¡<DEB7><C2A1><EFBFBD><EFBFBD><EFBFBD>׻<EFBFBD><D7BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Է<EFBFBD><D4B7><EFBFBD><EFBFBD>ͱ<EFBFBD><CDB1><EFBFBD>ľ<EFBFBD>£<EFBFBD> */
snprintf( outwork ,sizeof( outwork ) ,
"%s" SPACESTRING "%s" SPACESTRING "%s" ,
nmwork_p , optwork_p , infowork_p );
l = strlen( outwork );
if( l >= (outlen-1)){
return -1;
}
/* NULL ٯ<><D9AF> <20><>ؤ<EFBFBD>¾<EFBFBD><C2BE><EFBFBD><30><C3AB>ľ<EFBFBD><C4BE><EFBFBD><EFBFBD><EFBFBD>о<EFBFBD><D0BE>ϼ<EFBFBD><CFBC>֣<EFBFBD> */
memcpy( out , outwork , l + 1);
return 0;
}
int getCharIndexByName( char *id , char *charname )
{
int i;
for(i=0;i<MAXCHAR_PER_USER;i++){
char output[CHARDATASIZE];
if( loadCharOne( id , i , output , sizeof( output )) < 0 ){
/* ؤ<>л<EFBFBD><D0BB><EFBFBD><EFBFBD>¡<EFBFBD> */
continue;
} else {
/* ƽ<>ҷ»<D2B7><C2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
char cn[CHARDATASIZE];
getCharNameFromString( output , cn );
/* Escapeëݩ<C3AB><DDA9> */
if( strcmp( charname , makeStringFromEscaped(cn) ) == 0 ){
return i;
}else{
}
}
}
return -1;
}
/*
ƽ<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>0<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD><EFBFBD>ؤ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>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><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 findBlankCharIndex( char *id )
{
int i;
char output[CHARDATASIZE];
for(i=0;i<MAXCHAR_PER_USER;i++){
if( loadCharOne( id , i , output , sizeof( output ) ) < 0 ){
return i;
}
}
return -1;
}
static int unlinkCharFile( char *id , int num )
{
char fname[1024];
#ifdef _SLEEP_CHAR //ɾ<><C9BE><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD>ɵ<EFBFBD>Ҳɾ
makeSleepCharFileName( id, fname, sizeof(fname),num );
unlink( fname );
#endif
makeCharFileName( id, fname, sizeof(fname),num );
return unlink( fname );
}
#ifdef _LOCK_ADD_NAME
int lockUser( char *gmsvname , char *id , char *name, char *passwd , int lock ,
char *result, int resultlen,
char *retdata , int retdatalen , char *process , char *deadline)
#else
int lockUser( char *gmsvname , char *id , char *passwd , int lock ,
char *result, int resultlen,
char *retdata , int retdatalen , char *process , char *deadline)
#endif
{
char fname[1024];
int ret = -1;
if(!id[0]){
snprintf(result , resultlen , FAILED);
snprintf(retdata , retdatalen , "bad id");
return -1;
}
makeDirFilename( fname,sizeof(fname),lockdir , getHash(id), id );
retdata[0] = 0;
if( lock ){
if (isLocked(id)) {
snprintf( result , resultlen, FAILED );
snprintf( retdata , retdatalen, "already locked" );
log( "д<EFBFBD><EFBFBD><EFBFBD>ڴ<EFBFBD><EFBFBD><EFBFBD>Ϣ: <20>û<EFBFBD>:%x/%s <20>Ѿ<EFBFBD>ͬ<EFBFBD><CDAC><EFBFBD><EFBFBD><EFBFBD><EFBFBD> !!\n", getHash(id), id);
return -1;
} else {
#ifdef _LOCK_ADD_NAME
if( InsertMemLock( getHash(id) & 0xff, id, name, passwd, gmsvname, atoi(process), deadline ) )
#else
if( InsertMemLock( getHash(id) & 0xff, id, passwd, gmsvname, atoi(process), deadline ) )
#endif
return 0;
else
return -1;
}
} else {
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) ) {
snprintf( result , resultlen, SUCCESSFUL );
snprintf( retdata , retdatalen, "removed" );
return ret;
} else {
snprintf( result , resultlen, FAILED );
snprintf( retdata , retdatalen, "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƴ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>" );
log( "<EFBFBD><EFBFBD><EFBFBD>ܽ<EFBFBD><EFBFBD><EFBFBD> %x:%s !\n", getHash(id), id);
return ret;
}
}
}
int isLocked( char *id )
{
if (!id[0]) return 1; // invalid id: lock it
return isMemLocked(getHash(id) & 0xff, id);
}
int checkValidCharName( char *a)
{
int i;
for(i=0;;i++){
if( a[i] == 0 )break;
if( a[i] == SPACE )return -1;
}
return 0;
}
#ifdef _CHAR_POOLITEM
static void makeCharPoolItemFileName( char *id,char *output, int outlen)
{
char poolitem[256];
if ( strlen( id) < 1)return;
snprintf( poolitem , sizeof( poolitem ) , "%s.item" , id);
makeDirFilename(output , outlen, chardir , getHash(id) ,poolitem);
}
#ifdef _SLEEP_CHAR // ȡ<>÷ǻ<C3B7>Ծ<EFBFBD><D4BE><EFBFBD><EFBFBD><EFBFBD>ֿ⵵<D6BF><E2B5B5>
static void makeSleepCharPoolItemFileName( char *id,char *output, int outlen)
{
char poolitem[256];
if ( strlen( id) < 1)return;
snprintf( poolitem , sizeof( poolitem ) , "%s.item" , id);
makeDirFilename(output , outlen, sleepchardir , getHash(id) ,poolitem);
}
#endif
int InsertCharPoolItem( char *id , char *input, int sizes)
{
char fn[256];
FILE *fp;
if( sizes <= 0 ) return sizes;
makeCharPoolItemFileName( id , fn , sizeof(fn));
fp= fopen( fn , "a+" );
if( fp == NULL ) {
fp= fopen( fn , "w" );
if( fp == NULL ) {
log( "save %s error.\n", fn);
return -1;
}
}
fprintf( fp , "%s" , input );
fclose(fp);
log( "add %s charpoolitem file:%s\n", id , fn );
return sizes;
}
int saveCharPoolItem( char *id , char *input, int sizes)
{
char fn[256];
FILE *fp;
if( sizes < 0 ) return sizes;
if( input == NULL ) return -1;
makeCharPoolItemFileName( id , fn , sizeof(fn));
fp= fopen( fn , "w" );
if( fp == NULL ) {
log( "save %s error.\n", fn);
return -1;
}
fprintf( fp , "%s" , input );
fclose(fp);
log( "д<EFBFBD><EFBFBD> %s <20><><EFBFBD>ߵ<EFBFBD><DFB5><EFBFBD><EFBFBD>ļ<EFBFBD>:%s\n", id , fn );
return sizes;
}
int loadCharPoolItemOne( char *id , char *output , int outlen)
{
char fn[256];
FILE *fp;
char c_temp,*c_ptr;
int sizes=0;
c_ptr=output;
makeCharPoolItemFileName( id , fn , sizeof(fn));
fp = fopen( fn , "r" );
if( fp == NULL ){
if( (fp = fopen( fn , "w" )) == NULL)
return -1;
return 0;
}
do{
c_temp = fgetc(fp);
*c_ptr=c_temp;
c_ptr++;
sizes++;
if( sizes >= (outlen-1) ) break;
}while(c_temp != EOF);
*c_ptr='\0';
fclose(fp);
return sizes;
}
int checkCharPoolItem( char *id)
{
char fn[256];
FILE *fp;
makeCharPoolItemFileName( id , fn , sizeof(fn));
fp = fopen( fn , "r" );
if( fp == NULL ) {
if( saveCharPoolItem( id , "", 0) < 0 ){
log("\n Can't Create char:%s poolitem File!!", id);
return -1;
}
}else{
fclose(fp);
}
return 1;
}
#endif
#ifdef _CHAR_POOLPET
static void makeCharPoolPetFileName( char *id,char *output, int outlen)
{
char poolpet[256];
if ( strlen( id) < 1)return;
snprintf( poolpet , sizeof( poolpet ) , "%s.pet" , id);
makeDirFilename(output , outlen, chardir , getHash(id) ,poolpet);
}
#ifdef _SLEEP_CHAR // ȡ<>÷ǻ<C3B7>Ծ<EFBFBD><D4BE><EFBFBD><EFBFBD><EFBFBD>ֿ⵵<D6BF><E2B5B5>
static void makeSleepCharPoolPetFileName( char *id,char *output, int outlen)
{
char poolpet[256];
if ( strlen( id) < 1)return;
snprintf( poolpet , sizeof( poolpet ) , "%s.pet" , id);
makeDirFilename(output , outlen, sleepchardir , getHash(id) ,poolpet);
}
#endif
int InsertCharPoolPet( char *id , char *input, int sizes)
{
char fn[256];
FILE *fp;
if( sizes <= 0 ) return sizes;
makeCharPoolPetFileName( id , fn , sizeof(fn));
fp= fopen( fn , "a+" );
if( fp == NULL ) {
fp= fopen( fn , "w" );
if( fp == NULL ) {
log( "save %s error.\n", fn);
return -1;
}
}
fprintf( fp , "%s" , input );
fclose(fp);
log( "add %s charpoolpet file:%s\n", id , fn );
return sizes;
}
int saveCharPoolPet( char *id , char *input, int sizes)
{
char fn[256];
FILE *fp;
if( sizes < 0 ) return sizes;
if( input == NULL ) return -1;
makeCharPoolPetFileName( id , fn , sizeof(fn));
fp= fopen( fn , "w" );
if( fp == NULL ) {
log( "save %s error.\n", fn);
return -1;
}
fprintf( fp , "%s" , input );
fclose(fp);
log( "д<EFBFBD><EFBFBD> %s <20><><EFBFBD><EFBFBD><EFB5B5><EFBFBD>ļ<EFBFBD>:%s\n", id , fn );
return sizes;
}
int loadCharPoolPetOne( char *id , char *output , int outlen)
{
char fn[256];
FILE *fp;
char c_temp,*c_ptr;
int sizes=0;
c_ptr=output;
makeCharPoolPetFileName( id , fn , sizeof(fn));
fp = fopen( fn , "r" );
if( fp == NULL ){
if( (fp = fopen( fn , "w" )) == NULL)
return -1;
return 0;
}
do{
c_temp = fgetc(fp);
*c_ptr=c_temp;
c_ptr++;
sizes++;
if( sizes >= (outlen-1) ) break;
}while(c_temp != EOF);
*c_ptr='\0';
fclose(fp);
return sizes;
}
int checkCharPoolPet( char *id)
{
char fn[256];
FILE *fp;
makeCharPoolPetFileName( id , fn , sizeof(fn));
fp = fopen( fn , "r" );
if( fp == NULL ) {
if( saveCharPoolPet( id , "", 0) < 0 ){
log("\n Can't Create char:%s poolpet File!!", id);
return -1;
}
}else{
fclose(fp);
}
return 1;
}
#endif
int filecopy( char *oldfilename, char *newfilename)
{
FILE *oldfile;
FILE *newfile;
char c_temp;
if( (oldfile = fopen( oldfilename, "r") ) == NULL ) {
return -1;
}
if( (newfile = fopen( newfilename, "w") ) == NULL ) {
return -1;
}
while(1) {
c_temp = fgetc( oldfile);
if( c_temp == EOF)
break;
fputc( c_temp, newfile);
};
fclose( oldfile);
fclose( newfile);
return 0;
}