Talk:Server queries
SteamAppID
@Megaoerti: The change with the bot count and the unknown value can't be correct :/
Yes you're right, but i worry about the SteamAppID set as a 2 byte value 'F000'. This isn't zero?!
- F0 is in decimal 240, which stands for CS: Source (see Steam Application IDs) --King2500 14:53, 15 Aug 2005 (PDT)
- ok ... i forgot the sweet little endian of these two bytes *g* --MEGAOerti 13:17, 16 Aug 2005 (PDT)
Protocol
Source seems to handle multiple packet replies differently. It also sends the 0xFFFFFFFE header followed by the request id. But then the next byte contains the total number of packets, the one after the current packet number. Also Source does not seem to start all "actual" replies with 0xFFFFFFFF (only contained the first packet).
Is this completely right or did I miss something? If it is it will have to be updated in the main page.
--Philip 08:41, 4 Sep 2006 (PDT)
SteamAppID Again
Either I'm being blind and stupid, or do Goldsource a2s_info replies not include an AppID... I think I should point out that I may be both blind and stupid, but I'm just not seeing it
| LINE | Hex | ||||||||
| 0000 | FF | FF | FF | FF | 6D | 31 | 39 | 34 | ....m194 | 
| 0008 | 2E | 31 | 34 | 30 | 2E | 32 | 34 | 32 | .140.242 | 
| 0010 | 2E | 32 | 3A | 32 | 37 | 30 | 32 | 35 | .2:27025 | 
| 0018 | 00 | 32 | 5E | 48 | 41 | 42 | 20 | 43 | .2^HAB C | 
| 0020 | 6C | 61 | 6E | 20 | 53 | 65 | 72 | 76 | lan Serv | 
| 0028 | 65 | 72 | 3A | 3A | 77 | 77 | 77 | 2E | er::www. | 
| 0030 | 32 | 68 | 61 | 62 | 2D | 70 | 72 | 6F | 2hab-pro | 
| 0038 | 67 | 61 | 6D | 65 | 72 | 73 | 2E | 63 | gamers.c | 
| 0040 | 6F | 2E | 6E | 72 | 3A | 3A | 00 | 63 | o.nr::.c | 
| 0048 | 73 | 5F | 6F | 66 | 66 | 69 | 63 | 65 | s_office | 
| 0050 | 00 | 63 | 73 | 74 | 72 | 69 | 6B | 65 | .cstrike | 
| 0058 | 00 | 43 | 6F | 75 | 6E | 74 | 65 | 72 | .Counter | 
| 0060 | 2D | 53 | 74 | 72 | 69 | 6B | 65 | 00 | -Strike. | 
| 0068 | 01 | 0B | 2F | 64 | 6C | 00 | 01 | 77 | ../dl..w | 
| 0070 | 77 | 77 | 2E | 63 | 6F | 75 | 6E | 74 | ww.count | 
| 0078 | 65 | 72 | 2D | 73 | 74 | 72 | 69 | 6B | er-strik | 
| 0080 | 65 | 2E | 6E | 65 | 74 | 00 | 00 | 00 | e.net... | 
| 0088 | 01 | 00 | 00 | 00 | 00 | 9E | F7 | 0A | ........ | 
| 0090 | 00 | 01 | 01 | 00 | .... | 
--Luthias 09:05, 13 Nov 2006 (PST)
- You're right. GoldSrc server replies doesn't include an AppID. --King2500 17:32, 11 Jan 2007 (PST)
Counter-strike server reply format
I couldn't find anything about CS1.6 servers, AFAIK this is their reply format for A2S_INFO. There is more after this but I dont know what it is.
| Data | Type | Comment | 
|---|---|---|
| Type | byte | Should be equal to 'm' | 
| IP | string | The server's IP address and port | 
| Server Name | string | The server's name, eg: "Recoil NZ CS Server #1" | 
| Map | string | The current map being played, eg: "de_dust" | 
| Game Directory | string | The name of the folder containing the game files, ie: "cstrike" | 
| Game Description | string | A friendly string name for the game type, ie: "Counter-Strike" | 
| Number of players | byte | The number of players currently on the server | 
| Maximum players | byte | Maximum allowed players for the server | 
| ??? | byte | A '/' | 
| Dedicated | byte | 'l' for listen, 'd' for dedicated | 
| OS | byte | Host operating system. 'l' for Linux, 'w' for Windows | 
| Password | byte | If set to 0x01, a password is required to join this server | 
| Secure | byte | If set to 0x01, this server is VAC secured | 
| ??? | string | "www.counter-strike.net" | 
More information to add to this article
The French version of this article now has more information than this one (the english version). I have asked the person that is currently updating the French article if it were possible to add the same information to the English version. If anyone else has the time to do it as well, please step forth! Perhaps we need a new template to "tag" situations such as these... a template like {{TranslationUpdate}}, but for any language (specified when the template is used), rather than just for the English version. --Etset 14:23, 31 Jan 2008 (PST)
Bug on Rag Doll Kung Fu server reply
Sometime (actually once in two) a RDKF server will reply like this :
| FF FF FF FF 49 FC 55 00 53 00 45 00 52 00 20 00 ....I.U.S.E.R. . 32 00 27 00 73 00 20 00 64 00 6F 00 6A 00 6F 00 2.'.s. .d.o.j.o. 00 00 53 6F 63 63 65 72 00 52 44 4B 46 53 6F 63 ..Soccer.RDKFSoc 63 65 72 00 52 61 67 44 6F 6C 6C 4B 75 6E 67 46 cer.RagDollKungF 75 3A 20 53 6F 63 63 65 72 00 EA 03 01 04 00 00 u: Soccer....... 77 00 00 32 2E 33 2E 30 2E 30 00 w..2.3.0.0. | 
Everything is fine except the server name (in blue) : a NUL byte is inserted between each character. There is the same effect with the player names on the A2S_PLAYER query. What about? --Cortexd 17:55, 17 Feb 2008 (PST)
- I think these strings are in UTF-16 instead UTF-8 --Cortexd 19:49, 2 Mar 2008 (PST)
GoldSource RCON Protocol
Hi all,
This is probably an old topic - but is there any definitions for "GoldSource" aka "Classic" rcon packet requests/responses. Is this the correct place to start one ?
I am slowly working my way through the protocol so I may be able to contribute in some areas as well.
cheers will Beattie Wlbeattie 19:04, 6 Mar 2008 (PST)
Player connection time
Does anyone know what a player connection time of -1 (0x000080bf) stands for? Maybe someting like "is connecting"? --Koraktor 23:55, 7 Aug 2008 (PDT)
- Bots I think. --TomEdwards 09:26, 8 Aug 2008 (PDT)
A2S_SERVERQUERY_GETCHALLENGE not working since last HLDS update
GoldSrc servers do not respond to A2S_SERVERQUERY_GETCHALLENGE requests since the last HLDS update (GoldSrc protocol version 48). Does anyone know what has changed? Or is this a bug? --Koraktor 07:42, 2 Nov 2008 (PST)
Indeed, kept me busy for quite some time too, but got the solution with the help of some others:
I'm using the function below. If you look closely you discover that the 5th byte has changed to 55 instead of 57 and it's now followed by 4 times \xFF .... dunno how, why and so on, but it works!
function getQuery($queryType) {
	switch($queryType)
	{
		case "A2S_SERVERQUERY_GETCHALLENGE":
		return "\xFF\xFF\xFF\xFF\x55\xFF\xFF\xFF\xFF";
		break;
		case "A2S_INFO":
		return "\xFF\xFF\xFF\xFFTSource Engine Query\x00";
		break;
		case "A2S_PLAYER":
		return sprintf("\xFF\xFF\xFF\xFF\x55%s", $this->getChallenge());
		break;
		}
	}
Hope this works for you too :) —The preceding unsigned comment was added by Ouwe tosti (talk • contribs).
"Does anyone know what has changed? Or is this a bug?"
Current protocol 48 bugs:
- A2S_SERVERQUERY_GETCHALLENGE does not work at all, use A2S_PLAYER or A2S_RULES instead with ffffffffh (-1) as challenge.
- The map name from A2S_INFO is only updated when players are present.
- Hostname and bot flag from A2S_INFO are only updated when the map changes.
- Server rules from A2S_RULES, like amx_nextmap or mp_timeleft, are only updated when the map changes.
- mp_timelimit is off by a few minutes (only the value returned by A2S_RULES, rcon is ok though).
- bot count is now a bot flag, 1 means there were only bots during map change.
I'm not exactly sure which part of the query info gets updated when so take these bug descriptions with a grain of salt. Example, I join an empty server and the map name gets updated, but mp_timeleft is still wrong. I join a server with bots that also has a plugin that updates the server name with the time left, but only the map name gets updated via the query, not the hostname. (You can check the actual full-length hostname by typing status in console.)
--pizzahut 23:30, 2 Nov 2008 (PST)
- I can, and I think everyone else can, confirm the above things written by pizzahut. GoldSource servers switched to the Source protocol, which is absolutely fine, but the implementation is incorrect (for former GoldSource servers only). These bugs are now within there for over 2 months, Valve got notified of it by people whos word should have at least a little weight for that matter (e.g. the HLSW staff) long ago and it's their very own server browser that displays these data as wrong as they are reported by the server (of course), still nothing was fixed. I'm one of the many coders that work in some way with this data and are annoyed by it while threads over this in the Steam forums just died. So I vote for putting information about these problems to the main page, as it has been a steady situation for over 2 months now.
- These "unwanted features" have become part of the protocol in a way, everyone starting to work with it coming to this Wiki has to deal with them. Currently they will see the information how they could query the bot counter or current map and not everyone is suspecting such additional information in the comments page, so people will probably waste time over trying to find out the problem in their code that makes the bot counter or map be displayed wrong until they notice it isn't their fault.
- However, I am new to this Wiki (and to public Wikis in general), so I didn't want to do such a change myself straight away, maybe some people even consider that being rude or whatever. Of course I would be happy if that could also catch the attention of Valve but, to be honest, I doubt that. But at least let us save newcomers some time. Any comments on that from others?
- --xOR 19:55, 5 Jan 2009 (GMT+1)
Looks like all GoldSource servers are responding with the Source protocol format. You will have to use appids to tell source/goldsource servers apart (IE CS/CSS). --The MAZZTer 09:47, 9 Nov 2008 (PST)
A2S_SERVERQUERY_GETCHALLENGE seems to be ignored, because it is changed. It is now 0x55 instead of 0x57 (and Steam seems to send an extra Int32 0 after it, not sure what that is). --The MAZZTer 13:52, 10 Nov 2008 (PST)
- The A2S_SERVERQUERY_GETCHALLENGE hasn't "changed", it stopped working with the update. Steam apparently never used it. The header 0x55 belongs to a A2S_PLAYER request. The additional (long) 0 is an invalid challenge, therefore the server responds with a S2C_CHALLENGE containing a valid challenge. --Koraktor 10:06, 13 Nov 2008 (PST)
I put a warning on the main page about this, but it'd be really nice to know if this is a permanent change. Also, it'd be nice to know if this query will stop working in Source servers in the future. --BarkerJr 09:07, 26 Nov 2008 (PST)
Goldsource servers are still responding to the old challenge method. Just send the default header with "challenge rcon\n" after it. The server will send back a packet with the default header followed by: "challenge rcon (unsigned int)\n\0" where (unsigned int) is the challenge number.--Chris03 12:07, 30 Dec 2008 (GMT-5)
Made a new wiki page for this, Half-Life 1 Engine Bug Reports. --pizzahut 20:03, 20 January 2009 (UTC)
No longer works in Left4Dead, either -BarkerJr 03:35, 4 October 2009 (UTC) It seems A2S_PLAYER and A2S_RULES are broken, too.[1] -BarkerJr
Source: S2A_RULES doesn't return all rules
Since an update in the past weeks the S2A_RULES reply doesn't contain all rules. For a vanilla TF2 server example see below. As you can see the last rule (should be tf_gamemode_ctf) is cut off and there's no way to get the rest of the rules. The reply doesn't use split packets and when querying with an additional A2S_RULES (similar to GoldSrc RCON) I get the same response. Is this a (known) bug or did I miss something?
000000FC ff ff ff ff 45 50 00 6d 70 5f 74 65 61 6d 70 6c ....EP.m p_teampl 0000010C 61 79 00 30 00 6d 70 5f 66 72 61 67 6c 69 6d 69 ay.0.mp_ fraglimi 0000011C 74 00 30 00 6d 70 5f 66 61 6c 6c 64 61 6d 61 67 t.0.mp_f alldamag 0000012C 65 00 30 00 6d 70 5f 77 65 61 70 6f 6e 73 74 61 e.0.mp_w eaponsta 0000013C 79 00 30 00 6d 70 5f 66 6f 72 63 65 72 65 73 70 y.0.mp_f orceresp 0000014C 61 77 6e 00 31 00 6d 70 5f 66 6f 6f 74 73 74 65 awn.1.mp _footste 0000015C 70 73 00 31 00 6d 70 5f 66 6c 61 73 68 6c 69 67 ps.1.mp_ flashlig 0000016C 68 74 00 30 00 6d 70 5f 61 75 74 6f 63 72 6f 73 ht.0.mp_ autocros 0000017C 73 68 61 69 72 00 31 00 64 65 63 61 6c 66 72 65 shair.1. decalfre 0000018C 71 75 65 6e 63 79 00 31 30 00 6d 70 5f 74 65 61 quency.1 0.mp_tea 0000019C 6d 6c 69 73 74 00 68 67 72 75 6e 74 3b 73 63 69 mlist.hg runt;sci 000001AC 65 6e 74 69 73 74 00 6d 70 5f 61 6c 6c 6f 77 4e entist.m p_allowN 000001BC 50 43 73 00 31 00 6d 70 5f 66 72 69 65 6e 64 6c PCs.1.mp _friendl 000001CC 79 66 69 72 65 00 30 00 6d 70 5f 66 61 64 65 74 yfire.0. mp_fadet 000001DC 6f 62 6c 61 63 6b 00 30 00 73 76 5f 67 72 61 76 oblack.0 .sv_grav 000001EC 69 74 79 00 38 30 30 00 73 76 5f 73 74 6f 70 73 ity.800. sv_stops 000001FC 70 65 65 64 00 31 30 30 00 73 76 5f 6e 6f 63 6c peed.100 .sv_nocl 0000020C 69 70 61 63 63 65 6c 65 72 61 74 65 00 35 00 73 ipaccele rate.5.s 0000021C 76 5f 6e 6f 63 6c 69 70 73 70 65 65 64 00 35 00 v_noclip speed.5. [...] 00000998 6d 70 5f 64 69 73 61 62 6c 65 5f 72 65 73 70 61 mp_disab le_respa 000009A8 77 6e 5f 74 69 6d 65 73 00 30 00 6d 70 5f 61 75 wn_times .0.mp_au 000009B8 74 6f 74 65 61 6d 62 61 6c 61 6e 63 65 00 31 00 toteamba lance.1. 000009C8 6d 70 5f 73 74 61 6c 65 6d 61 74 65 5f 65 6e 61 mp_stale mate_ena 000009D8 62 6c 65 00 30 00 6d 70 5f 6d 61 74 63 68 5f 65 ble.0.mp _match_e 000009E8 6e 64 5f 61 74 5f 74 69 6d 65 6c 69 6d 69 74 00 nd_at_ti melimit. 000009F8 30 00 73 76 5f 61 6c 6c 74 61 6c 6b 00 30 00 74 0.sv_all talk.0.t 00000A08 66 5f 6d 61 78 73 70 65 65 64 00 34 30 30 00 74 f_maxspe ed.400.t 00000A18 66 5f 62 69 72 74 68 64 61 79 00 30 00 6d 70 5f f_birthd ay.0.mp_ 00000A28 74 6f 75 72 6e 61 6d 65 6e 74 5f 73 74 6f 70 77 tourname nt_stopw 00000A38 61 74 63 68 00 31 00 74 66 5f 61 72 65 6e 61 5f atch.1.t f_arena_ 00000A48 66 6f 72 63 65 5f 63 6c 61 73 73 00 30 00 74 66 force_cl ass.0.tf 00000A58 5f 61 72 65 6e 61 5f 63 68 61 6e 67 65 5f 6c 69 _arena_c hange_li 00000A68 6d 69 74 00 31 00 74 66 5f 61 72 65 6e 61 5f 6f mit.1.tf _arena_o 00000A78 76 65 72 72 69 64 65 5f 63 61 70 5f 65 6e 61 62 verride_ cap_enab 00000A88 6c 65 5f 74 69 6d 65 00 2d 31 00 74 66 5f 61 72 le_time. -1.tf_ar 00000A98 65 6e 61 5f 66 69 72 73 74 5f 62 6c 6f 6f 64 00 ena_firs t_blood. 00000AA8 31 00 74 66 5f 67 61 6d 65 6d 6f 64 65 5f 61 72 1.tf_gam emode_ar 00000AB8 65 6e 61 00 30 00 74 66 5f 67 61 6d 65 6d 6f 64 ena.0.tf _gamemod 00000AC8 65 5f 63 70 00 31 00 74 66 5f 67 61 e_cp.1.t f_ga
--Koraktor 10:36, 30 August 2009 (UTC)