2017-01-11 14:04:53 +00:00
|
|
|
//
|
|
|
|
// Created by koncord on 07.01.17.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include <cassert>
|
|
|
|
#include <QtCore/QTime>
|
|
|
|
#include "NetController.hpp"
|
|
|
|
#include "qdebug.h"
|
|
|
|
|
|
|
|
#include <RakPeer.h>
|
|
|
|
#include <RakSleep.h>
|
|
|
|
|
|
|
|
#include <sstream>
|
|
|
|
|
|
|
|
#include <QJsonDocument>
|
|
|
|
#include <QJsonArray>
|
2017-01-22 09:11:13 +00:00
|
|
|
#include <QJsonObject>
|
2017-01-11 14:04:53 +00:00
|
|
|
#include <memory>
|
2017-01-11 15:00:46 +00:00
|
|
|
#include <QtWidgets/QMessageBox>
|
2017-01-11 14:04:53 +00:00
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
NetController *NetController::mThis = nullptr;
|
|
|
|
|
|
|
|
NetController *NetController::get()
|
|
|
|
{
|
|
|
|
assert(mThis);
|
|
|
|
return mThis;
|
|
|
|
}
|
|
|
|
|
2017-01-11 14:58:50 +00:00
|
|
|
void NetController::Create(std::string addr, unsigned short port)
|
2017-01-11 14:04:53 +00:00
|
|
|
{
|
|
|
|
assert(!mThis);
|
2017-01-11 14:58:50 +00:00
|
|
|
mThis = new NetController(addr, port);
|
2017-01-11 14:04:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void NetController::Destroy()
|
|
|
|
{
|
|
|
|
assert(mThis);
|
|
|
|
delete mThis;
|
|
|
|
mThis = nullptr;
|
|
|
|
}
|
|
|
|
|
2017-01-11 14:58:50 +00:00
|
|
|
NetController::NetController(std::string addr, unsigned short port) : httpNetwork(addr, port)
|
2017-01-11 14:04:53 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
NetController::~NetController()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
struct pattern
|
|
|
|
{
|
|
|
|
pattern(QString value): value(value) {}
|
|
|
|
bool operator()(const ServerData &data)
|
|
|
|
{
|
|
|
|
return value == data.addr;
|
|
|
|
}
|
|
|
|
QString value;
|
|
|
|
};
|
|
|
|
|
2017-01-22 09:11:13 +00:00
|
|
|
void NetController::setData(QString address, QJsonObject server, ServerModel *model)
|
|
|
|
{
|
|
|
|
QModelIndex mi = model->index(0, ServerData::ADDR);
|
|
|
|
model->setData(mi, address);
|
|
|
|
|
|
|
|
mi = model->index(0, ServerData::PLAYERS);
|
|
|
|
model->setData(mi, server["players"].toInt());
|
|
|
|
|
|
|
|
mi = model->index(0, ServerData::MAX_PLAYERS);
|
|
|
|
model->setData(mi, server["max_players"].toInt());
|
|
|
|
|
|
|
|
mi = model->index(0, ServerData::HOSTNAME);
|
|
|
|
model->setData(mi, server["hostname"].toString());
|
|
|
|
|
|
|
|
mi = model->index(0, ServerData::MODNAME);
|
|
|
|
model->setData(mi, server["modname"].toString());
|
|
|
|
|
|
|
|
mi = model->index(0, ServerData::PING);
|
|
|
|
|
|
|
|
QStringList addr = address.split(":");
|
|
|
|
model->setData(mi, PingRakNetServer(addr[0].toLatin1().data(), addr[1].toUShort()));
|
|
|
|
}
|
|
|
|
|
2017-01-11 15:00:46 +00:00
|
|
|
bool NetController::downloadInfo(QAbstractItemModel *pModel, QModelIndex index)
|
2017-01-11 14:04:53 +00:00
|
|
|
{
|
|
|
|
ServerModel *model = ((ServerModel *) pModel);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* download stuff
|
|
|
|
*/
|
|
|
|
|
|
|
|
QString data;
|
2017-01-22 09:11:13 +00:00
|
|
|
QJsonParseError err;
|
|
|
|
|
|
|
|
if(index.isValid() && index.row() >= 0)
|
|
|
|
{
|
2017-01-22 10:02:12 +00:00
|
|
|
const ServerData &sd = model->myData[index.row()];
|
2017-01-22 09:11:13 +00:00
|
|
|
while(true)
|
|
|
|
{
|
|
|
|
data = QString::fromStdString(httpNetwork.getData((QString("/api/servers/") + sd.addr).toLatin1()));
|
|
|
|
if (!data.isEmpty() && data != "NO_CONTENT" && data != "LOST_CONNECTION")
|
|
|
|
break;
|
|
|
|
RakSleep(30);
|
|
|
|
}
|
|
|
|
qDebug() << "Content for \"" << sd.addr << "\": " << data;
|
|
|
|
|
2017-01-22 10:02:12 +00:00
|
|
|
if(data == "bad request" || data == "not found") // TODO: if server is not registered we should download info directly from the server
|
2017-01-22 09:11:13 +00:00
|
|
|
{
|
|
|
|
qDebug() << "Server is not registered";
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
QJsonDocument jsonDocument = QJsonDocument::fromJson(data.toLatin1(), &err);
|
|
|
|
QJsonObject server = jsonDocument.object()["server"].toObject();
|
|
|
|
|
|
|
|
setData(sd.addr, server, model);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2017-01-11 14:04:53 +00:00
|
|
|
while (true)
|
|
|
|
{
|
|
|
|
data = QString::fromStdString(httpNetwork.getData("/api/servers"));
|
|
|
|
if (!data.isEmpty() && data != "NO_CONTENT" && data != "LOST_CONNECTION")
|
|
|
|
break;
|
|
|
|
RakSleep(30);
|
|
|
|
}
|
|
|
|
|
2017-01-11 15:00:46 +00:00
|
|
|
if(data == "UNKNOWN_ADDRESS")
|
|
|
|
{
|
|
|
|
QMessageBox::critical(0, "Error", "Cannot connect to the master server!");
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-01-11 14:04:53 +00:00
|
|
|
qDebug() << "Content: " << data;
|
|
|
|
|
|
|
|
QJsonDocument jsonDocument = QJsonDocument::fromJson(data.toLatin1(), &err);
|
|
|
|
|
2017-01-22 09:11:13 +00:00
|
|
|
QJsonObject listServers = jsonDocument.object()["list servers"].toObject();
|
2017-01-11 14:04:53 +00:00
|
|
|
|
2017-01-22 09:11:13 +00:00
|
|
|
for(auto iter = listServers.begin(); iter != listServers.end(); iter++)
|
2017-01-11 14:04:53 +00:00
|
|
|
{
|
2017-01-22 09:11:13 +00:00
|
|
|
QJsonObject server = iter->toObject();
|
2017-01-11 14:04:53 +00:00
|
|
|
qDebug() << iter.key();
|
2017-01-22 09:11:13 +00:00
|
|
|
qDebug() << server["hostname"].toString();
|
|
|
|
qDebug() << server["modname"].toString();
|
|
|
|
qDebug() << server["players"].toInt();
|
|
|
|
qDebug() << server["max_players"].toInt();
|
2017-01-11 14:04:53 +00:00
|
|
|
|
|
|
|
QVector<ServerData>::Iterator value = std::find_if(model->myData.begin(), model->myData.end(), pattern(iter.key()));
|
|
|
|
if(value == model->myData.end())
|
|
|
|
model->insertRow(0);
|
|
|
|
|
2017-01-22 09:11:13 +00:00
|
|
|
setData(iter.key(), server, model);
|
2017-01-11 14:04:53 +00:00
|
|
|
}
|
|
|
|
|
2017-01-11 15:00:46 +00:00
|
|
|
return true;
|
2017-01-11 14:04:53 +00:00
|
|
|
}
|
|
|
|
|
2017-01-11 14:58:50 +00:00
|
|
|
bool NetController::updateInfo(QAbstractItemModel *pModel, QModelIndex index)
|
2017-01-11 14:04:53 +00:00
|
|
|
{
|
|
|
|
ServerModel *model = ((ServerModel*)pModel);
|
|
|
|
|
2017-01-11 14:58:50 +00:00
|
|
|
bool result;
|
2017-01-11 14:04:53 +00:00
|
|
|
if (index.isValid() && index.row() >= 0)
|
2017-01-11 14:58:50 +00:00
|
|
|
result = downloadInfo(pModel, index);
|
2017-01-11 14:04:53 +00:00
|
|
|
else
|
|
|
|
{
|
2017-01-22 09:16:55 +00:00
|
|
|
for (auto iter = model->myData.begin(); iter != model->myData.end(); iter++)
|
2017-01-11 14:04:53 +00:00
|
|
|
{
|
|
|
|
qDebug() << iter->addr;
|
|
|
|
}
|
|
|
|
model->removeRows(0, model->rowCount(index));
|
2017-01-11 15:00:46 +00:00
|
|
|
result = downloadInfo(pModel, index);
|
2017-01-11 14:04:53 +00:00
|
|
|
}
|
2017-01-11 15:00:46 +00:00
|
|
|
return result;
|
2017-01-11 14:04:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void NetController::updateInfo()
|
|
|
|
{
|
|
|
|
QString data;
|
|
|
|
QString uri = "/api/servers/" + sd->addr;
|
|
|
|
while (true)
|
|
|
|
{
|
|
|
|
data = QString::fromStdString(httpNetwork.getData(uri.toLatin1()));
|
|
|
|
if (!data.isEmpty() && data != "NO_CONTENT" && data != "LOST_CONNECTION")
|
|
|
|
break;
|
|
|
|
RakSleep(30);
|
|
|
|
}
|
|
|
|
|
2017-01-11 15:00:46 +00:00
|
|
|
if(data == "UNKNOWN_ADDRESS")
|
|
|
|
{
|
|
|
|
QMessageBox::critical(0, "Error", "Cannot connect to the master server!");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2017-01-11 14:04:53 +00:00
|
|
|
qDebug() << "Content: " << data;
|
|
|
|
|
|
|
|
QJsonParseError err;
|
|
|
|
QJsonDocument jsonDocument = QJsonDocument::fromJson(data.toLatin1(), &err);
|
|
|
|
|
|
|
|
QMap<QString, QVariant> map = jsonDocument.toVariant().toMap()["server"].toMap();
|
|
|
|
|
|
|
|
qDebug() << sd->addr;
|
|
|
|
qDebug() << map["hostname"].toString();
|
|
|
|
qDebug() << map["modname"].toString();
|
|
|
|
qDebug() << map["players"].toInt();
|
|
|
|
qDebug() << map["max_players"].toInt();
|
|
|
|
|
|
|
|
sd->hostName = map["hostname"].toString();
|
|
|
|
sd->modName = map["modname"].toString();
|
|
|
|
sd->players = map["players"].toInt();
|
|
|
|
sd->maxPlayers = map["max_players"].toInt();
|
|
|
|
|
|
|
|
QStringList addr = sd->addr.split(":");
|
|
|
|
sd->ping = PingRakNetServer(addr[0].toLatin1(), addr[1].toUShort());
|
2017-01-29 20:17:18 +00:00
|
|
|
if(sd->ping != PING_UNREACHABLE)
|
|
|
|
sed = getExtendedData(addr[0].toLatin1(), addr[1].toUShort());
|
|
|
|
else
|
|
|
|
qDebug() << "Server is unreachable";
|
2017-01-11 14:04:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
QStringList NetController::players()
|
|
|
|
{
|
|
|
|
QStringList listPlayers;
|
2017-01-22 09:16:55 +00:00
|
|
|
for(auto player = sed.players.begin(); player != sed.players.end(); player++)
|
2017-01-11 14:04:53 +00:00
|
|
|
listPlayers.push_back(player->c_str());
|
|
|
|
return listPlayers;
|
|
|
|
}
|
|
|
|
|
|
|
|
QStringList NetController::plugins()
|
|
|
|
{
|
|
|
|
QStringList listPlugins;
|
2017-01-22 09:16:55 +00:00
|
|
|
for(auto plugin = sed.plugins.begin(); plugin != sed.plugins.end(); plugin++)
|
2017-01-11 14:04:53 +00:00
|
|
|
listPlugins.push_back(plugin->c_str());
|
|
|
|
return listPlugins;
|
|
|
|
}
|
|
|
|
|
|
|
|
void NetController::selectServer(ServerData *pServerData)
|
|
|
|
{
|
|
|
|
sd = pServerData;
|
|
|
|
}
|
|
|
|
|
|
|
|
ServerData *NetController::selectedServer()
|
|
|
|
{
|
|
|
|
return sd;
|
|
|
|
}
|
|
|
|
|