mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-21 12:53:51 +00:00
[General] Add Master Packets
This commit is contained in:
parent
5854f680f0
commit
546bb42abb
7 changed files with 340 additions and 0 deletions
45
components/openmw-mp/Master/PacketMasterAnnounce.cpp
Normal file
45
components/openmw-mp/Master/PacketMasterAnnounce.cpp
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
//
|
||||||
|
// Created by koncord on 22.04.17.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <components/openmw-mp/NetworkMessages.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
#include "PacketMasterAnnounce.hpp"
|
||||||
|
#include "ProxyMasterPacket.hpp"
|
||||||
|
|
||||||
|
using namespace mwmp;
|
||||||
|
using namespace RakNet;
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
PacketMasterAnnounce::PacketMasterAnnounce(RakNet::RakPeerInterface *peer) : BasePacket(peer)
|
||||||
|
{
|
||||||
|
packetID = ID_MASTER_ANNOUNCE;
|
||||||
|
orderChannel = CHANNEL_MASTER;
|
||||||
|
}
|
||||||
|
|
||||||
|
void PacketMasterAnnounce::Packet(BitStream *bs, bool send)
|
||||||
|
{
|
||||||
|
this->bs = bs;
|
||||||
|
if (send)
|
||||||
|
bs->Write(packetID);
|
||||||
|
|
||||||
|
RW(func, send);
|
||||||
|
|
||||||
|
if(func == FUNCTION_ANNOUNCE)
|
||||||
|
ProxyMasterPacket::addServer(this, *server, send);
|
||||||
|
}
|
||||||
|
|
||||||
|
void PacketMasterAnnounce::SetServer(Server *_server)
|
||||||
|
{
|
||||||
|
server = _server;
|
||||||
|
}
|
||||||
|
|
||||||
|
void PacketMasterAnnounce::SetFunc(int _func)
|
||||||
|
{
|
||||||
|
func = _func;
|
||||||
|
}
|
||||||
|
|
||||||
|
int PacketMasterAnnounce::GetFunc()
|
||||||
|
{
|
||||||
|
return func;
|
||||||
|
}
|
38
components/openmw-mp/Master/PacketMasterAnnounce.hpp
Normal file
38
components/openmw-mp/Master/PacketMasterAnnounce.hpp
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
//
|
||||||
|
// Created by koncord on 22.04.17.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef OPENMW_PACKETMASTERANNOUNCE_HPP
|
||||||
|
#define OPENMW_PACKETMASTERANNOUNCE_HPP
|
||||||
|
|
||||||
|
#include "../Packets/BasePacket.hpp"
|
||||||
|
#include "MasterData.hpp"
|
||||||
|
|
||||||
|
namespace mwmp
|
||||||
|
{
|
||||||
|
class ProxyMasterPacket;
|
||||||
|
class PacketMasterAnnounce : public BasePacket
|
||||||
|
{
|
||||||
|
friend class ProxyMasterPacket;
|
||||||
|
public:
|
||||||
|
PacketMasterAnnounce(RakNet::RakPeerInterface *peer);
|
||||||
|
|
||||||
|
virtual void Packet(RakNet::BitStream *bs, bool send);
|
||||||
|
|
||||||
|
void SetServer(Server *server);
|
||||||
|
void SetFunc(int keep);
|
||||||
|
int GetFunc();
|
||||||
|
|
||||||
|
enum Func
|
||||||
|
{
|
||||||
|
FUNCTION_DELETE = 0,
|
||||||
|
FUNCTION_ANNOUNCE,
|
||||||
|
FUNCTION_KEEP
|
||||||
|
};
|
||||||
|
private:
|
||||||
|
Server *server;
|
||||||
|
int func;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //OPENMW_PACKETMASTERANNOUNCE_HPP
|
60
components/openmw-mp/Master/PacketMasterQuery.cpp
Normal file
60
components/openmw-mp/Master/PacketMasterQuery.cpp
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
//
|
||||||
|
// Created by koncord on 22.04.17.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <components/openmw-mp/NetworkMessages.hpp>
|
||||||
|
#include <iostream>
|
||||||
|
#include "MasterData.hpp"
|
||||||
|
#include "PacketMasterQuery.hpp"
|
||||||
|
#include "ProxyMasterPacket.hpp"
|
||||||
|
|
||||||
|
|
||||||
|
using namespace mwmp;
|
||||||
|
using namespace std;
|
||||||
|
using namespace RakNet;
|
||||||
|
|
||||||
|
PacketMasterQuery::PacketMasterQuery(RakNet::RakPeerInterface *peer) : BasePacket(peer)
|
||||||
|
{
|
||||||
|
packetID = ID_MASTER_QUERY;
|
||||||
|
orderChannel = CHANNEL_MASTER;
|
||||||
|
}
|
||||||
|
|
||||||
|
void PacketMasterQuery::Packet(RakNet::BitStream *bs, bool send)
|
||||||
|
{
|
||||||
|
this->bs = bs;
|
||||||
|
if (send)
|
||||||
|
bs->Write(packetID);
|
||||||
|
|
||||||
|
int serversCount = servers->size();
|
||||||
|
|
||||||
|
RW(serversCount, send);
|
||||||
|
|
||||||
|
map<SystemAddress, Server>::iterator serverIt;
|
||||||
|
if(send)
|
||||||
|
serverIt = servers->begin();
|
||||||
|
|
||||||
|
Server server;
|
||||||
|
SystemAddress sa;
|
||||||
|
while(serversCount--)
|
||||||
|
{
|
||||||
|
if(send)
|
||||||
|
{
|
||||||
|
sa = serverIt->first;
|
||||||
|
server = serverIt->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
RW(sa, send);
|
||||||
|
ProxyMasterPacket::addServer(this, server, send);
|
||||||
|
|
||||||
|
if(send)
|
||||||
|
serverIt++;
|
||||||
|
else
|
||||||
|
servers->insert(pair<SystemAddress, Server>(sa, server));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void PacketMasterQuery::SetServers(map<SystemAddress, Server> *serverMap)
|
||||||
|
{
|
||||||
|
servers = serverMap;
|
||||||
|
}
|
28
components/openmw-mp/Master/PacketMasterQuery.hpp
Normal file
28
components/openmw-mp/Master/PacketMasterQuery.hpp
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
//
|
||||||
|
// Created by koncord on 22.04.17.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef OPENMW_PACKETMASTERQUERY_HPP
|
||||||
|
#define OPENMW_PACKETMASTERQUERY_HPP
|
||||||
|
|
||||||
|
#include "../Packets/BasePacket.hpp"
|
||||||
|
#include "MasterData.hpp"
|
||||||
|
|
||||||
|
namespace mwmp
|
||||||
|
{
|
||||||
|
class ProxyMasterPacket;
|
||||||
|
class PacketMasterQuery : public BasePacket
|
||||||
|
{
|
||||||
|
friend class ProxyMasterPacket;
|
||||||
|
public:
|
||||||
|
PacketMasterQuery(RakNet::RakPeerInterface *peer);
|
||||||
|
|
||||||
|
virtual void Packet(RakNet::BitStream *bs, bool send);
|
||||||
|
|
||||||
|
void SetServers(std::map<RakNet::SystemAddress, Server> *serverMap);
|
||||||
|
private:
|
||||||
|
std::map<RakNet::SystemAddress, Server> *servers;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //OPENMW_PACKETMASTERQUERY_HPP
|
34
components/openmw-mp/Master/PacketMasterUpdate.cpp
Normal file
34
components/openmw-mp/Master/PacketMasterUpdate.cpp
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
//
|
||||||
|
// Created by koncord on 22.04.17.
|
||||||
|
//
|
||||||
|
|
||||||
|
#include <components/openmw-mp/NetworkMessages.hpp>
|
||||||
|
#include "PacketMasterUpdate.hpp"
|
||||||
|
#include "ProxyMasterPacket.hpp"
|
||||||
|
|
||||||
|
using namespace mwmp;
|
||||||
|
using namespace std;
|
||||||
|
using namespace RakNet;
|
||||||
|
|
||||||
|
PacketMasterUpdate::PacketMasterUpdate(RakNet::RakPeerInterface *peer) : BasePacket(peer)
|
||||||
|
{
|
||||||
|
packetID = ID_MASTER_UPDATE;
|
||||||
|
orderChannel = CHANNEL_MASTER;
|
||||||
|
}
|
||||||
|
|
||||||
|
void PacketMasterUpdate::Packet(RakNet::BitStream *bs, bool send)
|
||||||
|
{
|
||||||
|
this->bs = bs;
|
||||||
|
if (send)
|
||||||
|
bs->Write(packetID);
|
||||||
|
|
||||||
|
RW(server->first, send);
|
||||||
|
|
||||||
|
ProxyMasterPacket::addServer(this, server->second, send);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void PacketMasterUpdate::SetServer(std::pair<RakNet::SystemAddress, Server> *serverPair)
|
||||||
|
{
|
||||||
|
server = serverPair;
|
||||||
|
}
|
28
components/openmw-mp/Master/PacketMasterUpdate.hpp
Normal file
28
components/openmw-mp/Master/PacketMasterUpdate.hpp
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
//
|
||||||
|
// Created by koncord on 22.04.17.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef OPENMW_PACKETMASTERUPDATE_HPP
|
||||||
|
#define OPENMW_PACKETMASTERUPDATE_HPP
|
||||||
|
|
||||||
|
#include "../Packets/BasePacket.hpp"
|
||||||
|
#include "MasterData.hpp"
|
||||||
|
|
||||||
|
namespace mwmp
|
||||||
|
{
|
||||||
|
class ProxyMasterPacket;
|
||||||
|
class PacketMasterUpdate : public BasePacket
|
||||||
|
{
|
||||||
|
friend class ProxyMasterPacket;
|
||||||
|
public:
|
||||||
|
PacketMasterUpdate(RakNet::RakPeerInterface *peer);
|
||||||
|
|
||||||
|
virtual void Packet(RakNet::BitStream *bs, bool send);
|
||||||
|
|
||||||
|
void SetServer(std::pair<RakNet::SystemAddress, Server> *serverPair);
|
||||||
|
private:
|
||||||
|
std::pair<RakNet::SystemAddress, Server> *server;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //OPENMW_PACKETMASTERUPDATE_HPP
|
107
components/openmw-mp/Master/ProxyMasterPacket.hpp
Normal file
107
components/openmw-mp/Master/ProxyMasterPacket.hpp
Normal file
|
@ -0,0 +1,107 @@
|
||||||
|
//
|
||||||
|
// Created by koncord on 22.04.17.
|
||||||
|
//
|
||||||
|
|
||||||
|
#ifndef OPENMW_PROXYMASTERPACKET_HPP
|
||||||
|
#define OPENMW_PROXYMASTERPACKET_HPP
|
||||||
|
|
||||||
|
#include <components/openmw-mp/Packets/BasePacket.hpp>
|
||||||
|
#include "MasterData.hpp"
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
namespace mwmp
|
||||||
|
{
|
||||||
|
class ProxyMasterPacket : public BasePacket
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
ProxyMasterPacket(RakNet::RakPeerInterface *peer) : BasePacket(peer)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public:
|
||||||
|
template<class Packet>
|
||||||
|
static void addServer(Packet *packet, Server &server, bool send)
|
||||||
|
{
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
int rulesSize = server.rules.size();
|
||||||
|
|
||||||
|
packet->RW(rulesSize, send);
|
||||||
|
|
||||||
|
map<string, ServerRule>::iterator ruleIt;
|
||||||
|
if (send)
|
||||||
|
ruleIt = server.rules.begin();
|
||||||
|
|
||||||
|
while (rulesSize--)
|
||||||
|
{
|
||||||
|
ServerRule *rule = 0;
|
||||||
|
string key;
|
||||||
|
if (send)
|
||||||
|
{
|
||||||
|
key = ruleIt->first;
|
||||||
|
rule = &ruleIt->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
packet->RW(key, send);
|
||||||
|
if (!send)
|
||||||
|
{
|
||||||
|
ruleIt = server.rules.insert(pair<string, ServerRule>(key, ServerRule())).first;
|
||||||
|
rule = &ruleIt->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
packet->RW(rule->type, send);
|
||||||
|
|
||||||
|
if (rule->type == 's')
|
||||||
|
packet->RW(rule->str, send);
|
||||||
|
else
|
||||||
|
packet->RW(rule->val, send);
|
||||||
|
|
||||||
|
if (send)
|
||||||
|
ruleIt++;
|
||||||
|
}
|
||||||
|
|
||||||
|
list<string>::iterator plIt;
|
||||||
|
|
||||||
|
if (send)
|
||||||
|
plIt = server.players.begin();
|
||||||
|
else
|
||||||
|
server.players.clear();
|
||||||
|
|
||||||
|
int playersCount = server.GetPlayers();
|
||||||
|
while (playersCount--)
|
||||||
|
{
|
||||||
|
string player;
|
||||||
|
if (send)
|
||||||
|
player = *plIt;
|
||||||
|
|
||||||
|
packet->RW(player, send);
|
||||||
|
|
||||||
|
if (!send)
|
||||||
|
server.players.push_back(player);
|
||||||
|
}
|
||||||
|
|
||||||
|
int pluginsCount = server.plugins.size();
|
||||||
|
packet->RW(pluginsCount, send);
|
||||||
|
|
||||||
|
vector<Plugin>::iterator pluginIt;
|
||||||
|
|
||||||
|
if (send)
|
||||||
|
pluginIt = server.plugins.begin();
|
||||||
|
else
|
||||||
|
server.plugins.clear();
|
||||||
|
|
||||||
|
while (pluginsCount--)
|
||||||
|
{
|
||||||
|
Plugin plugin;
|
||||||
|
if (send)
|
||||||
|
plugin = *pluginIt;
|
||||||
|
|
||||||
|
packet->RW(plugin.name, send);
|
||||||
|
packet->RW(plugin.hash, send);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif //OPENMW_PROXYMASTERPACKET_HPP
|
Loading…
Reference in a new issue