Allow using --connect-now with wan server with server-id
This commit is contained in:
parent
07e681e927
commit
2c35b0f03c
@ -22,6 +22,7 @@
|
||||
#include "guiengine/widgets/model_view_widget.hpp"
|
||||
#include "graphics/irr_driver.hpp"
|
||||
#include "graphics/render_target.hpp"
|
||||
#include "modes/profile_world.hpp"
|
||||
|
||||
#include <IAnimatedMesh.h>
|
||||
#include <IAnimatedMeshSceneNode.h>
|
||||
@ -55,7 +56,7 @@ m_rtt_size(rtt_size)
|
||||
// so that the base class doesn't complain there is no icon defined
|
||||
m_properties[PROP_ICON]="gui/main_help.png";
|
||||
|
||||
m_rtt_unsupported = false;
|
||||
m_rtt_unsupported = ProfileWorld::isNoGraphics();
|
||||
} // ModelViewWidget
|
||||
|
||||
// -----------------------------------------------------------------------------
|
||||
|
87
src/main.cpp
87
src/main.cpp
@ -224,6 +224,7 @@
|
||||
#include "network/server_config.hpp"
|
||||
#include "network/servers_manager.hpp"
|
||||
#include "network/stk_host.hpp"
|
||||
#include "network/stk_peer.hpp"
|
||||
#include "online/profile_manager.hpp"
|
||||
#include "online/request_manager.hpp"
|
||||
#include "race/grand_prix_manager.hpp"
|
||||
@ -608,6 +609,7 @@ void cmdLineHelp()
|
||||
" --connect-now=ip Connect to a server with IP known now\n"
|
||||
" (in format x.x.x.x:xxx(port)), the port should be its\n"
|
||||
" public port.\n"
|
||||
" --server-id=n Server id in stk addons for --connect-now.\n"
|
||||
" --login=s Automatically log in (set the login).\n"
|
||||
" --password=s Automatically log in (set the password).\n"
|
||||
" --init-user Save the above login and password (if set) in config.\n"
|
||||
@ -1243,40 +1245,10 @@ int handleCmdLine(bool has_server_config, bool has_parent_process)
|
||||
{
|
||||
NetworkConfig::get()->setIsPublicServer();
|
||||
}
|
||||
if (CommandLine::has("--connect-now", &s))
|
||||
{
|
||||
TransportAddress server_addr(s);
|
||||
NetworkConfig::get()->setIsWAN();
|
||||
NetworkConfig::get()->setIsServer(false);
|
||||
auto server = std::make_shared<Server>(0, L"", 0, 0, 0, 0, server_addr,
|
||||
!server_password.empty(), false);
|
||||
NetworkConfig::get()->addNetworkPlayer(
|
||||
input_manager->getDeviceManager()->getLatestUsedDevice(),
|
||||
PlayerManager::getCurrentPlayer(), PLAYER_DIFFICULTY_NORMAL);
|
||||
NetworkConfig::get()->doneAddingNetworkPlayers();
|
||||
STKHost::create();
|
||||
auto cts = std::make_shared<ConnectToServer>(server);
|
||||
cts->setup();
|
||||
Log::info("main", "Trying to connect to server '%s'.",
|
||||
server_addr.toString().c_str());
|
||||
if (!cts->tryConnect(2000, 15))
|
||||
{
|
||||
Log::error("main", "Timeout trying to connect to server '%s'.",
|
||||
server_addr.toString().c_str());
|
||||
STKHost::get()->shutdown();
|
||||
exit(0);
|
||||
}
|
||||
else
|
||||
{
|
||||
auto cl = LobbyProtocol::create<ClientLobby>(server_addr, server);
|
||||
cl->requestStart();
|
||||
}
|
||||
}
|
||||
|
||||
if (NetworkConfig::get()->isServer())
|
||||
{
|
||||
const std::string& server_name = ServerConfig::m_server_name;
|
||||
if (ServerConfig::m_wan_server)
|
||||
unsigned server_id = 0;
|
||||
if ((NetworkConfig::get()->isServer() && ServerConfig::m_wan_server) ||
|
||||
CommandLine::has("--server-id", &server_id))
|
||||
{
|
||||
PlayerProfile* player = PlayerManager::getCurrentPlayer();
|
||||
// Try to use saved user token if exists
|
||||
@ -1293,9 +1265,54 @@ int handleCmdLine(bool has_server_config, bool has_parent_process)
|
||||
}
|
||||
else if (!can_wan)
|
||||
{
|
||||
Log::warn("main",
|
||||
"No saved online player session to create a wan server");
|
||||
Log::warn("main","No saved online player session to create "
|
||||
"or connect to a wan server.");
|
||||
}
|
||||
}
|
||||
|
||||
if (CommandLine::has("--connect-now", &s))
|
||||
{
|
||||
TransportAddress server_addr(s);
|
||||
NetworkConfig::get()->setIsWAN();
|
||||
NetworkConfig::get()->setIsServer(false);
|
||||
auto server = std::make_shared<Server>(0, L"", 0, 0, 0, 0, server_addr,
|
||||
!server_password.empty(), false);
|
||||
NetworkConfig::get()->addNetworkPlayer(
|
||||
input_manager->getDeviceManager()->getLatestUsedDevice(),
|
||||
PlayerManager::getCurrentPlayer(), PLAYER_DIFFICULTY_NORMAL);
|
||||
NetworkConfig::get()->doneAddingNetworkPlayers();
|
||||
STKHost::create();
|
||||
auto cts = std::make_shared<ConnectToServer>(server);
|
||||
cts->setup();
|
||||
if (server_id != 0)
|
||||
{
|
||||
server->setServerId(server_id);
|
||||
server->setSupportsEncryption(true);
|
||||
cts->registerWithSTKServer();
|
||||
}
|
||||
Log::info("main", "Trying to connect to server '%s'.",
|
||||
server_addr.toString().c_str());
|
||||
if (!cts->tryConnect(2000, 15))
|
||||
{
|
||||
Log::error("main", "Timeout trying to connect to server '%s'.",
|
||||
server_addr.toString().c_str());
|
||||
STKHost::get()->shutdown();
|
||||
exit(0);
|
||||
}
|
||||
else
|
||||
{
|
||||
server_addr =
|
||||
STKHost::get()->getServerPeerForClient()->getAddress();
|
||||
auto cl = LobbyProtocol::create<ClientLobby>(server_addr, server);
|
||||
cl->requestStart();
|
||||
}
|
||||
}
|
||||
|
||||
if (NetworkConfig::get()->isServer())
|
||||
{
|
||||
const std::string& server_name = ServerConfig::m_server_name;
|
||||
if (ServerConfig::m_wan_server)
|
||||
{
|
||||
if (can_wan)
|
||||
{
|
||||
// Server owner online account will keep online as long as
|
||||
|
@ -44,7 +44,6 @@ private:
|
||||
std::atomic<ConnectState> m_state;
|
||||
|
||||
void getClientServerInfo();
|
||||
void registerWithSTKServer();
|
||||
static TransportAddress m_server_address;
|
||||
static int interceptCallback(ENetHost* host, ENetEvent* event);
|
||||
static int m_retry_count;
|
||||
@ -56,6 +55,7 @@ public:
|
||||
virtual void setup() OVERRIDE;
|
||||
virtual void asynchronousUpdate() OVERRIDE;
|
||||
virtual void update(int ticks) OVERRIDE;
|
||||
void registerWithSTKServer();
|
||||
bool tryConnect(int timeout, int retry, bool another_port = false);
|
||||
|
||||
}; // class ConnectToServer
|
||||
|
Loading…
Reference in New Issue
Block a user