Restructure repository to include all source folders
Move git root from Client/ to src/ to track all source code: - Client: Game client source (moved to Client/Client/) - Server: Game server source - GameTools: Development tools - CryptoSource: Encryption utilities - database: Database scripts - Script: Game scripts - rylCoder_16.02.2008_src: Legacy coder tools - GMFont, Game: Additional resources 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
318
Server/DBProcess/ConvertTwoNation/ConvertTwoNation.cpp
Normal file
318
Server/DBProcess/ConvertTwoNation/ConvertTwoNation.cpp
Normal file
@@ -0,0 +1,318 @@
|
||||
// ConvertTwoNation.cpp : <20>ܼ<EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD>α<CEB1><D7B7><EFBFBD> <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>մϴ<D5B4>.
|
||||
//
|
||||
|
||||
#pragma warning(disable:4800)
|
||||
|
||||
#include "stdafx.h"
|
||||
#include <atldbcli.h>
|
||||
#include <sqloledb.h>
|
||||
#include <Log/ServerLog.h>
|
||||
#include <RylDBLibrary/RylDBCharCommand.h>
|
||||
#include <RylDBLibrary/RylDBLibrary.h>
|
||||
|
||||
#include <Community/FriendList.h>
|
||||
#include <Community/BanList.h>
|
||||
|
||||
#include <set>
|
||||
#include <string>
|
||||
#include <algorithm>
|
||||
#include <ctime>
|
||||
#include <hash_map>
|
||||
|
||||
#include <boost/pool/pool_alloc.hpp>
|
||||
|
||||
#define LOG_CONVERT0(str) { ERRLOG0(g_Log, (str)); printf(str "\n"); }
|
||||
#define LOG_CONVERT1(str, arg1) { ERRLOG1(g_Log, (str), (arg1)); printf(str "\n", (arg1)); }
|
||||
#define LOG_CONVERT2(str, arg1, arg2) { ERRLOG2(g_Log, (str), (arg1), (arg2)); printf(str "\n", (arg1), (arg2)); }
|
||||
|
||||
class CRemoveOtherNation : public IDBFriendProcess
|
||||
{
|
||||
public:
|
||||
|
||||
typedef stdext::hash_map<unsigned long, unsigned long,
|
||||
stdext::hash_compare<unsigned long, std::less<unsigned long> >,
|
||||
boost::fast_pool_allocator<std::pair<unsigned long, unsigned long> > > CIDRaceMap;
|
||||
|
||||
CRemoveOtherNation(ATL::CSession& session) : m_Session(session) { }
|
||||
~CRemoveOtherNation() { }
|
||||
|
||||
HRESULT Initialize();
|
||||
|
||||
virtual ConvertResult operator() (RylDBCommand::CFriendData& friendData);
|
||||
|
||||
private:
|
||||
|
||||
ATL::CSession& m_Session;
|
||||
CIDRaceMap m_CIDRaceMap;
|
||||
};
|
||||
|
||||
|
||||
int _tmain(int argc, _TCHAR* argv[])
|
||||
{
|
||||
// DB<44><42> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
|
||||
// <20><><EFBFBD>̺<EFBFBD><CCBA><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ٽ<EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>.
|
||||
// <20>α<CEB1> <20>м<EFBFBD><D0BC>ؼ<EFBFBD> <20><><EFBFBD>̺<EFBFBD><CCBA><EFBFBD> Row<6F><77> <20>ִ´<D6B4>.
|
||||
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD> Log<6F><67> <20>м<EFBFBD><D0BC>ؼ<EFBFBD> <20><><EFBFBD>̺<EFBFBD><CCBA><EFBFBD> <20>ֵ<EFBFBD><D6B5><EFBFBD> <20>Ѵ<EFBFBD>. <20><><EFBFBD>߿<EFBFBD> <20><><EFBFBD><EFBFBD> <20>߰<EFBFBD><DFB0>Ѵ<EFBFBD>.
|
||||
|
||||
if (5 != argc)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
CoInitialize(0);
|
||||
|
||||
HRESULT hr = S_OK;
|
||||
|
||||
ATL::CDataSource ds;
|
||||
ATL::CSession session;
|
||||
ATL::CDBPropSet dsPropSet;
|
||||
|
||||
dsPropSet.SetGUID(DBPROPSET_DBINIT);
|
||||
dsPropSet.AddProperty(DBPROP_INIT_DATASOURCE, argv[1]);
|
||||
dsPropSet.AddProperty(DBPROP_INIT_CATALOG, argv[2]);
|
||||
dsPropSet.AddProperty(DBPROP_AUTH_USERID, argv[3]);
|
||||
dsPropSet.AddProperty(DBPROP_AUTH_PASSWORD, argv[4]);
|
||||
|
||||
// <20><><EFBFBD><EFBFBD><EFBFBD>ͺ<EFBFBD><CDBA>̽<EFBFBD> <20><><EFBFBD><EFBFBD>
|
||||
if (FAILED(hr = ds.Open(CLSID_SQLOLEDB, &dsPropSet, 1)))
|
||||
{
|
||||
LOG_CONVERT1("Connect DB failed : hr:0%08x", hr);
|
||||
}
|
||||
else if (FAILED(hr = session.Open(ds)))
|
||||
{
|
||||
LOG_CONVERT1("Connect Session failed : hr:0x%08x", hr);
|
||||
}
|
||||
else if (FAILED(hr = session.StartTransaction()))
|
||||
{
|
||||
LOG_CONVERT1("Start transaction failed : hr:0x%08x", hr);
|
||||
}
|
||||
else
|
||||
{
|
||||
try
|
||||
{
|
||||
CRylDBProcess dbProcess(session);
|
||||
CConsoleCounter consoleCounter(1000);
|
||||
CRemoveOtherNation remove(session);
|
||||
|
||||
if (FAILED(hr = remove.Initialize()))
|
||||
{
|
||||
LOG_CONVERT1("Data initialize failed : hr:0x%08x", hr);
|
||||
}
|
||||
else if (FAILED(hr = dbProcess.Friend(remove, consoleCounter)))
|
||||
{
|
||||
LOG_CONVERT1("Friend process failed : hr:0x%08x", hr);
|
||||
}
|
||||
}
|
||||
catch(...)
|
||||
{
|
||||
LOG_CONVERT0("Exception occured! rollback transaction now!");
|
||||
LOG_CONVERT2("Rollback transaction %s! : hr:0x%08x",
|
||||
FAILED(hr = session.Abort()) ? "failed" : "succeeded", hr);
|
||||
}
|
||||
|
||||
LOG_CONVERT0("Commit transaction now!");
|
||||
LOG_CONVERT2("Commit transaction %s! : hr:0x%08x",
|
||||
FAILED(hr = session.Commit()) ? "failed" : "succeeded", hr);
|
||||
}
|
||||
|
||||
session.Close();
|
||||
ds.Close();
|
||||
|
||||
CoUninitialize();
|
||||
return 0;
|
||||
}
|
||||
|
||||
HRESULT CRemoveOtherNation::Initialize()
|
||||
{
|
||||
HRESULT hr = S_OK;
|
||||
|
||||
ATL::CCommand<ATL::CDynamicAccessor,
|
||||
ATL::CBulkRowset, ATL::CMultipleResults> getCharRace;
|
||||
|
||||
getCharRace.SetRows(1000000);
|
||||
|
||||
if (FAILED(hr = getCharRace.Open(m_Session, "SELECT CID, Race FROM dbo.CharInfo")))
|
||||
{
|
||||
LOG_CONVERT1("Read Race from CharInfo failed : hr:0x%08x", hr);
|
||||
}
|
||||
else
|
||||
{
|
||||
int nCount = 0;
|
||||
|
||||
DWORD nCID = 0;
|
||||
BYTE nRace = 0;
|
||||
|
||||
hr = getCharRace.MoveFirst( );
|
||||
while (SUCCEEDED(hr) && hr != DB_S_ENDOFROWSET)
|
||||
{
|
||||
getCharRace.GetValue(1, &nCID);
|
||||
getCharRace.GetValue(2, &nRace);
|
||||
|
||||
m_CIDRaceMap.insert(CIDRaceMap::value_type(nCID, nRace));
|
||||
hr = getCharRace.MoveNext();
|
||||
|
||||
if (0 == (++nCount % 1000)) { printf("Read race info : %d", nCount); }
|
||||
}
|
||||
}
|
||||
|
||||
return hr;
|
||||
}
|
||||
|
||||
class CRemoveTargetCID
|
||||
{
|
||||
public:
|
||||
|
||||
CRemoveTargetCID(DWORD* dwCIDList, DWORD& dwMaxCIDNum,
|
||||
CRemoveOtherNation::CIDRaceMap& CIDRaceMap, DWORD dwMyRace)
|
||||
: m_dwCIDList(dwCIDList)
|
||||
, m_dwCIDNum(dwMaxCIDNum)
|
||||
, m_dwMaxCIDNum(dwMaxCIDNum)
|
||||
, m_CIDRaceMap(CIDRaceMap)
|
||||
, m_dwMyRace(dwMyRace)
|
||||
{
|
||||
m_dwCIDNum = 0;
|
||||
}
|
||||
|
||||
void operator () (CFriendList::Rebind& rebind)
|
||||
{
|
||||
DWORD dwCID = rebind.GetCID();
|
||||
|
||||
CRemoveOtherNation::CIDRaceMap::iterator pos = m_CIDRaceMap.find(dwCID);
|
||||
CRemoveOtherNation::CIDRaceMap::iterator end = m_CIDRaceMap.end();
|
||||
|
||||
if (pos != end && m_dwMyRace != pos->second)
|
||||
{
|
||||
if (m_dwCIDNum < m_dwMaxCIDNum)
|
||||
{
|
||||
m_dwCIDList[m_dwCIDNum] = dwCID;
|
||||
++m_dwCIDNum;
|
||||
}
|
||||
else
|
||||
{
|
||||
LOG_CONVERT1("Cannot remove friend (CID:%10d) : buffer full", dwCID);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void operator () (CBanList::Rebind& rebind)
|
||||
{
|
||||
DWORD dwCID = rebind.GetCID();
|
||||
|
||||
CRemoveOtherNation::CIDRaceMap::iterator pos = m_CIDRaceMap.find(dwCID);
|
||||
CRemoveOtherNation::CIDRaceMap::iterator end = m_CIDRaceMap.end();
|
||||
|
||||
if (pos != end && m_dwMyRace != pos->second)
|
||||
{
|
||||
if (m_dwCIDNum < m_dwMaxCIDNum)
|
||||
{
|
||||
m_dwCIDList[m_dwCIDNum] = dwCID;
|
||||
++m_dwCIDNum;
|
||||
}
|
||||
else
|
||||
{
|
||||
LOG_CONVERT1("Cannot remove ban (CID:%10d) : buffer full", dwCID);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private:
|
||||
|
||||
DWORD* m_dwCIDList;
|
||||
DWORD& m_dwCIDNum;
|
||||
DWORD m_dwMaxCIDNum;
|
||||
DWORD m_dwMyRace;
|
||||
|
||||
CRemoveOtherNation::CIDRaceMap& m_CIDRaceMap;
|
||||
};
|
||||
|
||||
|
||||
ConvertResult CRemoveOtherNation::operator() (RylDBCommand::CFriendData& friendData)
|
||||
{
|
||||
DWORD dwCID = friendData.GetCID();
|
||||
|
||||
CIDRaceMap::iterator pos = m_CIDRaceMap.find(dwCID);
|
||||
CIDRaceMap::iterator end = m_CIDRaceMap.end();
|
||||
|
||||
if (pos == end)
|
||||
{
|
||||
LOG_CONVERT1("CID:%10u / Cannot find race", dwCID);
|
||||
}
|
||||
else
|
||||
{
|
||||
DWORD dwMyRace = pos->second;
|
||||
|
||||
CFriendList friendList(dwCID, 0);
|
||||
FRIEND myfriend = friendData.GetFriend();
|
||||
|
||||
if (!friendList.SerializeIn(myfriend.Data,
|
||||
myfriend.Info, myfriend.dwSize, myfriend.dwInfoSize))
|
||||
{
|
||||
LOG_CONVERT1("CID:%10u / SerializeIn friend failed", dwCID);
|
||||
}
|
||||
else
|
||||
{
|
||||
// <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ƴ<EFBFBD> ģ<><C4A3><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
|
||||
DWORD dwMaxCID[CFriendList::MAX_FRIENDS_NUM];
|
||||
DWORD dwMaxCIDNum = CFriendList::MAX_FRIENDS_NUM;
|
||||
|
||||
friendList.Process(CRemoveTargetCID(dwMaxCID,
|
||||
dwMaxCIDNum, m_CIDRaceMap, dwMyRace));
|
||||
|
||||
for (DWORD dwIndex = 0; dwIndex < dwMaxCIDNum; ++dwIndex)
|
||||
{
|
||||
friendList.Remove(dwMaxCID[dwIndex]);
|
||||
}
|
||||
|
||||
myfriend.dwSize = _FRIEND::MAX_FRIEND_SIZE;
|
||||
myfriend.dwInfoSize = _FRIEND::MAX_FRIENDINFO_SIZE;
|
||||
|
||||
if (!friendList.SerializeOut(myfriend.Data,
|
||||
myfriend.Info, myfriend.dwSize, myfriend.dwInfoSize))
|
||||
{
|
||||
LOG_CONVERT1("CID:%10u / SerializeOut friend failed", dwCID);
|
||||
}
|
||||
else
|
||||
{
|
||||
friendData.SetFriend(myfriend);
|
||||
}
|
||||
}
|
||||
|
||||
CBanList banList(dwCID, 0);
|
||||
BAN myBan = friendData.GetBan();
|
||||
|
||||
if (!banList.SerializeIn(myBan.Data, myBan.Info, myBan.dwSize, myBan.dwInfoSize))
|
||||
{
|
||||
LOG_CONVERT1("CID:%10u / SerializeIn ban failed", dwCID);
|
||||
}
|
||||
else
|
||||
{
|
||||
// <20><><EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <20>ƴ<EFBFBD> <20>źθ<C5BA> <20><><EFBFBD><EFBFBD><EFBFBD>Ѵ<EFBFBD>.
|
||||
DWORD dwMaxCID[CBanList::MAX_BAN_NUM];
|
||||
DWORD dwMaxCIDNum = CBanList::MAX_BAN_NUM;
|
||||
|
||||
banList.Process(CRemoveTargetCID(dwMaxCID,
|
||||
dwMaxCIDNum, m_CIDRaceMap, dwMyRace));
|
||||
|
||||
for (DWORD dwIndex = 0; dwIndex < dwMaxCIDNum; ++dwIndex)
|
||||
{
|
||||
banList.Remove(dwMaxCID[dwIndex]);
|
||||
}
|
||||
|
||||
myBan.dwSize = _BAN::MAX_BAN_SIZE;
|
||||
myBan.dwInfoSize = _BAN::MAX_BANINFO_SIZE;
|
||||
|
||||
if (!banList.SerializeOut(myBan.Data,
|
||||
myBan.Info, myBan.dwSize, myBan.dwInfoSize))
|
||||
{
|
||||
LOG_CONVERT1("CID:%10u / SerializeOut ban failed", dwCID);
|
||||
}
|
||||
else
|
||||
{
|
||||
friendData.SetBan(myBan);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return CONVERT_SUCCEEDED;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user