NetPlayDialog: Display external IP/Port as seen by the traversal server when it's used.
This commit is contained in:
parent
d599620fdd
commit
c058c8e1a6
|
@ -29,6 +29,11 @@ TraversalHostId TraversalClient::GetHostID() const
|
||||||
return m_HostId;
|
return m_HostId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TraversalInetAddress TraversalClient::GetExternalAddress() const
|
||||||
|
{
|
||||||
|
return m_external_address;
|
||||||
|
}
|
||||||
|
|
||||||
TraversalClient::State TraversalClient::GetState() const
|
TraversalClient::State TraversalClient::GetState() const
|
||||||
{
|
{
|
||||||
return m_State;
|
return m_State;
|
||||||
|
@ -153,6 +158,7 @@ void TraversalClient::HandleServerPacket(TraversalPacket* packet)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
m_HostId = packet->helloFromServer.yourHostId;
|
m_HostId = packet->helloFromServer.yourHostId;
|
||||||
|
m_external_address = packet->helloFromServer.yourAddress;
|
||||||
m_State = State::Connected;
|
m_State = State::Connected;
|
||||||
if (m_Client)
|
if (m_Client)
|
||||||
m_Client->OnTraversalStateChanged();
|
m_Client->OnTraversalStateChanged();
|
||||||
|
|
|
@ -44,6 +44,7 @@ public:
|
||||||
~TraversalClient();
|
~TraversalClient();
|
||||||
|
|
||||||
TraversalHostId GetHostID() const;
|
TraversalHostId GetHostID() const;
|
||||||
|
TraversalInetAddress GetExternalAddress() const;
|
||||||
State GetState() const;
|
State GetState() const;
|
||||||
FailureReason GetFailureReason() const;
|
FailureReason GetFailureReason() const;
|
||||||
|
|
||||||
|
@ -77,6 +78,7 @@ private:
|
||||||
|
|
||||||
ENetHost* m_NetHost;
|
ENetHost* m_NetHost;
|
||||||
TraversalHostId m_HostId{};
|
TraversalHostId m_HostId{};
|
||||||
|
TraversalInetAddress m_external_address{};
|
||||||
State m_State{};
|
State m_State{};
|
||||||
FailureReason m_FailureReason{};
|
FailureReason m_FailureReason{};
|
||||||
TraversalRequestId m_ConnectRequestId = 0;
|
TraversalRequestId m_ConnectRequestId = 0;
|
||||||
|
|
|
@ -69,7 +69,7 @@ struct TraversalPacket
|
||||||
{
|
{
|
||||||
u8 ok;
|
u8 ok;
|
||||||
TraversalHostId yourHostId;
|
TraversalHostId yourHostId;
|
||||||
TraversalInetAddress yourAddress; // currently unused
|
TraversalInetAddress yourAddress;
|
||||||
} helloFromServer;
|
} helloFromServer;
|
||||||
struct
|
struct
|
||||||
{
|
{
|
||||||
|
|
|
@ -64,6 +64,31 @@
|
||||||
#include "VideoCommon/RenderBase.h"
|
#include "VideoCommon/RenderBase.h"
|
||||||
#include "VideoCommon/VideoConfig.h"
|
#include "VideoCommon/VideoConfig.h"
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
QString InetAddressToString(const TraversalInetAddress& addr)
|
||||||
|
{
|
||||||
|
QString ip;
|
||||||
|
|
||||||
|
if (addr.isIPV6)
|
||||||
|
{
|
||||||
|
ip = QStringLiteral("IPv6-Not-Implemented");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const auto ipv4 = reinterpret_cast<const u8*>(addr.address);
|
||||||
|
ip = QString::number(ipv4[0]);
|
||||||
|
for (u32 i = 1; i != 4; ++i)
|
||||||
|
{
|
||||||
|
ip += QStringLiteral(".");
|
||||||
|
ip += QString::number(ipv4[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return QStringLiteral("%1:%2").arg(ip, QString::number(ntohs(addr.port)));
|
||||||
|
}
|
||||||
|
} // namespace
|
||||||
|
|
||||||
NetPlayDialog::NetPlayDialog(const GameListModel& game_list_model,
|
NetPlayDialog::NetPlayDialog(const GameListModel& game_list_model,
|
||||||
StartGameCallback start_game_callback, QWidget* parent)
|
StartGameCallback start_game_callback, QWidget* parent)
|
||||||
: QDialog(parent), m_game_list_model(game_list_model),
|
: QDialog(parent), m_game_list_model(game_list_model),
|
||||||
|
@ -270,7 +295,7 @@ void NetPlayDialog::ConnectWidgets()
|
||||||
connect(m_room_box, qOverload<int>(&QComboBox::currentIndexChanged), this,
|
connect(m_room_box, qOverload<int>(&QComboBox::currentIndexChanged), this,
|
||||||
&NetPlayDialog::UpdateGUI);
|
&NetPlayDialog::UpdateGUI);
|
||||||
connect(m_hostcode_action_button, &QPushButton::clicked, [this] {
|
connect(m_hostcode_action_button, &QPushButton::clicked, [this] {
|
||||||
if (m_is_copy_button_retry && m_room_box->currentIndex() == 0)
|
if (m_is_copy_button_retry)
|
||||||
g_TraversalClient->ReconnectToServer();
|
g_TraversalClient->ReconnectToServer();
|
||||||
else
|
else
|
||||||
QApplication::clipboard()->setText(m_hostcode_label->text());
|
QApplication::clipboard()->setText(m_hostcode_label->text());
|
||||||
|
@ -622,20 +647,48 @@ void NetPlayDialog::UpdateGUI()
|
||||||
m_players_list->selectRow(i);
|
m_players_list->selectRow(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Update Room ID / IP label
|
if (m_old_player_count != m_player_count)
|
||||||
if (m_use_traversal && m_room_box->currentIndex() == 0)
|
{
|
||||||
|
UpdateDiscordPresence();
|
||||||
|
m_old_player_count = m_player_count;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!server)
|
||||||
|
return;
|
||||||
|
|
||||||
|
const bool is_local_ip_selected = m_room_box->currentIndex() > (m_use_traversal ? 1 : 0);
|
||||||
|
if (is_local_ip_selected)
|
||||||
|
{
|
||||||
|
m_hostcode_label->setText(QString::fromStdString(
|
||||||
|
server->GetInterfaceHost(m_room_box->currentData().toString().toStdString())));
|
||||||
|
m_hostcode_action_button->setEnabled(true);
|
||||||
|
m_hostcode_action_button->setText(tr("Copy"));
|
||||||
|
m_is_copy_button_retry = false;
|
||||||
|
}
|
||||||
|
else if (m_use_traversal)
|
||||||
{
|
{
|
||||||
switch (g_TraversalClient->GetState())
|
switch (g_TraversalClient->GetState())
|
||||||
{
|
{
|
||||||
case TraversalClient::State::Connecting:
|
case TraversalClient::State::Connecting:
|
||||||
m_hostcode_label->setText(tr("..."));
|
m_hostcode_label->setText(tr("Connecting"));
|
||||||
m_hostcode_action_button->setEnabled(false);
|
m_hostcode_action_button->setEnabled(false);
|
||||||
|
m_hostcode_action_button->setText(tr("..."));
|
||||||
break;
|
break;
|
||||||
case TraversalClient::State::Connected:
|
case TraversalClient::State::Connected:
|
||||||
{
|
{
|
||||||
const auto host_id = g_TraversalClient->GetHostID();
|
if (m_room_box->currentIndex() == 0)
|
||||||
m_hostcode_label->setText(
|
{
|
||||||
QString::fromStdString(std::string(host_id.begin(), host_id.end())));
|
// Display Room ID.
|
||||||
|
const auto host_id = g_TraversalClient->GetHostID();
|
||||||
|
m_hostcode_label->setText(
|
||||||
|
QString::fromStdString(std::string(host_id.begin(), host_id.end())));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Externally mapped IP and port are known when using the traversal server.
|
||||||
|
m_hostcode_label->setText(InetAddressToString(g_TraversalClient->GetExternalAddress()));
|
||||||
|
}
|
||||||
|
|
||||||
m_hostcode_action_button->setEnabled(true);
|
m_hostcode_action_button->setEnabled(true);
|
||||||
m_hostcode_action_button->setText(tr("Copy"));
|
m_hostcode_action_button->setText(tr("Copy"));
|
||||||
m_is_copy_button_retry = false;
|
m_is_copy_button_retry = false;
|
||||||
|
@ -649,39 +702,25 @@ void NetPlayDialog::UpdateGUI()
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (server)
|
else
|
||||||
{
|
{
|
||||||
if (m_room_box->currentIndex() == (m_use_traversal ? 1 : 0))
|
// Display External IP.
|
||||||
|
if (!m_external_ip_address->empty())
|
||||||
{
|
{
|
||||||
if (!m_external_ip_address->empty())
|
const int port = Settings::Instance().GetNetPlayServer()->GetPort();
|
||||||
{
|
m_hostcode_label->setText(QStringLiteral("%1:%2").arg(
|
||||||
const int port = Settings::Instance().GetNetPlayServer()->GetPort();
|
QString::fromStdString(*m_external_ip_address), QString::number(port)));
|
||||||
m_hostcode_label->setText(QStringLiteral("%1:%2").arg(
|
m_hostcode_action_button->setEnabled(true);
|
||||||
QString::fromStdString(*m_external_ip_address), QString::number(port)));
|
|
||||||
m_hostcode_action_button->setEnabled(true);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_hostcode_label->setText(tr("Unknown"));
|
|
||||||
m_hostcode_action_button->setEnabled(false);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_hostcode_label->setText(QString::fromStdString(
|
m_hostcode_label->setText(tr("Unknown"));
|
||||||
server->GetInterfaceHost(m_room_box->currentData().toString().toStdString())));
|
m_hostcode_action_button->setEnabled(false);
|
||||||
m_hostcode_action_button->setEnabled(true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
m_hostcode_action_button->setText(tr("Copy"));
|
m_hostcode_action_button->setText(tr("Copy"));
|
||||||
m_is_copy_button_retry = false;
|
m_is_copy_button_retry = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_old_player_count != m_player_count)
|
|
||||||
{
|
|
||||||
UpdateDiscordPresence();
|
|
||||||
m_old_player_count = m_player_count;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// NetPlayUI methods
|
// NetPlayUI methods
|
||||||
|
|
Loading…
Reference in New Issue