|
|
|
@ -91,7 +91,7 @@ struct CliAuConn : hsRefCnt {
|
|
|
|
|
LINK(CliAuConn) link; |
|
|
|
|
AsyncSocket sock; |
|
|
|
|
NetCli * cli; |
|
|
|
|
char name[MAX_PATH]; |
|
|
|
|
plString name; |
|
|
|
|
plNetAddress addr; |
|
|
|
|
plUUID token; |
|
|
|
|
unsigned seq; |
|
|
|
@ -194,14 +194,14 @@ struct LoginRequestTrans : NetAuthTrans {
|
|
|
|
|
struct AgeRequestTrans : NetAuthTrans { |
|
|
|
|
FNetCliAuthAgeRequestCallback m_callback; |
|
|
|
|
void * m_param; |
|
|
|
|
wchar_t m_ageName[kMaxAgeNameLength]; |
|
|
|
|
plString m_ageName; |
|
|
|
|
unsigned m_ageMcpId; |
|
|
|
|
plUUID m_ageInstId; |
|
|
|
|
unsigned m_ageVaultId; |
|
|
|
|
uint32_t m_gameSrvNode; |
|
|
|
|
|
|
|
|
|
AgeRequestTrans ( |
|
|
|
|
const wchar_t ageName[], |
|
|
|
|
const plString& ageName, |
|
|
|
|
const plUUID& ageInstId, |
|
|
|
|
FNetCliAuthAgeRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
@ -291,18 +291,18 @@ struct PlayerCreateRequestTrans : NetAuthTrans {
|
|
|
|
|
void * m_param; |
|
|
|
|
|
|
|
|
|
// send
|
|
|
|
|
wchar_t m_playerName[kMaxPlayerNameLength]; |
|
|
|
|
wchar_t m_avatarShape[MAX_PATH]; |
|
|
|
|
wchar_t m_friendInvite[MAX_PATH]; |
|
|
|
|
plString m_playerName; |
|
|
|
|
plString m_avatarShape; |
|
|
|
|
plString m_friendInvite; |
|
|
|
|
|
|
|
|
|
// recv
|
|
|
|
|
NetCliAuthPlayerInfo m_playerInfo; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
PlayerCreateRequestTrans ( |
|
|
|
|
const wchar_t playerName[], |
|
|
|
|
const wchar_t avatarShape[], |
|
|
|
|
const wchar_t friendInvite[], |
|
|
|
|
const plString& playerName, |
|
|
|
|
const plString& avatarShape, |
|
|
|
|
const plString& friendInvite, |
|
|
|
|
FNetCliAuthPlayerCreateRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
|
); |
|
|
|
@ -401,12 +401,12 @@ struct AccountChangePasswordRequestTrans : NetAuthTrans {
|
|
|
|
|
void * m_param; |
|
|
|
|
|
|
|
|
|
// send
|
|
|
|
|
wchar_t m_accountName[kMaxAccountNameLength]; |
|
|
|
|
plString m_accountName; |
|
|
|
|
ShaDigest m_namePassHash; |
|
|
|
|
|
|
|
|
|
AccountChangePasswordRequestTrans ( |
|
|
|
|
const wchar_t accountName[], |
|
|
|
|
const wchar_t password[], |
|
|
|
|
const plString& accountName, |
|
|
|
|
const plString& password, |
|
|
|
|
FNetCliAuthAccountChangePasswordRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
|
); |
|
|
|
@ -427,13 +427,13 @@ struct GetPublicAgeListTrans : NetAuthTrans {
|
|
|
|
|
void * m_param; |
|
|
|
|
|
|
|
|
|
// send
|
|
|
|
|
wchar_t m_ageName[MAX_PATH]; |
|
|
|
|
plString m_ageName; |
|
|
|
|
|
|
|
|
|
// recv
|
|
|
|
|
ARRAY(NetAgeInfo) m_ages; |
|
|
|
|
|
|
|
|
|
GetPublicAgeListTrans ( |
|
|
|
|
const wchar_t ageName[], |
|
|
|
|
const plString& ageName, |
|
|
|
|
FNetCliAuthGetPublicAgeListCallback callback, |
|
|
|
|
void * param |
|
|
|
|
); |
|
|
|
@ -686,10 +686,10 @@ struct VaultInitAgeTrans : NetAuthTrans {
|
|
|
|
|
|
|
|
|
|
plUUID m_ageInstId; |
|
|
|
|
plUUID m_parentAgeInstId; |
|
|
|
|
wchar_t * m_ageFilename; |
|
|
|
|
wchar_t * m_ageInstName; |
|
|
|
|
wchar_t * m_ageUserName; |
|
|
|
|
wchar_t * m_ageDesc; |
|
|
|
|
plString m_ageFilename; |
|
|
|
|
plString m_ageInstName; |
|
|
|
|
plString m_ageUserName; |
|
|
|
|
plString m_ageDesc; |
|
|
|
|
unsigned m_ageSequenceNumber; |
|
|
|
|
unsigned m_ageLanguage; |
|
|
|
|
|
|
|
|
@ -701,10 +701,10 @@ struct VaultInitAgeTrans : NetAuthTrans {
|
|
|
|
|
void * param, // optional
|
|
|
|
|
const plUUID& ageInstId, // optional. is used in match
|
|
|
|
|
const plUUID& parentAgeInstId, // optional. is used in match
|
|
|
|
|
const wchar_t ageFilename[], // optional. is used in match
|
|
|
|
|
const wchar_t ageInstName[], // optional. not used in match
|
|
|
|
|
const wchar_t ageUserName[], // optional. not used in match
|
|
|
|
|
const wchar_t ageDesc[], // optional. not used in match
|
|
|
|
|
const plString ageFilename, // optional. is used in match
|
|
|
|
|
const plString ageInstName, // optional. not used in match
|
|
|
|
|
const plString ageUserName, // optional. not used in match
|
|
|
|
|
const plString ageDesc, // optional. not used in match
|
|
|
|
|
unsigned ageSequenceNumber, // optional. not used in match
|
|
|
|
|
unsigned ageLanguage // optional. not used in match
|
|
|
|
|
); |
|
|
|
@ -943,13 +943,13 @@ struct SendFriendInviteTrans : NetAuthTrans {
|
|
|
|
|
void * m_param; |
|
|
|
|
|
|
|
|
|
// send
|
|
|
|
|
wchar_t m_emailAddress[kMaxEmailAddressLength]; |
|
|
|
|
wchar_t m_toName[kMaxPlayerNameLength]; |
|
|
|
|
plString m_emailAddress; |
|
|
|
|
plString m_toName; |
|
|
|
|
plUUID m_inviteUuid; |
|
|
|
|
|
|
|
|
|
SendFriendInviteTrans( |
|
|
|
|
const wchar_t emailAddr[], |
|
|
|
|
const wchar_t toName[], |
|
|
|
|
const plString& emailAddr, |
|
|
|
|
const plString& toName, |
|
|
|
|
const plUUID& inviteUuid, |
|
|
|
|
FNetCliAuthSendFriendInviteCallback callback, |
|
|
|
|
void * param |
|
|
|
@ -982,7 +982,7 @@ struct ScoreCreateTrans : NetAuthTrans {
|
|
|
|
|
|
|
|
|
|
// send
|
|
|
|
|
unsigned m_ownerId; |
|
|
|
|
char m_gameName[kMaxGameScoreNameLength]; |
|
|
|
|
plString m_gameName; |
|
|
|
|
unsigned m_gameType; |
|
|
|
|
int m_value; |
|
|
|
|
|
|
|
|
@ -992,7 +992,7 @@ struct ScoreCreateTrans : NetAuthTrans {
|
|
|
|
|
|
|
|
|
|
ScoreCreateTrans ( |
|
|
|
|
unsigned ownerId, |
|
|
|
|
const char* gameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
unsigned gameType, |
|
|
|
|
int value, |
|
|
|
|
FNetCliAuthCreateScoreCallback callback, |
|
|
|
@ -1040,7 +1040,7 @@ struct ScoreGetScoresTrans : NetAuthTrans {
|
|
|
|
|
|
|
|
|
|
// send
|
|
|
|
|
unsigned m_ownerId; |
|
|
|
|
char m_gameName[kMaxGameScoreNameLength]; |
|
|
|
|
plString m_gameName; |
|
|
|
|
|
|
|
|
|
// recv
|
|
|
|
|
NetGameScore * m_scores; |
|
|
|
@ -1048,7 +1048,7 @@ struct ScoreGetScoresTrans : NetAuthTrans {
|
|
|
|
|
|
|
|
|
|
ScoreGetScoresTrans ( |
|
|
|
|
unsigned ownerId, |
|
|
|
|
const char* gameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
FNetCliAuthGetScoresCallback callback, |
|
|
|
|
void * param |
|
|
|
|
); |
|
|
|
@ -1154,7 +1154,7 @@ struct ScoreGetRanksTrans : NetAuthTrans {
|
|
|
|
|
unsigned m_ownerId; |
|
|
|
|
unsigned m_scoreGroup; |
|
|
|
|
unsigned m_parentFolderId; |
|
|
|
|
wchar_t m_gameName[kMaxGameScoreNameLength]; |
|
|
|
|
plString m_gameName; |
|
|
|
|
unsigned m_timePeriod; |
|
|
|
|
unsigned m_numResults; |
|
|
|
|
unsigned m_pageNumber; |
|
|
|
@ -1168,7 +1168,7 @@ struct ScoreGetRanksTrans : NetAuthTrans {
|
|
|
|
|
unsigned ownerId, |
|
|
|
|
unsigned scoreGroup, |
|
|
|
|
unsigned parentFolderId, |
|
|
|
|
const char * cGameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
unsigned timePeriod, |
|
|
|
|
unsigned numResults, |
|
|
|
|
unsigned pageNumber, |
|
|
|
@ -1203,7 +1203,7 @@ static bool s_running;
|
|
|
|
|
static CCritSect s_critsect; |
|
|
|
|
static LISTDECL(CliAuConn, link) s_conns; |
|
|
|
|
static CliAuConn * s_active; |
|
|
|
|
static wchar_t s_accountName[kMaxAccountNameLength]; |
|
|
|
|
static plString s_accountName; |
|
|
|
|
static ShaDigest s_accountNamePassHash; |
|
|
|
|
static wchar_t s_authToken[kMaxPublisherAuthKeyLength]; |
|
|
|
|
static wchar_t s_os[kMaxGTOSIdLength]; |
|
|
|
@ -1231,42 +1231,28 @@ static FNotifyNewBuildHandler s_notifyNewBuildHandler;
|
|
|
|
|
***/ |
|
|
|
|
|
|
|
|
|
//===========================================================================
|
|
|
|
|
static inline bool ICharIsSpace (unsigned ch) { |
|
|
|
|
return ch == ' '; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//===========================================================================
|
|
|
|
|
static ENetError FixupPlayerName (wchar_t * name) { |
|
|
|
|
ASSERT(name); |
|
|
|
|
static ENetError FixupPlayerName (plString& name) { |
|
|
|
|
ASSERT(!name.IsEmpty()); |
|
|
|
|
|
|
|
|
|
// Trim leading and trailing whitespace and convert
|
|
|
|
|
// multiple internal spaces into only one space
|
|
|
|
|
unsigned nonSpaceChars = 0; |
|
|
|
|
wchar_t *dst = name; |
|
|
|
|
for (wchar_t *src = name; *src; ) { |
|
|
|
|
// Skip whitespace
|
|
|
|
|
while (*src && ICharIsSpace(*src)) |
|
|
|
|
src++; |
|
|
|
|
// Trim leading and trailing whitespace
|
|
|
|
|
name = name.Trim(" \t\n\r"); |
|
|
|
|
|
|
|
|
|
// If the block skipped was not at the beginning
|
|
|
|
|
// of the string then add one space character
|
|
|
|
|
if (*src && (dst != name)) |
|
|
|
|
*dst++ = ' '; |
|
|
|
|
// Convert remaining internal whitespace to a single space.
|
|
|
|
|
// Kind of hacky, but meh.
|
|
|
|
|
std::vector<plString> things = name.Tokenize(" \t\n\r"); |
|
|
|
|
|
|
|
|
|
// Copy characters until end-of-string or next whitespace
|
|
|
|
|
while (*src && !ICharIsSpace(*src)) { |
|
|
|
|
++nonSpaceChars; |
|
|
|
|
*dst++ = *src++; |
|
|
|
|
plStringStream ss; |
|
|
|
|
for (auto it = things.begin(); it != things.end(); ++it) { |
|
|
|
|
ss << *it; |
|
|
|
|
if ((it + 1) != things.end()) |
|
|
|
|
ss << " "; |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Ensure destination string is terminated
|
|
|
|
|
*dst = 0; |
|
|
|
|
name = ss.GetString(); |
|
|
|
|
|
|
|
|
|
// Check for minimum name length
|
|
|
|
|
if (nonSpaceChars < 3) |
|
|
|
|
// Now, check to see if we have the appropriate length
|
|
|
|
|
// We could count the characters, but lazy...
|
|
|
|
|
if (name.Replace(" ", "").GetSize() < 3) |
|
|
|
|
return kNetErrPlayerNameInvalid; |
|
|
|
|
|
|
|
|
|
return kNetSuccess; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -1529,7 +1515,7 @@ static void Connect (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
static void Connect ( |
|
|
|
|
const char name[], |
|
|
|
|
const plString& name, |
|
|
|
|
const plNetAddress& addr |
|
|
|
|
) { |
|
|
|
|
ASSERT(s_running); |
|
|
|
@ -1538,7 +1524,7 @@ static void Connect (
|
|
|
|
|
conn->addr = addr; |
|
|
|
|
conn->seq = ConnNextSequence(); |
|
|
|
|
conn->lastHeardTimeMs = GetNonZeroTimeMs(); // used in connect timeout, and ping timeout
|
|
|
|
|
strncpy(conn->name, name, arrsize(conn->name)); |
|
|
|
|
conn->name = name; |
|
|
|
|
|
|
|
|
|
conn->Ref("Lifetime"); |
|
|
|
|
conn->AutoReconnect(); |
|
|
|
@ -1594,8 +1580,6 @@ CliAuConn::CliAuConn ()
|
|
|
|
|
, sock(nil), cli(nil), seq(0), serverChallenge(0) |
|
|
|
|
, cancelId(nil), abandoned(false) |
|
|
|
|
{ |
|
|
|
|
memset(name, 0, sizeof(name)); |
|
|
|
|
|
|
|
|
|
++s_perf[kPerfConnCount]; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -2622,8 +2606,8 @@ void LoginRequestTrans::AddPlayer (
|
|
|
|
|
ASSERT(index < kMaxPlayersPerAccount); |
|
|
|
|
m_players[index].playerInt = playerInt; |
|
|
|
|
m_players[index].explorer = explorer; |
|
|
|
|
StrCopy(m_players[index].playerName, playerName, arrsize(m_players[index].playerName)); |
|
|
|
|
StrCopy(m_players[index].avatarShape, avatarShape, arrsize(m_players[index].avatarShape)); |
|
|
|
|
m_players[index].playerName = plString::FromWchar(playerName); |
|
|
|
|
m_players[index].avatarShape = plString::FromWchar(avatarShape); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
@ -2636,7 +2620,7 @@ bool LoginRequestTrans::Send () {
|
|
|
|
|
uint32_t clientChallenge = 0; |
|
|
|
|
|
|
|
|
|
// Regex search for primary email domain
|
|
|
|
|
std::vector<plString> match = plString::FromWchar(s_accountName).RESearch("[^@]+@([^.]+\\.)*([^.]+)\\.[^.]+"); |
|
|
|
|
std::vector<plString> match = s_accountName.RESearch("[^@]+@([^.]+\\.)*([^.]+)\\.[^.]+"); |
|
|
|
|
if (match.empty() || match[2].CompareI("gametap") == 0) { |
|
|
|
|
memcpy(challengeHash, s_accountNamePassHash, sizeof(ShaDigest)); |
|
|
|
|
} else { |
|
|
|
@ -2653,11 +2637,13 @@ bool LoginRequestTrans::Send () {
|
|
|
|
|
); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
plStringBuffer<uint16_t> accountName = s_accountName.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_AcctLoginRequest, |
|
|
|
|
m_transId, |
|
|
|
|
clientChallenge, |
|
|
|
|
(uintptr_t) s_accountName, |
|
|
|
|
(uintptr_t) accountName.GetData(), |
|
|
|
|
(uintptr_t) &challengeHash, |
|
|
|
|
(uintptr_t) s_authToken, |
|
|
|
|
(uintptr_t) s_os, |
|
|
|
@ -2723,16 +2709,16 @@ bool LoginRequestTrans::Recv (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
AgeRequestTrans::AgeRequestTrans ( |
|
|
|
|
const wchar_t ageName[], |
|
|
|
|
const plString& ageName, |
|
|
|
|
const plUUID& ageInstId, |
|
|
|
|
FNetCliAuthAgeRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) : NetAuthTrans(kAgeRequestTrans) |
|
|
|
|
, m_ageName(ageName) |
|
|
|
|
, m_ageInstId(ageInstId) |
|
|
|
|
, m_callback(callback) |
|
|
|
|
, m_param(param) |
|
|
|
|
{ |
|
|
|
|
StrCopy(m_ageName, ageName, arrsize(m_ageName)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
@ -2744,10 +2730,12 @@ bool AgeRequestTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return true; |
|
|
|
|
|
|
|
|
|
plStringBuffer<uint16_t> ageName = m_ageName.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_AgeRequest, |
|
|
|
|
m_transId, |
|
|
|
|
(uintptr_t) m_ageName, |
|
|
|
|
(uintptr_t) ageName.GetData(), |
|
|
|
|
(uintptr_t) &m_ageInstId, |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
@ -2936,21 +2924,18 @@ bool AccountCreateFromKeyRequestTrans::Recv (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
PlayerCreateRequestTrans::PlayerCreateRequestTrans ( |
|
|
|
|
const wchar_t playerName[], |
|
|
|
|
const wchar_t avatarShape[], |
|
|
|
|
const wchar_t friendInvite[], |
|
|
|
|
const plString& playerName, |
|
|
|
|
const plString& avatarShape, |
|
|
|
|
const plString& friendInvite, |
|
|
|
|
FNetCliAuthPlayerCreateRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) : NetAuthTrans(kPlayerCreateRequestTrans) |
|
|
|
|
, m_playerName(playerName) |
|
|
|
|
, m_avatarShape(avatarShape) |
|
|
|
|
, m_friendInvite(friendInvite) |
|
|
|
|
, m_callback(callback) |
|
|
|
|
, m_param(param) |
|
|
|
|
{ |
|
|
|
|
StrCopy(m_playerName, playerName, arrsize(m_playerName)); |
|
|
|
|
StrCopy(m_avatarShape, avatarShape, arrsize(m_avatarShape)); |
|
|
|
|
if (friendInvite) |
|
|
|
|
StrCopy(m_friendInvite, friendInvite, arrsize(m_friendInvite)); |
|
|
|
|
else |
|
|
|
|
m_friendInvite[0] = 0; |
|
|
|
|
memset(&m_playerInfo, 0, sizeof(m_playerInfo)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
@ -2959,12 +2944,16 @@ bool PlayerCreateRequestTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
plStringBuffer<uint16_t> playerName = m_playerName.ToUtf16(); |
|
|
|
|
plStringBuffer<uint16_t> avatarShape = m_avatarShape.ToUtf16(); |
|
|
|
|
plStringBuffer<uint16_t> friendInvite = m_friendInvite.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_PlayerCreateRequest, |
|
|
|
|
m_transId, |
|
|
|
|
(uintptr_t) m_playerName, |
|
|
|
|
(uintptr_t) m_avatarShape, |
|
|
|
|
(uintptr_t) m_friendInvite, |
|
|
|
|
(uintptr_t) playerName.GetData(), |
|
|
|
|
(uintptr_t) avatarShape.GetData(), |
|
|
|
|
(uintptr_t) friendInvite.GetData(), |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
m_conn->Send(msg, arrsize(msg)); |
|
|
|
@ -2990,8 +2979,8 @@ bool PlayerCreateRequestTrans::Recv (
|
|
|
|
|
if (!IS_NET_ERROR(reply.result)) { |
|
|
|
|
m_playerInfo.playerInt = reply.playerInt; |
|
|
|
|
m_playerInfo.explorer = reply.explorer; |
|
|
|
|
StrCopy(m_playerInfo.playerName, reply.playerName, arrsize(m_playerInfo.playerName)); |
|
|
|
|
StrCopy(m_playerInfo.avatarShape, reply.avatarShape, arrsize(m_playerInfo.avatarShape)); |
|
|
|
|
m_playerInfo.playerName = plString::FromWchar(reply.playerName); |
|
|
|
|
m_playerInfo.avatarShape = plString::FromWchar(reply.avatarShape); |
|
|
|
|
} |
|
|
|
|
m_result = reply.result; |
|
|
|
|
m_state = kTransStateComplete; |
|
|
|
@ -3166,19 +3155,18 @@ bool SetPlayerRequestTrans::Recv (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
AccountChangePasswordRequestTrans::AccountChangePasswordRequestTrans ( |
|
|
|
|
const wchar_t accountName[], |
|
|
|
|
const wchar_t password[], |
|
|
|
|
const plString& accountName, |
|
|
|
|
const plString& password, |
|
|
|
|
FNetCliAuthAccountChangePasswordRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) : NetAuthTrans(kAccountChangePasswordRequestTrans) |
|
|
|
|
, m_accountName(accountName) |
|
|
|
|
, m_callback(callback) |
|
|
|
|
, m_param(param) |
|
|
|
|
{ |
|
|
|
|
StrCopy(m_accountName, accountName, arrsize(m_accountName)); |
|
|
|
|
|
|
|
|
|
CryptHashPassword( |
|
|
|
|
plString::FromWchar(m_accountName), |
|
|
|
|
plString::FromWchar(password), |
|
|
|
|
m_accountName, |
|
|
|
|
password, |
|
|
|
|
m_namePassHash |
|
|
|
|
); |
|
|
|
|
} |
|
|
|
@ -3188,10 +3176,12 @@ bool AccountChangePasswordRequestTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
plStringBuffer<uint16_t> accountName = m_accountName.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_AcctChangePasswordRequest, |
|
|
|
|
m_transId, |
|
|
|
|
(uintptr_t) m_accountName, |
|
|
|
|
(uintptr_t) accountName.GetData(), |
|
|
|
|
(uintptr_t) &m_namePassHash, |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
@ -3228,14 +3218,14 @@ bool AccountChangePasswordRequestTrans::Recv (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
GetPublicAgeListTrans::GetPublicAgeListTrans ( |
|
|
|
|
const wchar_t ageName[], |
|
|
|
|
const plString& ageName, |
|
|
|
|
FNetCliAuthGetPublicAgeListCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) : NetAuthTrans(kGetPublicAgeListTrans) |
|
|
|
|
, m_ageName(ageName) |
|
|
|
|
, m_callback(callback) |
|
|
|
|
, m_param(param) |
|
|
|
|
{ |
|
|
|
|
StrCopy(m_ageName, ageName, arrsize(m_ageName)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
@ -3243,10 +3233,12 @@ bool GetPublicAgeListTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
plStringBuffer<uint16_t> ageName = m_ageName.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_GetPublicAgeList, |
|
|
|
|
m_transId, |
|
|
|
|
(uintptr_t) &m_ageName, |
|
|
|
|
(uintptr_t) ageName.GetData(), |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
m_conn->Send(msg, arrsize(msg)); |
|
|
|
@ -3817,10 +3809,10 @@ VaultInitAgeTrans::VaultInitAgeTrans (
|
|
|
|
|
void * param, // optional
|
|
|
|
|
const plUUID& ageInstId, // optional. is used in match
|
|
|
|
|
const plUUID& parentAgeInstId, // optional. is used in match
|
|
|
|
|
const wchar_t ageFilename[], // optional. is used in match
|
|
|
|
|
const wchar_t ageInstName[], // optional. not used in match
|
|
|
|
|
const wchar_t ageUserName[], // optional. not used in match
|
|
|
|
|
const wchar_t ageDesc[], // optional. not used in match
|
|
|
|
|
const plString ageFilename, // optional. is used in match
|
|
|
|
|
const plString ageInstName, // optional. not used in match
|
|
|
|
|
const plString ageUserName, // optional. not used in match
|
|
|
|
|
const plString ageDesc, // optional. not used in match
|
|
|
|
|
unsigned ageSequenceNumber, // optional. not used in match
|
|
|
|
|
unsigned ageLanguage // optional. not used in match
|
|
|
|
|
) : NetAuthTrans(kVaultInitAgeTrans) |
|
|
|
@ -3828,10 +3820,6 @@ VaultInitAgeTrans::VaultInitAgeTrans (
|
|
|
|
|
, m_param(param) |
|
|
|
|
, m_ageInstId(ageInstId) |
|
|
|
|
, m_parentAgeInstId(parentAgeInstId) |
|
|
|
|
, m_ageFilename(StrDup(ageFilename ? ageFilename : L"")) |
|
|
|
|
, m_ageInstName(StrDup(ageInstName ? ageInstName : L"")) |
|
|
|
|
, m_ageUserName(StrDup(ageUserName ? ageUserName : L"")) |
|
|
|
|
, m_ageDesc(StrDup(ageDesc ? ageDesc : L"")) |
|
|
|
|
, m_ageSequenceNumber(ageSequenceNumber) |
|
|
|
|
, m_ageLanguage(ageLanguage) |
|
|
|
|
, m_ageId(0) |
|
|
|
@ -3841,10 +3829,6 @@ VaultInitAgeTrans::VaultInitAgeTrans (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
VaultInitAgeTrans::~VaultInitAgeTrans () { |
|
|
|
|
free(m_ageFilename); |
|
|
|
|
free(m_ageInstName); |
|
|
|
|
free(m_ageUserName); |
|
|
|
|
free(m_ageDesc); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
@ -3852,15 +3836,20 @@ bool VaultInitAgeTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
plStringBuffer<uint16_t> ageFilename = m_ageFilename.ToUtf16(); |
|
|
|
|
plStringBuffer<uint16_t> ageInstName = m_ageInstName.ToUtf16(); |
|
|
|
|
plStringBuffer<uint16_t> ageUserName = m_ageUserName.ToUtf16(); |
|
|
|
|
plStringBuffer<uint16_t> ageDesc = m_ageDesc.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_VaultInitAgeRequest, |
|
|
|
|
m_transId, |
|
|
|
|
(uintptr_t) &m_ageInstId, |
|
|
|
|
(uintptr_t) &m_parentAgeInstId, |
|
|
|
|
(uintptr_t) m_ageFilename, |
|
|
|
|
(uintptr_t) m_ageInstName, |
|
|
|
|
(uintptr_t) m_ageUserName, |
|
|
|
|
(uintptr_t) m_ageDesc, |
|
|
|
|
(uintptr_t) ageFilename.GetData(), |
|
|
|
|
(uintptr_t) ageInstName.GetData(), |
|
|
|
|
(uintptr_t) ageUserName.GetData(), |
|
|
|
|
(uintptr_t) ageDesc.GetData(), |
|
|
|
|
m_ageSequenceNumber, |
|
|
|
|
m_ageLanguage, |
|
|
|
|
}; |
|
|
|
@ -4416,8 +4405,8 @@ bool ChangePlayerNameRequestTrans::Recv (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
SendFriendInviteTrans::SendFriendInviteTrans ( |
|
|
|
|
const wchar_t emailAddr[], |
|
|
|
|
const wchar_t toName[], |
|
|
|
|
const plString& emailAddr, |
|
|
|
|
const plString& toName, |
|
|
|
|
const plUUID& inviteUuid, |
|
|
|
|
FNetCliAuthSendFriendInviteCallback callback, |
|
|
|
|
void * param |
|
|
|
@ -4425,9 +4414,9 @@ SendFriendInviteTrans::SendFriendInviteTrans (
|
|
|
|
|
, m_callback(callback) |
|
|
|
|
, m_param(param) |
|
|
|
|
, m_inviteUuid(inviteUuid) |
|
|
|
|
, m_toName(toName) |
|
|
|
|
, m_emailAddress(emailAddr) |
|
|
|
|
{ |
|
|
|
|
StrCopy(m_emailAddress, emailAddr, arrsize(m_emailAddress)); |
|
|
|
|
StrCopy(m_toName, toName, arrsize(m_toName)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
@ -4435,12 +4424,15 @@ bool SendFriendInviteTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
plStringBuffer<uint16_t> emailAddress = m_emailAddress.ToUtf16(); |
|
|
|
|
plStringBuffer<uint16_t> toName = m_toName.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_SendFriendInviteRequest, |
|
|
|
|
m_transId, |
|
|
|
|
(uintptr_t) &m_inviteUuid, |
|
|
|
|
(uintptr_t) m_emailAddress, |
|
|
|
|
(uintptr_t) m_toName, |
|
|
|
|
(uintptr_t) emailAddress.GetData(), |
|
|
|
|
(uintptr_t) toName.GetData(), |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
m_conn->Send(msg, arrsize(msg)); |
|
|
|
@ -4491,7 +4483,7 @@ void AuthConnectedNotifyTrans::Post() {
|
|
|
|
|
//============================================================================
|
|
|
|
|
ScoreCreateTrans::ScoreCreateTrans ( |
|
|
|
|
unsigned ownerId, |
|
|
|
|
const char* gameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
unsigned gameType, |
|
|
|
|
int value, |
|
|
|
|
FNetCliAuthCreateScoreCallback callback, |
|
|
|
@ -4500,12 +4492,12 @@ ScoreCreateTrans::ScoreCreateTrans (
|
|
|
|
|
, m_callback(callback) |
|
|
|
|
, m_param(param) |
|
|
|
|
, m_ownerId(ownerId) |
|
|
|
|
, m_gameName(gameName) |
|
|
|
|
, m_gameType(gameType) |
|
|
|
|
, m_value(value) |
|
|
|
|
, m_scoreId(0) |
|
|
|
|
, m_createdTime(0) |
|
|
|
|
{ |
|
|
|
|
StrCopy(m_gameName, gameName, arrsize(m_gameName)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
@ -4513,14 +4505,13 @@ bool ScoreCreateTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
wchar_t wgameName[kMaxGameScoreNameLength]; |
|
|
|
|
StrToUnicode(wgameName, m_gameName, arrsize(wgameName)); |
|
|
|
|
plStringBuffer<uint16_t> gameName = m_gameName.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_ScoreCreate, |
|
|
|
|
m_transId, |
|
|
|
|
m_ownerId, |
|
|
|
|
(uintptr_t) wgameName, |
|
|
|
|
(uintptr_t) gameName.GetData(), |
|
|
|
|
m_gameType, |
|
|
|
|
(uintptr_t) m_value |
|
|
|
|
}; |
|
|
|
@ -4626,17 +4617,17 @@ bool ScoreDeleteTrans::Recv (
|
|
|
|
|
//============================================================================
|
|
|
|
|
ScoreGetScoresTrans::ScoreGetScoresTrans ( |
|
|
|
|
unsigned ownerId, |
|
|
|
|
const char* gameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
FNetCliAuthGetScoresCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) : NetAuthTrans(kScoreGetScoresTrans) |
|
|
|
|
, m_callback(callback) |
|
|
|
|
, m_param(param) |
|
|
|
|
, m_ownerId(ownerId) |
|
|
|
|
, m_scores(nil) |
|
|
|
|
, m_gameName(gameName) |
|
|
|
|
, m_scores(nullptr) |
|
|
|
|
, m_scoreCount(0) |
|
|
|
|
{ |
|
|
|
|
StrCopy(m_gameName, gameName, arrsize(m_gameName)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
@ -4649,14 +4640,13 @@ bool ScoreGetScoresTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
wchar_t wgameName[kMaxGameScoreNameLength]; |
|
|
|
|
StrToUnicode(wgameName, m_gameName, arrsize(wgameName)); |
|
|
|
|
plStringBuffer<uint16_t> gameName = m_gameName.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_ScoreGetScores, |
|
|
|
|
m_transId, |
|
|
|
|
m_ownerId, |
|
|
|
|
(uintptr_t) wgameName |
|
|
|
|
(uintptr_t) gameName.GetData() |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
m_conn->Send(msg, arrsize(msg)); |
|
|
|
@ -4896,7 +4886,7 @@ ScoreGetRanksTrans::ScoreGetRanksTrans (
|
|
|
|
|
unsigned ownerId, |
|
|
|
|
unsigned scoreGroup, |
|
|
|
|
unsigned parentFolderId, |
|
|
|
|
const char * cGameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
unsigned timePeriod, |
|
|
|
|
unsigned numResults, |
|
|
|
|
unsigned pageNumber, |
|
|
|
@ -4909,12 +4899,12 @@ ScoreGetRanksTrans::ScoreGetRanksTrans (
|
|
|
|
|
, m_ownerId(ownerId) |
|
|
|
|
, m_scoreGroup(scoreGroup) |
|
|
|
|
, m_parentFolderId(parentFolderId) |
|
|
|
|
, m_gameName(gameName) |
|
|
|
|
, m_timePeriod(timePeriod) |
|
|
|
|
, m_numResults(numResults) |
|
|
|
|
, m_pageNumber(pageNumber) |
|
|
|
|
, m_sortDesc(sortDesc) |
|
|
|
|
{ |
|
|
|
|
StrToUnicode(m_gameName, cGameName, arrsize(m_gameName)); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
@ -4922,13 +4912,15 @@ bool ScoreGetRanksTrans::Send () {
|
|
|
|
|
if (!AcquireConn()) |
|
|
|
|
return false; |
|
|
|
|
|
|
|
|
|
plStringBuffer<uint16_t> gameName = m_gameName.ToUtf16(); |
|
|
|
|
|
|
|
|
|
const uintptr_t msg[] = { |
|
|
|
|
kCli2Auth_ScoreGetRanks, |
|
|
|
|
m_transId, |
|
|
|
|
m_ownerId, |
|
|
|
|
m_scoreGroup, |
|
|
|
|
m_parentFolderId, |
|
|
|
|
(uintptr_t) m_gameName, |
|
|
|
|
(uintptr_t) gameName.GetData(), |
|
|
|
|
m_timePeriod, |
|
|
|
|
m_numResults, |
|
|
|
|
m_pageNumber, |
|
|
|
@ -5124,7 +5116,7 @@ void AuthPingEnable (bool enable) {
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthStartConnect ( |
|
|
|
|
const char* authAddrList[], |
|
|
|
|
const plString authAddrList[], |
|
|
|
|
uint32_t authAddrCount |
|
|
|
|
) { |
|
|
|
|
// TEMP: Only connect to one auth server until we fill out this module
|
|
|
|
@ -5133,7 +5125,7 @@ void NetCliAuthStartConnect (
|
|
|
|
|
|
|
|
|
|
for (unsigned i = 0; i < authAddrCount; ++i) { |
|
|
|
|
// Do we need to lookup the address?
|
|
|
|
|
const char* name = authAddrList[i]; |
|
|
|
|
const char* name = authAddrList[i].c_str(); |
|
|
|
|
while (unsigned ch = *name) { |
|
|
|
|
++name; |
|
|
|
|
if (!(isdigit(ch) || ch == L'.' || ch == L':')) { |
|
|
|
@ -5141,7 +5133,7 @@ void NetCliAuthStartConnect (
|
|
|
|
|
AsyncAddressLookupName( |
|
|
|
|
&cancelId, |
|
|
|
|
AsyncLookupCallback, |
|
|
|
|
authAddrList[i], |
|
|
|
|
authAddrList[i].c_str(), |
|
|
|
|
GetClientPort(), |
|
|
|
|
nil |
|
|
|
|
); |
|
|
|
@ -5230,7 +5222,7 @@ void NetCliAuthAccountExistsRequest (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthLoginRequest ( |
|
|
|
|
const wchar_t accountName[], |
|
|
|
|
const plString& accountName, |
|
|
|
|
const ShaDigest * accountNamePassHash, |
|
|
|
|
const wchar_t authToken[], |
|
|
|
|
const wchar_t os[], |
|
|
|
@ -5238,8 +5230,8 @@ void NetCliAuthLoginRequest (
|
|
|
|
|
void * param |
|
|
|
|
) { |
|
|
|
|
// Cache updated login info if provided.
|
|
|
|
|
if (accountName) |
|
|
|
|
StrCopy(s_accountName, accountName, arrsize(s_accountName)); |
|
|
|
|
if (!accountName.IsEmpty()) |
|
|
|
|
s_accountName = accountName; |
|
|
|
|
if (accountNamePassHash) |
|
|
|
|
memcpy(s_accountNamePassHash, *accountNamePassHash, sizeof(ShaDigest)); |
|
|
|
|
if (authToken) |
|
|
|
@ -5253,7 +5245,7 @@ void NetCliAuthLoginRequest (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthAgeRequest ( |
|
|
|
|
const wchar_t ageName[], |
|
|
|
|
const plString& ageName, |
|
|
|
|
const plUUID& ageInstId, |
|
|
|
|
FNetCliAuthAgeRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
@ -5319,14 +5311,13 @@ void NetCliAuthAccountCreateFromKeyRequest (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthPlayerCreateRequest ( |
|
|
|
|
const wchar_t playerName[], |
|
|
|
|
const wchar_t avatarShape[], |
|
|
|
|
const wchar_t friendInvite[], |
|
|
|
|
const plString& playerName, |
|
|
|
|
const plString& avatarShape, |
|
|
|
|
const plString& friendInvite, |
|
|
|
|
FNetCliAuthPlayerCreateRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) { |
|
|
|
|
wchar_t name[kMaxPlayerNameLength]; |
|
|
|
|
StrCopy(name, playerName, arrsize(name)); |
|
|
|
|
plString name = playerName; |
|
|
|
|
ENetError error = FixupPlayerName(name); |
|
|
|
|
if (IS_NET_ERROR(error)) { |
|
|
|
|
NetCliAuthPlayerInfo playerInfo; |
|
|
|
@ -5425,7 +5416,7 @@ void NetCliAuthSetAgePublic (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthGetPublicAgeList ( |
|
|
|
|
const wchar_t ageName[], |
|
|
|
|
const plString& ageName, |
|
|
|
|
FNetCliAuthGetPublicAgeListCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) { |
|
|
|
@ -5439,8 +5430,8 @@ void NetCliAuthGetPublicAgeList (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthAccountChangePasswordRequest ( |
|
|
|
|
const wchar_t accountName[], |
|
|
|
|
const wchar_t password[], |
|
|
|
|
const plString& accountName, |
|
|
|
|
const plString& password, |
|
|
|
|
FNetCliAuthAccountChangePasswordRequestCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) { |
|
|
|
@ -5738,10 +5729,10 @@ void NetCliAuthVaultSendNode (
|
|
|
|
|
void NetCliAuthVaultInitAge ( |
|
|
|
|
const plUUID& ageInstId, // optional. is used in match
|
|
|
|
|
const plUUID& parentAgeInstId, // optional. is used in match
|
|
|
|
|
const wchar_t ageFilename[], // optional. is used in match
|
|
|
|
|
const wchar_t ageInstName[], // optional. not used in match
|
|
|
|
|
const wchar_t ageUserName[], // optional. not used in match
|
|
|
|
|
const wchar_t ageDesc[], // optional. not used in match
|
|
|
|
|
const plString& ageFilename, // optional. is used in match
|
|
|
|
|
const plString& ageInstName, // optional. not used in match
|
|
|
|
|
const plString& ageUserName, // optional. not used in match
|
|
|
|
|
const plString& ageDesc, // optional. not used in match
|
|
|
|
|
unsigned ageSequenceNumber, // optional. not used in match
|
|
|
|
|
unsigned ageLanguage, // optional. not used in match
|
|
|
|
|
FNetCliAuthAgeInitCallback callback, // optional
|
|
|
|
@ -5771,7 +5762,7 @@ void NetCliAuthSetRecvBufferHandler (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthSendCCRPetition ( |
|
|
|
|
const wchar_t * petitionText |
|
|
|
|
const plString& petitionText |
|
|
|
|
) { |
|
|
|
|
hsAssert(false, "eric, implement me."); |
|
|
|
|
} |
|
|
|
@ -5907,8 +5898,8 @@ void NetCliAuthChangePlayerNameRequest (
|
|
|
|
|
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthSendFriendInvite ( |
|
|
|
|
const wchar_t emailAddress[], |
|
|
|
|
const wchar_t toName[], |
|
|
|
|
const plString& emailAddress, |
|
|
|
|
const plString& toName, |
|
|
|
|
const plUUID& inviteUuid, |
|
|
|
|
FNetCliAuthSendFriendInviteCallback callback, |
|
|
|
|
void * param |
|
|
|
@ -5926,7 +5917,7 @@ void NetCliAuthSendFriendInvite (
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthScoreCreate ( |
|
|
|
|
unsigned ownerId, |
|
|
|
|
const char* gameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
unsigned gameType, |
|
|
|
|
int value, |
|
|
|
|
FNetCliAuthCreateScoreCallback callback, |
|
|
|
@ -5960,7 +5951,7 @@ void NetCliAuthScoreDelete(
|
|
|
|
|
//============================================================================
|
|
|
|
|
void NetCliAuthScoreGetScores( |
|
|
|
|
unsigned ownerId, |
|
|
|
|
const char* gameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
FNetCliAuthGetScoresCallback callback, |
|
|
|
|
void * param |
|
|
|
|
) { |
|
|
|
@ -6028,7 +6019,7 @@ void NetCliAuthScoreGetRankList(
|
|
|
|
|
unsigned ownerId, |
|
|
|
|
unsigned scoreGroup, |
|
|
|
|
unsigned parentFolderId, |
|
|
|
|
const char * gameName, |
|
|
|
|
const plString& gameName, |
|
|
|
|
unsigned timePeriod, |
|
|
|
|
unsigned numResults, |
|
|
|
|
unsigned pageNumber, |
|
|
|
|