You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
392 lines
13 KiB
392 lines
13 KiB
/*==LICENSE==* |
|
|
|
CyanWorlds.com Engine - MMOG client, server and tools |
|
Copyright (C) 2011 Cyan Worlds, Inc. |
|
|
|
This program is free software: you can redistribute it and/or modify |
|
it under the terms of the GNU General Public License as published by |
|
the Free Software Foundation, either version 3 of the License, or |
|
(at your option) any later version. |
|
|
|
This program is distributed in the hope that it will be useful, |
|
but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
GNU General Public License for more details. |
|
|
|
You should have received a copy of the GNU General Public License |
|
along with this program. If not, see <http://www.gnu.org/licenses/>. |
|
|
|
Additional permissions under GNU GPL version 3 section 7 |
|
|
|
If you modify this Program, or any covered work, by linking or |
|
combining it with any of RAD Game Tools Bink SDK, Autodesk 3ds Max SDK, |
|
NVIDIA PhysX SDK, Microsoft DirectX SDK, OpenSSL library, Independent |
|
JPEG Group JPEG library, Microsoft Windows Media SDK, or Apple QuickTime SDK |
|
(or a modified version of those libraries), |
|
containing parts covered by the terms of the Bink SDK EULA, 3ds Max EULA, |
|
PhysX SDK EULA, DirectX SDK EULA, OpenSSL and SSLeay licenses, IJG |
|
JPEG Library README, Windows Media SDK EULA, or QuickTime SDK EULA, the |
|
licensors of this Program grant you additional |
|
permission to convey the resulting work. Corresponding Source for a |
|
non-source form of such a combination shall include the source code for |
|
the parts of OpenSSL and IJG JPEG Library used as well as that of the covered |
|
work. |
|
|
|
You can contact Cyan Worlds, Inc. by email legal@cyan.com |
|
or by snail mail at: |
|
Cyan Worlds, Inc. |
|
14617 N Newport Hwy |
|
Mead, WA 99021 |
|
|
|
*==LICENSE==*/ |
|
/***************************************************************************** |
|
* |
|
* $/Plasma20/Sources/Plasma/PubUtilLib/plNetClientComm/plNetClientComm.h |
|
* |
|
* This module is the translation layer between simple network types |
|
* such as uint8_t arrays, and higher-level Plasma-specific types such |
|
* as the plFactory-managed types. |
|
* |
|
***/ |
|
|
|
#ifndef PLASMA20_SOURCES_PLASMA_PUBUTILLIB_PLNETCLIENTCOMM_PLNETCLIENTCOMM_H |
|
#define PLASMA20_SOURCES_PLASMA_PUBUTILLIB_PLNETCLIENTCOMM_PLNETCLIENTCOMM_H |
|
|
|
|
|
#include "HeadSpin.h" |
|
#include "pnUtils/pnUtils.h" |
|
#include "pnNetBase/pnNetBase.h" |
|
#include "plNetCommon/plNetServerSessionInfo.h" |
|
#include "plNetCommon/plNetCommonHelpers.h" |
|
#include "plMessage/plNetCommMsgs.h" |
|
|
|
|
|
class plNetMessage; |
|
|
|
|
|
/***************************************************************************** |
|
* |
|
* NetClientComm API |
|
* |
|
***/ |
|
|
|
struct NetCommPlayer { |
|
unsigned playerInt; |
|
wchar_t playerName[kMaxPlayerNameLength]; |
|
char playerNameAnsi[kMaxPlayerNameLength]; |
|
char avatarDatasetName[64]; |
|
unsigned explorer; |
|
}; |
|
|
|
struct NetCommAccount { |
|
Uuid accountUuid; |
|
wchar_t accountName[kMaxAccountNameLength]; |
|
ShaDigest accountNamePassHash; |
|
char accountNameAnsi[kMaxAccountNameLength]; |
|
unsigned accountFlags; |
|
unsigned billingType; |
|
}; |
|
|
|
struct NetCommAge { |
|
Uuid ageInstId; |
|
unsigned ageVaultId; |
|
char ageDatasetName[kMaxAgeNameLength]; |
|
char spawnPtName[64]; |
|
}; |
|
|
|
const NetCommAge * NetCommGetAge (); |
|
const NetCommAge * NetCommGetStartupAge (); |
|
const NetCommAccount * NetCommGetAccount (); |
|
const NetCommPlayer * NetCommGetPlayer (); |
|
const ARRAY(NetCommPlayer) & NetCommGetPlayerList (); |
|
unsigned NetCommGetPlayerCount (); |
|
bool NetCommIsLoginComplete (); |
|
void NetCommSetReadIniAccountInfo (bool readFromIni); |
|
void NetCommSetAccountUsernamePassword (wchar_t username[], const ShaDigest & namePassHash); |
|
void NetCommSetAuthTokenAndOS (wchar_t authToken[], wchar_t os[]); |
|
ENetError NetCommGetAuthResult (); |
|
|
|
bool NetCommNeedToLoadAvatar (); |
|
void NetCommSetAvatarLoaded (bool loaded = true); |
|
void NetCommChangeMyPassword (const wchar_t password[]); |
|
|
|
void NetCommStartup (); |
|
void NetCommShutdown (); |
|
void NetCommUpdate (); |
|
void NetCommConnect (); |
|
void NetCommDisconnect (); |
|
void NetCommSendMsg ( |
|
plNetMessage * msg |
|
); |
|
void NetCommRecvMsg ( |
|
plNetMessage * msg |
|
); |
|
void NetCommEnableNet ( |
|
bool enabled, |
|
bool wait |
|
); |
|
void NetCommActivatePostInitErrorHandler(); |
|
|
|
|
|
/***************************************************************************** |
|
* |
|
* Net message handlers |
|
* |
|
***/ |
|
|
|
// Return this value from your registered msg handler |
|
// to stop further dispatching of incoming msg. |
|
const unsigned kOK_MsgConsumed = hsOK + 1; |
|
|
|
typedef int (FNetCommMsgHandler)( |
|
plNetMessage * msg, |
|
void * userState |
|
); |
|
|
|
// Adds a msg handler for a msg that is convertable to specified type. |
|
void NetCommAddMsgHandlerForType ( |
|
unsigned msgClassIdx, |
|
FNetCommMsgHandler * handler, |
|
void * userState |
|
); |
|
// Adds a msg handler for a specific msg type. |
|
void NetCommAddMsgHandlerForExactType ( |
|
unsigned msgClassIdx, |
|
FNetCommMsgHandler * handler, |
|
void * userState |
|
); |
|
|
|
extern const unsigned kNetCommAllMsgClasses; |
|
extern FNetCommMsgHandler * kNetCommAllMsgHandlers; |
|
extern const void * kNetCommAllUserStates; |
|
|
|
void NetCommRemoveMsgHandler ( |
|
unsigned msgClassIdx, |
|
FNetCommMsgHandler * handler, |
|
const void * userState |
|
); |
|
|
|
void NetCommSetDefaultMsgHandler ( |
|
FNetCommMsgHandler * handler, |
|
void * userState |
|
); |
|
void NetCommSetMsgPreHandler ( |
|
FNetCommMsgHandler * handler, |
|
void * userState |
|
); |
|
|
|
/***************************************************************************** |
|
* |
|
* Network requests |
|
* Network replies are posted via plDispatch |
|
* |
|
***/ |
|
|
|
void NetCommAuthenticate ( // --> plNetCommAuthMsg |
|
void * param |
|
); |
|
void NetCommGetFileList ( // --> plNetCommFileListMsg |
|
const wchar_t dir[], |
|
const wchar_t ext[], |
|
void * param |
|
); |
|
void NetCommGetFile ( // --> plNetCommFileDownloadMsg |
|
const wchar_t filename[], |
|
hsStream * writer, |
|
void * param |
|
); |
|
void NetCommLinkToAge ( // --> plNetCommLinkToAgeMsg |
|
const NetCommAge & age, |
|
void * param |
|
); |
|
void NetCommSetActivePlayer (//--> plNetCommActivePlayerMsg |
|
unsigned desiredPlayerInt, |
|
void * param |
|
); |
|
void NetCommCreatePlayer ( // --> plNetCommCreatePlayerMsg |
|
const char playerName[], |
|
const char avatarShape[], |
|
const char friendInvite[], |
|
unsigned createFlags, |
|
void * param |
|
); |
|
void NetCommCreatePlayer ( // --> plNetCommCreatePlayerMsg |
|
const wchar_t playerName[], |
|
const wchar_t avatarShape[], |
|
const wchar_t friendInvite[], |
|
unsigned createFlags, |
|
void * param |
|
); |
|
void NetCommDeletePlayer ( // --> plNetCommDeletePlayerMsg |
|
unsigned playerInt, |
|
void * param |
|
); |
|
void NetCommGetPublicAgeList (//-> plNetCommPublicAgeListMsg |
|
const char ageName[], |
|
void * param, |
|
plNetCommReplyMsg::EParamType ptype = plNetCommReplyMsg::kParamTypeOther |
|
); |
|
void NetCommSetAgePublic ( // --> no msg |
|
unsigned ageInfoId, |
|
bool makePublic |
|
); |
|
void NetCommCreatePublicAge (// --> plNetCommPublicAgeMsg |
|
const char ageName[], |
|
const Uuid & ageInstId, |
|
void * param |
|
); |
|
void NetCommRemovePublicAge(// --> plNetCommPublicAgeMsg |
|
const Uuid & ageInstId, |
|
void * param |
|
); |
|
void NetCommRegisterOwnedAge ( |
|
const NetCommAge & age, |
|
const char ageInstDesc[], |
|
unsigned playerInt, |
|
void * param |
|
); |
|
void NetCommUnregisterOwnedAge ( |
|
const char ageName[], |
|
unsigned playerInt, |
|
void * param |
|
); |
|
void NetCommRegisterVisitAge ( |
|
const NetCommAge & age, |
|
const char ageInstDesc[], |
|
unsigned playerInt, |
|
void * param |
|
); |
|
void NetCommUnregisterVisitAge ( |
|
const Uuid & ageInstId, |
|
unsigned playerInt, |
|
void * param |
|
); |
|
void NetCommConnectPlayerVault ( |
|
void * param |
|
); |
|
void NetCommDisconnectPlayerVault (); |
|
void NetCommConnectAgeVault ( |
|
const Uuid & ageInstId, |
|
void * param |
|
); |
|
void NetCommDisconnectAgeVault (); |
|
void NetCommUpgradeVisitorToExplorer ( |
|
unsigned playerInt, |
|
void * param |
|
); |
|
void NetCommSetCCRLevel ( |
|
unsigned ccrLevel |
|
); |
|
void NetCommSendFriendInvite ( |
|
const wchar_t emailAddress[], |
|
const wchar_t toName[], |
|
const Uuid& inviteUuid |
|
); |
|
|
|
#endif // PLASMA20_SOURCES_PLASMA_PUBUTILLIB_PLNETCLIENTCOMM_PLNETCLIENTCOMM_H |
|
|
|
|
|
|
|
|
|
/***************************************************************************** |
|
* |
|
* Old code... |
|
* |
|
***/ |
|
#ifndef plNetClientComm_h_inc |
|
#define plNetClientComm_h_inc |
|
|
|
|
|
//////////////////////////////////////////////////////////////////// |
|
|
|
class plCreatable; |
|
class plStatusLog; |
|
class plAgeLinkStruct; |
|
class plNetClientCommTask; |
|
class plNetMessage; |
|
class plNetMsgTerminated; |
|
class plPlayerMigrationPkg; |
|
|
|
//////////////////////////////////////////////////////////////////// |
|
// plNetClientComm |
|
// - Sends/Recvs messages with a server. |
|
// - Performs common network tasks (eg. auth, ping, join, leave, |
|
// create player, delete player, etc.). |
|
// - Calls you back when network task is complete. |
|
// - Fwds unsolicited messages to your supplied handler. |
|
// - You can register a msg handler msg type family (i.e. msg |
|
// type or base of type). |
|
// - You can register a msg handler for an exact msg type. |
|
// - Sends periodic alive msg to server when authenticated. |
|
// - Tracks message receipts for message types you specify. |
|
// - Checks for server silence. |
|
// |
|
|
|
class plNetClientComm |
|
{ |
|
public: |
|
//////////////////////////////////////////////////////////////// |
|
// CALLBACK CLASSES |
|
|
|
// Callback object sent with calls to our API as optional arg. |
|
class Callback |
|
{ |
|
public: |
|
// OPERATION-SPECIFIC RESULT ARGS. |
|
//------------------------------- |
|
// Auth: 0=guid of server that authenticated us, if success. |
|
// Leave: None |
|
// Alive: None |
|
// Ping: 0=The plNetMsgPing rcvd. |
|
// FindAge: 0=plNetServerSessionInfo for spawned game server. |
|
// Join: 0=fireWalled bool, 1=joinOrder int, 2=experimentalLevel int, 3=initialAgeSDL rec |
|
// GetPlayerList: 0=numPlayers int, 1=player1ID int, 2=player1Name string, 3=flags ... |
|
// SetActivePlayer: None |
|
// CreatePlayer: 0=newPlayerID int |
|
// DeletePlayer: None |
|
// GetPublicAgeList:0=plCreatableStream of plAgeInfoStruct, 1=plCreatableStream of nPlayers |
|
// PublicAgeCreated:0=plAgeInfoStruct |
|
plCreatableListHelper fCbArgs; |
|
//------------------------------- |
|
virtual ~Callback(){} |
|
virtual void OperationStarted( uint32_t context ) = 0; |
|
virtual void OperationComplete( uint32_t context, int resultCode ) = 0; |
|
}; |
|
class StubbedCallback : public Callback |
|
{ |
|
public: |
|
void OperationStarted( uint32_t context ) {} |
|
void OperationComplete( uint32_t context, int resultCode ) {} |
|
}; |
|
|
|
// Message handler for unsolicited msgs or registered for specific msg types. |
|
class MsgHandler |
|
{ |
|
public: |
|
static int StaticMsgHandler(plNetMessage * msg, void * userState); |
|
virtual int HandleMessage( plNetMessage* msg ) = 0; |
|
}; |
|
|
|
//////////////////////////////////////////////////////////////// |
|
|
|
plNetClientComm(); |
|
~plNetClientComm(); |
|
|
|
//////////////////////////////////////////////////////////////// |
|
|
|
// Adds a msg handler for a msg that is convertable to specified type. |
|
void AddMsgHandlerForType( uint16_t msgClassIdx, MsgHandler* handler ); |
|
|
|
// Adds a msg handler for a specific msg type. |
|
void AddMsgHandlerForExactType( uint16_t msgClassIdx, MsgHandler* handler ); |
|
|
|
bool RemoveMsgHandler( MsgHandler* handler ); |
|
|
|
// Msgs not part of a task controlled by this |
|
// object, and doesn't have a handler set for its type |
|
// are sent to this handler (if set). |
|
void SetDefaultHandler( MsgHandler* msgHandler ); |
|
}; |
|
|
|
//////////////////////////////////////////////////////////////////// |
|
#endif // plNetClientComm_h_inc
|
|
|