server/db/src/ClientManager.cpp

4985 lines
136 KiB
C++
Raw Normal View History

2022-03-05 12:44:06 +02:00
#include "stdafx.h"
2022-03-05 19:59:39 +02:00
#include <common/billing.h>
#include <common/building.h>
#include <common/VnumHelper.h>
2022-03-05 12:44:06 +02:00
#include "../../libgame/include/grid.h"
#include "ClientManager.h"
#include "Main.h"
#include "Config.h"
#include "DBManager.h"
#include "QID.h"
#include "GuildManager.h"
#include "PrivManager.h"
#include "MoneyLog.h"
#include "ItemAwardManager.h"
#include "Marriage.h"
#include "Monarch.h"
#include "BlockCountry.h"
#include "ItemIDRangeManager.h"
#include "Cache.h"
#ifdef __AUCTION__
#include "AuctionManager.h"
#endif
extern int g_iPlayerCacheFlushSeconds;
extern int g_iItemCacheFlushSeconds;
extern int g_test_server;
extern int g_log;
extern std::string g_stLocale;
extern std::string g_stLocaleNameColumn;
bool CreateItemTableFromRes(MYSQL_RES * res, std::vector<TPlayerItem> * pVec, DWORD dwPID);
DWORD g_dwUsageMax = 0;
DWORD g_dwUsageAvg = 0;
CPacketInfo g_query_info;
CPacketInfo g_item_info;
int g_item_count = 0;
int g_query_count[2];
CClientManager::CClientManager() :
m_pkAuthPeer(NULL),
m_iPlayerIDStart(0),
m_iPlayerDeleteLevelLimit(0),
m_iPlayerDeleteLevelLimitLower(0),
m_bChinaEventServer(false),
m_iShopTableSize(0),
m_pShopTable(NULL),
m_iRefineTableSize(0),
m_pRefineTable(NULL),
m_bShutdowned(FALSE),
m_iCacheFlushCount(0),
m_iCacheFlushCountLimit(200)
{
m_itemRange.dwMin = 0;
m_itemRange.dwMax = 0;
m_itemRange.dwUsableItemIDMin = 0;
memset(g_query_count, 0, sizeof(g_query_count));
}
CClientManager::~CClientManager()
{
Destroy();
}
void CClientManager::SetPlayerIDStart(int iIDStart)
{
m_iPlayerIDStart = iIDStart;
}
void CClientManager::Destroy()
{
m_mChannelStatus.clear();
for (itertype(m_peerList) i = m_peerList.begin(); i != m_peerList.end(); ++i)
(*i)->Destroy();
m_peerList.clear();
if (m_fdAccept > 0)
{
socket_close(m_fdAccept);
m_fdAccept = -1;
}
}
bool CClientManager::Initialize()
{
int tmpValue;
//BOOT_LOCALIZATION
if (!InitializeLocalization())
{
fprintf(stderr, "Failed Localization Infomation so exit\n");
return false;
}
//END_BOOT_LOCALIZATION
//ITEM_UNIQUE_ID
if (!InitializeNowItemID())
{
fprintf(stderr, " Item range Initialize Failed. Exit DBCache Server\n");
return false;
}
//END_ITEM_UNIQUE_ID
if (!InitializeTables())
{
sys_err("Table Initialize FAILED");
return false;
}
CGuildManager::instance().BootReserveWar();
if (!CConfig::instance().GetValue("BIND_PORT", &tmpValue))
tmpValue = 5300;
char szBindIP[128];
if (!CConfig::instance().GetValue("BIND_IP", szBindIP, 128))
2022-03-05 19:59:39 +02:00
strncpy(szBindIP, "0", sizeof(szBindIP));
2022-03-05 12:44:06 +02:00
m_fdAccept = socket_tcp_bind(szBindIP, tmpValue);
if (m_fdAccept < 0)
{
perror("socket");
return false;
}
sys_log(0, "ACCEPT_HANDLE: %u", m_fdAccept);
fdwatch_add_fd(m_fdWatcher, m_fdAccept, NULL, FDW_READ, false);
if (!CConfig::instance().GetValue("BACKUP_LIMIT_SEC", &tmpValue))
tmpValue = 600;
m_looping = true;
if (!CConfig::instance().GetValue("PLAYER_DELETE_LEVEL_LIMIT", &m_iPlayerDeleteLevelLimit))
{
sys_err("conf.txt: Cannot find PLAYER_DELETE_LEVEL_LIMIT, use default level %d", PLAYER_MAX_LEVEL_CONST + 1);
m_iPlayerDeleteLevelLimit = PLAYER_MAX_LEVEL_CONST + 1;
}
if (!CConfig::instance().GetValue("PLAYER_DELETE_LEVEL_LIMIT_LOWER", &m_iPlayerDeleteLevelLimitLower))
{
m_iPlayerDeleteLevelLimitLower = 0;
}
sys_log(0, "PLAYER_DELETE_LEVEL_LIMIT set to %d", m_iPlayerDeleteLevelLimit);
sys_log(0, "PLAYER_DELETE_LEVEL_LIMIT_LOWER set to %d", m_iPlayerDeleteLevelLimitLower);
m_bChinaEventServer = false;
int iChinaEventServer = 0;
if (CConfig::instance().GetValue("CHINA_EVENT_SERVER", &iChinaEventServer))
m_bChinaEventServer = (iChinaEventServer);
sys_log(0, "CHINA_EVENT_SERVER %s", CClientManager::instance().IsChinaEventServer()?"true":"false");
LoadEventFlag();
// database character-set<65><74> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
if (g_stLocale == "big5" || g_stLocale == "sjis")
CDBManager::instance().QueryLocaleSet();
return true;
}
void CClientManager::MainLoop()
{
SQLMsg * tmp;
sys_log(0, "ClientManager pointer is %p", this);
// <20><><EFBFBD>η<EFBFBD><CEB7><EFBFBD>
while (!m_bShutdowned)
{
while ((tmp = CDBManager::instance().PopResult()))
{
AnalyzeQueryResult(tmp);
delete tmp;
}
if (!Process())
break;
log_rotate();
}
//
// <20><><EFBFBD>η<EFBFBD><CEB7><EFBFBD> <20><><EFBFBD><EFBFBD>ó<EFBFBD><C3B3>
//
sys_log(0, "MainLoop exited, Starting cache flushing");
signal_timer_disable();
itertype(m_map_playerCache) it = m_map_playerCache.begin();
//<2F>÷<EFBFBD><C3B7>̾<EFBFBD> <20><><EFBFBD>̺<EFBFBD> ij<><C4B3> <20>÷<EFBFBD><C3B7><EFBFBD>
while (it != m_map_playerCache.end())
{
CPlayerTableCache * c = (it++)->second;
c->Flush();
delete c;
}
m_map_playerCache.clear();
itertype(m_map_itemCache) it2 = m_map_itemCache.begin();
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>÷<EFBFBD><C3B7><EFBFBD>
while (it2 != m_map_itemCache.end())
{
CItemCache * c = (it2++)->second;
c->Flush();
delete c;
}
m_map_itemCache.clear();
// MYSHOP_PRICE_LIST
//
// <20><><EFBFBD>λ<EFBFBD><CEBB><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>Ʈ Flush
//
for (itertype(m_mapItemPriceListCache) itPriceList = m_mapItemPriceListCache.begin(); itPriceList != m_mapItemPriceListCache.end(); ++itPriceList)
{
CItemPriceListTableCache* pCache = itPriceList->second;
pCache->Flush();
delete pCache;
}
m_mapItemPriceListCache.clear();
// END_OF_MYSHOP_PRICE_LIST
}
void CClientManager::Quit()
{
m_bShutdowned = TRUE;
}
void CClientManager::QUERY_BOOT(CPeer* peer, TPacketGDBoot * p)
{
const BYTE bPacketVersion = 6; // BOOT <20><>Ŷ<EFBFBD><C5B6> <20>ٲ𶧸<D9B2><F0B6A7B8><EFBFBD> <20><>ȣ<EFBFBD><C8A3> <20>ø<EFBFBD><C3B8><EFBFBD><EFBFBD><EFBFBD> <20>Ѵ<EFBFBD>.
std::vector<tAdminInfo> vAdmin;
std::vector<std::string> vHost;
__GetHostInfo(vHost);
__GetAdminInfo(p->szIP, vAdmin);
sys_log(0, "QUERY_BOOT : AdminInfo (Request ServerIp %s) ", p->szIP);
DWORD dwPacketSize =
sizeof(DWORD) +
sizeof(BYTE) +
sizeof(WORD) + sizeof(WORD) + sizeof(TMobTable) * m_vec_mobTable.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(TItemTable) * m_vec_itemTable.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(TShopTable) * m_iShopTableSize +
sizeof(WORD) + sizeof(WORD) + sizeof(TSkillTable) * m_vec_skillTable.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(TRefineTable) * m_iRefineTableSize +
sizeof(WORD) + sizeof(WORD) + sizeof(TItemAttrTable) * m_vec_itemAttrTable.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(TItemAttrTable) * m_vec_itemRareTable.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(TBanwordTable) * m_vec_banwordTable.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(building::TLand) * m_vec_kLandTable.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(building::TObjectProto) * m_vec_kObjectProto.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(building::TObject) * m_map_pkObjectTable.size() +
#ifdef __AUCTION__
sizeof(WORD) + sizeof(WORD) + sizeof(TPlayerItem) * AuctionManager::instance().GetAuctionItemSize() +
sizeof(WORD) + sizeof(WORD) + sizeof(TAuctionItemInfo) * AuctionManager::instance().GetAuctionSize() +
sizeof(WORD) + sizeof(WORD) + sizeof(TSaleItemInfo) * AuctionManager::instance().GetSaleSize() +
sizeof(WORD) + sizeof(WORD) + sizeof(TWishItemInfo) * AuctionManager::instance().GetWishSize() +
sizeof(WORD) + sizeof(WORD) + (sizeof(DWORD) + sizeof(DWORD) + sizeof(int)) * AuctionManager::instance().GetMyBidSize() +
#endif
sizeof(time_t) +
sizeof(WORD) + sizeof(WORD) + sizeof(TItemIDRangeTable)*2 +
//ADMIN_MANAGER
sizeof(WORD) + sizeof(WORD) + 16 * vHost.size() +
sizeof(WORD) + sizeof(WORD) + sizeof(tAdminInfo) * vAdmin.size() +
//END_ADMIN_MANAGER
sizeof(WORD) + sizeof(WORD) + sizeof(TMonarchInfo) +
sizeof(WORD) + sizeof(WORD) + sizeof(MonarchCandidacy)* CMonarch::instance().MonarchCandidacySize() +
sizeof(WORD);
peer->EncodeHeader(HEADER_DG_BOOT, 0, dwPacketSize);
peer->Encode(&dwPacketSize, sizeof(DWORD));
peer->Encode(&bPacketVersion, sizeof(BYTE));
sys_log(0, "BOOT: PACKET: %d", dwPacketSize);
sys_log(0, "BOOT: VERSION: %d", bPacketVersion);
sys_log(0, "sizeof(TMobTable) = %d", sizeof(TMobTable));
sys_log(0, "sizeof(TItemTable) = %d", sizeof(TItemTable));
sys_log(0, "sizeof(TShopTable) = %d", sizeof(TShopTable));
sys_log(0, "sizeof(TSkillTable) = %d", sizeof(TSkillTable));
sys_log(0, "sizeof(TRefineTable) = %d", sizeof(TRefineTable));
sys_log(0, "sizeof(TItemAttrTable) = %d", sizeof(TItemAttrTable));
sys_log(0, "sizeof(TItemRareTable) = %d", sizeof(TItemAttrTable));
sys_log(0, "sizeof(TBanwordTable) = %d", sizeof(TBanwordTable));
sys_log(0, "sizeof(TLand) = %d", sizeof(building::TLand));
sys_log(0, "sizeof(TObjectProto) = %d", sizeof(building::TObjectProto));
sys_log(0, "sizeof(TObject) = %d", sizeof(building::TObject));
//ADMIN_MANAGER
sys_log(0, "sizeof(tAdminInfo) = %d * %d ", sizeof(tAdminInfo) * vAdmin.size());
//END_ADMIN_MANAGER
sys_log(0, "sizeof(TMonarchInfo) = %d * %d", sizeof(TMonarchInfo));
peer->EncodeWORD(sizeof(TMobTable));
peer->EncodeWORD(m_vec_mobTable.size());
peer->Encode(&m_vec_mobTable[0], sizeof(TMobTable) * m_vec_mobTable.size());
peer->EncodeWORD(sizeof(TItemTable));
peer->EncodeWORD(m_vec_itemTable.size());
peer->Encode(&m_vec_itemTable[0], sizeof(TItemTable) * m_vec_itemTable.size());
peer->EncodeWORD(sizeof(TShopTable));
peer->EncodeWORD(m_iShopTableSize);
peer->Encode(m_pShopTable, sizeof(TShopTable) * m_iShopTableSize);
peer->EncodeWORD(sizeof(TSkillTable));
peer->EncodeWORD(m_vec_skillTable.size());
peer->Encode(&m_vec_skillTable[0], sizeof(TSkillTable) * m_vec_skillTable.size());
peer->EncodeWORD(sizeof(TRefineTable));
peer->EncodeWORD(m_iRefineTableSize);
peer->Encode(m_pRefineTable, sizeof(TRefineTable) * m_iRefineTableSize);
peer->EncodeWORD(sizeof(TItemAttrTable));
peer->EncodeWORD(m_vec_itemAttrTable.size());
peer->Encode(&m_vec_itemAttrTable[0], sizeof(TItemAttrTable) * m_vec_itemAttrTable.size());
peer->EncodeWORD(sizeof(TItemAttrTable));
peer->EncodeWORD(m_vec_itemRareTable.size());
peer->Encode(&m_vec_itemRareTable[0], sizeof(TItemAttrTable) * m_vec_itemRareTable.size());
peer->EncodeWORD(sizeof(TBanwordTable));
peer->EncodeWORD(m_vec_banwordTable.size());
peer->Encode(&m_vec_banwordTable[0], sizeof(TBanwordTable) * m_vec_banwordTable.size());
peer->EncodeWORD(sizeof(building::TLand));
peer->EncodeWORD(m_vec_kLandTable.size());
peer->Encode(&m_vec_kLandTable[0], sizeof(building::TLand) * m_vec_kLandTable.size());
peer->EncodeWORD(sizeof(building::TObjectProto));
peer->EncodeWORD(m_vec_kObjectProto.size());
peer->Encode(&m_vec_kObjectProto[0], sizeof(building::TObjectProto) * m_vec_kObjectProto.size());
peer->EncodeWORD(sizeof(building::TObject));
peer->EncodeWORD(m_map_pkObjectTable.size());
itertype(m_map_pkObjectTable) it = m_map_pkObjectTable.begin();
while (it != m_map_pkObjectTable.end())
peer->Encode((it++)->second, sizeof(building::TObject));
// Auction Boot
#ifdef __AUCTION__
AuctionManager::instance().Boot (peer);
#endif
time_t now = time(0);
peer->Encode(&now, sizeof(time_t));
TItemIDRangeTable itemRange = CItemIDRangeManager::instance().GetRange();
TItemIDRangeTable itemRangeSpare = CItemIDRangeManager::instance().GetRange();
peer->EncodeWORD(sizeof(TItemIDRangeTable));
peer->EncodeWORD(1);
peer->Encode(&itemRange, sizeof(TItemIDRangeTable));
peer->Encode(&itemRangeSpare, sizeof(TItemIDRangeTable));
peer->SetItemIDRange(itemRange);
peer->SetSpareItemIDRange(itemRangeSpare);
//ADMIN_MANAGER
peer->EncodeWORD(16);
peer->EncodeWORD(vHost.size());
for (size_t n = 0; n < vHost.size(); ++n)
{
peer->Encode(vHost[n].c_str(), 16);
sys_log(0, "GMHosts %s", vHost[n].c_str());
}
peer->EncodeWORD(sizeof(tAdminInfo));
peer->EncodeWORD(vAdmin.size());
for (size_t n = 0; n < vAdmin.size(); ++n)
{
peer->Encode(&vAdmin[n], sizeof(tAdminInfo));
sys_log(0, "Admin name %s ConntactIP %s", vAdmin[n].m_szName, vAdmin[n].m_szContactIP);
}
//END_ADMIN_MANAGER
//MONARCH
peer->EncodeWORD(sizeof(TMonarchInfo));
peer->EncodeWORD(1);
peer->Encode(CMonarch::instance().GetMonarch(), sizeof(TMonarchInfo));
CMonarch::VEC_MONARCHCANDIDACY & rVecMonarchCandidacy = CMonarch::instance().GetVecMonarchCandidacy();
size_t num_monarch_candidacy = CMonarch::instance().MonarchCandidacySize();
peer->EncodeWORD(sizeof(MonarchCandidacy));
peer->EncodeWORD(num_monarch_candidacy);
if (num_monarch_candidacy != 0) {
peer->Encode(&rVecMonarchCandidacy[0], sizeof(MonarchCandidacy) * num_monarch_candidacy);
}
//END_MONARCE
if (g_test_server)
sys_log(0, "MONARCHCandidacy Size %d", CMonarch::instance().MonarchCandidacySize());
peer->EncodeWORD(0xffff);
}
void CClientManager::SendPartyOnSetup(CPeer* pkPeer)
{
TPartyMap & pm = m_map_pkChannelParty[pkPeer->GetChannel()];
for (itertype(pm) it_party = pm.begin(); it_party != pm.end(); ++it_party)
{
sys_log(0, "PARTY SendPartyOnSetup Party [%u]", it_party->first);
pkPeer->EncodeHeader(HEADER_DG_PARTY_CREATE, 0, sizeof(TPacketPartyCreate));
pkPeer->Encode(&it_party->first, sizeof(DWORD));
for (itertype(it_party->second) it_member = it_party->second.begin(); it_member != it_party->second.end(); ++it_member)
{
sys_log(0, "PARTY SendPartyOnSetup Party [%u] Member [%u]", it_party->first, it_member->first);
pkPeer->EncodeHeader(HEADER_DG_PARTY_ADD, 0, sizeof(TPacketPartyAdd));
pkPeer->Encode(&it_party->first, sizeof(DWORD));
pkPeer->Encode(&it_member->first, sizeof(DWORD));
pkPeer->Encode(&it_member->second.bRole, sizeof(BYTE));
pkPeer->EncodeHeader(HEADER_DG_PARTY_SET_MEMBER_LEVEL, 0, sizeof(TPacketPartySetMemberLevel));
pkPeer->Encode(&it_party->first, sizeof(DWORD));
pkPeer->Encode(&it_member->first, sizeof(DWORD));
pkPeer->Encode(&it_member->second.bLevel, sizeof(BYTE));
}
}
}
void CClientManager::QUERY_PLAYER_COUNT(CPeer * pkPeer, TPlayerCountPacket * pPacket)
{
pkPeer->SetUserCount(pPacket->dwCount);
}
void CClientManager::QUERY_QUEST_SAVE(CPeer * pkPeer, TQuestTable * pTable, DWORD dwLen)
{
if (0 != (dwLen % sizeof(TQuestTable)))
{
sys_err("invalid packet size %d, sizeof(TQuestTable) == %d", dwLen, sizeof(TQuestTable));
return;
}
int iSize = dwLen / sizeof(TQuestTable);
char szQuery[1024];
for (int i = 0; i < iSize; ++i, ++pTable)
{
if (pTable->lValue == 0)
{
snprintf(szQuery, sizeof(szQuery),
"DELETE FROM quest%s WHERE dwPID=%d AND szName='%s' AND szState='%s'",
GetTablePostfix(), pTable->dwPID, pTable->szName, pTable->szState);
}
else
{
snprintf(szQuery, sizeof(szQuery),
"REPLACE INTO quest%s (dwPID, szName, szState, lValue) VALUES(%d, '%s', '%s', %ld)",
GetTablePostfix(), pTable->dwPID, pTable->szName, pTable->szState, pTable->lValue);
}
CDBManager::instance().ReturnQuery(szQuery, QID_QUEST_SAVE, pkPeer->GetHandle(), NULL);
}
}
void CClientManager::QUERY_SAFEBOX_LOAD(CPeer * pkPeer, DWORD dwHandle, TSafeboxLoadPacket * packet, bool bMall)
{
ClientHandleInfo * pi = new ClientHandleInfo(dwHandle);
2022-03-05 19:59:39 +02:00
strncpy(pi->safebox_password, packet->szPassword, sizeof(pi->safebox_password));
2022-03-05 12:44:06 +02:00
pi->account_id = packet->dwID;
pi->account_index = 0;
pi->ip[0] = bMall ? 1 : 0;
2022-03-05 19:59:39 +02:00
strncpy(pi->login, packet->szLogin, sizeof(pi->login));
2022-03-05 12:44:06 +02:00
char szQuery[QUERY_MAX_LEN];
snprintf(szQuery, sizeof(szQuery),
"SELECT account_id, size, password FROM safebox%s WHERE account_id=%u",
GetTablePostfix(), packet->dwID);
if (g_log)
sys_log(0, "HEADER_GD_SAFEBOX_LOAD (handle: %d account.id %u is_mall %d)", dwHandle, packet->dwID, bMall ? 1 : 0);
CDBManager::instance().ReturnQuery(szQuery, QID_SAFEBOX_LOAD, pkPeer->GetHandle(), pi);
}
void CClientManager::RESULT_SAFEBOX_LOAD(CPeer * pkPeer, SQLMsg * msg)
{
CQueryInfo * qi = (CQueryInfo *) msg->pvUserData;
ClientHandleInfo * pi = (ClientHandleInfo *) qi->pvData;
DWORD dwHandle = pi->dwHandle;
// <20><><EFBFBD><EFBFBD><E2BFA1> <20><><EFBFBD><EFBFBD><EFBFBD>ϴ<EFBFBD> account_index<65><78> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD>Ѵ<EFBFBD>.
// ù<><C3B9>° <20>н<EFBFBD><D0BD><EFBFBD><EFBFBD><EFBFBD> <20>˾Ƴ<CBBE><C6B3><EFBFBD> <20><><EFBFBD><EFBFBD> <20>ϴ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 0
// <20>ι<EFBFBD>° <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>͸<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> 1
if (pi->account_index == 0)
{
char szSafeboxPassword[SAFEBOX_PASSWORD_MAX_LEN + 1];
2022-03-05 19:59:39 +02:00
strncpy(szSafeboxPassword, pi->safebox_password, sizeof(szSafeboxPassword));
2022-03-05 12:44:06 +02:00
TSafeboxTable * pSafebox = new TSafeboxTable;
memset(pSafebox, 0, sizeof(TSafeboxTable));
SQLResult * res = msg->Get();
if (res->uiNumRows == 0)
{
if (strcmp("000000", szSafeboxPassword))
{
pkPeer->EncodeHeader(HEADER_DG_SAFEBOX_WRONG_PASSWORD, dwHandle, 0);
delete pi;
return;
}
}
else
{
MYSQL_ROW row = mysql_fetch_row(res->pSQLResult);
// <20><><EFBFBD>й<EFBFBD>ȣ<EFBFBD><C8A3> Ʋ<><C6B2><EFBFBD><EFBFBD>..
if (((!row[2] || !*row[2]) && strcmp("000000", szSafeboxPassword)) ||
((row[2] && *row[2]) && strcmp(row[2], szSafeboxPassword)))
{
pkPeer->EncodeHeader(HEADER_DG_SAFEBOX_WRONG_PASSWORD, dwHandle, 0);
delete pi;
return;
}
if (!row[0])
pSafebox->dwID = 0;
else
str_to_number(pSafebox->dwID, row[0]);
if (!row[1])
pSafebox->bSize = 0;
else
str_to_number(pSafebox->bSize, row[1]);
/*
if (!row[3])
pSafebox->dwGold = 0;
else
pSafebox->dwGold = atoi(row[3]);
*/
if (pi->ip[0] == 1)
{
pSafebox->bSize = 1;
sys_log(0, "MALL id[%d] size[%d]", pSafebox->dwID, pSafebox->bSize);
}
else
sys_log(0, "SAFEBOX id[%d] size[%d]", pSafebox->dwID, pSafebox->bSize);
}
if (0 == pSafebox->dwID)
pSafebox->dwID = pi->account_id;
pi->pSafebox = pSafebox;
char szQuery[512];
snprintf(szQuery, sizeof(szQuery),
"SELECT id, window+0, pos, count, vnum, socket0, socket1, socket2, "
"attrtype0, attrvalue0, "
"attrtype1, attrvalue1, "
"attrtype2, attrvalue2, "
"attrtype3, attrvalue3, "
"attrtype4, attrvalue4, "
"attrtype5, attrvalue5, "
"attrtype6, attrvalue6 "
"FROM item%s WHERE owner_id=%d AND window='%s'",
GetTablePostfix(), pi->account_id, pi->ip[0] == 0 ? "SAFEBOX" : "MALL");
pi->account_index = 1;
CDBManager::instance().ReturnQuery(szQuery, QID_SAFEBOX_LOAD, pkPeer->GetHandle(), pi);
}
else
{
if (!pi->pSafebox)
{
sys_err("null safebox pointer!");
delete pi;
return;
}
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>־<EFBFBD><D6BE><EFBFBD><EFBFBD>Ƿ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> â<><C3A2><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ִ<EFBFBD> <20><> ó<><C3B3>
// <20><><EFBFBD>̱<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> â<><C3A2><EFBFBD><EFBFBD> <20>ƾ<EFBFBD> <20>ȿ<EFBFBD><C8BF><EFBFBD><EFBFBD>°<EFBFBD> <20><><EFBFBD><EFBFBD>
if (!msg->Get()->pSQLResult)
{
sys_err("null safebox result");
delete pi;
return;
}
static std::vector<TPlayerItem> s_items;
CreateItemTableFromRes(msg->Get()->pSQLResult, &s_items, pi->account_id);
std::set<TItemAward *> * pSet = ItemAwardManager::instance().GetByLogin(pi->login);
if (pSet && !m_vec_itemTable.empty())
{
CGrid grid(5, MAX(1, pi->pSafebox->bSize) * 9);
bool bEscape = false;
for (DWORD i = 0; i < s_items.size(); ++i)
{
TPlayerItem & r = s_items[i];
itertype(m_map_itemTableByVnum) it = m_map_itemTableByVnum.find(r.vnum);
if (it == m_map_itemTableByVnum.end())
{
bEscape = true;
sys_err("invalid item vnum %u in safebox: login %s", r.vnum, pi->login);
break;
}
grid.Put(r.pos, 1, it->second->bSize);
}
if (!bEscape)
{
std::vector<std::pair<DWORD, DWORD> > vec_dwFinishedAwardID;
typeof(pSet->begin()) it = pSet->begin();
char szQuery[512];
while (it != pSet->end())
{
TItemAward * pItemAward = *(it++);
const DWORD& dwItemVnum = pItemAward->dwVnum;
if (pItemAward->bTaken)
continue;
if (pi->ip[0] == 0 && pItemAward->bMall)
continue;
if (pi->ip[0] == 1 && !pItemAward->bMall)
continue;
itertype(m_map_itemTableByVnum) it = m_map_itemTableByVnum.find(pItemAward->dwVnum);
if (it == m_map_itemTableByVnum.end())
{
sys_err("invalid item vnum %u in item_award: login %s", pItemAward->dwVnum, pi->login);
continue;
}
TItemTable * pItemTable = it->second;
int iPos;
if ((iPos = grid.FindBlank(1, it->second->bSize)) == -1)
break;
TPlayerItem item;
memset(&item, 0, sizeof(TPlayerItem));
DWORD dwSocket2 = 0;
if (pItemTable->bType == ITEM_UNIQUE)
{
if (pItemAward->dwSocket2 != 0)
dwSocket2 = pItemAward->dwSocket2;
else
dwSocket2 = pItemTable->alValues[0];
}
else if ((dwItemVnum == 50300 || dwItemVnum == 70037) && pItemAward->dwSocket0 == 0)
{
DWORD dwSkillIdx;
DWORD dwSkillVnum;
do
{
dwSkillIdx = number(0, m_vec_skillTable.size()-1);
dwSkillVnum = m_vec_skillTable[dwSkillIdx].dwVnum;
if (!dwSkillVnum > 120)
continue;
break;
} while (1);
pItemAward->dwSocket0 = dwSkillVnum;
}
else
{
switch (dwItemVnum)
{
case 72723: case 72724: case 72725: case 72726:
case 72727: case 72728: case 72729: case 72730:
// <20><><EFBFBD>ù<EFBFBD><C3B9><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ϴ<EFBFBD> <20><> <20><>ġ<EFBFBD><C4A1><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>...
// <20>׷<EFBFBD><D7B7><EFBFBD> <20>׳<EFBFBD> <20>ϵ<EFBFBD> <20>ڵ<EFBFBD>. <20><><EFBFBD><EFBFBD> <20><><EFBFBD>ڿ<EFBFBD> <20>ڵ<EFBFBD><DAB5><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>۵<EFBFBD>.
case 76004: case 76005: case 76021: case 76022:
case 79012: case 79013:
if (pItemAward->dwSocket2 == 0)
{
dwSocket2 = pItemTable->alValues[0];
}
else
{
dwSocket2 = pItemAward->dwSocket2;
}
break;
}
}
if (GetItemID () > m_itemRange.dwMax)
{
sys_err("UNIQUE ID OVERFLOW!!");
break;
}
{
itertype(m_map_itemTableByVnum) it = m_map_itemTableByVnum.find (dwItemVnum);
if (it == m_map_itemTableByVnum.end())
{
sys_err ("Invalid item(vnum : %d). It is not in m_map_itemTableByVnum.", dwItemVnum);
continue;
}
TItemTable* item_table = it->second;
if (item_table == NULL)
{
sys_err ("Invalid item_table (vnum : %d). It's value is NULL in m_map_itemTableByVnum.", dwItemVnum);
continue;
}
if (0 == pItemAward->dwSocket0)
{
for (int i = 0; i < ITEM_LIMIT_MAX_NUM; i++)
{
if (LIMIT_REAL_TIME == item_table->aLimits[i].bType)
{
if (0 == item_table->aLimits[i].lValue)
pItemAward->dwSocket0 = time(0) + 60 * 60 * 24 * 7;
else
pItemAward->dwSocket0 = time(0) + item_table->aLimits[i].lValue;
break;
}
else if (LIMIT_REAL_TIME_START_FIRST_USE == item_table->aLimits[i].bType || LIMIT_TIMER_BASED_ON_WEAR == item_table->aLimits[i].bType)
{
if (0 == item_table->aLimits[i].lValue)
pItemAward->dwSocket0 = 60 * 60 * 24 * 7;
else
pItemAward->dwSocket0 = item_table->aLimits[i].lValue;
break;
}
}
}
snprintf(szQuery, sizeof(szQuery),
"INSERT INTO item%s (id, owner_id, window, pos, vnum, count, socket0, socket1, socket2) "
"VALUES(%u, %u, '%s', %d, %u, %u, %u, %u, %u)",
GetTablePostfix(),
GainItemID(),
pi->account_id,
pi->ip[0] == 0 ? "SAFEBOX" : "MALL",
iPos,
pItemAward->dwVnum, pItemAward->dwCount, pItemAward->dwSocket0, pItemAward->dwSocket1, dwSocket2);
}
std::auto_ptr<SQLMsg> pmsg(CDBManager::instance().DirectQuery(szQuery));
SQLResult * pRes = pmsg->Get();
sys_log(0, "SAFEBOX Query : [%s]", szQuery);
if (pRes->uiAffectedRows == 0 || pRes->uiInsertID == 0 || pRes->uiAffectedRows == (uint32_t)-1)
break;
item.id = pmsg->Get()->uiInsertID;
item.window = pi->ip[0] == 0 ? SAFEBOX : MALL,
item.pos = iPos;
item.count = pItemAward->dwCount;
item.vnum = pItemAward->dwVnum;
item.alSockets[0] = pItemAward->dwSocket0;
item.alSockets[1] = pItemAward->dwSocket1;
item.alSockets[2] = dwSocket2;
s_items.push_back(item);
vec_dwFinishedAwardID.push_back(std::make_pair(pItemAward->dwID, item.id));
grid.Put(iPos, 1, it->second->bSize);
}
for (DWORD i = 0; i < vec_dwFinishedAwardID.size(); ++i)
ItemAwardManager::instance().Taken(vec_dwFinishedAwardID[i].first, vec_dwFinishedAwardID[i].second);
}
}
pi->pSafebox->wItemCount = s_items.size();
pkPeer->EncodeHeader(pi->ip[0] == 0 ? HEADER_DG_SAFEBOX_LOAD : HEADER_DG_MALL_LOAD, dwHandle, sizeof(TSafeboxTable) + sizeof(TPlayerItem) * s_items.size());
pkPeer->Encode(pi->pSafebox, sizeof(TSafeboxTable));
if (!s_items.empty())
pkPeer->Encode(&s_items[0], sizeof(TPlayerItem) * s_items.size());
delete pi;
}
}
void CClientManager::QUERY_SAFEBOX_CHANGE_SIZE(CPeer * pkPeer, DWORD dwHandle, TSafeboxChangeSizePacket * p)
{
ClientHandleInfo * pi = new ClientHandleInfo(dwHandle);
pi->account_index = p->bSize; // account_index<65><78> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ӽ÷<D3BD> <20><><EFBFBD><EFBFBD>
char szQuery[QUERY_MAX_LEN];
if (p->bSize == 1)
snprintf(szQuery, sizeof(szQuery), "INSERT INTO safebox%s (account_id, size) VALUES(%u, %u)", GetTablePostfix(), p->dwID, p->bSize);
else
snprintf(szQuery, sizeof(szQuery), "UPDATE safebox%s SET size=%u WHERE account_id=%u", GetTablePostfix(), p->bSize, p->dwID);
CDBManager::instance().ReturnQuery(szQuery, QID_SAFEBOX_CHANGE_SIZE, pkPeer->GetHandle(), pi);
}
void CClientManager::RESULT_SAFEBOX_CHANGE_SIZE(CPeer * pkPeer, SQLMsg * msg)
{
CQueryInfo * qi = (CQueryInfo *) msg->pvUserData;
ClientHandleInfo * p = (ClientHandleInfo *) qi->pvData;
DWORD dwHandle = p->dwHandle;
BYTE bSize = p->account_index;
delete p;
if (msg->Get()->uiNumRows > 0)
{
pkPeer->EncodeHeader(HEADER_DG_SAFEBOX_CHANGE_SIZE, dwHandle, sizeof(BYTE));
pkPeer->EncodeBYTE(bSize);
}
}
void CClientManager::QUERY_SAFEBOX_CHANGE_PASSWORD(CPeer * pkPeer, DWORD dwHandle, TSafeboxChangePasswordPacket * p)
{
ClientHandleInfo * pi = new ClientHandleInfo(dwHandle);
2022-03-05 19:59:39 +02:00
strncpy(pi->safebox_password, p->szNewPassword, sizeof(pi->safebox_password));
strncpy(pi->login, p->szOldPassword, sizeof(pi->login));
2022-03-05 12:44:06 +02:00
pi->account_id = p->dwID;
char szQuery[QUERY_MAX_LEN];
snprintf(szQuery, sizeof(szQuery), "SELECT password FROM safebox%s WHERE account_id=%u", GetTablePostfix(), p->dwID);
CDBManager::instance().ReturnQuery(szQuery, QID_SAFEBOX_CHANGE_PASSWORD, pkPeer->GetHandle(), pi);
}
void CClientManager::RESULT_SAFEBOX_CHANGE_PASSWORD(CPeer * pkPeer, SQLMsg * msg)
{
CQueryInfo * qi = (CQueryInfo *) msg->pvUserData;
ClientHandleInfo * p = (ClientHandleInfo *) qi->pvData;
DWORD dwHandle = p->dwHandle;
if (msg->Get()->uiNumRows > 0)
{
MYSQL_ROW row = mysql_fetch_row(msg->Get()->pSQLResult);
if (row[0] && *row[0] && !strcasecmp(row[0], p->login) || (!row[0] || !*row[0]) && !strcmp("000000", p->login))
{
char szQuery[QUERY_MAX_LEN];
char escape_pwd[64];
CDBManager::instance().EscapeString(escape_pwd, p->safebox_password, strlen(p->safebox_password));
snprintf(szQuery, sizeof(szQuery), "UPDATE safebox%s SET password='%s' WHERE account_id=%u", GetTablePostfix(), escape_pwd, p->account_id);
CDBManager::instance().ReturnQuery(szQuery, QID_SAFEBOX_CHANGE_PASSWORD_SECOND, pkPeer->GetHandle(), p);
return;
}
}
delete p;
// Wrong old password
pkPeer->EncodeHeader(HEADER_DG_SAFEBOX_CHANGE_PASSWORD_ANSWER, dwHandle, sizeof(BYTE));
pkPeer->EncodeBYTE(0);
}
void CClientManager::RESULT_SAFEBOX_CHANGE_PASSWORD_SECOND(CPeer * pkPeer, SQLMsg * msg)
{
CQueryInfo * qi = (CQueryInfo *) msg->pvUserData;
ClientHandleInfo * p = (ClientHandleInfo *) qi->pvData;
DWORD dwHandle = p->dwHandle;
delete p;
pkPeer->EncodeHeader(HEADER_DG_SAFEBOX_CHANGE_PASSWORD_ANSWER, dwHandle, sizeof(BYTE));
pkPeer->EncodeBYTE(1);
}
// MYSHOP_PRICE_LIST
void CClientManager::RESULT_PRICELIST_LOAD(CPeer* peer, SQLMsg* pMsg)
{
TItemPricelistReqInfo* pReqInfo = (TItemPricelistReqInfo*)static_cast<CQueryInfo*>(pMsg->pvUserData)->pvData;
//
// DB <20><><EFBFBD><EFBFBD> <20>ε<EFBFBD><CEB5><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Cache <20><> <20><><EFBFBD><EFBFBD>
//
TItemPriceListTable table;
table.dwOwnerID = pReqInfo->second;
table.byCount = 0;
MYSQL_ROW row;
while ((row = mysql_fetch_row(pMsg->Get()->pSQLResult)))
{
str_to_number(table.aPriceInfo[table.byCount].dwVnum, row[0]);
str_to_number(table.aPriceInfo[table.byCount].dwPrice, row[1]);
table.byCount++;
}
PutItemPriceListCache(&table);
//
// <20>ε<EFBFBD><CEB5><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>͸<EFBFBD> Game server <20><> <20><><EFBFBD><EFBFBD>
//
TPacketMyshopPricelistHeader header;
header.dwOwnerID = pReqInfo->second;
header.byCount = table.byCount;
size_t sizePriceListSize = sizeof(TItemPriceInfo) * header.byCount;
peer->EncodeHeader(HEADER_DG_MYSHOP_PRICELIST_RES, pReqInfo->first, sizeof(header) + sizePriceListSize);
peer->Encode(&header, sizeof(header));
peer->Encode(table.aPriceInfo, sizePriceListSize);
sys_log(0, "Load MyShopPricelist handle[%d] pid[%d] count[%d]", pReqInfo->first, pReqInfo->second, header.byCount);
delete pReqInfo;
}
void CClientManager::RESULT_PRICELIST_LOAD_FOR_UPDATE(SQLMsg* pMsg)
{
TItemPriceListTable* pUpdateTable = (TItemPriceListTable*)static_cast<CQueryInfo*>(pMsg->pvUserData)->pvData;
//
// DB <20><><EFBFBD><EFBFBD> <20>ε<EFBFBD><CEB5><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Cache <20><> <20><><EFBFBD><EFBFBD>
//
TItemPriceListTable table;
table.dwOwnerID = pUpdateTable->dwOwnerID;
table.byCount = 0;
MYSQL_ROW row;
while ((row = mysql_fetch_row(pMsg->Get()->pSQLResult)))
{
str_to_number(table.aPriceInfo[table.byCount].dwVnum, row[0]);
str_to_number(table.aPriceInfo[table.byCount].dwPrice, row[1]);
table.byCount++;
}
PutItemPriceListCache(&table);
// Update cache
GetItemPriceListCache(pUpdateTable->dwOwnerID)->UpdateList(pUpdateTable);
delete pUpdateTable;
}
// END_OF_MYSHOP_PRICE_LIST
void CClientManager::QUERY_SAFEBOX_SAVE(CPeer * pkPeer, TSafeboxTable * pTable)
{
char szQuery[QUERY_MAX_LEN];
snprintf(szQuery, sizeof(szQuery),
"UPDATE safebox%s SET gold='%u' WHERE account_id=%u",
GetTablePostfix(), pTable->dwGold, pTable->dwID);
CDBManager::instance().ReturnQuery(szQuery, QID_SAFEBOX_SAVE, pkPeer->GetHandle(), NULL);
}
void CClientManager::QUERY_EMPIRE_SELECT(CPeer * pkPeer, DWORD dwHandle, TEmpireSelectPacket * p)
{
char szQuery[QUERY_MAX_LEN];
snprintf(szQuery, sizeof(szQuery), "UPDATE player_index%s SET empire=%u WHERE id=%u", GetTablePostfix(), p->bEmpire, p->dwAccountID);
delete CDBManager::instance().DirectQuery(szQuery);
sys_log(0, "EmpireSelect: %s", szQuery);
{
snprintf(szQuery, sizeof(szQuery),
"SELECT pid1, pid2, pid3, pid4 FROM player_index%s WHERE id=%u", GetTablePostfix(), p->dwAccountID);
std::auto_ptr<SQLMsg> pmsg(CDBManager::instance().DirectQuery(szQuery));
SQLResult * pRes = pmsg->Get();
if (pRes->uiNumRows)
{
sys_log(0, "EMPIRE %lu", pRes->uiNumRows);
MYSQL_ROW row = mysql_fetch_row(pRes->pSQLResult);
DWORD pids[3];
UINT g_start_map[4] =
{
0, // reserved
1, // <20>ż<EFBFBD><C5BC><EFBFBD>
21, // õ<><C3B5><EFBFBD><EFBFBD>
41 // <20><><EFBFBD>
};
// FIXME share with game
DWORD g_start_position[4][2]=
{
{ 0, 0 },
{ 469300, 964200 }, // <20>ż<EFBFBD><C5BC><EFBFBD>
{ 55700, 157900 }, // õ<><C3B5><EFBFBD><EFBFBD>
{ 969600, 278400 } // <20><><EFBFBD>
};
for (int i = 0; i < 3; ++i)
{
str_to_number(pids[i], row[i]);
sys_log(0, "EMPIRE PIDS[%d]", pids[i]);
if (pids[i])
{
sys_log(0, "EMPIRE move to pid[%d] to villiage of %u, map_index %d",
pids[i], p->bEmpire, g_start_map[p->bEmpire]);
snprintf(szQuery, sizeof(szQuery), "UPDATE player%s SET map_index=%u,x=%u,y=%u WHERE id=%u",
GetTablePostfix(),
g_start_map[p->bEmpire],
g_start_position[p->bEmpire][0],
g_start_position[p->bEmpire][1],
pids[i]);
std::auto_ptr<SQLMsg> pmsg2(CDBManager::instance().DirectQuery(szQuery));
}
}
}
}
pkPeer->EncodeHeader(HEADER_DG_EMPIRE_SELECT, dwHandle, sizeof(BYTE));
pkPeer->EncodeBYTE(p->bEmpire);
}
void CClientManager::QUERY_SETUP(CPeer * peer, DWORD dwHandle, const char * c_pData)
{
TPacketGDSetup * p = (TPacketGDSetup *) c_pData;
c_pData += sizeof(TPacketGDSetup);
if (p->bAuthServer)
{
sys_log(0, "AUTH_PEER ptr %p", peer);
m_pkAuthPeer = peer;
SendAllLoginToBilling();
return;
}
peer->SetPublicIP(p->szPublicIP);
peer->SetChannel(p->bChannel);
peer->SetListenPort(p->wListenPort);
peer->SetP2PPort(p->wP2PPort);
peer->SetMaps(p->alMaps);
//
// <20><20><><EFBFBD><EFBFBD> <20><20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ִ<EFBFBD><D6B4><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
//
TMapLocation kMapLocations;
2022-03-05 19:59:39 +02:00
strncpy(kMapLocations.szHost, peer->GetPublicIP(), sizeof(kMapLocations.szHost));
2022-03-05 12:44:06 +02:00
kMapLocations.wPort = peer->GetListenPort();
thecore_memcpy(kMapLocations.alMaps, peer->GetMaps(), sizeof(kMapLocations.alMaps));
BYTE bMapCount;
std::vector<TMapLocation> vec_kMapLocations;
if (peer->GetChannel() == 1)
{
for (itertype(m_peerList) i = m_peerList.begin(); i != m_peerList.end(); ++i)
{
CPeer * tmp = *i;
if (tmp == peer)
continue;
if (!tmp->GetChannel())
continue;
if (tmp->GetChannel() == GUILD_WARP_WAR_CHANNEL || tmp->GetChannel() == peer->GetChannel())
{
TMapLocation kMapLocation2;
2022-03-05 19:59:39 +02:00
strncpy(kMapLocation2.szHost, tmp->GetPublicIP(), sizeof(kMapLocation2.szHost));
2022-03-05 12:44:06 +02:00
kMapLocation2.wPort = tmp->GetListenPort();
thecore_memcpy(kMapLocation2.alMaps, tmp->GetMaps(), sizeof(kMapLocation2.alMaps));
vec_kMapLocations.push_back(kMapLocation2);
tmp->EncodeHeader(HEADER_DG_MAP_LOCATIONS, 0, sizeof(BYTE) + sizeof(TMapLocation));
bMapCount = 1;
tmp->EncodeBYTE(bMapCount);
tmp->Encode(&kMapLocations, sizeof(TMapLocation));
}
}
}
else if (peer->GetChannel() == GUILD_WARP_WAR_CHANNEL)
{
for (itertype(m_peerList) i = m_peerList.begin(); i != m_peerList.end(); ++i)
{
CPeer * tmp = *i;
if (tmp == peer)
continue;
if (!tmp->GetChannel())
continue;
if (tmp->GetChannel() == 1 || tmp->GetChannel() == peer->GetChannel())
{
TMapLocation kMapLocation2;
2022-03-05 19:59:39 +02:00
strncpy(kMapLocation2.szHost, tmp->GetPublicIP(), sizeof(kMapLocation2.szHost));
2022-03-05 12:44:06 +02:00
kMapLocation2.wPort = tmp->GetListenPort();
thecore_memcpy(kMapLocation2.alMaps, tmp->GetMaps(), sizeof(kMapLocation2.alMaps));
vec_kMapLocations.push_back(kMapLocation2);
}
tmp->EncodeHeader(HEADER_DG_MAP_LOCATIONS, 0, sizeof(BYTE) + sizeof(TMapLocation));
bMapCount = 1;
tmp->EncodeBYTE(bMapCount);
tmp->Encode(&kMapLocations, sizeof(TMapLocation));
}
}
else
{
for (itertype(m_peerList) i = m_peerList.begin(); i != m_peerList.end(); ++i)
{
CPeer * tmp = *i;
if (tmp == peer)
continue;
if (!tmp->GetChannel())
continue;
if (tmp->GetChannel() == GUILD_WARP_WAR_CHANNEL || tmp->GetChannel() == peer->GetChannel())
{
TMapLocation kMapLocation2;
2022-03-05 19:59:39 +02:00
strncpy(kMapLocation2.szHost, tmp->GetPublicIP(), sizeof(kMapLocation2.szHost));
2022-03-05 12:44:06 +02:00
kMapLocation2.wPort = tmp->GetListenPort();
thecore_memcpy(kMapLocation2.alMaps, tmp->GetMaps(), sizeof(kMapLocation2.alMaps));
vec_kMapLocations.push_back(kMapLocation2);
}
if (tmp->GetChannel() == peer->GetChannel())
{
tmp->EncodeHeader(HEADER_DG_MAP_LOCATIONS, 0, sizeof(BYTE) + sizeof(TMapLocation));
bMapCount = 1;
tmp->EncodeBYTE(bMapCount);
tmp->Encode(&kMapLocations, sizeof(TMapLocation));
}
}
}
vec_kMapLocations.push_back(kMapLocations);
peer->EncodeHeader(HEADER_DG_MAP_LOCATIONS, 0, sizeof(BYTE) + sizeof(TMapLocation) * vec_kMapLocations.size());
bMapCount = vec_kMapLocations.size();
peer->EncodeBYTE(bMapCount);
peer->Encode(&vec_kMapLocations[0], sizeof(TMapLocation) * vec_kMapLocations.size());
//
// <20>¾<EFBFBD> : <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>Ǿ <20>ٸ<EFBFBD> <20>Ǿ<EFBFBD><C7BE><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ϰ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>. (P2P <20><><EFBFBD>ؼ<EFBFBD> <20><><EFBFBD><EFBFBD>)
//
sys_log(0, "SETUP: channel %u listen %u p2p %u count %u", peer->GetChannel(), p->wListenPort, p->wP2PPort, bMapCount);
TPacketDGP2P p2pSetupPacket;
p2pSetupPacket.wPort = peer->GetP2PPort();
p2pSetupPacket.bChannel = peer->GetChannel();
2022-03-05 19:59:39 +02:00
strncpy(p2pSetupPacket.szHost, peer->GetPublicIP(), sizeof(p2pSetupPacket.szHost));
2022-03-05 12:44:06 +02:00
for (itertype(m_peerList) i = m_peerList.begin(); i != m_peerList.end();++i)
{
CPeer * tmp = *i;
if (tmp == peer)
continue;
// ä<><C3A4><EFBFBD><EFBFBD> 0<>̶<EFBFBD><CCB6><EFBFBD> <20><><EFBFBD><EFBFBD> SETUP <20><>Ŷ<EFBFBD><C5B6> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20>Ǿ<EFBFBD> <20>Ǵ<EFBFBD> auth<74><68><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD>
if (0 == tmp->GetChannel())
continue;
tmp->EncodeHeader(HEADER_DG_P2P, 0, sizeof(TPacketDGP2P));
tmp->Encode(&p2pSetupPacket, sizeof(TPacketDGP2P));
}
//
// <20>α<EFBFBD><CEB1><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
//
TPacketLoginOnSetup * pck = (TPacketLoginOnSetup *) c_pData;;
std::vector<TPacketBillingRepair> vec_repair;
for (DWORD c = 0; c < p->dwLoginCount; ++c, ++pck)
{
CLoginData * pkLD = new CLoginData;
pkLD->SetKey(pck->dwLoginKey);
pkLD->SetClientKey(pck->adwClientKey);
pkLD->SetIP(pck->szHost);
TAccountTable & r = pkLD->GetAccountRef();
r.id = pck->dwID;
trim_and_lower(pck->szLogin, r.login, sizeof(r.login));
2022-03-05 19:59:39 +02:00
strncpy(r.social_id, pck->szSocialID, sizeof(r.social_id));
strncpy(r.passwd, "TEMP", sizeof(r.passwd));
2022-03-05 12:44:06 +02:00
InsertLoginData(pkLD);
if (InsertLogonAccount(pck->szLogin, peer->GetHandle(), pck->szHost))
{
sys_log(0, "SETUP: login %u %s login_key %u host %s", pck->dwID, pck->szLogin, pck->dwLoginKey, pck->szHost);
pkLD->SetPlay(true);
if (m_pkAuthPeer)
{
TPacketBillingRepair pck_repair;
pck_repair.dwLoginKey = pkLD->GetKey();
2022-03-05 19:59:39 +02:00
strncpy(pck_repair.szLogin, pck->szLogin, sizeof(pck_repair.szLogin));
strncpy(pck_repair.szHost, pck->szHost, sizeof(pck_repair.szHost));
2022-03-05 12:44:06 +02:00
vec_repair.push_back(pck_repair);
}
}
else
sys_log(0, "SETUP: login_fail %u %s login_key %u", pck->dwID, pck->szLogin, pck->dwLoginKey);
}
if (m_pkAuthPeer && !vec_repair.empty())
{
sys_log(0, "REPAIR size %d", vec_repair.size());
m_pkAuthPeer->EncodeHeader(HEADER_DG_BILLING_REPAIR, 0, sizeof(DWORD) + sizeof(TPacketBillingRepair) * vec_repair.size());
m_pkAuthPeer->EncodeDWORD(vec_repair.size());
m_pkAuthPeer->Encode(&vec_repair[0], sizeof(TPacketBillingRepair) * vec_repair.size());
}
SendPartyOnSetup(peer);
CGuildManager::instance().OnSetup(peer);
CPrivManager::instance().SendPrivOnSetup(peer);
SendEventFlagsOnSetup(peer);
marriage::CManager::instance().OnSetup(peer);
}
void CClientManager::QUERY_ITEM_FLUSH(CPeer * pkPeer, const char * c_pData)
{
DWORD dwID = *(DWORD *) c_pData;
if (g_log)
sys_log(0, "HEADER_GD_ITEM_FLUSH: %u", dwID);
CItemCache * c = GetItemCache(dwID);
if (c)
c->Flush();
}
void CClientManager::QUERY_ITEM_SAVE(CPeer * pkPeer, const char * c_pData)
{
TPlayerItem * p = (TPlayerItem *) c_pData;
// â<><C3A2><EFBFBD><EFBFBD> ij<><C4B3><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ʰ<EFBFBD>, ij<><C4B3><EFBFBD><EFBFBD> <20>ִ<EFBFBD> <20>͵<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>Ѵ<EFBFBD>.
// auction<6F><6E> <20><> <20><>Ʈ<EFBFBD><C6AE> Ÿ<><C5B8> <20>ʾƾ<CABE> <20>Ѵ<EFBFBD>. EnrollInAuction<6F><6E> Ÿ<><C5B8><EFBFBD>Ѵ<EFBFBD>.
if (p->window == SAFEBOX || p->window == MALL)
{
CItemCache * c = GetItemCache(p->id);
if (c)
{
TItemCacheSetPtrMap::iterator it = m_map_pkItemCacheSetPtr.find(c->Get()->owner);
if (it != m_map_pkItemCacheSetPtr.end())
{
if (g_test_server)
sys_log(0, "ITEM_CACHE: safebox owner %u id %u", c->Get()->owner, c->Get()->id);
it->second->erase(c);
}
m_map_itemCache.erase(p->id);
delete c;
}
char szQuery[512];
snprintf(szQuery, sizeof(szQuery),
"REPLACE INTO item%s (id, owner_id, window, pos, count, vnum, socket0, socket1, socket2, "
"attrtype0, attrvalue0, "
"attrtype1, attrvalue1, "
"attrtype2, attrvalue2, "
"attrtype3, attrvalue3, "
"attrtype4, attrvalue4, "
"attrtype5, attrvalue5, "
"attrtype6, attrvalue6) "
"VALUES(%u, %u, %d, %d, %u, %u, %ld, %ld, %ld, %d, %d, %d, %d, %d, %d, %d, %d, %d, %d, %d, %d, %d, %d)",
GetTablePostfix(),
p->id,
p->owner,
p->window,
p->pos,
p->count,
p->vnum,
p->alSockets[0],
p->alSockets[1],
p->alSockets[2],
p->aAttr[0].bType, p->aAttr[0].sValue,
p->aAttr[1].bType, p->aAttr[1].sValue,
p->aAttr[2].bType, p->aAttr[2].sValue,
p->aAttr[3].bType, p->aAttr[3].sValue,
p->aAttr[4].bType, p->aAttr[4].sValue,
p->aAttr[5].bType, p->aAttr[5].sValue,
p->aAttr[6].bType, p->aAttr[6].sValue);
CDBManager::instance().ReturnQuery(szQuery, QID_ITEM_SAVE, pkPeer->GetHandle(), NULL);
}
#ifdef __AUCTION__
else if (p->window == AUCTION)
{
sys_err("invalid window. how can you enter this route?");
return ;
}
#endif
else
{
if (g_test_server)
sys_log(0, "QUERY_ITEM_SAVE => PutItemCache() owner %d id %d vnum %d ", p->owner, p->id, p->vnum);
PutItemCache(p);
}
}
CClientManager::TItemCacheSet * CClientManager::GetItemCacheSet(DWORD pid)
{
TItemCacheSetPtrMap::iterator it = m_map_pkItemCacheSetPtr.find(pid);
if (it == m_map_pkItemCacheSetPtr.end())
return NULL;
return it->second;
}
void CClientManager::CreateItemCacheSet(DWORD pid)
{
if (m_map_pkItemCacheSetPtr.find(pid) != m_map_pkItemCacheSetPtr.end())
return;
TItemCacheSet * pSet = new TItemCacheSet;
m_map_pkItemCacheSetPtr.insert(TItemCacheSetPtrMap::value_type(pid, pSet));
if (g_log)
sys_log(0, "ITEM_CACHE: new cache %u", pid);
}
void CClientManager::FlushItemCacheSet(DWORD pid)
{
TItemCacheSetPtrMap::iterator it = m_map_pkItemCacheSetPtr.find(pid);
if (it == m_map_pkItemCacheSetPtr.end())
{
sys_log(0, "FLUSH_ITEMCACHESET : No ItemCacheSet pid(%d)", pid);
return;
}
TItemCacheSet * pSet = it->second;
TItemCacheSet::iterator it_set = pSet->begin();
while (it_set != pSet->end())
{
CItemCache * c = *it_set++;
c->Flush();
m_map_itemCache.erase(c->Get()->id);
delete c;
}
pSet->clear();
delete pSet;
m_map_pkItemCacheSetPtr.erase(it);
if (g_log)
sys_log(0, "FLUSH_ITEMCACHESET : Deleted pid(%d)", pid);
}
CItemCache * CClientManager::GetItemCache(DWORD id)
{
TItemCacheMap::iterator it = m_map_itemCache.find(id);
if (it == m_map_itemCache.end())
return NULL;
return it->second;
}
void CClientManager::PutItemCache(TPlayerItem * pNew, bool bSkipQuery)
{
CItemCache * c;
c = GetItemCache(pNew->id);
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>
if (!c)
{
if (g_log)
sys_log(0, "ITEM_CACHE: PutItemCache ==> New CItemCache id%d vnum%d new owner%d", pNew->id, pNew->vnum, pNew->owner);
c = new CItemCache;
m_map_itemCache.insert(TItemCacheMap::value_type(pNew->id, c));
}
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
else
{
if (g_log)
sys_log(0, "ITEM_CACHE: PutItemCache ==> Have Cache");
// <20><><EFBFBD><EFBFBD><EFBFBD>ڰ<EFBFBD> Ʋ<><C6B2><EFBFBD><EFBFBD>
if (pNew->owner != c->Get()->owner)
{
// <20>̹<EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>־<EFBFBD><D6BE><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
TItemCacheSetPtrMap::iterator it = m_map_pkItemCacheSetPtr.find(c->Get()->owner);
if (it != m_map_pkItemCacheSetPtr.end())
{
if (g_log)
sys_log(0, "ITEM_CACHE: delete owner %u id %u new owner %u", c->Get()->owner, c->Get()->id, pNew->owner);
it->second->erase(c);
}
}
}
// <20><><EFBFBD>ο<EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ʈ
c->Put(pNew, bSkipQuery);
TItemCacheSetPtrMap::iterator it = m_map_pkItemCacheSetPtr.find(c->Get()->owner);
if (it != m_map_pkItemCacheSetPtr.end())
{
if (g_log)
sys_log(0, "ITEM_CACHE: save %u id %u", c->Get()->owner, c->Get()->id);
else
sys_log(1, "ITEM_CACHE: save %u id %u", c->Get()->owner, c->Get()->id);
it->second->insert(c);
}
else
{
// <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ڰ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ƿ<EFBFBD> <20>ٷ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ؾ<EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><> <20><> SQL<51><4C> <20><><EFBFBD><EFBFBD><EFBFBD>Ͽ<EFBFBD>
// <20><><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD>Ƿ<EFBFBD> <20>ٷ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
if (g_log)
sys_log(0, "ITEM_CACHE: direct save %u id %u", c->Get()->owner, c->Get()->id);
else
sys_log(1, "ITEM_CACHE: direct save %u id %u", c->Get()->owner, c->Get()->id);
c->OnFlush();
}
}
bool CClientManager::DeleteItemCache(DWORD dwID)
{
CItemCache * c = GetItemCache(dwID);
if (!c)
return false;
c->Delete();
return true;
}
// MYSHOP_PRICE_LIST
CItemPriceListTableCache* CClientManager::GetItemPriceListCache(DWORD dwID)
{
TItemPriceListCacheMap::iterator it = m_mapItemPriceListCache.find(dwID);
if (it == m_mapItemPriceListCache.end())
return NULL;
return it->second;
}
void CClientManager::PutItemPriceListCache(const TItemPriceListTable* pItemPriceList)
{
CItemPriceListTableCache* pCache = GetItemPriceListCache(pItemPriceList->dwOwnerID);
if (!pCache)
{
pCache = new CItemPriceListTableCache;
m_mapItemPriceListCache.insert(TItemPriceListCacheMap::value_type(pItemPriceList->dwOwnerID, pCache));
}
pCache->Put(const_cast<TItemPriceListTable*>(pItemPriceList), true);
}
void CClientManager::UpdatePlayerCache()
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.begin();
while (it != m_map_playerCache.end())
{
CPlayerTableCache * c = (it++)->second;
if (c->CheckTimeout())
{
if (g_log)
sys_log(0, "UPDATE : UpdatePlayerCache() ==> FlushPlayerCache %d %s ", c->Get(false)->id, c->Get(false)->name);
c->Flush();
// Item Cache<68><65> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ʈ
UpdateItemCacheSet(c->Get()->id);
}
else if (c->CheckFlushTimeout())
c->Flush();
}
}
// END_OF_MYSHOP_PRICE_LIST
void CClientManager::SetCacheFlushCountLimit(int iLimit)
{
m_iCacheFlushCountLimit = MAX(10, iLimit);
sys_log(0, "CACHE_FLUSH_LIMIT_PER_SECOND: %d", m_iCacheFlushCountLimit);
}
void CClientManager::UpdateItemCache()
{
if (m_iCacheFlushCount >= m_iCacheFlushCountLimit)
return;
TItemCacheMap::iterator it = m_map_itemCache.begin();
while (it != m_map_itemCache.end())
{
CItemCache * c = (it++)->second;
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Flush<73><68> <20>Ѵ<EFBFBD>.
if (c->CheckFlushTimeout())
{
if (g_test_server)
sys_log(0, "UpdateItemCache ==> Flush() vnum %d id owner %d", c->Get()->vnum, c->Get()->id, c->Get()->owner);
c->Flush();
if (++m_iCacheFlushCount >= m_iCacheFlushCountLimit)
break;
}
}
}
void CClientManager::UpdateItemPriceListCache()
{
TItemPriceListCacheMap::iterator it = m_mapItemPriceListCache.begin();
while (it != m_mapItemPriceListCache.end())
{
CItemPriceListTableCache* pCache = it->second;
if (pCache->CheckFlushTimeout())
{
pCache->Flush();
m_mapItemPriceListCache.erase(it++);
}
else
++it;
}
}
void CClientManager::QUERY_ITEM_DESTROY(CPeer * pkPeer, const char * c_pData)
{
DWORD dwID = *(DWORD *) c_pData;
c_pData += sizeof(DWORD);
DWORD dwPID = *(DWORD *) c_pData;
if (!DeleteItemCache(dwID))
{
char szQuery[64];
snprintf(szQuery, sizeof(szQuery), "DELETE FROM item%s WHERE id=%u", GetTablePostfix(), dwID);
if (g_log)
sys_log(0, "HEADER_GD_ITEM_DESTROY: PID %u ID %u", dwPID, dwID);
if (dwPID == 0) // <20>ƹ<EFBFBD><C6B9><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ٸ<EFBFBD>, <20>񵿱<EFBFBD> <20><><EFBFBD><EFBFBD>
CDBManager::instance().AsyncQuery(szQuery);
else
CDBManager::instance().ReturnQuery(szQuery, QID_ITEM_DESTROY, pkPeer->GetHandle(), NULL);
}
}
void CClientManager::QUERY_FLUSH_CACHE(CPeer * pkPeer, const char * c_pData)
{
DWORD dwPID = *(DWORD *) c_pData;
CPlayerTableCache * pkCache = GetPlayerCache(dwPID);
if (!pkCache)
return;
sys_log(0, "FLUSH_CACHE: %u", dwPID);
pkCache->Flush();
FlushItemCacheSet(dwPID);
m_map_playerCache.erase(dwPID);
delete pkCache;
}
void CClientManager::QUERY_SMS(CPeer * pkPeer, TPacketGDSMS * pack)
{
char szQuery[QUERY_MAX_LEN];
char szMsg[256+1];
//unsigned long len = CDBManager::instance().EscapeString(szMsg, pack->szMsg, strlen(pack->szMsg), SQL_ACCOUNT);
unsigned long len = CDBManager::instance().EscapeString(szMsg, pack->szMsg, strlen(pack->szMsg));
szMsg[len] = '\0';
snprintf(szQuery, sizeof(szQuery),
"INSERT INTO sms_pool (server, sender, receiver, mobile, msg) VALUES(%d, '%s', '%s', '%s', '%s')",
(m_iPlayerIDStart + 2) / 3, pack->szFrom, pack->szTo, pack->szMobile, szMsg);
CDBManager::instance().AsyncQuery(szQuery);
}
void CClientManager::QUERY_RELOAD_PROTO()
{
if (!InitializeTables())
{
sys_err("QUERY_RELOAD_PROTO: cannot load tables");
return;
}
for (TPeerList::iterator i = m_peerList.begin(); i != m_peerList.end(); ++i)
{
CPeer * tmp = *i;
if (!tmp->GetChannel())
continue;
tmp->EncodeHeader(HEADER_DG_RELOAD_PROTO, 0,
sizeof(WORD) + sizeof(TSkillTable) * m_vec_skillTable.size() +
sizeof(WORD) + sizeof(TBanwordTable) * m_vec_banwordTable.size() +
sizeof(WORD) + sizeof(TItemTable) * m_vec_itemTable.size() +
sizeof(WORD) + sizeof(TMobTable) * m_vec_mobTable.size());
tmp->EncodeWORD(m_vec_skillTable.size());
tmp->Encode(&m_vec_skillTable[0], sizeof(TSkillTable) * m_vec_skillTable.size());
tmp->EncodeWORD(m_vec_banwordTable.size());
tmp->Encode(&m_vec_banwordTable[0], sizeof(TBanwordTable) * m_vec_banwordTable.size());
tmp->EncodeWORD(m_vec_itemTable.size());
tmp->Encode(&m_vec_itemTable[0], sizeof(TItemTable) * m_vec_itemTable.size());
tmp->EncodeWORD(m_vec_mobTable.size());
tmp->Encode(&m_vec_mobTable[0], sizeof(TMobTable) * m_vec_mobTable.size());
}
}
// ADD_GUILD_PRIV_TIME
/**
* @version 05/06/08 Bang2ni - <EFBFBD><EFBFBD><EFBFBD>ӽð<EFBFBD> <EFBFBD>߰<EFBFBD>
*/
void CClientManager::AddGuildPriv(TPacketGiveGuildPriv* p)
{
CPrivManager::instance().AddGuildPriv(p->guild_id, p->type, p->value, p->duration_sec);
}
void CClientManager::AddEmpirePriv(TPacketGiveEmpirePriv* p)
{
CPrivManager::instance().AddEmpirePriv(p->empire, p->type, p->value, p->duration_sec);
}
// END_OF_ADD_GUILD_PRIV_TIME
void CClientManager::AddCharacterPriv(TPacketGiveCharacterPriv* p)
{
CPrivManager::instance().AddCharPriv(p->pid, p->type, p->value);
}
void CClientManager::MoneyLog(TPacketMoneyLog* p)
{
CMoneyLog::instance().AddLog(p->type, p->vnum, p->gold);
}
CLoginData * CClientManager::GetLoginData(DWORD dwKey)
{
TLoginDataByLoginKey::iterator it = m_map_pkLoginData.find(dwKey);
if (it == m_map_pkLoginData.end())
return NULL;
return it->second;
}
CLoginData * CClientManager::GetLoginDataByLogin(const char * c_pszLogin)
{
char szLogin[LOGIN_MAX_LEN + 1];
trim_and_lower(c_pszLogin, szLogin, sizeof(szLogin));
TLoginDataByLogin::iterator it = m_map_pkLoginDataByLogin.find(szLogin);
if (it == m_map_pkLoginDataByLogin.end())
return NULL;
return it->second;
}
CLoginData * CClientManager::GetLoginDataByAID(DWORD dwAID)
{
TLoginDataByAID::iterator it = m_map_pkLoginDataByAID.find(dwAID);
if (it == m_map_pkLoginDataByAID.end())
return NULL;
return it->second;
}
void CClientManager::InsertLoginData(CLoginData * pkLD)
{
char szLogin[LOGIN_MAX_LEN + 1];
trim_and_lower(pkLD->GetAccountRef().login, szLogin, sizeof(szLogin));
m_map_pkLoginData.insert(std::make_pair(pkLD->GetKey(), pkLD));
m_map_pkLoginDataByLogin.insert(std::make_pair(szLogin, pkLD));
m_map_pkLoginDataByAID.insert(std::make_pair(pkLD->GetAccountRef().id, pkLD));
}
void CClientManager::DeleteLoginData(CLoginData * pkLD)
{
m_map_pkLoginData.erase(pkLD->GetKey());
m_map_pkLoginDataByLogin.erase(pkLD->GetAccountRef().login);
m_map_pkLoginDataByAID.erase(pkLD->GetAccountRef().id);
if (m_map_kLogonAccount.find(pkLD->GetAccountRef().login) == m_map_kLogonAccount.end())
delete pkLD;
else
pkLD->SetDeleted(true);
}
void CClientManager::QUERY_AUTH_LOGIN(CPeer * pkPeer, DWORD dwHandle, TPacketGDAuthLogin * p)
{
if (g_test_server)
sys_log(0, "QUERY_AUTH_LOGIN %d %d %s", p->dwID, p->dwLoginKey, p->szLogin);
CLoginData * pkLD = GetLoginDataByLogin(p->szLogin);
if (pkLD)
{
DeleteLoginData(pkLD);
}
BYTE bResult;
if (GetLoginData(p->dwLoginKey))
{
sys_err("LoginData already exist key %u login %s", p->dwLoginKey, p->szLogin);
bResult = 0;
pkPeer->EncodeHeader(HEADER_DG_AUTH_LOGIN, dwHandle, sizeof(BYTE));
pkPeer->EncodeBYTE(bResult);
}
else
{
CLoginData * pkLD = new CLoginData;
pkLD->SetKey(p->dwLoginKey);
pkLD->SetClientKey(p->adwClientKey);
pkLD->SetBillType(p->bBillType);
pkLD->SetBillID(p->dwBillID);
pkLD->SetPremium(p->iPremiumTimes);
TAccountTable & r = pkLD->GetAccountRef();
r.id = p->dwID;
trim_and_lower(p->szLogin, r.login, sizeof(r.login));
2022-03-05 19:59:39 +02:00
strncpy(r.social_id, p->szSocialID, sizeof(r.social_id));
strncpy(r.passwd, "TEMP", sizeof(r.passwd));
2022-03-05 12:44:06 +02:00
sys_log(0, "AUTH_LOGIN id(%u) login(%s) social_id(%s) login_key(%u), client_key(%u %u %u %u)",
p->dwID, p->szLogin, p->szSocialID, p->dwLoginKey,
p->adwClientKey[0], p->adwClientKey[1], p->adwClientKey[2], p->adwClientKey[3]);
bResult = 1;
InsertLoginData(pkLD);
pkPeer->EncodeHeader(HEADER_DG_AUTH_LOGIN, dwHandle, sizeof(BYTE));
pkPeer->EncodeBYTE(bResult);
}
}
void CClientManager::BillingExpire(TPacketBillingExpire * p)
{
char key[LOGIN_MAX_LEN + 1];
trim_and_lower(p->szLogin, key, sizeof(key));
switch (p->bBillType)
{
case BILLING_IP_TIME:
case BILLING_IP_DAY:
{
DWORD dwIPID = 0;
str_to_number(dwIPID, p->szLogin);
TLogonAccountMap::iterator it = m_map_kLogonAccount.begin();
while (it != m_map_kLogonAccount.end())
{
CLoginData * pkLD = (it++)->second;
if (pkLD->GetBillID() == dwIPID)
{
CPeer * pkPeer = GetPeer(pkLD->GetConnectedPeerHandle());
if (pkPeer)
{
2022-03-05 19:59:39 +02:00
strncpy(p->szLogin, pkLD->GetAccountRef().login, sizeof(p->szLogin));
2022-03-05 12:44:06 +02:00
pkPeer->EncodeHeader(HEADER_DG_BILLING_EXPIRE, 0, sizeof(TPacketBillingExpire));
pkPeer->Encode(p, sizeof(TPacketBillingExpire));
}
}
}
}
break;
case BILLING_TIME:
case BILLING_DAY:
{
TLogonAccountMap::iterator it = m_map_kLogonAccount.find(key);
if (it != m_map_kLogonAccount.end())
{
CLoginData * pkLD = it->second;
CPeer * pkPeer = GetPeer(pkLD->GetConnectedPeerHandle());
if (pkPeer)
{
pkPeer->EncodeHeader(HEADER_DG_BILLING_EXPIRE, 0, sizeof(TPacketBillingExpire));
pkPeer->Encode(p, sizeof(TPacketBillingExpire));
}
}
}
break;
}
}
void CClientManager::BillingCheck(const char * data)
{
if (!m_pkAuthPeer)
return;
time_t curTime = GetCurrentTime();
DWORD dwCount = *(DWORD *) data;
data += sizeof(DWORD);
std::vector<DWORD> vec;
sys_log(0, "BillingCheck: size %u", dwCount);
for (DWORD i = 0; i < dwCount; ++i)
{
DWORD dwKey = *(DWORD *) data;
data += sizeof(DWORD);
sys_log(0, "BillingCheck: %u", dwKey);
TLoginDataByLoginKey::iterator it = m_map_pkLoginData.find(dwKey);
if (it == m_map_pkLoginData.end())
{
sys_log(0, "BillingCheck: key not exist: %u", dwKey);
vec.push_back(dwKey);
}
else
{
CLoginData * pkLD = it->second;
if (!pkLD->IsPlay() && curTime - pkLD->GetLastPlayTime() > 180)
{
sys_log(0, "BillingCheck: not login: %u", dwKey);
vec.push_back(dwKey);
}
}
}
m_pkAuthPeer->EncodeHeader(HEADER_DG_BILLING_CHECK, 0, sizeof(DWORD) + sizeof(DWORD) * vec.size());
m_pkAuthPeer->EncodeDWORD(vec.size());
if (!vec.empty())
m_pkAuthPeer->Encode(&vec[0], sizeof(DWORD) * vec.size());
}
void CClientManager::GuildDepositMoney(TPacketGDGuildMoney* p)
{
CGuildManager::instance().DepositMoney(p->dwGuild, p->iGold);
}
void CClientManager::GuildWithdrawMoney(CPeer* peer, TPacketGDGuildMoney* p)
{
CGuildManager::instance().WithdrawMoney(peer, p->dwGuild, p->iGold);
}
void CClientManager::GuildWithdrawMoneyGiveReply(TPacketGDGuildMoneyWithdrawGiveReply* p)
{
CGuildManager::instance().WithdrawMoneyReply(p->dwGuild, p->bGiveSuccess, p->iChangeGold);
}
void CClientManager::GuildWarBet(TPacketGDGuildWarBet * p)
{
CGuildManager::instance().Bet(p->dwWarID, p->szLogin, p->dwGold, p->dwGuild);
}
void CClientManager::SendAllLoginToBilling()
{
if (!m_pkAuthPeer)
return;
std::vector<TPacketBillingRepair> vec;
TPacketBillingRepair p;
TLogonAccountMap::iterator it = m_map_kLogonAccount.begin();
while (it != m_map_kLogonAccount.end())
{
CLoginData * pkLD = (it++)->second;
p.dwLoginKey = pkLD->GetKey();
2022-03-05 19:59:39 +02:00
strncpy(p.szLogin, pkLD->GetAccountRef().login, sizeof(p.szLogin));
strncpy(p.szHost, pkLD->GetIP(), sizeof(p.szHost));
2022-03-05 12:44:06 +02:00
sys_log(0, "SendAllLoginToBilling %s %s", pkLD->GetAccountRef().login, pkLD->GetIP());
vec.push_back(p);
}
if (!vec.empty())
{
m_pkAuthPeer->EncodeHeader(HEADER_DG_BILLING_REPAIR, 0, sizeof(DWORD) + sizeof(TPacketBillingRepair) * vec.size());
m_pkAuthPeer->EncodeDWORD(vec.size());
m_pkAuthPeer->Encode(&vec[0], sizeof(TPacketBillingRepair) * vec.size());
}
}
void CClientManager::SendLoginToBilling(CLoginData * pkLD, bool bLogin)
{
if (!m_pkAuthPeer)
return;
TPacketBillingLogin p;
p.dwLoginKey = pkLD->GetKey();
p.bLogin = bLogin ? 1 : 0;
DWORD dwCount = 1;
m_pkAuthPeer->EncodeHeader(HEADER_DG_BILLING_LOGIN, 0, sizeof(DWORD) + sizeof(TPacketBillingLogin));
m_pkAuthPeer->EncodeDWORD(dwCount);
m_pkAuthPeer->Encode(&p, sizeof(TPacketBillingLogin));
}
void CClientManager::CreateObject(TPacketGDCreateObject * p)
{
using namespace building;
char szQuery[512];
snprintf(szQuery, sizeof(szQuery),
"INSERT INTO object%s (land_id, vnum, map_index, x, y, x_rot, y_rot, z_rot) VALUES(%u, %u, %d, %d, %d, %f, %f, %f)",
GetTablePostfix(), p->dwLandID, p->dwVnum, p->lMapIndex, p->x, p->y, p->xRot, p->yRot, p->zRot);
std::auto_ptr<SQLMsg> pmsg(CDBManager::instance().DirectQuery(szQuery));
if (pmsg->Get()->uiInsertID == 0)
{
sys_err("cannot insert object");
return;
}
TObject * pkObj = new TObject;
memset(pkObj, 0, sizeof(TObject));
pkObj->dwID = pmsg->Get()->uiInsertID;
pkObj->dwVnum = p->dwVnum;
pkObj->dwLandID = p->dwLandID;
pkObj->lMapIndex = p->lMapIndex;
pkObj->x = p->x;
pkObj->y = p->y;
pkObj->xRot = p->xRot;
pkObj->yRot = p->yRot;
pkObj->zRot = p->zRot;
pkObj->lLife = 0;
ForwardPacket(HEADER_DG_CREATE_OBJECT, pkObj, sizeof(TObject));
m_map_pkObjectTable.insert(std::make_pair(pkObj->dwID, pkObj));
}
void CClientManager::DeleteObject(DWORD dwID)
{
char szQuery[128];
snprintf(szQuery, sizeof(szQuery), "DELETE FROM object%s WHERE id=%u", GetTablePostfix(), dwID);
std::auto_ptr<SQLMsg> pmsg(CDBManager::instance().DirectQuery(szQuery));
if (pmsg->Get()->uiAffectedRows == 0 || pmsg->Get()->uiAffectedRows == (uint32_t)-1)
{
sys_err("no object by id %u", dwID);
return;
}
itertype(m_map_pkObjectTable) it = m_map_pkObjectTable.find(dwID);
if (it != m_map_pkObjectTable.end())
{
delete it->second;
m_map_pkObjectTable.erase(it);
}
ForwardPacket(HEADER_DG_DELETE_OBJECT, &dwID, sizeof(DWORD));
}
void CClientManager::UpdateLand(DWORD * pdw)
{
DWORD dwID = pdw[0];
DWORD dwGuild = pdw[1];
building::TLand * p = &m_vec_kLandTable[0];
DWORD i;
for (i = 0; i < m_vec_kLandTable.size(); ++i, ++p)
{
if (p->dwID == dwID)
{
char buf[256];
snprintf(buf, sizeof(buf), "UPDATE land%s SET guild_id=%u WHERE id=%u", GetTablePostfix(), dwGuild, dwID);
CDBManager::instance().AsyncQuery(buf);
p->dwGuildID = dwGuild;
break;
}
}
if (i < m_vec_kLandTable.size())
ForwardPacket(HEADER_DG_UPDATE_LAND, p, sizeof(building::TLand));
}
void CClientManager::VCard(TPacketGDVCard * p)
{
sys_log(0, "VCARD: %u %s %s %s %s",
p->dwID, p->szSellCharacter, p->szSellAccount, p->szBuyCharacter, p->szBuyAccount);
m_queue_vcard.push(*p);
}
void CClientManager::VCardProcess()
{
if (!m_pkAuthPeer)
return;
while (!m_queue_vcard.empty())
{
m_pkAuthPeer->EncodeHeader(HEADER_DG_VCARD, 0, sizeof(TPacketGDVCard));
m_pkAuthPeer->Encode(&m_queue_vcard.front(), sizeof(TPacketGDVCard));
m_queue_vcard.pop();
}
}
// BLOCK_CHAT
void CClientManager::BlockChat(TPacketBlockChat* p)
{
char szQuery[256];
if (g_stLocale == "sjis")
snprintf(szQuery, sizeof(szQuery), "SELECT id FROM player%s WHERE name = '%s' collate sjis_japanese_ci", GetTablePostfix(), p->szName);
else
snprintf(szQuery, sizeof(szQuery), "SELECT id FROM player%s WHERE name = '%s'", GetTablePostfix(), p->szName);
std::auto_ptr<SQLMsg> pmsg(CDBManager::instance().DirectQuery(szQuery));
SQLResult * pRes = pmsg->Get();
if (pRes->uiNumRows)
{
MYSQL_ROW row = mysql_fetch_row(pRes->pSQLResult);
DWORD pid = strtoul(row[0], NULL, 10);
TPacketGDAddAffect pa;
pa.dwPID = pid;
pa.elem.dwType = 223;
pa.elem.bApplyOn = 0;
pa.elem.lApplyValue = 0;
pa.elem.dwFlag = 0;
pa.elem.lDuration = p->lDuration;
pa.elem.lSPCost = 0;
QUERY_ADD_AFFECT(NULL, &pa);
}
else
{
// cannot find user with that name
}
}
// END_OF_BLOCK_CHAT
void CClientManager::MarriageAdd(TPacketMarriageAdd * p)
{
sys_log(0, "MarriageAdd %u %u %s %s", p->dwPID1, p->dwPID2, p->szName1, p->szName2);
marriage::CManager::instance().Add(p->dwPID1, p->dwPID2, p->szName1, p->szName2);
}
void CClientManager::MarriageUpdate(TPacketMarriageUpdate * p)
{
sys_log(0, "MarriageUpdate PID:%u %u LP:%d ST:%d", p->dwPID1, p->dwPID2, p->iLovePoint, p->byMarried);
marriage::CManager::instance().Update(p->dwPID1, p->dwPID2, p->iLovePoint, p->byMarried);
}
void CClientManager::MarriageRemove(TPacketMarriageRemove * p)
{
sys_log(0, "MarriageRemove %u %u", p->dwPID1, p->dwPID2);
marriage::CManager::instance().Remove(p->dwPID1, p->dwPID2);
}
void CClientManager::WeddingRequest(TPacketWeddingRequest * p)
{
sys_log(0, "WeddingRequest %u %u", p->dwPID1, p->dwPID2);
ForwardPacket(HEADER_DG_WEDDING_REQUEST, p, sizeof(TPacketWeddingRequest));
//marriage::CManager::instance().RegisterWedding(p->dwPID1, p->szName1, p->dwPID2, p->szName2);
}
void CClientManager::WeddingReady(TPacketWeddingReady * p)
{
sys_log(0, "WeddingReady %u %u", p->dwPID1, p->dwPID2);
ForwardPacket(HEADER_DG_WEDDING_READY, p, sizeof(TPacketWeddingReady));
marriage::CManager::instance().ReadyWedding(p->dwMapIndex, p->dwPID1, p->dwPID2);
}
void CClientManager::WeddingEnd(TPacketWeddingEnd * p)
{
sys_log(0, "WeddingEnd %u %u", p->dwPID1, p->dwPID2);
marriage::CManager::instance().EndWedding(p->dwPID1, p->dwPID2);
}
//
// ij<>ÿ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ij<>ø<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ʈ <20>ϰ<EFBFBD> ij<>ÿ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD>ٸ<EFBFBD>
// <20><20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>͸<EFBFBD> <20>ε<EFBFBD><CEB5><EFBFBD> <20>ڿ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ij<>ø<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ʈ <20>Ѵ<EFBFBD>.
//
void CClientManager::MyshopPricelistUpdate(const TPacketMyshopPricelistHeader* pPacket)
{
if (pPacket->byCount > SHOP_PRICELIST_MAX_NUM)
{
sys_err("count overflow!");
return;
}
CItemPriceListTableCache* pCache = GetItemPriceListCache(pPacket->dwOwnerID);
if (pCache)
{
TItemPriceListTable table;
table.dwOwnerID = pPacket->dwOwnerID;
table.byCount = pPacket->byCount;
const TItemPriceInfo * pInfo = reinterpret_cast<const TItemPriceInfo*>(pPacket + sizeof(TPacketMyshopPricelistHeader));
thecore_memcpy(table.aPriceInfo, pInfo, sizeof(TItemPriceInfo) * pPacket->byCount);
pCache->UpdateList(&table);
}
else
{
TItemPriceListTable* pUpdateTable = new TItemPriceListTable;
pUpdateTable->dwOwnerID = pPacket->dwOwnerID;
pUpdateTable->byCount = pPacket->byCount;
const TItemPriceInfo * pInfo = reinterpret_cast<const TItemPriceInfo*>(pPacket + sizeof(TPacketMyshopPricelistHeader));
thecore_memcpy(pUpdateTable->aPriceInfo, pInfo, sizeof(TItemPriceInfo) * pPacket->byCount);
char szQuery[QUERY_MAX_LEN];
snprintf(szQuery, sizeof(szQuery), "SELECT item_vnum, price FROM myshop_pricelist%s WHERE owner_id=%u", GetTablePostfix(), pPacket->dwOwnerID);
CDBManager::instance().ReturnQuery(szQuery, QID_ITEMPRICE_LOAD_FOR_UPDATE, 0, pUpdateTable);
}
}
// MYSHOP_PRICE_LIST
// ij<>õ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ij<>ø<EFBFBD> <20>о<EFBFBD> <20>ٷ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ϰ<EFBFBD> ij<>ÿ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> DB <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>Ѵ<EFBFBD>.
//
void CClientManager::MyshopPricelistRequest(CPeer* peer, DWORD dwHandle, DWORD dwPlayerID)
{
if (CItemPriceListTableCache* pCache = GetItemPriceListCache(dwPlayerID))
{
sys_log(0, "Cache MyShopPricelist handle[%d] pid[%d]", dwHandle, dwPlayerID);
TItemPriceListTable* pTable = pCache->Get(false);
TPacketMyshopPricelistHeader header =
{
pTable->dwOwnerID,
pTable->byCount
};
size_t sizePriceListSize = sizeof(TItemPriceInfo) * pTable->byCount;
peer->EncodeHeader(HEADER_DG_MYSHOP_PRICELIST_RES, dwHandle, sizeof(header) + sizePriceListSize);
peer->Encode(&header, sizeof(header));
peer->Encode(pTable->aPriceInfo, sizePriceListSize);
}
else
{
sys_log(0, "Query MyShopPricelist handle[%d] pid[%d]", dwHandle, dwPlayerID);
char szQuery[QUERY_MAX_LEN];
snprintf(szQuery, sizeof(szQuery), "SELECT item_vnum, price FROM myshop_pricelist%s WHERE owner_id=%u", GetTablePostfix(), dwPlayerID);
CDBManager::instance().ReturnQuery(szQuery, QID_ITEMPRICE_LOAD, peer->GetHandle(), new TItemPricelistReqInfo(dwHandle, dwPlayerID));
}
}
// END_OF_MYSHOP_PRICE_LIST
void CPacketInfo::Add(int header)
{
itertype(m_map_info) it = m_map_info.find(header);
if (it == m_map_info.end())
m_map_info.insert(std::map<int, int>::value_type(header, 1));
else
++it->second;
}
void CPacketInfo::Reset()
{
m_map_info.clear();
}
void CClientManager::ProcessPackets(CPeer * peer)
{
BYTE header;
DWORD dwHandle;
DWORD dwLength;
const char * data = NULL;
int i = 0;
int iCount = 0;
while (peer->PeekPacket(i, header, dwHandle, dwLength, &data))
{
// DISABLE_DB_HEADER_LOG
// sys_log(0, "header %d %p size %d", header, this, dwLength);
// END_OF_DISABLE_DB_HEADER_LOG
m_bLastHeader = header;
++iCount;
#ifdef _TEST
if (header != 10)
sys_log(0, " ProcessPacket Header [%d] Handle[%d] Length[%d] iCount[%d]", header, dwHandle, dwLength, iCount);
#endif
if (g_test_server)
{
if (header != 10)
sys_log(0, " ProcessPacket Header [%d] Handle[%d] Length[%d] iCount[%d]", header, dwHandle, dwLength, iCount);
}
// test log by mhh
{
if (HEADER_GD_BLOCK_COUNTRY_IP == header)
sys_log(0, "recved : HEADER_GD_BLOCK_COUNTRY_IP");
}
switch (header)
{
case HEADER_GD_BOOT:
QUERY_BOOT(peer, (TPacketGDBoot *) data);
break;
case HEADER_GD_HAMMER_OF_TOR:
break;
case HEADER_GD_LOGIN_BY_KEY:
QUERY_LOGIN_BY_KEY(peer, dwHandle, (TPacketGDLoginByKey *) data);
break;
case HEADER_GD_LOGOUT:
//sys_log(0, "HEADER_GD_LOGOUT (handle: %d length: %d)", dwHandle, dwLength);
QUERY_LOGOUT(peer, dwHandle, data);
break;
case HEADER_GD_PLAYER_LOAD:
sys_log(1, "HEADER_GD_PLAYER_LOAD (handle: %d length: %d)", dwHandle, dwLength);
QUERY_PLAYER_LOAD(peer, dwHandle, (TPlayerLoadPacket *) data);
break;
case HEADER_GD_PLAYER_SAVE:
sys_log(1, "HEADER_GD_PLAYER_SAVE (handle: %d length: %d)", dwHandle, dwLength);
QUERY_PLAYER_SAVE(peer, dwHandle, (TPlayerTable *) data);
break;
case HEADER_GD_PLAYER_CREATE:
sys_log(0, "HEADER_GD_PLAYER_CREATE (handle: %d length: %d)", dwHandle, dwLength);
__QUERY_PLAYER_CREATE(peer, dwHandle, (TPlayerCreatePacket *) data);
sys_log(0, "END");
break;
case HEADER_GD_PLAYER_DELETE:
sys_log(1, "HEADER_GD_PLAYER_DELETE (handle: %d length: %d)", dwHandle, dwLength);
__QUERY_PLAYER_DELETE(peer, dwHandle, (TPlayerDeletePacket *) data);
break;
case HEADER_GD_PLAYER_COUNT:
QUERY_PLAYER_COUNT(peer, (TPlayerCountPacket *) data);
break;
case HEADER_GD_QUEST_SAVE:
sys_log(1, "HEADER_GD_QUEST_SAVE (handle: %d length: %d)", dwHandle, dwLength);
QUERY_QUEST_SAVE(peer, (TQuestTable *) data, dwLength);
break;
case HEADER_GD_SAFEBOX_LOAD:
QUERY_SAFEBOX_LOAD(peer, dwHandle, (TSafeboxLoadPacket *) data, 0);
break;
case HEADER_GD_SAFEBOX_SAVE:
sys_log(1, "HEADER_GD_SAFEBOX_SAVE (handle: %d length: %d)", dwHandle, dwLength);
QUERY_SAFEBOX_SAVE(peer, (TSafeboxTable *) data);
break;
case HEADER_GD_SAFEBOX_CHANGE_SIZE:
QUERY_SAFEBOX_CHANGE_SIZE(peer, dwHandle, (TSafeboxChangeSizePacket *) data);
break;
case HEADER_GD_SAFEBOX_CHANGE_PASSWORD:
QUERY_SAFEBOX_CHANGE_PASSWORD(peer, dwHandle, (TSafeboxChangePasswordPacket *) data);
break;
case HEADER_GD_MALL_LOAD:
QUERY_SAFEBOX_LOAD(peer, dwHandle, (TSafeboxLoadPacket *) data, 1);
break;
case HEADER_GD_EMPIRE_SELECT:
QUERY_EMPIRE_SELECT(peer, dwHandle, (TEmpireSelectPacket *) data);
break;
case HEADER_GD_SETUP:
QUERY_SETUP(peer, dwHandle, data);
break;
case HEADER_GD_GUILD_CREATE:
GuildCreate(peer, *(DWORD *) data);
break;
case HEADER_GD_GUILD_SKILL_UPDATE:
GuildSkillUpdate(peer, (TPacketGuildSkillUpdate *) data);
break;
case HEADER_GD_GUILD_EXP_UPDATE:
GuildExpUpdate(peer, (TPacketGuildExpUpdate *) data);
break;
case HEADER_GD_GUILD_ADD_MEMBER:
GuildAddMember(peer, (TPacketGDGuildAddMember*) data);
break;
case HEADER_GD_GUILD_REMOVE_MEMBER:
GuildRemoveMember(peer, (TPacketGuild*) data);
break;
case HEADER_GD_GUILD_CHANGE_GRADE:
GuildChangeGrade(peer, (TPacketGuild*) data);
break;
case HEADER_GD_GUILD_CHANGE_MEMBER_DATA:
GuildChangeMemberData(peer, (TPacketGuildChangeMemberData*) data);
break;
case HEADER_GD_GUILD_DISBAND:
GuildDisband(peer, (TPacketGuild*) data);
break;
case HEADER_GD_GUILD_WAR:
GuildWar(peer, (TPacketGuildWar*) data);
break;
case HEADER_GD_GUILD_WAR_SCORE:
GuildWarScore(peer, (TPacketGuildWarScore*) data);
break;
case HEADER_GD_GUILD_CHANGE_LADDER_POINT:
GuildChangeLadderPoint((TPacketGuildLadderPoint*) data);
break;
case HEADER_GD_GUILD_USE_SKILL:
GuildUseSkill((TPacketGuildUseSkill*) data);
break;
case HEADER_GD_FLUSH_CACHE:
QUERY_FLUSH_CACHE(peer, data);
break;
case HEADER_GD_ITEM_SAVE:
QUERY_ITEM_SAVE(peer, data);
break;
case HEADER_GD_ITEM_DESTROY:
QUERY_ITEM_DESTROY(peer, data);
break;
case HEADER_GD_ITEM_FLUSH:
QUERY_ITEM_FLUSH(peer, data);
break;
case HEADER_GD_ADD_AFFECT:
sys_log(1, "HEADER_GD_ADD_AFFECT");
QUERY_ADD_AFFECT(peer, (TPacketGDAddAffect *) data);
break;
case HEADER_GD_REMOVE_AFFECT:
sys_log(1, "HEADER_GD_REMOVE_AFFECT");
QUERY_REMOVE_AFFECT(peer, (TPacketGDRemoveAffect *) data);
break;
case HEADER_GD_HIGHSCORE_REGISTER:
QUERY_HIGHSCORE_REGISTER(peer, (TPacketGDHighscore *) data);
break;
case HEADER_GD_PARTY_CREATE:
QUERY_PARTY_CREATE(peer, (TPacketPartyCreate*) data);
break;
case HEADER_GD_PARTY_DELETE:
QUERY_PARTY_DELETE(peer, (TPacketPartyDelete*) data);
break;
case HEADER_GD_PARTY_ADD:
QUERY_PARTY_ADD(peer, (TPacketPartyAdd*) data);
break;
case HEADER_GD_PARTY_REMOVE:
QUERY_PARTY_REMOVE(peer, (TPacketPartyRemove*) data);
break;
case HEADER_GD_PARTY_STATE_CHANGE:
QUERY_PARTY_STATE_CHANGE(peer, (TPacketPartyStateChange*) data);
break;
case HEADER_GD_PARTY_SET_MEMBER_LEVEL:
QUERY_PARTY_SET_MEMBER_LEVEL(peer, (TPacketPartySetMemberLevel*) data);
break;
case HEADER_GD_RELOAD_PROTO:
QUERY_RELOAD_PROTO();
break;
case HEADER_GD_CHANGE_NAME:
QUERY_CHANGE_NAME(peer, dwHandle, (TPacketGDChangeName *) data);
break;
case HEADER_GD_SMS:
QUERY_SMS(peer, (TPacketGDSMS *) data);
break;
case HEADER_GD_AUTH_LOGIN:
QUERY_AUTH_LOGIN(peer, dwHandle, (TPacketGDAuthLogin *) data);
break;
case HEADER_GD_REQUEST_GUILD_PRIV:
AddGuildPriv((TPacketGiveGuildPriv*)data);
break;
case HEADER_GD_REQUEST_EMPIRE_PRIV:
AddEmpirePriv((TPacketGiveEmpirePriv*)data);
break;
case HEADER_GD_REQUEST_CHARACTER_PRIV:
AddCharacterPriv((TPacketGiveCharacterPriv*) data);
break;
case HEADER_GD_MONEY_LOG:
MoneyLog((TPacketMoneyLog*)data);
break;
case HEADER_GD_GUILD_DEPOSIT_MONEY:
GuildDepositMoney((TPacketGDGuildMoney*)data);
break;
case HEADER_GD_GUILD_WITHDRAW_MONEY:
GuildWithdrawMoney(peer, (TPacketGDGuildMoney*)data);
break;
case HEADER_GD_GUILD_WITHDRAW_MONEY_GIVE_REPLY:
GuildWithdrawMoneyGiveReply((TPacketGDGuildMoneyWithdrawGiveReply*)data);
break;
case HEADER_GD_GUILD_WAR_BET:
GuildWarBet((TPacketGDGuildWarBet *) data);
break;
case HEADER_GD_SET_EVENT_FLAG:
SetEventFlag((TPacketSetEventFlag*) data);
break;
case HEADER_GD_BILLING_EXPIRE:
BillingExpire((TPacketBillingExpire *) data);
break;
case HEADER_GD_BILLING_CHECK:
BillingCheck(data);
break;
case HEADER_GD_CREATE_OBJECT:
CreateObject((TPacketGDCreateObject *) data);
break;
case HEADER_GD_DELETE_OBJECT:
DeleteObject(*(DWORD *) data);
break;
case HEADER_GD_UPDATE_LAND:
UpdateLand((DWORD *) data);
break;
case HEADER_GD_VCARD:
VCard((TPacketGDVCard *) data);
break;
case HEADER_GD_MARRIAGE_ADD:
MarriageAdd((TPacketMarriageAdd *) data);
break;
case HEADER_GD_MARRIAGE_UPDATE:
MarriageUpdate((TPacketMarriageUpdate *) data);
break;
case HEADER_GD_MARRIAGE_REMOVE:
MarriageRemove((TPacketMarriageRemove *) data);
break;
case HEADER_GD_WEDDING_REQUEST:
WeddingRequest((TPacketWeddingRequest *) data);
break;
case HEADER_GD_WEDDING_READY:
WeddingReady((TPacketWeddingReady *) data);
break;
case HEADER_GD_WEDDING_END:
WeddingEnd((TPacketWeddingEnd *) data);
break;
// BLOCK_CHAT
case HEADER_GD_BLOCK_CHAT:
BlockChat((TPacketBlockChat *) data);
break;
// END_OF_BLOCK_CHAT
// MYSHOP_PRICE_LIST
case HEADER_GD_MYSHOP_PRICELIST_UPDATE:
MyshopPricelistUpdate((TPacketMyshopPricelistHeader*)data);
break;
case HEADER_GD_MYSHOP_PRICELIST_REQ:
MyshopPricelistRequest(peer, dwHandle, *(DWORD*)data);
break;
// END_OF_MYSHOP_PRICE_LIST
//RELOAD_ADMIN
case HEADER_GD_RELOAD_ADMIN:
ReloadAdmin(peer, (TPacketReloadAdmin*)data);
break;
//END_RELOAD_ADMIN
case HEADER_GD_BREAK_MARRIAGE:
BreakMarriage(peer, data);
break;
//MOANRCH
case HEADER_GD_ELECT_MONARCH:
Election(peer, dwHandle, data);
break;
case HEADER_GD_CANDIDACY:
Candidacy(peer, dwHandle, data);
break;
case HEADER_GD_ADD_MONARCH_MONEY:
AddMonarchMoney(peer, dwHandle, data);
break;
case HEADER_GD_DEC_MONARCH_MONEY:
DecMonarchMoney(peer, dwHandle, data);
break;
case HEADER_GD_TAKE_MONARCH_MONEY:
TakeMonarchMoney(peer, dwHandle, data);
break;
case HEADER_GD_COME_TO_VOTE:
ComeToVote(peer, dwHandle, data);
break;
case HEADER_GD_RMCANDIDACY: //< <20>ĺ<EFBFBD> <20><><EFBFBD><EFBFBD> (<28><EFBFBD><EEBFB5>)
RMCandidacy(peer, dwHandle, data);
break;
case HEADER_GD_SETMONARCH: ///<<3C><><EFBFBD>ּ<EFBFBD><D6BC><EFBFBD> (<28><EFBFBD><EEBFB5>)
SetMonarch(peer, dwHandle, data);
break;
case HEADER_GD_RMMONARCH: ///<<3C><><EFBFBD>ֻ<EFBFBD><D6BB><EFBFBD>
RMMonarch(peer, dwHandle, data);
break;
//END_MONARCH
case HEADER_GD_CHANGE_MONARCH_LORD :
ChangeMonarchLord(peer, dwHandle, (TPacketChangeMonarchLord*)data);
break;
case HEADER_GD_BLOCK_COUNTRY_IP:
sys_log(0, "HEADER_GD_BLOCK_COUNTRY_IP received");
CBlockCountry::instance().SendBlockedCountryIp(peer);
CBlockCountry::instance().SendBlockException(peer);
break;
case HEADER_GD_BLOCK_EXCEPTION:
sys_log(0, "HEADER_GD_BLOCK_EXCEPTION received");
BlockException((TPacketBlockException*) data);
break;
case HEADER_GD_REQ_SPARE_ITEM_ID_RANGE :
SendSpareItemIDRange(peer);
break;
case HEADER_GD_REQ_CHANGE_GUILD_MASTER :
GuildChangeMaster((TPacketChangeGuildMaster*) data);
break;
case HEADER_GD_UPDATE_HORSE_NAME :
UpdateHorseName((TPacketUpdateHorseName*) data, peer);
break;
case HEADER_GD_REQ_HORSE_NAME :
AckHorseName(*(DWORD*)data, peer);
break;
case HEADER_GD_DC:
DeleteLoginKey((TPacketDC*) data);
break;
case HEADER_GD_VALID_LOGOUT:
ResetLastPlayerID((TPacketNeedLoginLogInfo*)data);
break;
case HEADER_GD_REQUEST_CHARGE_CASH:
ChargeCash((TRequestChargeCash*)data);
break;
//delete gift notify icon
case HEADER_GD_DELETE_AWARDID:
DeleteAwardId((TPacketDeleteAwardID*) data);
break;
case HEADER_GD_UPDATE_CHANNELSTATUS:
UpdateChannelStatus((SChannelStatus*) data);
break;
case HEADER_GD_REQUEST_CHANNELSTATUS:
RequestChannelStatus(peer, dwHandle);
break;
#ifdef __AUCTION__
case HEADER_GD_COMMAND_AUCTION:
{
TPacketGDCommnadAuction* auction_data = (TPacketGDCommnadAuction*)data;
switch (auction_data->get_cmd())
{
case AUCTION_ENR_AUC:
EnrollInAuction (peer, dwHandle, (AuctionEnrollProductInfo*)data);
break;
case AUCTION_ENR_SALE:
EnrollInSale (peer, dwHandle, (AuctionEnrollSaleInfo*)data);
break;
case AUCTION_ENR_WISH:
EnrollInWish (peer, dwHandle, (AuctionEnrollWishInfo*)data);
break;
case AUCTION_BID:
AuctionBid (peer, dwHandle, (AuctionBidInfo*)data);
break;
case AUCTION_IMME_PUR:
AuctionImpur (peer, dwHandle, (AuctionImpurInfo*)data);
break;
case AUCTION_GET_AUC:
AuctionGetAuctionedItem (peer, dwHandle, auction_data->get_item());
break;
case AUCTION_BUY_SOLD:
AuctionBuySoldItem (peer, dwHandle, auction_data->get_item());
break;
case AUCTION_CANCEL_AUC:
AuctionCancelAuction (peer, dwHandle, auction_data->get_item());
break;
case AUCTION_CANCEL_WISH:
AuctionCancelWish (peer, dwHandle, auction_data->get_item());
break;
case AUCTION_CANCEL_SALE:
AuctionCancelSale (peer, dwHandle, auction_data->get_item());
break;
case AUCTION_DELETE_AUCTION_ITEM:
AuctionDeleteAuctionItem (peer, dwHandle, auction_data->get_item());
break;
case AUCTION_DELETE_SALE_ITEM:
AuctionDeleteSaleItem (peer, dwHandle, auction_data->get_item());
break;
case AUCTION_REBID:
AuctionReBid (peer, dwHandle, (AuctionBidInfo*)data);
break;
// case AUCTION_BID_CANCEL:
// AuctionBidCancel (peer, dwHandle, data->get_item());
default :
break;
}
}
break;
#endif
default:
sys_err("Unknown header (header: %d handle: %d length: %d)", header, dwHandle, dwLength);
break;
}
}
peer->RecvEnd(i);
}
void CClientManager::AddPeer(socket_t fd)
{
CPeer * pPeer = new CPeer;
if (pPeer->Accept(fd))
m_peerList.push_front(pPeer);
else
delete pPeer;
}
void CClientManager::RemovePeer(CPeer * pPeer)
{
if (m_pkAuthPeer == pPeer)
{
m_pkAuthPeer = NULL;
}
else
{
TLogonAccountMap::iterator it = m_map_kLogonAccount.begin();
while (it != m_map_kLogonAccount.end())
{
CLoginData * pkLD = it->second;
if (pkLD->GetConnectedPeerHandle() == pPeer->GetHandle())
{
if (pkLD->IsPlay())
{
pkLD->SetPlay(false);
SendLoginToBilling(pkLD, false);
}
if (pkLD->IsDeleted())
{
sys_log(0, "DELETING LoginData");
delete pkLD;
}
m_map_kLogonAccount.erase(it++);
}
else
++it;
}
}
m_peerList.remove(pPeer);
delete pPeer;
}
CPeer * CClientManager::GetPeer(IDENT ident)
{
for (itertype(m_peerList) i = m_peerList.begin(); i != m_peerList.end();++i)
{
CPeer * tmp = *i;
if (tmp->GetHandle() == ident)
return tmp;
}
return NULL;
}
CPeer * CClientManager::GetAnyPeer()
{
if (m_peerList.empty())
return NULL;
return m_peerList.front();
}
// DB <20>Ŵ<EFBFBD><C5B4><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ó<><C3B3><EFBFBD>Ѵ<EFBFBD>.
//
// @version 05/06/10 Bang2ni - <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>(QID_ITEMPRICE_XXX) <20>߰<EFBFBD>
int CClientManager::AnalyzeQueryResult(SQLMsg * msg)
{
CQueryInfo * qi = (CQueryInfo *) msg->pvUserData;
CPeer * peer = GetPeer(qi->dwIdent);
#ifdef _TEST
if (qi->iType != QID_ITEM_AWARD_LOAD)
sys_log(0, "AnalyzeQueryResult %d", qi->iType);
#endif
switch (qi->iType)
{
case QID_ITEM_AWARD_LOAD:
ItemAwardManager::instance().Load(msg);
delete qi;
return true;
case QID_GUILD_RANKING:
CGuildManager::instance().ResultRanking(msg->Get()->pSQLResult);
break;
// MYSHOP_PRICE_LIST
case QID_ITEMPRICE_LOAD_FOR_UPDATE:
RESULT_PRICELIST_LOAD_FOR_UPDATE(msg);
break;
// END_OF_MYSHOP_PRICE_LIST
}
if (!peer)
{
//sys_err("CClientManager::AnalyzeQueryResult: peer not exist anymore. (ident: %d)", qi->dwIdent);
delete qi;
return true;
}
switch (qi->iType)
{
case QID_PLAYER:
case QID_ITEM:
case QID_QUEST:
case QID_AFFECT:
RESULT_COMPOSITE_PLAYER(peer, msg, qi->iType);
break;
case QID_LOGIN:
RESULT_LOGIN(peer, msg);
break;
case QID_SAFEBOX_LOAD:
sys_log(0, "QUERY_RESULT: HEADER_GD_SAFEBOX_LOAD");
RESULT_SAFEBOX_LOAD(peer, msg);
break;
case QID_SAFEBOX_CHANGE_SIZE:
sys_log(0, "QUERY_RESULT: HEADER_GD_SAFEBOX_CHANGE_SIZE");
RESULT_SAFEBOX_CHANGE_SIZE(peer, msg);
break;
case QID_SAFEBOX_CHANGE_PASSWORD:
sys_log(0, "QUERY_RESULT: HEADER_GD_SAFEBOX_CHANGE_PASSWORD %p", msg);
RESULT_SAFEBOX_CHANGE_PASSWORD(peer, msg);
break;
case QID_SAFEBOX_CHANGE_PASSWORD_SECOND:
sys_log(0, "QUERY_RESULT: HEADER_GD_SAFEBOX_CHANGE_PASSWORD %p", msg);
RESULT_SAFEBOX_CHANGE_PASSWORD_SECOND(peer, msg);
break;
case QID_HIGHSCORE_REGISTER:
sys_log(0, "QUERY_RESULT: HEADER_GD_HIGHSCORE_REGISTER %p", msg);
RESULT_HIGHSCORE_REGISTER(peer, msg);
break;
case QID_SAFEBOX_SAVE:
case QID_ITEM_SAVE:
case QID_ITEM_DESTROY:
case QID_QUEST_SAVE:
case QID_PLAYER_SAVE:
case QID_ITEM_AWARD_TAKEN:
break;
// PLAYER_INDEX_CREATE_BUG_FIX
case QID_PLAYER_INDEX_CREATE:
RESULT_PLAYER_INDEX_CREATE(peer, msg);
break;
// END_PLAYER_INDEX_CREATE_BUG_FIX
case QID_PLAYER_DELETE:
__RESULT_PLAYER_DELETE(peer, msg);
break;
case QID_LOGIN_BY_KEY:
RESULT_LOGIN_BY_KEY(peer, msg);
break;
// MYSHOP_PRICE_LIST
case QID_ITEMPRICE_LOAD:
RESULT_PRICELIST_LOAD(peer, msg);
break;
// END_OF_MYSHOP_PRICE_LIST
default:
sys_log(0, "CClientManager::AnalyzeQueryResult unknown query result type: %d, str: %s", qi->iType, msg->stQuery.c_str());
break;
}
delete qi;
return true;
}
void UsageLog()
{
FILE* fp = NULL;
time_t ct;
char *time_s;
struct tm lt;
int avg = g_dwUsageAvg / 3600; // 60 <20><> * 60 <20><>
fp = fopen("usage.txt", "a+");
if (!fp)
return;
ct = time(0);
lt = *localtime(&ct);
time_s = asctime(&lt);
time_s[strlen(time_s) - 1] = '\0';
fprintf(fp, "| %4d %-15.15s | %5d | %5u |", lt.tm_year + 1900, time_s + 4, avg, g_dwUsageMax);
fprintf(fp, "\n");
fclose(fp);
g_dwUsageMax = g_dwUsageAvg = 0;
}
int CClientManager::Process()
{
int pulses;
if (!(pulses = thecore_idle()))
return 0;
while (pulses--)
{
++thecore_heart->pulse;
/*
//30<33>и<EFBFBD><D0B8><EFBFBD> <20><><EFBFBD><EFBFBD>
if (((thecore_pulse() % (60 * 30 * 10)) == 0))
{
g_iPlayerCacheFlushSeconds = MAX(60, rand() % 180);
g_iItemCacheFlushSeconds = MAX(60, rand() % 180);
sys_log(0, "[SAVE_TIME]Change saving time item %d player %d", g_iPlayerCacheFlushSeconds, g_iItemCacheFlushSeconds);
}
*/
if (!(thecore_heart->pulse % thecore_heart->passes_per_sec))
{
if (g_test_server)
{
if (!(thecore_heart->pulse % thecore_heart->passes_per_sec * 10))
{
pt_log("[%9d] return %d/%d/%d/%d async %d/%d/%d/%d",
thecore_heart->pulse,
CDBManager::instance().CountReturnQuery(SQL_PLAYER),
CDBManager::instance().CountReturnResult(SQL_PLAYER),
CDBManager::instance().CountReturnQueryFinished(SQL_PLAYER),
CDBManager::instance().CountReturnCopiedQuery(SQL_PLAYER),
CDBManager::instance().CountAsyncQuery(SQL_PLAYER),
CDBManager::instance().CountAsyncResult(SQL_PLAYER),
CDBManager::instance().CountAsyncQueryFinished(SQL_PLAYER),
CDBManager::instance().CountAsyncCopiedQuery(SQL_PLAYER));
if ((thecore_heart->pulse % 50) == 0)
sys_log(0, "[%9d] return %d/%d/%d async %d/%d/%d",
thecore_heart->pulse,
CDBManager::instance().CountReturnQuery(SQL_PLAYER),
CDBManager::instance().CountReturnResult(SQL_PLAYER),
CDBManager::instance().CountReturnQueryFinished(SQL_PLAYER),
CDBManager::instance().CountAsyncQuery(SQL_PLAYER),
CDBManager::instance().CountAsyncResult(SQL_PLAYER),
CDBManager::instance().CountAsyncQueryFinished(SQL_PLAYER));
}
}
else
{
pt_log("[%9d] return %d/%d/%d/%d async %d/%d/%d%/%d",
thecore_heart->pulse,
CDBManager::instance().CountReturnQuery(SQL_PLAYER),
CDBManager::instance().CountReturnResult(SQL_PLAYER),
CDBManager::instance().CountReturnQueryFinished(SQL_PLAYER),
CDBManager::instance().CountReturnCopiedQuery(SQL_PLAYER),
CDBManager::instance().CountAsyncQuery(SQL_PLAYER),
CDBManager::instance().CountAsyncResult(SQL_PLAYER),
CDBManager::instance().CountAsyncQueryFinished(SQL_PLAYER),
CDBManager::instance().CountAsyncCopiedQuery(SQL_PLAYER));
if ((thecore_heart->pulse % 50) == 0)
sys_log(0, "[%9d] return %d/%d/%d async %d/%d/%d",
thecore_heart->pulse,
CDBManager::instance().CountReturnQuery(SQL_PLAYER),
CDBManager::instance().CountReturnResult(SQL_PLAYER),
CDBManager::instance().CountReturnQueryFinished(SQL_PLAYER),
CDBManager::instance().CountAsyncQuery(SQL_PLAYER),
CDBManager::instance().CountAsyncResult(SQL_PLAYER),
CDBManager::instance().CountAsyncQueryFinished(SQL_PLAYER));
}
CDBManager::instance().ResetCounter();
DWORD dwCount = CClientManager::instance().GetUserCount();
g_dwUsageAvg += dwCount;
g_dwUsageMax = MAX(g_dwUsageMax, dwCount);
memset(&thecore_profiler[0], 0, sizeof(thecore_profiler));
if (!(thecore_heart->pulse % (thecore_heart->passes_per_sec * 3600)))
UsageLog();
m_iCacheFlushCount = 0;
//<2F>÷<EFBFBD><C3B7>̾<EFBFBD> <20>÷<EFBFBD><C3B7><EFBFBD>
UpdatePlayerCache();
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>÷<EFBFBD><C3B7><EFBFBD>
UpdateItemCache();
//<2F>α׾ƿ<D7BE><C6BF><EFBFBD> ó<><C3B3>- ij<><C4B3><EFBFBD><EFBFBD> <20>÷<EFBFBD><C3B7><EFBFBD>
UpdateLogoutPlayer();
// MYSHOP_PRICE_LIST
UpdateItemPriceListCache();
// END_OF_MYSHOP_PRICE_LIST
CGuildManager::instance().Update();
CPrivManager::instance().Update();
marriage::CManager::instance().Update();
}
if (!(thecore_heart->pulse % (thecore_heart->passes_per_sec * 5)))
{
ItemAwardManager::instance().RequestLoad();
}
if (!(thecore_heart->pulse % (thecore_heart->passes_per_sec * 10)))
{
/*
char buf[4096 + 1];
int len
itertype(g_query_info.m_map_info) it;
/////////////////////////////////////////////////////////////////
buf[0] = '\0';
len = 0;
it = g_query_info.m_map_info.begin();
int count = 0;
while (it != g_query_info.m_map_info.end())
{
len += snprintf(buf + len, sizeof(buf) - len, "%2d %3d\n", it->first, it->second);
count += it->second;
it++;
}
pt_log("QUERY:\n%s-------------------- MAX : %d\n", buf, count);
g_query_info.Reset();
*/
pt_log("QUERY: MAIN[%d] ASYNC[%d]", g_query_count[0], g_query_count[1]);
g_query_count[0] = 0;
g_query_count[1] = 0;
/////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////
/*
buf[0] = '\0';
len = 0;
it = g_item_info.m_map_info.begin();
count = 0;
while (it != g_item_info.m_map_info.end())
{
len += snprintf(buf + len, sizeof(buf) - len, "%5d %3d\n", it->first, it->second);
count += it->second;
it++;
}
pt_log("ITEM:\n%s-------------------- MAX : %d\n", buf, count);
g_item_info.Reset();
*/
pt_log("ITEM:%d\n", g_item_count);
g_item_count = 0;
/////////////////////////////////////////////////////////////////
}
if (!(thecore_heart->pulse % (thecore_heart->passes_per_sec * 60))) // 60<36>ʿ<EFBFBD> <20>ѹ<EFBFBD>
{
// <20><><EFBFBD><EFBFBD>ũ <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20>ð<EFBFBD><C3B0><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
CClientManager::instance().SendTime();
}
if (!(thecore_heart->pulse % (thecore_heart->passes_per_sec * 3600))) // <20>ѽð<D1BD><C3B0><EFBFBD> <20>ѹ<EFBFBD>
{
CMoneyLog::instance().Save();
}
}
int num_events = fdwatch(m_fdWatcher, 0);
int idx;
CPeer * peer;
for (idx = 0; idx < num_events; ++idx) // <20><>Dz
{
peer = (CPeer *) fdwatch_get_client_data(m_fdWatcher, idx);
if (!peer)
{
if (fdwatch_check_event(m_fdWatcher, m_fdAccept, idx) == FDW_READ)
{
AddPeer(m_fdAccept);
fdwatch_clear_event(m_fdWatcher, m_fdAccept, idx);
}
else
{
sys_err("FDWATCH: peer null in event: ident %d", fdwatch_get_ident(m_fdWatcher, idx));
}
continue;
}
switch (fdwatch_check_event(m_fdWatcher, peer->GetFd(), idx))
{
case FDW_READ:
if (peer->Recv() < 0)
{
sys_err("Recv failed");
RemovePeer(peer);
}
else
{
if (peer == m_pkAuthPeer)
if (g_log)
sys_log(0, "AUTH_PEER_READ: size %d", peer->GetRecvLength());
ProcessPackets(peer);
}
break;
case FDW_WRITE:
if (peer == m_pkAuthPeer)
if (g_log)
sys_log(0, "AUTH_PEER_WRITE: size %d", peer->GetSendLength());
if (peer->Send() < 0)
{
sys_err("Send failed");
RemovePeer(peer);
}
break;
case FDW_EOF:
RemovePeer(peer);
break;
default:
sys_err("fdwatch_check_fd returned unknown result");
RemovePeer(peer);
break;
}
}
#ifdef __WIN32__
if (_kbhit()) {
int c = _getch();
switch (c) {
case 0x1b: // Esc
return 0; // shutdown
break;
default:
break;
}
}
#endif
VCardProcess();
return 1;
}
DWORD CClientManager::GetUserCount()
{
// <20>ܼ<EFBFBD><DCBC><EFBFBD> <20>α<EFBFBD><CEB1><EFBFBD> ī<><C4AB>Ʈ<EFBFBD><C6AE> <20><><EFBFBD><EFBFBD>.. --;
return m_map_kLogonAccount.size();
}
void CClientManager::SendAllGuildSkillRechargePacket()
{
ForwardPacket(HEADER_DG_GUILD_SKILL_RECHARGE, NULL, 0);
}
void CClientManager::SendTime()
{
time_t now = GetCurrentTime();
ForwardPacket(HEADER_DG_TIME, &now, sizeof(time_t));
}
void CClientManager::ForwardPacket(BYTE header, const void* data, int size, BYTE bChannel, CPeer* except)
{
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer * peer = *it;
if (peer == except)
continue;
if (!peer->GetChannel())
continue;
if (bChannel && peer->GetChannel() != bChannel)
continue;
peer->EncodeHeader(header, 0, size);
if (size > 0 && data)
peer->Encode(data, size);
}
}
void CClientManager::SendNotice(const char * c_pszFormat, ...)
{
char szBuf[255+1];
va_list args;
va_start(args, c_pszFormat);
int len = vsnprintf(szBuf, sizeof(szBuf), c_pszFormat, args);
va_end(args);
szBuf[len] = '\0';
ForwardPacket(HEADER_DG_NOTICE, szBuf, len + 1);
}
time_t CClientManager::GetCurrentTime()
{
return time(0);
}
// ITEM_UNIQUE_ID
bool CClientManager::InitializeNowItemID()
{
DWORD dwMin, dwMax;
//<2F><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ID<49><44> <20>ʱ<EFBFBD>ȭ <20>Ѵ<EFBFBD>.
if (!CConfig::instance().GetTwoValue("ITEM_ID_RANGE", &dwMin, &dwMax))
{
sys_err("conf.txt: Cannot find ITEM_ID_RANGE [start_item_id] [end_item_id]");
return false;
}
sys_log(0, "ItemRange From File %u ~ %u ", dwMin, dwMax);
if (CItemIDRangeManager::instance().BuildRange(dwMin, dwMax, m_itemRange) == false)
{
sys_err("Can not build ITEM_ID_RANGE");
return false;
}
sys_log(0, " Init Success Start %u End %u Now %u\n", m_itemRange.dwMin, m_itemRange.dwMax, m_itemRange.dwUsableItemIDMin);
return true;
}
DWORD CClientManager::GainItemID()
{
return m_itemRange.dwUsableItemIDMin++;
}
DWORD CClientManager::GetItemID()
{
return m_itemRange.dwUsableItemIDMin;
}
// ITEM_UNIQUE_ID_END
//BOOT_LOCALIZATION
bool CClientManager::InitializeLocalization()
{
char szQuery[512];
snprintf(szQuery, sizeof(szQuery), "SELECT mValue, mKey FROM locale");
SQLMsg * pMsg = CDBManager::instance().DirectQuery(szQuery, SQL_COMMON);
if (pMsg->Get()->uiNumRows == 0)
{
sys_err("InitializeLocalization() ==> DirectQuery failed(%s)", szQuery);
delete pMsg;
return false;
}
sys_log(0, "InitializeLocalization() - LoadLocaleTable(count:%d)", pMsg->Get()->uiNumRows);
m_vec_Locale.clear();
MYSQL_ROW row = NULL;
for (int n = 0; (row = mysql_fetch_row(pMsg->Get()->pSQLResult)) != NULL; ++n)
{
int col = 0;
tLocale locale;
2022-03-05 19:59:39 +02:00
strncpy(locale.szValue, row[col++], sizeof(locale.szValue));
strncpy(locale.szKey, row[col++], sizeof(locale.szKey));
2022-03-05 12:44:06 +02:00
//DB_NAME_COLUMN Setting
if (strcmp(locale.szKey, "LOCALE") == 0)
{
if (strcmp(locale.szValue, "cibn") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "gb2312");
g_stLocale = "gb2312";
g_stLocaleNameColumn = "gb2312name";
}
else if (strcmp(locale.szValue, "ymir") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "euckr";
g_stLocaleNameColumn = "name";
}
else if (strcmp(locale.szValue, "japan") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "sjis");
g_stLocale = "sjis";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "english") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "germany") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "france") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "italy") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "spain") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "uk") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "turkey") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin5";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "poland") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin2";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "portugal") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "hongkong") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "big5");
g_stLocale = "big5";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "newcibn") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "gb2312");
g_stLocale = "gb2312";
g_stLocaleNameColumn = "gb2312name";
}
else if (strcmp(locale.szValue, "korea") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "euckr";
g_stLocaleNameColumn = "name";
}
else if (strcmp(locale.szValue, "canada") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "latin1";
g_stLocaleNameColumn = "gb2312name";
}
else if (strcmp(locale.szValue, "brazil") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "greek") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "greek";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "russia") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "cp1251";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "denmark") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "bulgaria") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "cp1251";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "croatia") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "cp1251";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "mexico") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "arabia") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "cp1256";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "czech") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin2";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "hungary") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin2";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "romania") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin2";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "netherlands") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "singapore") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "vietnam") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "thailand") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "usa") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "latin1");
g_stLocale = "latin1";
g_stLocaleNameColumn = "locale_name";
}
else if (strcmp(locale.szValue, "we_korea") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "euckr");
g_stLocale = "euckr";
g_stLocaleNameColumn = "name";
}
else if (strcmp(locale.szValue, "taiwan") == 0)
{
sys_log(0, "locale[LOCALE] = %s", locale.szValue);
if (g_stLocale != locale.szValue)
sys_log(0, "Changed g_stLocale %s to %s", g_stLocale.c_str(), "big5");
g_stLocale = "big5";
g_stLocaleNameColumn = "locale_name";
}
else
{
sys_err("locale[LOCALE] = UNKNOWN(%s)", locale.szValue);
exit(0);
}
CDBManager::instance().SetLocale(g_stLocale.c_str());
}
else if (strcmp(locale.szKey, "DB_NAME_COLUMN") == 0)
{
sys_log(0, "locale[DB_NAME_COLUMN] = %s", locale.szValue);
g_stLocaleNameColumn = locale.szValue;
}
else
{
sys_log(0, "locale[UNKNOWN_KEY(%s)] = %s", locale.szKey, locale.szValue);
}
m_vec_Locale.push_back(locale);
}
delete pMsg;
return true;
}
//END_BOOT_LOCALIZATION
//ADMIN_MANAGER
bool CClientManager::__GetAdminInfo(const char *szIP, std::vector<tAdminInfo> & rAdminVec)
{
//szIP == NULL <20>ϰ<EFBFBD><CFB0><EFBFBD> <20><><EFBFBD><EFBFBD><E7BCAD><EFBFBD><EFBFBD> <20><EFBFBD><EEBFB5> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD>´<EFBFBD>.
char szQuery[512];
snprintf(szQuery, sizeof(szQuery),
"SELECT mID,mAccount,mName,mContactIP,mServerIP,mAuthority FROM gmlist WHERE mServerIP='ALL' or mServerIP='%s'",
szIP ? szIP : "ALL");
SQLMsg * pMsg = CDBManager::instance().DirectQuery(szQuery, SQL_COMMON);
if (pMsg->Get()->uiNumRows == 0)
{
sys_err("__GetAdminInfo() ==> DirectQuery failed(%s)", szQuery);
delete pMsg;
return false;
}
MYSQL_ROW row;
rAdminVec.reserve(pMsg->Get()->uiNumRows);
while ((row = mysql_fetch_row(pMsg->Get()->pSQLResult)))
{
int idx = 0;
tAdminInfo Info;
str_to_number(Info.m_ID, row[idx++]);
trim_and_lower(row[idx++], Info.m_szAccount, sizeof(Info.m_szAccount));
2022-03-05 19:59:39 +02:00
strncpy(Info.m_szName, row[idx++], sizeof(Info.m_szName));
strncpy(Info.m_szContactIP, row[idx++], sizeof(Info.m_szContactIP));
strncpy(Info.m_szServerIP, row[idx++], sizeof(Info.m_szServerIP));
2022-03-05 12:44:06 +02:00
std::string stAuth = row[idx++];
if (!stAuth.compare("IMPLEMENTOR"))
Info.m_Authority = GM_IMPLEMENTOR;
else if (!stAuth.compare("GOD"))
Info.m_Authority = GM_GOD;
else if (!stAuth.compare("HIGH_WIZARD"))
Info.m_Authority = GM_HIGH_WIZARD;
else if (!stAuth.compare("LOW_WIZARD"))
Info.m_Authority = GM_LOW_WIZARD;
else if (!stAuth.compare("WIZARD"))
Info.m_Authority = GM_WIZARD;
else
continue;
rAdminVec.push_back(Info);
sys_log(0, "GM: PID %u Login %s Character %s ContactIP %s ServerIP %s Authority %d[%s]",
Info.m_ID, Info.m_szAccount, Info.m_szName, Info.m_szContactIP, Info.m_szServerIP, Info.m_Authority, stAuth.c_str());
}
delete pMsg;
return true;
}
bool CClientManager::__GetHostInfo(std::vector<std::string> & rIPVec)
{
char szQuery[512];
snprintf(szQuery, sizeof(szQuery), "SELECT mIP FROM gmhost");
SQLMsg * pMsg = CDBManager::instance().DirectQuery(szQuery, SQL_COMMON);
if (pMsg->Get()->uiNumRows == 0)
{
sys_err("__GetHostInfo() ==> DirectQuery failed(%s)", szQuery);
delete pMsg;
return false;
}
rIPVec.reserve(pMsg->Get()->uiNumRows);
MYSQL_ROW row;
while ((row = mysql_fetch_row(pMsg->Get()->pSQLResult)))
{
if (row[0] && *row[0])
{
rIPVec.push_back(row[0]);
sys_log(0, "GMHOST: %s", row[0]);
}
}
delete pMsg;
return true;
}
//END_ADMIN_MANAGER
void CClientManager::ReloadAdmin(CPeer*, TPacketReloadAdmin* p)
{
std::vector<tAdminInfo> vAdmin;
std::vector<std::string> vHost;
__GetHostInfo(vHost);
__GetAdminInfo(p->szIP, vAdmin);
DWORD dwPacketSize = sizeof(WORD) + sizeof (WORD) + sizeof(tAdminInfo) * vAdmin.size() +
sizeof(WORD) + sizeof(WORD) + 16 * vHost.size();
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer * peer = *it;
if (!peer->GetChannel())
continue;
peer->EncodeHeader(HEADER_DG_RELOAD_ADMIN, 0, dwPacketSize);
peer->EncodeWORD(16);
peer->EncodeWORD(vHost.size());
for (size_t n = 0; n < vHost.size(); ++n)
peer->Encode(vHost[n].c_str(), 16);
peer->EncodeWORD(sizeof(tAdminInfo));
peer->EncodeWORD(vAdmin.size());
for (size_t n = 0; n < vAdmin.size(); ++n)
peer->Encode(&vAdmin[n], sizeof(tAdminInfo));
}
sys_log(0, "ReloadAdmin End %s", p->szIP);
}
//BREAK_MARRIAGE
void CClientManager::BreakMarriage(CPeer * peer, const char * data)
{
DWORD pid1, pid2;
pid1 = *(int *) data;
data += sizeof(int);
pid2 = *(int *) data;
data += sizeof(int);
sys_log(0, "Breaking off a marriage engagement! pid %d and pid %d", pid1, pid2);
marriage::CManager::instance().Remove(pid1, pid2);
}
//END_BREAK_MARIIAGE
void CClientManager::UpdateItemCacheSet(DWORD pid)
{
itertype(m_map_pkItemCacheSetPtr) it = m_map_pkItemCacheSetPtr.find(pid);
if (it == m_map_pkItemCacheSetPtr.end())
{
if (g_test_server)
sys_log(0, "UPDATE_ITEMCACHESET : UpdateItemCacheSet ==> No ItemCacheSet pid(%d)", pid);
return;
}
TItemCacheSet * pSet = it->second;
TItemCacheSet::iterator it_set = pSet->begin();
while (it_set != pSet->end())
{
CItemCache * c = *it_set++;
c->Flush();
}
if (g_log)
sys_log(0, "UPDATE_ITEMCACHESET : UpdateItemCachsSet pid(%d)", pid);
}
void CClientManager::Election(CPeer * peer, DWORD dwHandle, const char* data)
{
DWORD idx;
DWORD selectingpid;
idx = *(DWORD *) data;
data += sizeof(DWORD);
selectingpid = *(DWORD *) data;
data += sizeof(DWORD);
int Success = 0;
if (!(Success = CMonarch::instance().VoteMonarch(selectingpid, idx)))
{
if (g_test_server)
sys_log(0, "[MONARCH_VOTE] Failed %d %d", idx, selectingpid);
peer->EncodeHeader(HEADER_DG_ELECT_MONARCH, dwHandle, sizeof(int));
peer->Encode(&Success, sizeof(int));
return;
}
else
{
if (g_test_server)
sys_log(0, "[MONARCH_VOTE] Success %d %d", idx, selectingpid);
peer->EncodeHeader(HEADER_DG_ELECT_MONARCH, dwHandle, sizeof(int));
peer->Encode(&Success, sizeof(int));
return;
}
}
void CClientManager::Candidacy(CPeer * peer, DWORD dwHandle, const char* data)
{
DWORD pid;
pid = *(DWORD *) data;
data += sizeof(DWORD);
if (!CMonarch::instance().AddCandidacy(pid, data))
{
if (g_test_server)
sys_log(0, "[MONARCH_CANDIDACY] Failed %d %s", pid, data);
peer->EncodeHeader(HEADER_DG_CANDIDACY, dwHandle, sizeof(int) + 32);
peer->Encode(0, sizeof(int));
peer->Encode(data, 32);
return;
}
else
{
if (g_test_server)
sys_log(0, "[MONARCH_CANDIDACY] Success %d %s", pid, data);
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer * p = *it;
if (!p->GetChannel())
continue;
if (0 && p->GetChannel() != 0)
continue;
if (p == peer)
{
p->EncodeHeader(HEADER_DG_CANDIDACY, dwHandle, sizeof(int) + 32);
p->Encode(&pid, sizeof(int));
p->Encode(data, 32);
}
else
{
p->EncodeHeader(HEADER_DG_CANDIDACY, 0, sizeof(int) + 32);
p->Encode(&pid, sizeof(int));
p->Encode(data, 32);
}
}
}
}
void CClientManager::AddMonarchMoney(CPeer * peer, DWORD dwHandle, const char * data)
{
int Empire = *(int *) data;
data += sizeof(int);
int Money = *(int *) data;
data += sizeof(int);
if (g_test_server)
sys_log(0, "[MONARCH] Add money Empire(%d) Money(%d)", Empire, Money);
CMonarch::instance().AddMoney(Empire, Money);
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer * p = *it;
if (!p->GetChannel())
continue;
if (p == peer)
{
p->EncodeHeader(HEADER_DG_ADD_MONARCH_MONEY, dwHandle, sizeof(int) + sizeof(int));
p->Encode(&Empire, sizeof(int));
p->Encode(&Money, sizeof(int));
}
else
{
p->EncodeHeader(HEADER_DG_ADD_MONARCH_MONEY, 0, sizeof(int) + sizeof(int));
p->Encode(&Empire, sizeof(int));
p->Encode(&Money, sizeof(int));
}
}
}
void CClientManager::DecMonarchMoney(CPeer * peer, DWORD dwHandle, const char * data)
{
int Empire = *(int *) data;
data += sizeof(int);
int Money = *(int *) data;
data += sizeof(int);
if (g_test_server)
sys_log(0, "[MONARCH] Dec money Empire(%d) Money(%d)", Empire, Money);
CMonarch::instance().DecMoney(Empire, Money);
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer * p = *it;
if (!p->GetChannel())
continue;
if (p == peer)
{
p->EncodeHeader(HEADER_DG_DEC_MONARCH_MONEY, dwHandle, sizeof(int) + sizeof(int));
p->Encode(&Empire, sizeof(int));
p->Encode(&Money, sizeof(int));
}
else
{
p->EncodeHeader(HEADER_DG_DEC_MONARCH_MONEY, 0, sizeof(int) + sizeof(int));
p->Encode(&Empire, sizeof(int));
p->Encode(&Money, sizeof(int));
}
}
}
void CClientManager::TakeMonarchMoney(CPeer * peer, DWORD dwHandle, const char * data)
{
int Empire = *(int *) data;
data += sizeof(int);
DWORD pid = *(DWORD *) data;
data += sizeof(int);
int Money = *(int *) data;
data += sizeof(int);
if (g_test_server)
sys_log(0, "[MONARCH] Take money Empire(%d) Money(%d)", Empire, Money);
if (CMonarch::instance().TakeMoney(Empire, pid, Money) == true)
{
peer->EncodeHeader(HEADER_DG_TAKE_MONARCH_MONEY, dwHandle, sizeof(int) + sizeof(int));
peer->Encode(&Empire, sizeof(int));
peer->Encode(&Money, sizeof(int));
}
else
{
Money = 0;
peer->EncodeHeader(HEADER_DG_TAKE_MONARCH_MONEY, dwHandle, sizeof(int) + sizeof(int));
peer->Encode(&Empire, sizeof(int));
peer->Encode(&Money, sizeof(int));
}
}
void CClientManager::ComeToVote(CPeer * peer, DWORD dwHandle, const char * data)
{
CMonarch::instance().ElectMonarch();
}
void CClientManager::RMCandidacy(CPeer * peer, DWORD dwHandle, const char * data)
{
char szName[32];
2022-03-05 19:59:39 +02:00
strncpy(szName, data, sizeof(szName));
2022-03-05 12:44:06 +02:00
sys_log(0, "[MONARCH_GM] Remove candidacy name(%s)", szName);
int iRet = CMonarch::instance().DelCandidacy(szName) ? 1 : 0;
if (1 == iRet)
{
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer * p = *it;
if (!p->GetChannel())
continue;
if (p == peer)
{
p->EncodeHeader(HEADER_DG_RMCANDIDACY, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
else
{
p->EncodeHeader(HEADER_DG_RMCANDIDACY, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
}
}
else
{
CPeer * p = peer;
p->EncodeHeader(HEADER_DG_RMCANDIDACY, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
}
void CClientManager::SetMonarch(CPeer * peer, DWORD dwHandle, const char * data)
{
char szName[32];
2022-03-05 19:59:39 +02:00
strncpy(szName, data, sizeof(szName));
2022-03-05 12:44:06 +02:00
if (g_test_server)
sys_log(0, "[MONARCH_GM] Set Monarch name(%s)", szName);
int iRet = CMonarch::instance().SetMonarch(szName) ? 1 : 0;
if (1 == iRet)
{
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer * p = *it;
if (!p->GetChannel())
continue;
if (p == peer)
{
p->EncodeHeader(HEADER_DG_RMCANDIDACY, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
else
{
p->EncodeHeader(HEADER_DG_RMCANDIDACY, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
}
}
else
{
CPeer * p = peer;
p->EncodeHeader(HEADER_DG_RMCANDIDACY, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
}
void CClientManager::RMMonarch(CPeer * peer, DWORD dwHandle, const char * data)
{
char szName[32];
2022-03-05 19:59:39 +02:00
strncpy(szName, data, sizeof(szName));
2022-03-05 12:44:06 +02:00
if (g_test_server)
sys_log(0, "[MONARCH_GM] Remove Monarch name(%s)", szName);
CMonarch::instance().DelMonarch(szName);
int iRet = CMonarch::instance().DelMonarch(szName) ? 1 : 0;
if (1 == iRet)
{
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer * p = *it;
if (!p->GetChannel())
continue;
if (p == peer)
{
p->EncodeHeader(HEADER_DG_RMMONARCH, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
else
{
p->EncodeHeader(HEADER_DG_RMMONARCH, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
}
}
else
{
CPeer * p = peer;
p->EncodeHeader(HEADER_DG_RMCANDIDACY, dwHandle, sizeof(int) + sizeof(szName));
p->Encode(&iRet, sizeof(int));
p->Encode(szName, sizeof(szName));
}
}
void CClientManager::ChangeMonarchLord(CPeer * peer, DWORD dwHandle, TPacketChangeMonarchLord* info)
{
char szQuery[1024];
snprintf(szQuery, sizeof(szQuery),
"SELECT a.name, NOW() FROM player%s AS a, player_index%s AS b WHERE (a.account_id=b.id AND a.id=%u AND b.empire=%u) AND "
"(b.pid1=%u OR b.pid2=%u OR b.pid3=%u OR b.pid4=%u)",
GetTablePostfix(), GetTablePostfix(), info->dwPID, info->bEmpire,
info->dwPID, info->dwPID, info->dwPID, info->dwPID);
SQLMsg * pMsg = CDBManager::instance().DirectQuery(szQuery, SQL_PLAYER);
if (pMsg->Get()->uiNumRows != 0)
{
TPacketChangeMonarchLordACK ack;
ack.bEmpire = info->bEmpire;
ack.dwPID = info->dwPID;
MYSQL_ROW row = mysql_fetch_row(pMsg->Get()->pSQLResult);
2022-03-05 19:59:39 +02:00
strncpy(ack.szName, row[0], sizeof(ack.szName));
strncpy(ack.szDate, row[1], sizeof(ack.szDate));
2022-03-05 12:44:06 +02:00
snprintf(szQuery, sizeof(szQuery), "UPDATE monarch SET pid=%u, windate=NOW() WHERE empire=%d", ack.dwPID, ack.bEmpire);
SQLMsg* pMsg2 = CDBManager::instance().DirectQuery(szQuery, SQL_PLAYER);
if (pMsg2->Get()->uiAffectedRows > 0)
{
CMonarch::instance().LoadMonarch();
TMonarchInfo* newInfo = CMonarch::instance().GetMonarch();
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); it++)
{
CPeer* client = *it;
client->EncodeHeader(HEADER_DG_CHANGE_MONARCH_LORD_ACK, 0, sizeof(TPacketChangeMonarchLordACK));
client->Encode(&ack, sizeof(TPacketChangeMonarchLordACK));
client->EncodeHeader(HEADER_DG_UPDATE_MONARCH_INFO, 0, sizeof(TMonarchInfo));
client->Encode(newInfo, sizeof(TMonarchInfo));
}
}
delete pMsg2;
}
delete pMsg;
}
void CClientManager::BlockException(TPacketBlockException *data)
{
sys_log(0, "[BLOCK_EXCEPTION] CMD(%d) login(%s)", data->cmd, data->login);
// save sql
{
char buf[1024];
switch (data->cmd)
{
case BLOCK_EXCEPTION_CMD_ADD:
snprintf(buf, sizeof(buf), "INSERT INTO block_exception VALUES('%s')", data->login);
CDBManager::instance().AsyncQuery(buf, SQL_ACCOUNT);
CBlockCountry::instance().AddBlockException(data->login);
break;
case BLOCK_EXCEPTION_CMD_DEL:
snprintf(buf, sizeof(buf), "DELETE FROM block_exception VALUES('%s')", data->login);
CDBManager::instance().AsyncQuery(buf, SQL_ACCOUNT);
CBlockCountry::instance().DelBlockException(data->login);
break;
default:
return;
}
}
for (itertype(m_peerList) it = m_peerList.begin(); it != m_peerList.end(); ++it)
{
CPeer *peer = *it;
if (!peer->GetChannel())
continue;
CBlockCountry::instance().SendBlockExceptionOne(peer, data->login, data->cmd);
}
}
void CClientManager::SendSpareItemIDRange(CPeer* peer)
{
peer->SendSpareItemIDRange();
}
//
// Login Key<65><79> <20>ʿ<EFBFBD><CABF><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
//
void CClientManager::DeleteLoginKey(TPacketDC *data)
{
char login[LOGIN_MAX_LEN+1] = {0};
trim_and_lower(data->login, login, sizeof(login));
CLoginData *pkLD = GetLoginDataByLogin(login);
if (pkLD)
{
TLoginDataByLoginKey::iterator it = m_map_pkLoginData.find(pkLD->GetKey());
if (it != m_map_pkLoginData.end())
m_map_pkLoginData.erase(it);
}
}
// delete gift notify icon
void CClientManager::DeleteAwardId(TPacketDeleteAwardID *data)
{
//sys_log(0,"data from game server arrived %d",data->dwID);
std::map<DWORD, TItemAward *>::iterator it;
it = ItemAwardManager::Instance().GetMapAward().find(data->dwID);
if ( it != ItemAwardManager::Instance().GetMapAward().end() )
{
std::set<TItemAward *> & kSet = ItemAwardManager::Instance().GetMapkSetAwardByLogin()[it->second->szLogin];
if(kSet.erase(it->second))
sys_log(0,"erase ItemAward id: %d from cache", data->dwID);
ItemAwardManager::Instance().GetMapAward().erase(data->dwID);
}
else
{
sys_log(0,"DELETE_AWARDID : could not find the id: %d", data->dwID);
}
}
void CClientManager::UpdateChannelStatus(TChannelStatus* pData)
{
TChannelStatusMap::iterator it = m_mChannelStatus.find(pData->nPort);
if (it != m_mChannelStatus.end()) {
it->second = pData->bStatus;
}
else {
m_mChannelStatus.insert(TChannelStatusMap::value_type(pData->nPort, pData->bStatus));
}
}
void CClientManager::RequestChannelStatus(CPeer* peer, DWORD dwHandle)
{
const int nSize = m_mChannelStatus.size();
peer->EncodeHeader(HEADER_DG_RESPOND_CHANNELSTATUS, dwHandle, sizeof(TChannelStatus)*nSize+sizeof(int));
peer->Encode(&nSize, sizeof(int));
for (TChannelStatusMap::iterator it = m_mChannelStatus.begin(); it != m_mChannelStatus.end(); it++) {
peer->Encode(&it->first, sizeof(short));
peer->Encode(&it->second, sizeof(BYTE));
}
}
void CClientManager::ResetLastPlayerID(const TPacketNeedLoginLogInfo* data)
{
CLoginData* pkLD = GetLoginDataByAID( data->dwPlayerID );
if (NULL != pkLD)
{
pkLD->SetLastPlayerID( 0 );
}
}
void CClientManager::ChargeCash(const TRequestChargeCash* packet)
{
char szQuery[512];
if (ERequestCharge_Cash == packet->eChargeType)
sprintf(szQuery, "update account set `cash` = `cash` + %d where id = %d limit 1", packet->dwAmount, packet->dwAID);
else if(ERequestCharge_Mileage == packet->eChargeType)
sprintf(szQuery, "update account set `mileage` = `mileage` + %d where id = %d limit 1", packet->dwAmount, packet->dwAID);
else
{
sys_err ("Invalid request charge type (type : %d, amount : %d, aid : %d)", packet->eChargeType, packet->dwAmount, packet->dwAID);
return;
}
sys_err ("Request Charge (type : %d, amount : %d, aid : %d)", packet->eChargeType, packet->dwAmount, packet->dwAID);
CDBManager::Instance().AsyncQuery(szQuery, SQL_ACCOUNT);
}
#ifdef __AUCTION__
void CClientManager::EnrollInAuction (CPeer * peer, DWORD owner_id, AuctionEnrollProductInfo* data)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (owner_id);
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", owner_id);
return;
}
CItemCache* c = GetItemCache (data->get_item_id());
if (c == NULL)
{
sys_err ("Item %d doesn't exist in db cache.", data->get_item_id());
return;
}
TPlayerItem* item = c->Get(false);
if (item->owner != owner_id)
{
sys_err ("Player id %d doesn't have item %d.", owner_id, data->get_item_id());
return;
}
// <20><><EFBFBD><EFBFBD> <20>ð<EFBFBD> + 24<32>ð<EFBFBD> <20><>.
time_t expired_time = time(0) + 24 * 60 * 60;
TAuctionItemInfo auctioned_item_info (item->vnum, data->get_bid_price(),
data->get_impur_price(), owner_id, "", expired_time, data->get_item_id(), 0, data->get_empire());
AuctionResult result = AuctionManager::instance().EnrollInAuction( c, auctioned_item_info );
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_ENR_AUC;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
peer->EncodeHeader(HEADER_DG_AUCTION_RESULT, owner_id, sizeof(TPacketDGResultAuction) + sizeof(TPlayerItem));
peer->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
peer->Encode(c->Get(false), sizeof(TPlayerItem));
}
else
{
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ɽø<C9BD> Auction<6F><6E> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ClientManager<65><72><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>.
TItemCacheSetPtrMap::iterator it = m_map_pkItemCacheSetPtr.find(item->owner);
if (it != m_map_pkItemCacheSetPtr.end())
{
it->second->erase(c);
}
m_map_itemCache.erase(item->id);
sys_log(0, "Enroll In Auction Success. owner_id item_id %d %d", owner_id, item->id);
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_ENR_AUC;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader(HEADER_DG_AUCTION_RESULT, owner_id, sizeof(TPacketDGResultAuction) + sizeof(TPlayerItem) + sizeof(TAuctionItemInfo));
(*it)->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode(c->Get(false), sizeof(TPlayerItem));
(*it)->Encode(&auctioned_item_info, sizeof(TAuctionItemInfo));
}
}
return;
}
void CClientManager::EnrollInSale (CPeer * peer, DWORD owner_id, AuctionEnrollSaleInfo* data)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (owner_id);
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", owner_id);
return;
}
CPlayerTableCache* player_cache = it->second;
TPlayerTable* player = player_cache->Get(false);
CItemCache* c = GetItemCache (data->get_item_id());
if (c == NULL)
{
sys_err ("Item %d doesn't exist in db cache.", data->get_item_id());
return;
}
TPlayerItem* item = c->Get(false);
if (item->owner != owner_id)
{
sys_err ("Player id %d doesn't have item %d.", owner_id, data->get_item_id());
return;
}
// <20><><EFBFBD><EFBFBD> <20>ð<EFBFBD> + 24<32>ð<EFBFBD> <20><>.
time_t expired_time = time(0) + 24 * 60 * 60;
TSaleItemInfo sold_item_info (item->vnum, data->get_sale_price(),
owner_id, player->name, data->get_item_id(), data->get_wisher_id());
AuctionResult result = AuctionManager::instance().EnrollInSale( c, sold_item_info );
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_ENR_SALE;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
peer->EncodeHeader(HEADER_DG_AUCTION_RESULT, owner_id, sizeof(TPacketDGResultAuction) + sizeof(TPlayerItem));
peer->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
peer->Encode(c->Get(false), sizeof(TPlayerItem));
}
else
{
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ɽø<C9BD> Auction<6F><6E> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ClientManager<65><72><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>.
TItemCacheSetPtrMap::iterator it = m_map_pkItemCacheSetPtr.find(item->owner);
if (it != m_map_pkItemCacheSetPtr.end())
{
it->second->erase(c);
}
m_map_itemCache.erase(item->id);
sys_log(0, "Enroll In Sale Success. owner_id item_id %d %d", owner_id, item->id);
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_ENR_SALE;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader(HEADER_DG_AUCTION_RESULT, owner_id, sizeof(TPacketDGResultAuction) + sizeof(TPlayerItem) + sizeof(TSaleItemInfo));
(*it)->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode(c->Get(false), sizeof(TPlayerItem));
(*it)->Encode(&sold_item_info, sizeof(TSaleItemInfo));
}
}
return;
}
void CClientManager::EnrollInWish (CPeer * peer, DWORD wisher_id, AuctionEnrollWishInfo* data)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (wisher_id);
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", wisher_id);
return;
}
CPlayerTableCache* player_cache = it->second;
TPlayerTable* player = player_cache->Get(false);
// <20><><EFBFBD><EFBFBD> <20>ð<EFBFBD> + 24<32>ð<EFBFBD> <20><>.
time_t expired_time = time(0) + 24 * 60 * 60;
TWishItemInfo wished_item_info (data->get_item_num(), data->get_wish_price(), wisher_id, player->name, expired_time, data->get_empire());
AuctionResult result = AuctionManager::instance().EnrollInWish ( wished_item_info );
if (result <= AUCTION_FAIL)
{
sys_log(0, "Enroll In Wish Success. wisher_id item_num %d %d", wisher_id, data->get_item_num());
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_ENR_WISH;
enroll_result.target = data->get_item_num();
enroll_result.result = result;
peer->EncodeHeader(HEADER_DG_AUCTION_RESULT, wisher_id, sizeof(TPacketDGResultAuction));
peer->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
sys_log(0, "Enroll In Wish Fail. wisher_id item_num %d %d", wisher_id, data->get_item_num());
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_ENR_WISH;
enroll_result.target = data->get_item_num();
enroll_result.result = result;
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader(HEADER_DG_AUCTION_RESULT, wisher_id, sizeof(TPacketDGResultAuction) + sizeof(TWishItemInfo));
(*it)->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode(&wished_item_info, sizeof(TWishItemInfo));
}
}
return;
}
void CClientManager::AuctionBid (CPeer * peer, DWORD bidder_id, AuctionBidInfo* data)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (bidder_id);
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", bidder_id);
return;
}
CPlayerTableCache* player_cache = it->second;
TPlayerTable* player = player_cache->Get(false);
AuctionResult result = AuctionManager::instance().Bid(bidder_id, player->name, data->get_item_id(), data->get_bid_price());
if (result == AUCTION_FAIL)
{
sys_log(0, "Bid Fail. bidder_id item_id %d %d", bidder_id, data->get_item_id());
}
else
{
sys_log(0, "Bid Success. bidder_id item_id %d %d", bidder_id, data->get_item_id());
}
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_BID;
enroll_result.target = data->get_bid_price();
enroll_result.result = result;
peer->EncodeHeader(HEADER_DG_AUCTION_RESULT, bidder_id, sizeof(TPacketDGResultAuction) + sizeof(AuctionBidInfo));
peer->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_BID;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
TAuctionItemInfo* auctioned_item_info = AuctionManager::instance().GetAuctionItemInfoCache(data->get_item_id())->Get(false);
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader(HEADER_DG_AUCTION_RESULT, bidder_id, sizeof(TPacketDGResultAuction) + sizeof(TAuctionItemInfo));
(*it)->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode(auctioned_item_info, sizeof(TAuctionItemInfo));
}
}
return;
}
void CClientManager::AuctionImpur (CPeer * peer, DWORD purchaser_id, AuctionImpurInfo* data)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (purchaser_id);
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", purchaser_id);
return;
}
CPlayerTableCache* player_cache = it->second;
TPlayerTable* player = player_cache->Get(false);
AuctionResult result = AuctionManager::instance().Impur(purchaser_id, player->name, data->get_item_id());
if (result == AUCTION_FAIL)
{
sys_log(0, "Impur Fail. purchaser_id item_id %d %d", purchaser_id, data->get_item_id());
}
else
{
sys_log(0, "Impur Success. purchaser_id item_id %d %d", purchaser_id, data->get_item_id());
}
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_IMME_PUR;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
peer->EncodeHeader(HEADER_DG_AUCTION_RESULT, purchaser_id, sizeof(TPacketDGResultAuction));
peer->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_IMME_PUR;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
TAuctionItemInfo* auctioned_item_info = AuctionManager::instance().GetAuctionItemInfoCache(data->get_item_id())->Get(false);
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader(HEADER_DG_AUCTION_RESULT, purchaser_id, sizeof(TPacketDGResultAuction) + sizeof(TAuctionItemInfo));
(*it)->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode(auctioned_item_info, sizeof(TAuctionItemInfo));
}
}
return;
}
void CClientManager::AuctionGetAuctionedItem (CPeer * peer, DWORD actor_id, DWORD item_id)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (actor_id);
AuctionResult result = AUCTION_FAIL;
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", actor_id);
return;
}
TPlayerItem item;
result = AuctionManager::instance().GetAuctionedItem(actor_id, item_id, item);
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_GET_AUC;
enroll_result.target = item_id;
enroll_result.result = result;
peer->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction));
peer->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_GET_AUC;
enroll_result.target = item_id;
enroll_result.result = result;
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction) + sizeof(TPlayerItem));
(*it)->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode (&item, sizeof(TPlayerItem));
}
}
return;
}
void CClientManager::AuctionBuySoldItem (CPeer * peer, DWORD actor_id, DWORD item_id)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (actor_id);
AuctionResult result = AUCTION_FAIL;
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", actor_id);
return;
}
TPlayerItem item;
result = AuctionManager::instance().BuySoldItem(actor_id, item_id, item);
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_BUY_SOLD;
enroll_result.target = item_id;
enroll_result.result = result;
peer->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction));
peer->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_BUY_SOLD;
enroll_result.target = item_id;
enroll_result.result = result;
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction) + sizeof(TPlayerItem));
(*it)->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode (&item, sizeof(TPlayerItem));
}
}
return;
}
void CClientManager::AuctionCancelAuction (CPeer * peer, DWORD actor_id, DWORD item_id)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (actor_id);
AuctionResult result = AUCTION_FAIL;
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", actor_id);
return;
}
TPlayerItem item;
result = AuctionManager::instance().CancelAuction(actor_id, item_id, item);
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_CANCEL_AUC;
enroll_result.target = item_id;
enroll_result.result = result;
peer->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction));
peer->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_CANCEL_AUC;
enroll_result.target = item_id;
enroll_result.result = result;
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction) + sizeof(TPlayerItem));
(*it)->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode (&item, sizeof(TPlayerItem));
}
}
return;
}
void CClientManager::AuctionCancelWish (CPeer * peer, DWORD actor_id, DWORD item_num)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (actor_id);
AuctionResult result = AUCTION_FAIL;
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", actor_id);
return;
}
TPlayerItem item;
result = AuctionManager::instance().CancelWish(actor_id, item_num);
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_CANCEL_WISH;
enroll_result.target = item_num;
enroll_result.result = result;
peer->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction));
peer->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_CANCEL_WISH;
enroll_result.target = item_num;
enroll_result.result = result;
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction));
(*it)->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
}
}
return;
}
void CClientManager::AuctionCancelSale (CPeer * peer, DWORD actor_id, DWORD item_id)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (actor_id);
AuctionResult result = AUCTION_FAIL;
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", actor_id);
return;
}
TPlayerItem item;
result = AuctionManager::instance().CancelSale(actor_id, item_id, item);
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_CANCEL_SALE;
enroll_result.target = item_id;
enroll_result.result = result;
peer->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction));
peer->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_CANCEL_SALE;
enroll_result.target = item_id;
enroll_result.result = result;
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader (HEADER_DG_AUCTION_RESULT, actor_id, sizeof(TPacketDGResultAuction) + sizeof(TPlayerItem));
(*it)->Encode (&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode (&item, sizeof(TPlayerItem));
}
}
return;
}
void CClientManager::AuctionDeleteAuctionItem (CPeer * peer, DWORD actor_id, DWORD item_id)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (actor_id);
AuctionResult result = AUCTION_FAIL;
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", actor_id);
return;
}
AuctionManager::instance().DeleteAuctionItem (actor_id, item_id);
}
void CClientManager::AuctionDeleteSaleItem (CPeer * peer, DWORD actor_id, DWORD item_id)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (actor_id);
AuctionResult result = AUCTION_FAIL;
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", actor_id);
return;
}
AuctionManager::instance().DeleteSaleItem (actor_id, item_id);
}
// ReBid<69><64> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ݾ׿<DDBE> <20><><EFBFBD>ؼ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
// ReBid<69><64><EFBFBD><EFBFBD> data->bid_price<63><65> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
// <20><> <20>ݾ<EFBFBD><DDBE><EFBFBD><EFBFBD><EFBFBD> rebid<69>ϴ<EFBFBD> <20><>.
// <20>̷<EFBFBD><CCB7><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> rebid<69><64> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><>,
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ȣ<>ָӴϿ<D3B4><CFBF><EFBFBD> <20><> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ֱ<EFBFBD> <20><><EFBFBD>ϰ<EFBFBD> <20>ϱ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>̴<EFBFBD>.
void CClientManager::AuctionReBid (CPeer * peer, DWORD bidder_id, AuctionBidInfo* data)
{
TPlayerTableCacheMap::iterator it = m_map_playerCache.find (bidder_id);
if (it == m_map_playerCache.end())
{
sys_err ("Invalid Player id %d. how can you get it?", bidder_id);
return;
}
CPlayerTableCache* player_cache = it->second;
TPlayerTable* player = player_cache->Get(false);
AuctionResult result = AuctionManager::instance().ReBid(bidder_id, player->name, data->get_item_id(), data->get_bid_price());
if (result == AUCTION_FAIL)
{
sys_log(0, "ReBid Fail. bidder_id item_id %d %d", bidder_id, data->get_item_id());
}
else
{
sys_log(0, "ReBid Success. bidder_id item_id %d %d", bidder_id, data->get_item_id());
}
// <20>̰<EFBFBD> FAIL<49><4C> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ȵ<EFBFBD>.
// FAIL<49><4C> <20><> <20><><EFBFBD><EFBFBD> <20><><EFBFBD>°<EFBFBD>, MyBid<69><64> <20>ִ<EFBFBD> bidder_id<69><64> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> bidder_id<69><64><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><> <20><> <20>ְŵ<D6B0>?
// <20>׷<EFBFBD><D7B7>Ƿ<EFBFBD> <20>ٸ<EFBFBD> <20><><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>۵<EFBFBD><DBB5>Ѵٰ<D1B4> <20><><EFBFBD><EFBFBD> <20>Ѵٸ<D1B4>
// <20><> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> bidder_id<69><64> MyBid<69><64> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <20>װ<EFBFBD> <20><><EFBFBD><EFBFBD>ȭ <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>.
// <20>ٸ<EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>Ȱ<EFBFBD><C8B0><EFBFBD> bidder_id<69><64> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ϱ<EFBFBD>.
// <20>׷<EFBFBD><D7B7>Ƿ<EFBFBD> <20><> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> BidCancel <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> db<64><62> <20><><EFBFBD>ȴٴ<C8B4> <20><><EFBFBD><EFBFBD>,
// <20>̹<EFBFBD> <20><> <20>κп<CEBA> <20><><EFBFBD>ؼ<EFBFBD><D8BC><EFBFBD> <20>˻簡 <20>Ϻ<EFBFBD><CFBA>ϴٴ<CFB4> <20><><EFBFBD>̾<EFBFBD>.
// <20>׷<EFBFBD><D7B7><EFBFBD> Ȥ<>ó<EFBFBD> <20>;, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> fail <20>ڵ带 <20><><EFBFBD>ܵд<DCB5>.
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_REBID;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
peer->EncodeHeader(HEADER_DG_AUCTION_RESULT, bidder_id, sizeof(TPacketDGResultAuction) + sizeof(int));
peer->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
peer->EncodeDWORD(data->get_bid_price());
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_REBID;
enroll_result.target = data->get_item_id();
enroll_result.result = result;
TAuctionItemInfo* auctioned_item_info = AuctionManager::instance().GetAuctionItemInfoCache(data->get_item_id())->Get(false);
for (TPeerList::iterator it = m_peerList.begin(); it != m_peerList.end(); it++)
{
(*it)->EncodeHeader(HEADER_DG_AUCTION_RESULT, bidder_id, sizeof(TPacketDGResultAuction) + sizeof(TAuctionItemInfo));
(*it)->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
(*it)->Encode(auctioned_item_info, sizeof(TAuctionItemInfo));
}
}
return;
}
void CClientManager::AuctionBidCancel (CPeer * peer, DWORD bidder_id, DWORD item_id)
{
AuctionResult result = AuctionManager::instance().BidCancel (bidder_id, item_id);
// <20>̰<EFBFBD> FAIL<49><4C> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ȵ<EFBFBD>.
// FAIL<49><4C> <20><> <20><><EFBFBD><EFBFBD> <20><><EFBFBD>°<EFBFBD>, MyBid<69><64> <20>ִ<EFBFBD> bidder_id<69><64> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> bidder_id<69><64><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><> <20><> <20>ְŵ<D6B0>?
// <20>׷<EFBFBD><D7B7>Ƿ<EFBFBD> <20>ٸ<EFBFBD> <20><><EFBFBD><EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>۵<EFBFBD><DBB5>Ѵٰ<D1B4> <20><><EFBFBD><EFBFBD> <20>Ѵٸ<D1B4>
// <20><> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> bidder_id<69><64> MyBid<69><64> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD> <20><> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>, <20>װ<EFBFBD> <20><><EFBFBD><EFBFBD>ȭ <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>.
// <20>ٸ<EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>Ȱ<EFBFBD><C8B0><EFBFBD> bidder_id<69><64> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>ϱ<EFBFBD>.
// <20>׷<EFBFBD><D7B7>Ƿ<EFBFBD> <20><> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> BidCancel <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> db<64><62> <20><><EFBFBD>ȴٴ<C8B4> <20><><EFBFBD><EFBFBD>,
// <20>̹<EFBFBD> <20><> <20>κп<CEBA> <20><><EFBFBD>ؼ<EFBFBD><D8BC><EFBFBD> <20>˻簡 <20>Ϻ<EFBFBD><CFBA>ϴٴ<CFB4> <20><><EFBFBD>̾<EFBFBD>.
// <20>׷<EFBFBD><D7B7><EFBFBD> Ȥ<>ó<EFBFBD> <20>;, <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> fail <20>ڵ带 <20><><EFBFBD>ܵд<DCB5>.
if (result <= AUCTION_FAIL)
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_BID_CANCEL;
enroll_result.target = item_id;
enroll_result.result = result;
peer->EncodeHeader(HEADER_DG_AUCTION_RESULT, bidder_id, sizeof(TPacketDGResultAuction));
peer->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
}
else
{
TPacketDGResultAuction enroll_result;
enroll_result.cmd = AUCTION_BID_CANCEL;
enroll_result.target = item_id;
enroll_result.result = result;
peer->EncodeHeader(HEADER_DG_AUCTION_RESULT, bidder_id, sizeof(TPacketDGResultAuction));
peer->Encode(&enroll_result, sizeof(TPacketDGResultAuction));
}
}
#endif