Files
SLikeNet/DependentExtensions/Lobby2/PGSQL/Lobby2Message_PGSQL.h
2025-11-24 14:19:51 +05:30

532 lines
29 KiB
C++

/*
* Original work: Copyright (c) 2014, Oculus VR, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* RakNet License.txt file in the licenses directory of this source tree. An additional grant
* of patent rights can be found in the RakNet Patents.txt file in the same directory.
*
*
* Modified work: Copyright (c) 2017, SLikeSoft UG (haftungsbeschränkt)
*
* This source code was modified by SLikeSoft. Modifications are licensed under the MIT-style
* license found in the license.txt file in the root directory of this source tree.
*/
#include "Lobby2Message.h"
#include "Lobby2Server.h"
// libpq-fe.h is part of PostgreSQL which must be installed on this computer to use the PostgreRepository
#include "libpq-fe.h"
#include "PostgreSQLInterface.h"
#include "slikenet/EpochTimeToString.h"
#ifndef __LOBBY_2_MESSAGE_PGSQL_H
#define __LOBBY_2_MESSAGE_PGSQL_H
namespace SLNet
{
// --------------------------------------------- Database specific message implementations for the server --------------------------------------------
#define __L2_MSG_DB_HEADER(__NAME__,__DB__) \
struct __NAME__##_##__DB__ : public __NAME__
struct ClanMemberDescriptor
{
unsigned int userId;
SLNet::RakString name;
bool isSubleader;
ClanMemberState memberState;
SLNet::RakString banReason;
};
// Helper functions
unsigned int GetUserRowFromHandle(SLNet::RakString& userName, PostgreSQLInterface *pgsql);
unsigned int GetClanIdFromHandle(SLNet::RakString clanName, PostgreSQLInterface *pgsql);
bool IsClanLeader(SLNet::RakString clanName, unsigned int userId, PostgreSQLInterface *pgsql);
unsigned int GetClanLeaderId(unsigned int clanId, PostgreSQLInterface *pgsql);
bool IsClanLeader(unsigned int clanId, unsigned int userId, PostgreSQLInterface *pgsql);
ClanMemberState GetClanMemberState(unsigned int clanId, unsigned int userId, bool *isSubleader, PostgreSQLInterface *pgsql);
void GetClanMembers(unsigned int clanId, DataStructures::List<ClanMemberDescriptor> &clanMembers, PostgreSQLInterface *pgsql);
bool IsTitleInUse(SLNet::RakString titleName, PostgreSQLInterface *pgsql);
bool StringContainsProfanity(SLNet::RakString string, PostgreSQLInterface *pgsql);
bool IsValidCountry(SLNet::RakString string, bool *countryHasStates, PostgreSQLInterface *pgsql);
bool IsValidState(SLNet::RakString string, PostgreSQLInterface *pgsql);
bool IsValidRace(SLNet::RakString string, PostgreSQLInterface *pgsql);
void GetFriendIDs(unsigned int callerUserId, bool excludeIfIgnored, PostgreSQLInterface *pgsql, DataStructures::List<unsigned int> &output);
void GetClanMateIDs(unsigned int callerUserId, bool excludeIfIgnored, PostgreSQLInterface *pgsql, DataStructures::List<unsigned int> &output);
bool IsIgnoredByTarget(unsigned int callerUserId, unsigned int targetUserId, PostgreSQLInterface *pgsql);
void OutputFriendsNotification(SLNet::Notification_Friends_StatusChange::Status notificationType, Lobby2ServerCommand *command, PostgreSQLInterface *pgsql);
// This does NOT return the online status to output, as it is not threadsafe
void GetFriendInfosByStatus(unsigned int callerUserId, SLNet::RakString status, PostgreSQLInterface *pgsql, DataStructures::List<FriendInfo> &output, bool callerIsUserOne);
void SendEmail(DataStructures::List<SLNet::RakString> &recipientNames, unsigned int senderUserId, SLNet::RakString senderUserName, Lobby2Server *server, SLNet::RakString subject, SLNet::RakString body, RakNetSmartPtr<BinaryDataBlock>binaryData, int status, SLNet::RakString triggerString, PostgreSQLInterface *pgsql);
void SendEmail(DataStructures::List<unsigned int> &targetUserIds, unsigned int senderUserId, SLNet::RakString senderUserName, Lobby2Server *server, SLNet::RakString subject, SLNet::RakString body, RakNetSmartPtr<BinaryDataBlock>binaryData, int status, SLNet::RakString triggerString, PostgreSQLInterface *pgsql);
void SendEmail(unsigned int targetUserId, unsigned int senderUserId, SLNet::RakString senderUserName, Lobby2Server *server, SLNet::RakString subject, SLNet::RakString body, RakNetSmartPtr<BinaryDataBlock>binaryData, int status, SLNet::RakString triggerString, PostgreSQLInterface *pgsql);
int GetActiveClanCount(unsigned int userId, PostgreSQLInterface *pgsql);
bool CreateAccountParametersFailed( CreateAccountParameters &createAccountParameters, SLNet::Lobby2ResultCode &resultCode, Lobby2ServerCommand *command, PostgreSQLInterface *pgsql);
void UpdateAccountFromMissingCreationParameters(CreateAccountParameters &createAccountParameters, unsigned int userPrimaryKey, Lobby2ServerCommand *command, PostgreSQLInterface *pgsql);
__L2_MSG_DB_HEADER(Platform_Startup, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface ) { (void)command; (void)databaseInterface; return false; }};
__L2_MSG_DB_HEADER(Platform_Shutdown, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface ) { (void)command; (void)databaseInterface; return false; }};
__L2_MSG_DB_HEADER(System_CreateDatabase, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_DestroyDatabase, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_CreateTitle, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_DestroyTitle, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_GetTitleRequiredAge, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_GetTitleBinaryData, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_RegisterProfanity, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_BanUser, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_UnbanUser, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(CDKey_Add, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(CDKey_GetStatus, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(CDKey_Use, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(CDKey_FlagStolen, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_Login, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_Logoff, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_RegisterAccount, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_SetEmailAddressValidated, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_ValidateHandle, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_DeleteAccount, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(System_PruneAccounts, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_GetEmailAddress, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_GetPasswordRecoveryQuestionByHandle, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_GetPasswordByPasswordRecoveryAnswer, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_ChangeHandle, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_UpdateAccount, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_GetAccountDetails, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_StartIgnore, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_StopIgnore, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_GetIgnoreList, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Client_PerTitleIntegerStorage, PGSQL){
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );
virtual bool Write( Lobby2ServerCommand *command, void *databaseInterface );
virtual bool Read( Lobby2ServerCommand *command, void *databaseInterface );
virtual bool Delete( Lobby2ServerCommand *command, void *databaseInterface );
virtual bool Add( Lobby2ServerCommand *command, void *databaseInterface );
};
__L2_MSG_DB_HEADER(Client_SetPresence, PGSQL){virtual bool ServerPreDBMemoryImpl( Lobby2Server *server, RakString curUserHandle );};
__L2_MSG_DB_HEADER(Client_GetPresence, PGSQL){virtual bool ServerPreDBMemoryImpl( Lobby2Server *server, RakString curUserHandle );};
__L2_MSG_DB_HEADER(Client_PerTitleBinaryStorage, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Friends_SendInvite, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Friends_AcceptInvite, PGSQL){
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );
virtual void ServerPostDBMemoryImpl( Lobby2Server *server, RakString userHandle );
};
__L2_MSG_DB_HEADER(Friends_RejectInvite, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Friends_GetInvites, PGSQL){
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );
virtual void ServerPostDBMemoryImpl( Lobby2Server *server, RakString userHandle );
};
__L2_MSG_DB_HEADER(Friends_GetFriends, PGSQL){
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );
virtual void ServerPostDBMemoryImpl( Lobby2Server *server, RakString userHandle );
};
__L2_MSG_DB_HEADER(Friends_Remove, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(BookmarkedUsers_Add, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(BookmarkedUsers_Remove, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(BookmarkedUsers_Get, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Emails_Send, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Emails_Get, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Emails_Delete, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Emails_SetStatus, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_SubmitMatch, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_GetMatches, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_GetMatchBinaryData, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_GetTotalScore, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_WipeScoresForPlayer, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_WipeMatches, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_PruneMatches, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_UpdateRating, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_WipeRatings, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Ranking_GetRating, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_Create, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_SetProperties, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_GetProperties, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_SetMyMemberProperties, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_GrantLeader, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_SetSubleaderStatus, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_SetMemberRank, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_GetMemberProperties, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_ChangeHandle, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_Leave, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_Get, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_SendJoinInvitation, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_WithdrawJoinInvitation, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_AcceptJoinInvitation, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_RejectJoinInvitation, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_DownloadInvitationList, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_SendJoinRequest, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_WithdrawJoinRequest, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_AcceptJoinRequest, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_RejectJoinRequest, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_DownloadRequestList, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_KickAndBlacklistUser, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_UnblacklistUser, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_GetBlacklist, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_GetMembers, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_GetList, PGSQL){virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface );};
__L2_MSG_DB_HEADER(Clans_CreateBoard, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
(void)command;
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
PGresult *result = pgsql->QueryVariadic("");
if (result!=0)
{
PQclear(result);
resultCode=L2RC_SUCCESS;
}
else
{
resultCode=L2RC_SUCCESS;
}
return true;
}
};
__L2_MSG_DB_HEADER(Clans_DestroyBoard, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
(void)command;
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
PGresult *result = pgsql->QueryVariadic("");
if (result!=0)
{
PQclear(result);
resultCode=L2RC_SUCCESS;
}
else
{
resultCode=L2RC_SUCCESS;
}
return true;
}
};
__L2_MSG_DB_HEADER(Clans_CreateNewTopic, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
(void)command;
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
PGresult *result = pgsql->QueryVariadic("");
if (result!=0)
{
PQclear(result);
resultCode=L2RC_SUCCESS;
}
else
{
resultCode=L2RC_SUCCESS;
}
return true;
}
};
__L2_MSG_DB_HEADER(Clans_ReplyToTopic, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
(void)command;
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
PGresult *result = pgsql->QueryVariadic("");
if (result!=0)
{
PQclear(result);
resultCode=L2RC_SUCCESS;
}
else
{
resultCode=L2RC_SUCCESS;
}
return true;
}
};
__L2_MSG_DB_HEADER(Clans_RemovePost, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
(void)command;
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
PGresult *result = pgsql->QueryVariadic("");
if (result!=0)
{
PQclear(result);
resultCode=L2RC_SUCCESS;
}
else
{
resultCode=L2RC_SUCCESS;
}
return true;
}
};
__L2_MSG_DB_HEADER(Clans_GetBoards, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
(void)command;
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
PGresult *result = pgsql->QueryVariadic("");
if (result!=0)
{
PQclear(result);
resultCode=L2RC_SUCCESS;
}
else
{
resultCode=L2RC_SUCCESS;
}
return true;
}
};
__L2_MSG_DB_HEADER(Clans_GetTopics, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
(void)command;
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
PGresult *result = pgsql->QueryVariadic("");
if (result!=0)
{
PQclear(result);
resultCode=L2RC_SUCCESS;
}
else
{
resultCode=L2RC_SUCCESS;
}
return true;
}
};
__L2_MSG_DB_HEADER(Clans_GetPosts, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
(void)command;
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
PGresult *result = pgsql->QueryVariadic("");
if (result!=0)
{
PQclear(result);
resultCode=L2RC_SUCCESS;
}
else
{
resultCode=L2RC_SUCCESS;
}
return true;
}
};
__L2_MSG_DB_HEADER(Notification_Friends_StatusChange, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
if (command->callerSystemAddresses.Size()==0)
{
OutputFriendsNotification(Notification_Friends_StatusChange::FRIEND_LOGGED_OFF, command, pgsql);
}
// Don't let the thread return this notification with SLNet::UNASSIGNED_SYSTEM_ADDRESS to the user. It's just a message to the thread.
return false;
}
virtual void ServerPostDBMemoryImpl( Lobby2Server *server, RakString userHandle )
{
switch (op)
{
case Notification_Friends_StatusChange::FRIEND_LOGGED_IN:
case Notification_Friends_StatusChange::FRIEND_LOGGED_IN_DIFFERENT_CONTEXT:
case Notification_Friends_StatusChange::THEY_ACCEPTED_OUR_INVITATION_TO_BE_FRIENDS:
server->GetPresence(presence,otherHandle);
break;
case Notification_Friends_StatusChange::FRIEND_LOGGED_OFF:
presence.isVisible=false;
presence.status=Lobby2Presence::NOT_ONLINE;
break;
case Notification_Friends_StatusChange::FRIEND_ACCOUNT_WAS_DELETED:
case Notification_Friends_StatusChange::YOU_WERE_REMOVED_AS_A_FRIEND:
case Notification_Friends_StatusChange::GOT_INVITATION_TO_BE_FRIENDS:
case Notification_Friends_StatusChange::THEY_REJECTED_OUR_INVITATION_TO_BE_FRIENDS:
presence.isVisible=false;
presence.status=Lobby2Presence::UNDEFINED;
break;
}
}
};
__L2_MSG_DB_HEADER(Notification_Friends_PresenceUpdate, PGSQL)
{
virtual bool ServerDBImpl( Lobby2ServerCommand *command, void *databaseInterface )
{
PostgreSQLInterface *pgsql = (PostgreSQLInterface *)databaseInterface;
// Tell all friends about this new login
DataStructures::List<unsigned int> output;
GetFriendIDs(command->callerUserId, true, pgsql, output);
unsigned int idx;
for (idx=0; idx < output.Size(); idx++)
{
Notification_Friends_PresenceUpdate *notification = (Notification_Friends_PresenceUpdate *) command->server->GetMessageFactory()->Alloc(L2MID_Notification_Friends_PresenceUpdate);
notification->otherHandle=command->callingUserName;
notification->newPresence=newPresence;
notification->resultCode=L2RC_SUCCESS;
command->server->AddOutputFromThread(notification, output[idx], "");
}
// Don't let the thread return this notification with SLNet::UNASSIGNED_SYSTEM_ADDRESS to the user. It's just a message to the thread.
return false;
}
};
// --------------------------------------------- Database specific factory class for all messages --------------------------------------------
#define __L2_MSG_FACTORY_IMPL(__NAME__,__DB__) {case L2MID_##__NAME__ : return SLNet::OP_NEW< __NAME__##_##__DB__ >( _FILE_AND_LINE_ ) ;}
struct Lobby2MessageFactory_PGSQL : public Lobby2MessageFactory
{
STATIC_FACTORY_DECLARATIONS(Lobby2MessageFactory_PGSQL)
virtual Lobby2Message *Alloc(Lobby2MessageID id)
{
switch (id)
{
__L2_MSG_FACTORY_IMPL(Platform_Startup, PGSQL);
__L2_MSG_FACTORY_IMPL(Platform_Shutdown, PGSQL);
__L2_MSG_FACTORY_IMPL(System_CreateDatabase, PGSQL);
__L2_MSG_FACTORY_IMPL(System_DestroyDatabase, PGSQL);
__L2_MSG_FACTORY_IMPL(System_CreateTitle, PGSQL);
__L2_MSG_FACTORY_IMPL(System_DestroyTitle, PGSQL);
__L2_MSG_FACTORY_IMPL(System_GetTitleRequiredAge, PGSQL);
__L2_MSG_FACTORY_IMPL(System_GetTitleBinaryData, PGSQL);
__L2_MSG_FACTORY_IMPL(System_RegisterProfanity, PGSQL);
__L2_MSG_FACTORY_IMPL(System_BanUser, PGSQL);
__L2_MSG_FACTORY_IMPL(System_UnbanUser, PGSQL);
__L2_MSG_FACTORY_IMPL(CDKey_Add, PGSQL);
__L2_MSG_FACTORY_IMPL(CDKey_GetStatus, PGSQL);
__L2_MSG_FACTORY_IMPL(CDKey_Use, PGSQL);
__L2_MSG_FACTORY_IMPL(CDKey_FlagStolen, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_Login, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_Logoff, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_RegisterAccount, PGSQL);
__L2_MSG_FACTORY_IMPL(System_SetEmailAddressValidated, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_ValidateHandle, PGSQL);
__L2_MSG_FACTORY_IMPL(System_DeleteAccount, PGSQL);
__L2_MSG_FACTORY_IMPL(System_PruneAccounts, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_GetEmailAddress, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_GetPasswordRecoveryQuestionByHandle, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_GetPasswordByPasswordRecoveryAnswer, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_ChangeHandle, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_UpdateAccount, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_GetAccountDetails, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_StartIgnore, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_StopIgnore, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_GetIgnoreList, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_PerTitleIntegerStorage, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_PerTitleBinaryStorage, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_SetPresence, PGSQL);
__L2_MSG_FACTORY_IMPL(Client_GetPresence, PGSQL);
__L2_MSG_FACTORY_IMPL(Friends_SendInvite, PGSQL);
__L2_MSG_FACTORY_IMPL(Friends_AcceptInvite, PGSQL);
__L2_MSG_FACTORY_IMPL(Friends_RejectInvite, PGSQL);
__L2_MSG_FACTORY_IMPL(Friends_GetInvites, PGSQL);
__L2_MSG_FACTORY_IMPL(Friends_GetFriends, PGSQL);
__L2_MSG_FACTORY_IMPL(Friends_Remove, PGSQL);
__L2_MSG_FACTORY_IMPL(BookmarkedUsers_Add, PGSQL);
__L2_MSG_FACTORY_IMPL(BookmarkedUsers_Remove, PGSQL);
__L2_MSG_FACTORY_IMPL(BookmarkedUsers_Get, PGSQL);
__L2_MSG_FACTORY_IMPL(Emails_Send, PGSQL);
__L2_MSG_FACTORY_IMPL(Emails_Get, PGSQL);
__L2_MSG_FACTORY_IMPL(Emails_Delete, PGSQL);
__L2_MSG_FACTORY_IMPL(Emails_SetStatus, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_SubmitMatch, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_GetMatches, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_GetMatchBinaryData, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_GetTotalScore, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_WipeScoresForPlayer, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_WipeMatches, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_PruneMatches, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_UpdateRating, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_WipeRatings, PGSQL);
__L2_MSG_FACTORY_IMPL(Ranking_GetRating, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_Create, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_SetProperties, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GetProperties, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_SetMyMemberProperties, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GrantLeader, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_SetSubleaderStatus, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_SetMemberRank, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GetMemberProperties, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_ChangeHandle, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_Leave, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_Get, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_SendJoinInvitation, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_WithdrawJoinInvitation, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_AcceptJoinInvitation, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_RejectJoinInvitation, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_DownloadInvitationList, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_SendJoinRequest, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_WithdrawJoinRequest, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_AcceptJoinRequest, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_RejectJoinRequest, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_DownloadRequestList, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_KickAndBlacklistUser, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_UnblacklistUser, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GetBlacklist, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GetMembers, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GetList, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_CreateBoard, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_DestroyBoard, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_CreateNewTopic, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_ReplyToTopic, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_RemovePost, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GetBoards, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GetTopics, PGSQL);
__L2_MSG_FACTORY_IMPL(Clans_GetPosts, PGSQL);
__L2_MSG_FACTORY_BASE(Notification_Client_RemoteLogin);
__L2_MSG_FACTORY_BASE(Notification_Client_IgnoreStatus);
__L2_MSG_FACTORY_IMPL(Notification_Friends_StatusChange, PGSQL);
__L2_MSG_FACTORY_IMPL(Notification_Friends_PresenceUpdate, PGSQL);
__L2_MSG_FACTORY_BASE(Notification_User_ChangedHandle);
__L2_MSG_FACTORY_BASE(Notification_Friends_CreatedClan);
__L2_MSG_FACTORY_BASE(Notification_Emails_Received);
__L2_MSG_FACTORY_BASE(Notification_Clans_GrantLeader);
__L2_MSG_FACTORY_BASE(Notification_Clans_SetSubleaderStatus);
__L2_MSG_FACTORY_BASE(Notification_Clans_SetMemberRank);
__L2_MSG_FACTORY_BASE(Notification_Clans_ChangeHandle);
__L2_MSG_FACTORY_BASE(Notification_Clans_Leave);
__L2_MSG_FACTORY_BASE(Notification_Clans_PendingJoinStatus);
__L2_MSG_FACTORY_BASE(Notification_Clans_NewClanMember);
__L2_MSG_FACTORY_BASE(Notification_Clans_KickAndBlacklistUser);
__L2_MSG_FACTORY_BASE(Notification_Clans_UnblacklistUser);
__L2_MSG_FACTORY_BASE(Notification_Clans_Destroyed);
default:
return 0;
};
};
};
}; // namespace SLNet
#endif