engine: update server info reply

This commit is contained in:
nillerusr 2023-01-30 22:16:48 +03:00
parent 64f7bf9f96
commit a08b6ae7bf
4 changed files with 95 additions and 32 deletions

View File

@ -16,9 +16,14 @@
#include "master.h" #include "master.h"
#include "proto_oob.h" #include "proto_oob.h"
#include "host.h" #include "host.h"
#include "eiface.h"
#include "server.h"
extern ConVar sv_tags;
extern ConVar sv_lan; extern ConVar sv_lan;
#define S2A_EXTRA_DATA_HAS_GAMETAG_DATA 0x01 // Next bytes are the game tag string
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
// Purpose: List of master servers and some state info about them // Purpose: List of master servers and some state info about them
//----------------------------------------------------------------------------- //-----------------------------------------------------------------------------
@ -65,6 +70,8 @@ public:
void RunFrame(); void RunFrame();
void RequestServersInfo(); void RequestServersInfo();
void ReplyInfo( const netadr_t &adr );
newgameserver_t &ProcessInfo( bf_read &buf );
// SeversInfo // SeversInfo
void RequestInternetServerList( const char *gamedir, IServerListResponse *response ); void RequestInternetServerList( const char *gamedir, IServerListResponse *response );
@ -116,6 +123,79 @@ void CMaster::RunFrame()
CheckHeartbeat(); CheckHeartbeat();
} }
void CMaster::ReplyInfo( const netadr_t &adr )
{
static char gamedir[MAX_OSPATH];
Q_FileBase( com_gamedir, gamedir, sizeof( gamedir ) );
CUtlBuffer buf;
buf.EnsureCapacity( 2048 );
buf.PutUnsignedInt( LittleDWord( CONNECTIONLESS_HEADER ) );
buf.PutUnsignedChar( S2C_INFOREPLY );
buf.PutUnsignedChar( PROTOCOL_VERSION ); // Hardcoded protocol version number
buf.PutString( sv.GetName() );
buf.PutString( sv.GetMapName() );
buf.PutString( gamedir );
buf.PutString( serverGameDLL->GetGameDescription() );
// player info
buf.PutUnsignedChar( sv.GetNumClients() );
buf.PutUnsignedChar( sv.GetMaxClients() );
buf.PutUnsignedChar( sv.GetNumFakeClients() );
// Password?
buf.PutUnsignedChar( sv.GetPassword() != NULL ? 1 : 0 );
// Write a byte with some flags that describe what is to follow.
const char *pchTags = sv_tags.GetString();
int nFlags = 0;
if ( pchTags && pchTags[0] != '\0' )
nFlags |= S2A_EXTRA_DATA_HAS_GAMETAG_DATA;
buf.PutUnsignedInt( nFlags );
if ( nFlags & S2A_EXTRA_DATA_HAS_GAMETAG_DATA )
{
buf.PutString( pchTags );
}
NET_SendPacket( NULL, NS_SERVER, adr, (unsigned char *)buf.Base(), buf.TellPut() );
}
newgameserver_t &CMaster::ProcessInfo(bf_read &buf)
{
static newgameserver_t s;
memset( &s, 0, sizeof(s) );
s.m_nProtocolVersion = buf.ReadByte();
buf.ReadString( s.m_szServerName, sizeof(s.m_szServerName) );
buf.ReadString( s.m_szMap, sizeof(s.m_szMap) );
buf.ReadString( s.m_szGameDir, sizeof(s.m_szGameDir) );
buf.ReadString( s.m_szGameDescription, sizeof(s.m_szGameDescription) );
// player info
s.m_nPlayers = buf.ReadByte();
s.m_nMaxPlayers = buf.ReadByte();
s.m_nBotPlayers = buf.ReadByte();
// Password?
s.m_bPassword = buf.ReadByte();
s.m_iFlags = buf.ReadLong();
if( s.m_iFlags & S2A_EXTRA_DATA_HAS_GAMETAG_DATA )
{
buf.ReadString( s.m_szGameTags, sizeof(s.m_szGameTags) );
}
return s;
}
void CMaster::ProcessConnectionlessPacket( netpacket_t *packet ) void CMaster::ProcessConnectionlessPacket( netpacket_t *packet )
{ {
static ALIGN4 char string[2048] ALIGN4_POST; // Buffer for sending heartbeat static ALIGN4 char string[2048] ALIGN4_POST; // Buffer for sending heartbeat
@ -158,27 +238,24 @@ void CMaster::ProcessConnectionlessPacket( netpacket_t *packet )
} }
case C2S_INFOREQUEST: case C2S_INFOREQUEST:
{ {
bf_write p(string, sizeof(string)); ReplyInfo(packet->from);
p.WriteLong(CONNECTIONLESS_HEADER);
p.WriteByte(S2C_INFOREPLY);
p.WriteString(sv.GetName());
NET_SendPacket(NULL, NS_SERVER, packet->from, p.GetData(), p.GetNumBytesWritten());
break; break;
} }
case S2C_INFOREPLY: case S2C_INFOREPLY:
{ {
char hostname[1024]; newgameserver_t &s = ProcessInfo( msg );
msg.ReadString(hostname, sizeof(hostname)); Msg("hostname = %s\nplayers: %d/%d\nbots: %d\n", s.m_szServerName, s.m_nPlayers, s.m_nMaxPlayers, s.m_nBotPlayers);
newgameserver_t s;
s.m_NetAdr = packet->from; s.m_NetAdr = packet->from;
s.SetName( hostname );
m_serverListResponse->ServerResponded( s ); m_serverListResponse->ServerResponded( s );
break; break;
} }
case A2A_PING:
{
const char p = A2A_ACK;
NET_SendPacket( NULL, NS_SERVER, packet->from, (unsigned char*)&p, 1);
break;
}
} }
} }

View File

@ -25,25 +25,23 @@ class newgameserver_t
public: public:
newgameserver_t() = default; newgameserver_t() = default;
const char* GetName() const { return m_szServerName; }
void SetName( const char *pName )
{
strncpy( m_szServerName, pName, sizeof(m_szServerName) );
}
netadr_t m_NetAdr; ///< IP/Query Port/Connection Port for this server netadr_t m_NetAdr; ///< IP/Query Port/Connection Port for this server
int m_nPing; ///< current ping time in milliseconds int m_nPing; ///< current ping time in milliseconds
int m_nProtocolVersion;
bool m_bHadSuccessfulResponse; ///< server has responded successfully in the past bool m_bHadSuccessfulResponse; ///< server has responded successfully in the past
bool m_bDoNotRefresh; ///< server is marked as not responding and should no longer be refreshed bool m_bDoNotRefresh; ///< server is marked as not responding and should no longer be refreshed
char m_szGameDir[MAX_PATH]; ///< current game directory char m_szGameDir[MAX_PATH]; ///< current game directory
char m_szMap[MAX_PATH]; ///< current map char m_szMap[MAX_PATH]; ///< current map
char m_szGameTags[MAX_PATH];
char m_szGameDescription[MAX_GAME_DESCRIPTION]; ///< game description char m_szGameDescription[MAX_GAME_DESCRIPTION]; ///< game description
int m_nPlayers; int m_nPlayers;
int m_nMaxPlayers; ///< Maximum players that can join this server int m_nMaxPlayers; ///< Maximum players that can join this server
int m_nBotPlayers; ///< Number of bots (i.e simulated players) on this server int m_nBotPlayers; ///< Number of bots (i.e simulated players) on this server
bool m_bPassword; ///< true if this server needs a password to join bool m_bPassword; ///< true if this server needs a password to join
private:
int m_iFlags;
/// Game server name /// Game server name
char m_szServerName[MAX_SERVER_NAME]; char m_szServerName[MAX_SERVER_NAME];
}; };

View File

@ -2203,8 +2203,6 @@ const char *CBaseGamesPage::GetConnectCode()
void CBaseGamesPage::ServerResponded( newgameserver_t &server ) void CBaseGamesPage::ServerResponded( newgameserver_t &server )
{ {
Msg("Serverbrowser: hostname %s\n", server.GetName());
Assert( server.m_NetAdr.GetIPHostByteOrder() != 0 ); Assert( server.m_NetAdr.GetIPHostByteOrder() != 0 );
newgameserver_t *pServerItem = &server; newgameserver_t *pServerItem = &server;
@ -2232,7 +2230,7 @@ void CBaseGamesPage::ServerResponded( newgameserver_t &server )
// new entry // new entry
KeyValues *kv = new KeyValues("Server"); KeyValues *kv = new KeyValues("Server");
kv->SetString("name", pServerItem->GetName()); kv->SetString("name", pServerItem->m_szServerName);
kv->SetString("map", pServerItem->m_szMap); kv->SetString("map", pServerItem->m_szMap);
kv->SetString("GameDir", pServerItem->m_szGameDir); kv->SetString("GameDir", pServerItem->m_szGameDir);
kv->SetString("GameDesc", pServerItem->m_szGameDescription); kv->SetString("GameDesc", pServerItem->m_szGameDescription);
@ -2278,15 +2276,6 @@ void CBaseGamesPage::ServerResponded( newgameserver_t &server )
} }
}*/ }*/
// if ( pServer->m_bDoNotRefresh )
{
// clear out the vars
kv->SetString("Ping", "");
kv->SetWString("GameDesc", g_pVGuiLocalize->Find("#ServerBrowser_NotResponding"));
kv->SetString("Players", "");
kv->SetString("map", "");
}
int iServerIndex = m_serversInfo.AddToTail( server ); int iServerIndex = m_serversInfo.AddToTail( server );
//if ( !m_pGameList->IsValidItemID( pServer->m_iListID ) ) //if ( !m_pGameList->IsValidItemID( pServer->m_iListID ) )

View File

@ -127,7 +127,6 @@ void CInternetGames::OnTick()
void CInternetGames::ServerResponded( newgameserver_t &server ) void CInternetGames::ServerResponded( newgameserver_t &server )
{ {
m_bDirty = true; m_bDirty = true;
Msg("InternetGames::ServerResponded hostname = %s\n", server.GetName());
BaseClass::ServerResponded( server ); BaseClass::ServerResponded( server );
m_bAnyServersRespondedToQuery = true; m_bAnyServersRespondedToQuery = true;