You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2400 lines
74 KiB
2400 lines
74 KiB
5 years ago
|
//====== Copyright 1996-2010, Valve Corporation, All rights reserved. =======
|
||
|
//
|
||
|
// Purpose: The file defines our Google Protocol Buffers which are used in over
|
||
|
// the wire messages between servers as well as between the TF GC and TF gameservers
|
||
|
// and clients.
|
||
|
//
|
||
|
//=============================================================================
|
||
|
|
||
|
// We care more about speed than code size
|
||
|
option optimize_for = SPEED;
|
||
|
|
||
|
// We don't use the service generation functionality
|
||
|
option cc_generic_services = false;
|
||
|
|
||
|
|
||
|
//
|
||
|
// STYLE NOTES:
|
||
|
//
|
||
|
// Use CamelCase CMsgMyMessageName style names for messages.
|
||
|
//
|
||
|
// Use lowercase _ delimited names like my_steam_id for field names, this is non-standard for Steam,
|
||
|
// but plays nice with the Google formatted code generation.
|
||
|
//
|
||
|
// Try not to use required fields ever. Only do so if you are really really sure you'll never want them removed.
|
||
|
// Optional should be preffered as it will make versioning easier and cleaner in the future if someone refactors
|
||
|
// your message and wants to remove or rename fields.
|
||
|
//
|
||
|
// Use fixed64 for JobId_t, GID_t, or SteamID. This is appropriate for any field that is normally
|
||
|
// going to be larger than 2^56. Otherwise use int64 for 64 bit values that are frequently smaller
|
||
|
// than 2^56 as it will safe space on the wire in those cases.
|
||
|
//
|
||
|
// Similar to fixed64, use fixed32 for RTime32 or other 32 bit values that are frequently larger than
|
||
|
// 2^28. It will safe space in those cases, otherwise use int32 which will safe space for smaller values.
|
||
|
// An exception to this rule for RTime32 is if the value will frequently be zero rather than set to an actual
|
||
|
// time.
|
||
|
//
|
||
|
// Note: to make something a key field, list it like so:
|
||
|
// optional uint32 account_id = 1 [ (key_field) = true ];
|
||
|
|
||
|
import "steammessages.proto";
|
||
|
import "base_gcmessages.proto";
|
||
|
|
||
|
enum ETFGCMsg
|
||
|
{
|
||
|
k_EMsgGCReportWarKill = 5001; //War kill tracking. No longer in use
|
||
|
|
||
|
k_EMsgGCVoteKickBanPlayer = 5018; // client => GC
|
||
|
k_EMsgGCVoteKickBanPlayerResult = 5019; // game server => GC
|
||
|
|
||
|
k_EMsgGCKickPlayer_DEPRECATED = 5020; // GC => game server & client
|
||
|
|
||
|
k_EMsgGCStartedTraining_DEPRECATED = 5021; // client => GC
|
||
|
|
||
|
k_EMsgGCFreeTrial_ChooseMostHelpfulFriend = 5022; // client => GC
|
||
|
|
||
|
k_EMsgGCRequestTF2Friends = 5023; // client => GC
|
||
|
k_EMsgGCRequestTF2FriendsResponse = 5024; // GC => client
|
||
|
|
||
|
k_EMsgGCReplay_SubmitContestEntry = 5026; // client => GC
|
||
|
k_EMsgGCReplay_SubmitContestEntryResponse = 5027; // client => GC
|
||
|
|
||
|
k_EMsgGCSaxxy_Awarded = 5029; // GC => client
|
||
|
|
||
|
k_EMsgGCFreeTrial_ThankedBySomeone = 5028; // GC => client
|
||
|
k_EMsgGCFreeTrial_ThankedSomeone = 5030; // GC => client
|
||
|
k_EMsgGCFreeTrial_ConvertedToPremium = 5031; // GC => client
|
||
|
|
||
|
k_EMsgGCMeetThePyroSilliness_BananaCraft_DEPRECATED = 5032; // GC => client (was part of the pre-Meet-the-Pyro silliness)
|
||
|
k_EMsgGCMVMARG_HighFiveSuccessResponse_DEPRECATED = 5033; // GC => client (was part of the pre-MVM silliness)
|
||
|
k_EMsgGCMVMARG_HighFiveOnClient_DEPRECATED = 5034; // client => GC (was part of the pre-MVM silliness)
|
||
|
|
||
|
// Coaching
|
||
|
k_EMsgGCCoaching_AddToCoaches = 5200; // client is requesting that they be added to a list of eligible coaches
|
||
|
k_EMsgGCCoaching_AddToCoachesResponse = 5201;
|
||
|
k_EMsgGCCoaching_RemoveFromCoaches = 5202; // client is requesting to be removed from list of eligible coaches
|
||
|
k_EMsgGCCoaching_RemoveFromCoachesResponse =5203; // sent by GC to client
|
||
|
k_EMsgGCCoaching_FindCoach = 5204; // sent by client to GC requesting a coach be found
|
||
|
k_EMsgGCCoaching_FindCoachResponse = 5205; // sent by GC to client looking for a coach
|
||
|
k_EMsgGCCoaching_AskCoach = 5206; // sent by GC to coach asking if they want to coach a student
|
||
|
k_EMsgGCCoaching_AskCoachResponse = 5207; // (coach) client's response to whether they want to coach the found student
|
||
|
k_EMsgGCCoaching_CoachJoinGame = 5208; // sent by GC to (coach) client to tell them to join the server
|
||
|
k_EMsgGCCoaching_CoachJoining = 5209; // sent by GC to game session to tell them who is going to coach whom
|
||
|
k_EMsgGCCoaching_CoachJoined = 5210; // sent by GC to game server letting them know a coach has joined
|
||
|
k_EMsgGCCoaching_LikeCurrentCoach = 5211; // sent by (student) client to GC to indicate that they like their coach
|
||
|
k_EMsgGCCoaching_RemoveCurrentCoach = 5212; // sent by (student) client to GC to indicate that they want to get rid of their coach, and eventually to game server
|
||
|
k_EMsgGCCoaching_AlreadyRatedCoach = 5213; // sent by GC to (student) client
|
||
|
|
||
|
// mini-games:
|
||
|
// duel
|
||
|
k_EMsgGC_Duel_Request = 5500; // GC => target (all clients?)
|
||
|
k_EMsgGC_Duel_Response = 5501; // challenged client => GC and GC => all clients
|
||
|
k_EMsgGC_Duel_Results = 5502; // gameserver => GC
|
||
|
k_EMsgGC_Duel_Status = 5503; // GC => client
|
||
|
|
||
|
// halloween (deprecated GCMsg types)
|
||
|
k_EMsgGC_Halloween_ReservedItem_DEPRECATED = 5600; // GC => clients
|
||
|
k_EMsgGC_Halloween_GrantItem_DEPRECATED = 5601; // client(s) => GC
|
||
|
k_EMsgGC_Halloween_GrantItemResponse_DEPRECATED = 5604; // GC => client(s)
|
||
|
k_EMsgGC_Halloween_Cheat_QueryResponse_DEPRECATED = 5605; // clients => GC
|
||
|
k_EMsgGC_Halloween_ItemClaimed_DEPRECATED = 5606; // GC => clients
|
||
|
|
||
|
// Halloween (new CProtoBufMsg types)
|
||
|
k_EMsgGC_Halloween_ReservedItem = 5607; // GC => clients
|
||
|
k_EMsgGC_Halloween_GrantItem = 5608; // client(s) => GC
|
||
|
k_EMsgGC_Halloween_GrantItemResponse = 5609; // GC => client(s)
|
||
|
k_EMsgGC_Halloween_Cheat_QueryResponse_DEPRECATED_2 = 5610; // clients => GC
|
||
|
k_EMsgGC_Halloween_ItemClaimed_DEPRECATED_2 = 5611; // GC => clients
|
||
|
k_EMsgGC_Halloween_ServerBossEvent = 5612; // server => GC
|
||
|
k_EMsgGC_Halloween_Merasmus2012 = 5613; // server => GC
|
||
|
k_EMsgGC_Halloween_UpdateMerasmusLootLevel = 5614; // Client => GC
|
||
|
|
||
|
// Game Server stuff
|
||
|
k_EMsgGC_GameServer_LevelInfo = 5700; // game server => GC
|
||
|
k_EMsgGC_GameServer_AuthChallenge = 5701; // GC => game server
|
||
|
k_EMsgGC_GameServer_AuthChallengeResponse = 5702; // game server => GC
|
||
|
k_EMsgGC_GameServer_CreateIdentity = 5703; // client => GC
|
||
|
k_EMsgGC_GameServer_CreateIdentityResponse =5704; // GC => client
|
||
|
k_EMsgGC_GameServer_List = 5705; // client => GC
|
||
|
k_EMsgGC_GameServer_ListResponse = 5706; // GC => client
|
||
|
k_EMsgGC_GameServer_AuthResult = 5707; // GC => client
|
||
|
k_EMsgGC_GameServer_ResetIdentity = 5708; // GC => client
|
||
|
k_EMsgGC_GameServer_ResetIdentityResponse = 5709; // GC => client
|
||
|
|
||
|
// Game-server-modifying client items
|
||
|
k_EMsgGC_Client_UseServerModificationItem = 5710; // client => GC
|
||
|
k_EMsgGC_Client_UseServerModificationItem_Response = 5711; // GC => client
|
||
|
k_EMsgGC_GameServer_UseServerModificationItem = 5712; // GC => game server
|
||
|
k_EMsgGC_GameServer_UseServerModificationItem_Response = 5713; // game server => GC
|
||
|
k_EMsgGC_GameServer_ServerModificationItemExpired = 5714; // game server => GC
|
||
|
k_EMsgGC_GameServer_ModificationItemState = 5715; // GC => game server
|
||
|
|
||
|
k_EMsgGC_GameServer_AckPolicy = 5716; // client => GC
|
||
|
k_EMsgGC_GameServer_AckPolicyResponse = 5717; // GC => client
|
||
|
|
||
|
// Quickplay
|
||
|
k_EMsgGC_QP_ScoreServers = 5800; // client => GC
|
||
|
k_EMsgGC_QP_ScoreServersResponse = 5801; // client => GC
|
||
|
k_EMsgGC_QP_PlayerJoining = 5802; // GC => server
|
||
|
|
||
|
// Cheat challenge (deperecated GCMsg types)
|
||
|
k_EMsgGC_PickupItemEligibility_Query_DEPRECATED = 6000; // GC => clients
|
||
|
|
||
|
// Cheat challenge (new CProtoBufMsg types)
|
||
|
k_EMsgGC_PickupItemEligibility_Query_DEPRECATED_2 = 6001; // GC => clients
|
||
|
|
||
|
// Leveling Weapons
|
||
|
k_EMsgGC_IncrementKillCountAttribute_DEPRECATED = 6100; // client => GC (a player killed) (deprecated: moved to econ)
|
||
|
k_EMsgGC_IncrementKillCountResponse_DEPRECATED = 6101; // GC => client (deprecated: moved to econ)
|
||
|
|
||
|
//
|
||
|
// Coop matchmaking
|
||
|
//
|
||
|
//k_EMsgGCGameMatchSignOut= 6204;
|
||
|
//k_EMsgGCGameMatchSignOutResponse = 6205;
|
||
|
//k_EMsgGCJoinChatChannel = 6209;
|
||
|
//k_EMsgGCJoinChatChannelResponse = 6210;
|
||
|
//k_EMsgGCLeaveChatChannel = 6211;
|
||
|
//k_EMsgGCChatMessage = 6212;
|
||
|
//k_EMsgGCOtherJoinedChannel = 6213;
|
||
|
//k_EMsgGCOtherLeftChannel = 6214;
|
||
|
k_EMsgGCCreateOrUpdateParty = 6233; // sent from party leader to GC to create party, and/or start/stop the search
|
||
|
//k_EMsgGCConnectedPlayers = 6234;
|
||
|
k_EMsgGCAbandonCurrentGame = 6235;
|
||
|
//k_EMsgGCStopFindingMatch = 6236;
|
||
|
k_EMsgForceSOCacheResend = 6237;
|
||
|
k_EMsgGCRequestChatChannelList = 6260;
|
||
|
k_EMsgGCRequestChatChannelListResponse = 6261;
|
||
|
k_EMsgGCReadyUp = 6270; // sent to acknowledge lobby readiness
|
||
|
k_EMsgGCKickedFromMatchmakingQueue = 6271; // player has been removed from the matchmaking queue (for not readying up)
|
||
|
k_EMsgGCLeaverDetected = 6272; // sent from server to GC when a player has been AFK/disconnected too long
|
||
|
k_EMsgGCLeaverDetectedResponse = 6287;
|
||
|
// Removed
|
||
|
// k_EMsgGCPlayerFailedToConnect = 6288; // Response message added later as 6520 below
|
||
|
k_EMsgGCExitMatchmaking = 6289;
|
||
|
//k_EMsgGCAdjustMatchSearchCriteria = 6290;
|
||
|
k_EMsgGCAcceptInvite = 6291;
|
||
|
k_EMsgGCAcceptInviteResponse = 6292;
|
||
|
k_EMsgGCMatchmakingProgress = 6293;
|
||
|
k_EMsgGCMvMVictoryInfo = 6294;
|
||
|
k_EMsgGCGameServerMatchmakingStatus = 6295;
|
||
|
k_EMsgGCCreateOrUpdatePartyReply = 6296; // GC -> client, to acknowledge party change request
|
||
|
|
||
|
k_EMsgGCMvMVictory = 6297; // game server -> GC, report MvM Victory
|
||
|
k_EMsgGCMvMVictoryReply = 6298; // GC -> game server, acknowledge of recieving MvM Victory
|
||
|
k_EMsgGCGameServerKickingLobby = 6299; // Game server is finished running match, please destroy lobby.
|
||
|
// Reply message added later as 6521
|
||
|
k_EMsgGCLeaveGameAndPrepareToJoinParty = 6300; // GC -> client. Disconnect from the server and go to the lobby UI; I'm putting you in a party
|
||
|
// Deprecated, see PlayerAbandonedMatch
|
||
|
// k_EMsgGCRemovePlayerFromLobby = 6301; // Game server wants this player removed from the lobby.
|
||
|
// Response added later as 6514 below
|
||
|
// Deprecated
|
||
|
// k_EMsgGCSetLobbySafeToLeave = 6302; // Game server indicates that all players in the lobby are safe to leave
|
||
|
k_EMsgGC_UpdatePeriodicEvent = 6400; // game server => GC
|
||
|
|
||
|
k_EMsgGC_DuckLeaderboard_IndividualUpdate = 6401; // Client -> GC
|
||
|
|
||
|
k_EMsgGC_Client2GCEconPreviewDataBlockRequest = 6402;
|
||
|
k_EMsgGC_Client2GCEconPreviewDataBlockResponse = 6403;
|
||
|
|
||
|
k_EMsgGC_ClientVerificationChallenge = 6500; // GC -> client
|
||
|
k_EMsgGC_ClientVerificationChallengeResponse = 6501; // client -> GC
|
||
|
k_EMsgGC_ClientVerificationVerboseResponse = 6502; // client -> GC
|
||
|
|
||
|
k_EMsgGC_ClientSetItemSlotAttribute = 6503; // client -> GC
|
||
|
// k_EMsgGC_PlayerSkillRating_Adjustment = 6504; // game server -> GC
|
||
|
|
||
|
k_EMsgGC_War_IndividualUpdate = 6505; // game server -> GC
|
||
|
k_EMsgGC_War_JoinWar = 6506; // client -> GC
|
||
|
k_EMsgGC_War_RequestGlobalStats = 6507; // client -> GC
|
||
|
k_EMsgGC_War_GlobalStatsResponse = 6508; // GC -> client
|
||
|
|
||
|
k_EMsgGC_WorldItemPlacement_Attribute = 6510; //
|
||
|
k_EMsgGC_WorldItemPlacement_Update = 6511; // client -> GC
|
||
|
|
||
|
k_EMsgGC_Match_Result = 6512; // game server -> GC. Response message added later as 6520 below
|
||
|
|
||
|
k_EMsgGCVoteKickPlayerRequest = 6513; // game server -> GC
|
||
|
k_EMsgGCVoteKickPlayerRequestResponse = 6514; // GC -> game server
|
||
|
|
||
|
k_EMsgGC_DailyCompetitiveStatsRollup = 6516; // game server -> GC
|
||
|
k_EMsgGC_DailyCompetitiveStatsRollup_Response = 6517; // GC -> game server
|
||
|
|
||
|
k_EMsgGC_WorldStatusBroadcast = 6518; // GC -> client
|
||
|
k_EMsgGC_ReportPlayer = 6519; // client -> GC
|
||
|
|
||
|
k_EMsgGC_Match_ResultResponse = 6520; // GC -> game server. Response message for 6512 above
|
||
|
k_EMsgGCGameServerKickingLobbyResponse = 6521; // GC -> game server. Response message for 6299 above
|
||
|
k_EMsgGCPlayerLeftMatch = 6522; // game server -> GC, a player left this match
|
||
|
k_EMsgGCPlayerLeftMatchResponse = 6523; // GC -> game server. Response message for above
|
||
|
|
||
|
k_EMsgGCRequestMatchMakerStats = 6524; // Client -> GC. Request for the below message
|
||
|
k_EMsgGCMatchMakerStatsResponse = 6525; // GC -> Client. Response to above message
|
||
|
|
||
|
k_EMsgGCMatchHistoryLoad = 6526; // Client -> GC.
|
||
|
|
||
|
k_EMsgGC_AcknowledgeXP = 6527; // Client -> GC. Acknowledge pending XP
|
||
|
k_EMsgGCDataCenterPing_Update = 6528; // client -> GC.
|
||
|
|
||
|
k_EMsgGC_NotificationAcknowledge = 6529; // Client -> GC. Acknowledge notifications
|
||
|
k_EMsgGC_NotificationAcknowledgeReply = 6530; // GC -> Client. Let client know if we've received the acknowledgement
|
||
|
|
||
|
k_EMsgGC_KickPlayerFromLobby = 6531; // GC -> game server. Tell the server to kick a player
|
||
|
|
||
|
// Rematch is deprecated by NewMatchForLobby stuff
|
||
|
// k_EMsgGC_RematchRequest = 6532; // game server -> GC. Request a rematch
|
||
|
// k_EMsgGC_RematchRequestResponse = 6533; // GC -> game server
|
||
|
|
||
|
k_EMsgGC_SurveyQuestionRequest = 6534; // GC -> Client. Ask the client to fill out a survey
|
||
|
k_EMsgGC_SurveyQuestionResponse = 6535; // Client -> GC. Client response to the request
|
||
|
|
||
|
k_EMsgGC_TFClientInit = 6536; // Client -> GC. Clients send this in response to
|
||
|
// ClientWelcome with initial data such as language and
|
||
|
// version.
|
||
|
|
||
|
k_EMsgGC_NewMatchForLobbyRequest = 6537; // Game server -> GC.
|
||
|
k_EMsgGC_NewMatchForLobbyResponse = 6538; // GC -> Game server
|
||
|
|
||
|
k_EMsgGC_ChangeMatchPlayerTeamsRequest = 6539; // Game server -> GC.
|
||
|
k_EMsgGC_ChangeMatchPlayerTeamsResponse = 6540; // GC -> Game server
|
||
|
|
||
|
k_EMsgGCPlayerVoteKickedAfterLeavingMatch = 6551; // game server -> GC, a player was votekicked after they left a match
|
||
|
k_EMsgGCPlayerVoteKickedAfterLeavingMatchResponse = 6552; // GC -> game server. Response message for above
|
||
|
|
||
|
|
||
|
// Development only messages
|
||
|
k_EMsgGCDev_GrantWarKill = 10001; //War kill tracking. No longer in use
|
||
|
};
|
||
|
|
||
|
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCTFGoldenWrenchBroadcast
|
||
|
//
|
||
|
message CMsgTFGoldenWrenchBroadcast
|
||
|
{
|
||
|
optional int32 wrench_number = 1; // number of the deleted wrench
|
||
|
optional bool deleted = 2; // true if the wrench was deleted
|
||
|
optional string user_name = 3; // name of the user who deleted the wrench
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCTFSaxxyBroadcast
|
||
|
//
|
||
|
message CMsgTFSaxxyBroadcast
|
||
|
{
|
||
|
optional int32 category_number = 1; // number of the deleted wrench
|
||
|
optional string user_name = 2; // name of the user who deleted the wrench
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCTFSpecificItemBroadcast
|
||
|
//
|
||
|
message CMsgGCTFSpecificItemBroadcast
|
||
|
{
|
||
|
optional uint32 item_def_index = 1;
|
||
|
optional bool was_destruction = 2; // true if this item was destroyed, false if a new one was created
|
||
|
optional string user_name = 3; // name of the user who deleted the wrench
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_WorldStatusBroadcast
|
||
|
//
|
||
|
// This is the global heartbeat the GC sends to clients periodically. It should only contain live data that clients need
|
||
|
// to always be aware of, such as used on the global menu or to control global client state.
|
||
|
//
|
||
|
// I am obliged to mention, due to a certain email thread, that once TF is making better use of its WebAPI, this would
|
||
|
// be better served as a GetWorldStatus call clients can scrape, to take full advantage of caching and so on.
|
||
|
// Fletcher bloviated on this fact.
|
||
|
//
|
||
|
// !! Consider updating ITFGlobalStatus::GetWorldStatus when you change this
|
||
|
message CMsgTFWorldStatus
|
||
|
{
|
||
|
optional bool beta_stress_test_event_active = 1 [ default = false ];
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// CTFDuelSummary
|
||
|
//
|
||
|
message CSOTFDuelSummary
|
||
|
{
|
||
|
optional uint32 account_id = 1 [ (key_field) = true ];
|
||
|
optional uint32 duel_wins = 2;
|
||
|
optional uint32 duel_losses = 3;
|
||
|
optional uint32 last_duel_account_id = 4;
|
||
|
optional uint32 last_duel_timestamp = 5;
|
||
|
optional uint32 last_duel_status = 6;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CTFMapContribution
|
||
|
//
|
||
|
message CSOTFMapContribution
|
||
|
{
|
||
|
optional uint32 account_id = 1 [ (key_field) = true ];
|
||
|
optional uint32 def_index = 2 [ (key_field) = true ];
|
||
|
optional uint32 contribution_level = 3;
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// CMsgTFVoteKickBanPlayer
|
||
|
//
|
||
|
message CMsgTFVoteKickBanPlayer
|
||
|
{
|
||
|
optional uint32 account_id_subject = 1;
|
||
|
optional uint32 kick_reason = 2;
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// CMsgTFVoteKickBanPlayerResult
|
||
|
//
|
||
|
message CMsgTFVoteKickBanPlayerResult
|
||
|
{
|
||
|
optional uint32 account_id_initiator = 1;
|
||
|
optional uint32 account_id_subject = 2;
|
||
|
optional uint32 kick_reason = 3;
|
||
|
optional bool kick_successful = 4;
|
||
|
optional uint32 num_yes_votes = 5;
|
||
|
optional uint32 num_no_votes = 6;
|
||
|
optional uint32 num_possible_votes = 7;
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// CMsgTFFreeTrialChooseMostHelpfulFriend
|
||
|
//
|
||
|
message CMsgTFFreeTrialChooseMostHelpfulFriend
|
||
|
{
|
||
|
optional uint32 account_id_friend = 1;
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// CMsgTFRequestTF2Friends
|
||
|
//
|
||
|
message CMsgTFRequestTF2Friends
|
||
|
{
|
||
|
repeated uint32 account_ids = 1;
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// CMsgTFRequestTF2FriendsResponse
|
||
|
//
|
||
|
message CMsgTFRequestTF2FriendsResponse
|
||
|
{
|
||
|
repeated uint32 account_ids = 1;
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// CSOTFPlayerInfo
|
||
|
//
|
||
|
message CSOTFPlayerInfo
|
||
|
{
|
||
|
optional uint32 num_new_users_helped = 1;
|
||
|
// optional bool trial_account = 2 [ default = false ]; // DEPRECATED
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCFreeTrial_ThankedBySomeone
|
||
|
//
|
||
|
message CMsgTFThankedBySomeone
|
||
|
{
|
||
|
optional uint64 thanker_steam_id = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCFreeTrial_ThankedSomeone
|
||
|
//
|
||
|
message CMsgTFThankedSomeone
|
||
|
{
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCFreeTrial_ConvertedToPremium
|
||
|
//
|
||
|
message CMsgTFFreeTrialConvertedToPremium
|
||
|
{
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCSaxxy_Awarded
|
||
|
message CMsgSaxxyAwarded
|
||
|
{
|
||
|
optional uint32 category = 1;
|
||
|
repeated string winner_names = 2;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CMsgReplaySubmitContestEntry
|
||
|
//
|
||
|
message CMsgReplaySubmitContestEntry
|
||
|
{
|
||
|
optional string youtube_url = 1;
|
||
|
optional uint32 category = 2;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CMsgReplaySubmitContestEntryResponse
|
||
|
//
|
||
|
message CMsgReplaySubmitContestEntryResponse
|
||
|
{
|
||
|
optional bool success = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CReplayCachedContestData
|
||
|
// Tom Bui: stored in memcached by account id
|
||
|
//
|
||
|
message CReplayCachedContestData
|
||
|
{
|
||
|
optional fixed32 timestamp = 1;
|
||
|
optional uint32 num_votes_last_day = 2;
|
||
|
repeated uint32 video_entry_ids = 3;
|
||
|
optional uint32 num_flags_last_day = 4;
|
||
|
};
|
||
|
|
||
|
//=============================================================================
|
||
|
// Coaching
|
||
|
|
||
|
// k_EMsgGCCoaching_AddToCoaches
|
||
|
message CMsgTFCoaching_AddToCoaches
|
||
|
{
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_RemoveFromCoaches
|
||
|
message CMsgTFCoaching_RemoveFromCoaches
|
||
|
{
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_FindCoach
|
||
|
message CMsgTFCoaching_FindCoach
|
||
|
{
|
||
|
optional uint32 account_id_friend_as_coach = 1;
|
||
|
// @todo fill with criteria to match coach?
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_FindCoachResponse
|
||
|
message CMsgTFCoaching_FindCoachResponse
|
||
|
{
|
||
|
optional bool found_coach = 1;
|
||
|
optional uint32 num_likes = 2;
|
||
|
optional string coach_name = 3;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_AskCoach
|
||
|
message CMsgTFCoaching_AskCoach
|
||
|
{
|
||
|
optional uint32 account_id_student = 1;
|
||
|
optional bool student_is_friend = 2;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_AskCoachResponse
|
||
|
message CMsgTFCoaching_AskCoachResponse
|
||
|
{
|
||
|
optional bool accept_coaching_assignment = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_CoachJoinGame
|
||
|
message CMsgTFCoaching_CoachJoinGame
|
||
|
{
|
||
|
optional bool join_game = 1;
|
||
|
optional uint32 server_address = 2;
|
||
|
optional uint32 server_port = 3;
|
||
|
optional uint32 account_id_student = 4;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_CoachJoining
|
||
|
message CMsgTFCoaching_CoachJoining
|
||
|
{
|
||
|
optional uint32 account_id_coach = 1;
|
||
|
optional uint32 account_id_student = 2;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_CoachJoined
|
||
|
message CMsgTFCoaching_CoachJoined
|
||
|
{
|
||
|
optional uint32 account_id_coach = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_LikeCurrentCoach
|
||
|
message CMsgTFCoaching_LikeCurrentCoach
|
||
|
{
|
||
|
optional bool like_coach = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGCCoaching_RemoveCurrentCoach
|
||
|
message CMsgTFCoaching_RemoveCurrentCoach
|
||
|
{
|
||
|
optional uint32 account_id_coach = 1;
|
||
|
};
|
||
|
|
||
|
// End Coaching
|
||
|
//=============================================================================
|
||
|
|
||
|
//=============================================================================
|
||
|
// Quickplay
|
||
|
|
||
|
// k_EMsgGC_QP_ScoreServers
|
||
|
message CMsgTFQuickplay_ScoreServers
|
||
|
{
|
||
|
message ServerInfo
|
||
|
{
|
||
|
optional uint32 server_address = 1;
|
||
|
optional uint32 server_port = 2;
|
||
|
optional uint32 num_users = 3; // number of users the server is reporting to us
|
||
|
optional uint64 steam_id = 4;
|
||
|
optional uint32 max_users = 5; // max number of users the server reported
|
||
|
optional float user_score = 6; // what the client scored the server based on ping, preferences, etc
|
||
|
};
|
||
|
repeated ServerInfo servers = 1; // a list of servers
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_QP_ScoreServersResponse
|
||
|
message CMsgTFQuickplay_ScoreServersResponse
|
||
|
{
|
||
|
message ServerInfo
|
||
|
{
|
||
|
optional uint32 server_address = 1;
|
||
|
optional uint32 server_port = 2;
|
||
|
optional float total_score = 3;
|
||
|
optional uint64 steam_id = 4;
|
||
|
optional uint32 options_score = 5;
|
||
|
};
|
||
|
repeated ServerInfo servers = 1; // list of servers
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_QP_PlayerJoining
|
||
|
message CMsgTFQuickplay_PlayerJoining
|
||
|
{
|
||
|
optional uint32 account_id = 1;
|
||
|
};
|
||
|
|
||
|
// End Quickplay
|
||
|
//=============================================================================
|
||
|
|
||
|
|
||
|
//=============================================================================
|
||
|
// GameServer Auth
|
||
|
|
||
|
// k_EMsgGC_GameServer_LevelInfo
|
||
|
message CMsgGC_GameServer_LevelInfo
|
||
|
{
|
||
|
optional bool level_loaded = 1;
|
||
|
optional string level_name = 2;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_AuthChallenge
|
||
|
message CMsgGC_GameServer_AuthChallenge
|
||
|
{
|
||
|
// challenge string to be md5 hashed
|
||
|
optional string challenge_string = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_AuthResult
|
||
|
message CMsgGC_GameServer_AuthResult
|
||
|
{
|
||
|
optional bool authenticated = 1;
|
||
|
optional int32 game_server_standing = 2;
|
||
|
optional int32 game_server_standing_trend = 3;
|
||
|
optional bool is_valve_server = 4;
|
||
|
optional string message = 5; // error message to explain failure or success.
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_AuthChallengeResponse
|
||
|
message CMsgGC_GameServer_AuthChallengeResponse
|
||
|
{
|
||
|
optional uint32 game_server_account_id = 1;
|
||
|
optional bytes hashed_challenge_string = 2;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_CreateIdentity
|
||
|
message CMsgGC_GameServer_CreateIdentity
|
||
|
{
|
||
|
optional uint32 account_id = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_CreateIdentityResponse
|
||
|
message CMsgGC_GameServer_CreateIdentityResponse
|
||
|
{
|
||
|
optional bool account_created = 1;
|
||
|
optional uint32 game_server_account_id = 2;
|
||
|
optional string game_server_identity_token = 3;
|
||
|
enum EStatus
|
||
|
{
|
||
|
kStatus_GenericFailure = 0;
|
||
|
kStatus_TooMany = -1;
|
||
|
kStatus_NoPrivs = -2;
|
||
|
|
||
|
kStatus_Created = 1;
|
||
|
};
|
||
|
optional EStatus status = 4;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_List
|
||
|
message CMsgGC_GameServer_List
|
||
|
{
|
||
|
optional uint32 account_id = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_ListResponse
|
||
|
message CMsgGC_GameServer_ListResponse
|
||
|
{
|
||
|
message GameServerIdentity
|
||
|
{
|
||
|
optional uint32 game_server_account_id = 1;
|
||
|
optional string game_server_identity_token = 2;
|
||
|
optional int32 game_server_standing = 3;
|
||
|
optional int32 game_server_standing_trend = 4;
|
||
|
};
|
||
|
repeated GameServerIdentity owned_game_servers = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_ResetIdentity
|
||
|
message CMsgGC_GameServer_ResetIdentity
|
||
|
{
|
||
|
optional uint32 game_server_account_id = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_ResetIdentityResponse
|
||
|
message CMsgGC_GameServer_ResetIdentityResponse
|
||
|
{
|
||
|
optional bool game_server_identity_token_reset = 1;
|
||
|
optional uint32 game_server_account_id = 2;
|
||
|
optional string game_server_identity_token = 3;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_AckPolicy
|
||
|
message CMsgGC_GameServer_AckPolicy
|
||
|
{
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_AckPolicyResponse
|
||
|
message CMsgGC_GameServer_AckPolicyResponse
|
||
|
{
|
||
|
optional uint32 result = 1;
|
||
|
optional string message = 2;
|
||
|
};
|
||
|
|
||
|
|
||
|
// GameServer Auth
|
||
|
//=============================================================================
|
||
|
|
||
|
// k_EMsgGC_Client_UseServerModificationItem
|
||
|
message CMsgGC_Client_UseServerModificationItem
|
||
|
{
|
||
|
optional uint64 item_id = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_Client_UseServerModificationItem_Response
|
||
|
message CMsgGC_Client_UseServerModificationItem_Response
|
||
|
{
|
||
|
enum EServerModificationItemResponse
|
||
|
{
|
||
|
kServerModificationItemResponse_AlreadyInUse = 1;
|
||
|
kServerModificationItemResponse_NotOnAuthenticatedServer = 2;
|
||
|
kServerModificationItemResponse_ServerReject = 3;
|
||
|
kServerModificationItemResponse_InternalError = 4;
|
||
|
kServerModificationItemResponse_EventAlreadyActive = 5;
|
||
|
};
|
||
|
|
||
|
optional EServerModificationItemResponse response_code = 1;
|
||
|
};
|
||
|
|
||
|
enum EServerModificationItemType
|
||
|
{
|
||
|
kGameServerModificationItem_Halloween = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_UseServerModificationItem
|
||
|
message CMsgGC_GameServer_UseServerModificationItem
|
||
|
{
|
||
|
optional EServerModificationItemType modification_type = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_UseServerModificationItem_Response
|
||
|
message CMsgGC_GameServer_UseServerModificationItem_Response
|
||
|
{
|
||
|
enum EServerModificationItemServerResponse
|
||
|
{
|
||
|
kServerModificationItemServerResponse_Accepted = 1;
|
||
|
kServerModificationItemServerResponse_NoVoteCalled = 2;
|
||
|
kServerModificationItemServerResponse_VoteFailed = 3;
|
||
|
};
|
||
|
|
||
|
optional EServerModificationItemType modification_type = 1;
|
||
|
optional EServerModificationItemServerResponse server_response_code = 2;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_ServerModificationItemExpired
|
||
|
message CMsgGC_GameServer_ServerModificationItemExpired
|
||
|
{
|
||
|
optional EServerModificationItemType modification_type = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_GameServer_ModificationItemState
|
||
|
message CMsgGC_GameServer_ServerModificationItem
|
||
|
{
|
||
|
optional EServerModificationItemType modification_type = 1;
|
||
|
optional bool active = 2;
|
||
|
};
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
// Halloween
|
||
|
//=============================================================================
|
||
|
|
||
|
// k_EMsgGC_Halloween_ReserveItem
|
||
|
message CMsgGC_Halloween_ReservedItem
|
||
|
{
|
||
|
// position in the world where the item will spawn
|
||
|
repeated float x = 1;
|
||
|
repeated float y = 2;
|
||
|
repeated float z = 3;
|
||
|
|
||
|
// what type of package is this? where did it spawn? etc.
|
||
|
optional uint32 spawn_meta_info = 7;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_Halloween_GrantItem
|
||
|
message CMsgGC_Halloween_GrantItem
|
||
|
{
|
||
|
optional uint32 recipient_account_id = 1;
|
||
|
optional uint32 level_id = 2;
|
||
|
optional bool flagged = 3; // This is ambiguously named on purpose. It means flagged as a cheater (noclipper). Used for logging cheaters in the backend.
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_Halloween_GrantItemResponse
|
||
|
message CMsgGC_Halloween_GrantItemResponse
|
||
|
{
|
||
|
optional uint32 recipient_account_id = 1;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_Halloween_ItemClaimed
|
||
|
message CMsgGC_Halloween_ItemClaimed
|
||
|
{
|
||
|
};
|
||
|
|
||
|
|
||
|
// PVS
|
||
|
//=============================================================================
|
||
|
|
||
|
// k_EMsgGC_PickupItemEligibility_Query
|
||
|
message CMsgGC_PickupItemEligibility_Query
|
||
|
{
|
||
|
optional uint32 account_id = 1;
|
||
|
optional uint32 seconds_ago = 2; // positive, how many seconds ago was the item claimed
|
||
|
};
|
||
|
|
||
|
message CMsgGC_PickupItemEligibility_QueryResponse
|
||
|
{
|
||
|
optional uint32 account_id = 1;
|
||
|
optional bool was_eligible = 2;
|
||
|
optional uint32 level_id = 3; // we can't trust the level that the server reports as so we have clients vote
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CSOTFPartyMember
|
||
|
//
|
||
|
message CSOTFPartyMember
|
||
|
{
|
||
|
// optional fixed64 steamid = 1; // SteamID of player
|
||
|
optional bool owns_ticket = 2; // Do they have a ticket in their inventory?
|
||
|
optional uint32 completed_missions = 3; // Which missions have they completed (of the currently selected tour)
|
||
|
optional uint32 badge_level = 4; // Level of their badge
|
||
|
optional bool squad_surplus = 5; // Presenting voucher for the team to get "surplus"
|
||
|
|
||
|
// optional float latitude = 6; // approxmimate world location of this player
|
||
|
// optional float longitude = 7;
|
||
|
|
||
|
optional bool is_banned = 8 [ default = false ]; // mark the player as banned for abandoning MannUp mode
|
||
|
optional bool competitive_access = 9; // access to ranked ladder mode
|
||
|
|
||
|
// These two no longer shared with clients in favor of competitive_beta_access flag
|
||
|
// optional bool phone_verified = 10 [ default = false ]; // account is phone verified on Steam
|
||
|
// optional bool two_factor_enabled = 11 [ default = false ]; // two-factor auth
|
||
|
optional uint32 ladder_rank = 12;
|
||
|
optional bool is_low_priority = 13 [ default = false ];
|
||
|
optional uint32 experience = 14;
|
||
|
optional uint32 skillrating = 15 [ default = 10000 ];
|
||
|
};
|
||
|
|
||
|
enum TF_MatchmakingMode
|
||
|
{
|
||
|
TF_Matchmaking_INVALID = 0; // dummy sentinel value
|
||
|
TF_Matchmaking_MVM = 1;
|
||
|
TF_Matchmaking_LADDER = 2;
|
||
|
TF_Matchmaking_CASUAL = 3;
|
||
|
};
|
||
|
|
||
|
enum TF_Matchmaking_WizardStep
|
||
|
{
|
||
|
TF_Matchmaking_WizardStep_INVALID = 0;
|
||
|
TF_Matchmaking_WizardStep_MVM_PLAY_FOR_BRAGGING_RIGHTS = 1;
|
||
|
TF_Matchmaking_WizardStep_MVM_TOUR_OF_DUTY = 2;
|
||
|
TF_Matchmaking_WizardStep_MVM_CHALLENGE = 3;
|
||
|
TF_Matchmaking_WizardStep_SEARCHING = 4;
|
||
|
TF_Matchmaking_WizardStep_LADDER = 5;
|
||
|
TF_Matchmaking_WizardStep_CASUAL = 6;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Search criteria
|
||
|
//
|
||
|
message CMsgMatchSearchCriteria
|
||
|
{
|
||
|
optional TF_MatchmakingMode matchmaking_mode = 7;
|
||
|
optional bool late_join_ok = 5; // Is my party willing to join late?
|
||
|
optional uint32 custom_ping_tolerance = 13 [ default = 0 ]; // 0 == no custom tolerance
|
||
|
|
||
|
// MvM options
|
||
|
//LEGACY: optional string challenge = 4; // Requested pop file (empty string for "any")
|
||
|
optional string mvm_mannup_tour = 10; // Selected Mann Up tour. (Mann UP only)
|
||
|
repeated string mvm_missions = 9; // Pop files we are willing to play. NOTE: An empty list means "no change", it doesn't mean "none". We pass "invalid" to indicate an empty list
|
||
|
optional bool play_for_bragging_rights = 6; // Are we going to play for bragging rights? If false, we are just playing for fun
|
||
|
|
||
|
// Quickplay options
|
||
|
optional uint32 quickplay_game_type = 8; // eQuickplayGameType
|
||
|
|
||
|
// Ladder
|
||
|
optional uint32 ladder_game_type = 11; //
|
||
|
|
||
|
// Casual
|
||
|
optional CMsgCasualMatchmakingSearchCriteria casual_criteria = 12; // Search criteria for casual games
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CMsgCasualMatchmakingSearchCriteria
|
||
|
//
|
||
|
message CMsgCasualMatchmakingSearchCriteria
|
||
|
{
|
||
|
repeated fixed32 selected_maps_bits = 3; // Bitfield of selected maps from the "master_maps_list" in _maps.txt
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Message used for these purposes:
|
||
|
// - Create a party to start matchmaking
|
||
|
// - Update match search criteria or party properties
|
||
|
// - Leave the queue, but keep the party intact
|
||
|
// - Adjust whether a particular player in the lobby wants to cash in their squad surplus voucher
|
||
|
message CMsgCreateOrUpdateParty
|
||
|
{
|
||
|
optional CMsgMatchSearchCriteria search_criteria = 1;
|
||
|
//optional bool search_active = 2;
|
||
|
optional fixed64 steam_lobby_id = 3;
|
||
|
optional bool squad_surplus = 4;
|
||
|
optional TF_Matchmaking_WizardStep wizard_step = 5;
|
||
|
optional uint32 client_version = 6 [ default = 1225 ];
|
||
|
};
|
||
|
|
||
|
message CMsgCreateOrUpdatePartyReply
|
||
|
{
|
||
|
optional uint32 result = 1; // EResult code
|
||
|
optional string message = 2; // Diagnostic
|
||
|
optional TF_Matchmaking_WizardStep wizard_step = 3; // current wizard step
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// CSOTFParty
|
||
|
//
|
||
|
message CSOTFParty
|
||
|
{
|
||
|
optional uint64 party_id = 1 [ (key_field) = true ];
|
||
|
optional fixed64 leader_id = 2;
|
||
|
repeated fixed64 member_ids = 3;
|
||
|
repeated CSOTFPartyMember members = 13;
|
||
|
// optional uint32 game_mode = 4;
|
||
|
repeated fixed64 pending_invites = 5;
|
||
|
optional uint64 associated_lobby_id = 35;
|
||
|
|
||
|
enum State
|
||
|
{
|
||
|
UI = 0;
|
||
|
FINDING_MATCH = 1;
|
||
|
IN_MATCH = 2;
|
||
|
AWAITING_RESERVATION_CONFIRMATION = 3;
|
||
|
}
|
||
|
optional State state = 6;
|
||
|
optional TF_Matchmaking_WizardStep wizard_step = 29;
|
||
|
optional uint32 started_matchmaking_time = 7;
|
||
|
// optional uint32 searching_players = 8; // how many players are currently searching in the matchmaking system
|
||
|
repeated uint32 searching_players_by_group = 10; // how many players are currently searching in the matchmaking system
|
||
|
optional fixed64 steam_lobby_id = 27; // Steam lobby associated with this party
|
||
|
|
||
|
//
|
||
|
// Search criteria
|
||
|
//
|
||
|
optional TF_MatchmakingMode matchmaking_mode = 30; // high level search mode.
|
||
|
optional bool search_late_join_ok = 23; // Is my party willing to join late?
|
||
|
optional string search_mvm_mannup_tour = 32; // Selected Mann Up tour. (Mann UP only)
|
||
|
repeated string search_mvm_missions = 31; // MvM: Pop files we are willing to play. list must not be empty, if we are in MvM mode!
|
||
|
optional bool search_play_for_bragging_rights = 26; // Do we want to play for loot?
|
||
|
optional uint32 search_quickplay_game_type = 28; // eQuickplayGameType
|
||
|
optional uint32 search_ladder_game_type = 33; //
|
||
|
optional CMsgCasualMatchmakingSearchCriteria search_casual = 34;
|
||
|
optional uint32 custom_ping_tolerance = 36;
|
||
|
|
||
|
//
|
||
|
// Search status
|
||
|
//
|
||
|
// optional uint32 matching_players = 14; // how many players are currently matching us
|
||
|
// optional float search_fraction = 15; // fraction of search range (expands over time)
|
||
|
optional uint32 matchmaking_ban_time = 18; // party can't matchmake until this time
|
||
|
optional uint32 matchmaking_ban_account_id = 19; // accountID of the player preventing matchmaking
|
||
|
optional uint32 matchmaking_low_priority_time = 20; // if set, any official matchmaking mode will treat this party as low priority (superceded by prevent_match_until_date)
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// CSOTFPartyInvite - sent from the GC to possible new party member
|
||
|
//
|
||
|
message CSOTFPartyInvite
|
||
|
{
|
||
|
message PartyMember
|
||
|
{
|
||
|
optional string name = 1;
|
||
|
optional fixed64 steam_id = 2;
|
||
|
optional uint32 avatar = 3;
|
||
|
};
|
||
|
optional uint64 group_id = 1 [ (key_field) = true ];
|
||
|
optional fixed64 sender_id = 2;
|
||
|
optional string sender_name = 3;
|
||
|
repeated PartyMember members = 4;
|
||
|
};
|
||
|
|
||
|
enum TF_GC_GameState
|
||
|
{
|
||
|
TF_GC_GAMESTATE_STATE_INIT = 0;
|
||
|
TF_GC_GAMESTATE_WAIT_FOR_PLAYERS_TO_LOAD = 1;
|
||
|
TF_GC_GAMESTATE_STRATEGY_TIME = 3;
|
||
|
TF_GC_GAMESTATE_GAME_IN_PROGRESS = 5;
|
||
|
TF_GC_GAMESTATE_POST_GAME = 6;
|
||
|
TF_GC_GAMESTATE_DISCONNECT = 7;
|
||
|
|
||
|
TF_GC_GAMESTATE_LAST = 8; // keep this as the last index
|
||
|
}
|
||
|
|
||
|
enum TF_GC_TEAM
|
||
|
{
|
||
|
TF_GC_TEAM_DEFENDERS = 0; // Mann (used as red in ladder games)
|
||
|
TF_GC_TEAM_INVADERS = 1; // Machine (used as blue in ladder games)
|
||
|
TF_GC_TEAM_BROADCASTER = 2;
|
||
|
TF_GC_TEAM_SPECTATOR = 3;
|
||
|
TF_GC_TEAM_PLAYER_POOL = 4; // players that haven't been assign to a team yet
|
||
|
|
||
|
TF_GC_TEAM_NOTEAM = 5;
|
||
|
}
|
||
|
|
||
|
//enum TF_CM_PICK
|
||
|
//{
|
||
|
// TF_CM_RANDOM = 0;
|
||
|
// TF_CM_GOOD_GUYS = 1;
|
||
|
// TF_CM_BAD_GUYS = 2;
|
||
|
//}
|
||
|
|
||
|
enum TFMatchLeaveReason
|
||
|
{
|
||
|
TFMatchLeaveReason_UNSPECIFIED = 0; // No idea
|
||
|
TFMatchLeaveReason_VOTE_KICK = 1; // Vote kicked by teammates
|
||
|
TFMatchLeaveReason_IDLE = 2; // Idle kick
|
||
|
TFMatchLeaveReason_ADMIN_KICK = 3; // Admin kick
|
||
|
TFMatchLeaveReason_AWOL = 4; // Player left the match and did not return in time
|
||
|
TFMatchLeaveReason_NO_SHOW = 5; // Player never showed up
|
||
|
TFMatchLeaveReason_GC_REMOVED = 6; // Dropped via GC (e.g. refused to rejoin, removed themselves from the lobby, but wasn't clear to leave)
|
||
|
};
|
||
|
|
||
|
enum TFLobbyReadyState
|
||
|
{
|
||
|
TFLobbyReadyState_UNDECLARED = 0;
|
||
|
TFLobbyReadyState_ACCEPTED = 1;
|
||
|
TFLobbyReadyState_DECLINED = 2;
|
||
|
}
|
||
|
|
||
|
//enum TFBotDifficulty
|
||
|
//{
|
||
|
// BOT_DIFFICULTY_EASY = 0;
|
||
|
// BOT_DIFFICULTY_MEDIUM = 1;
|
||
|
// BOT_DIFFICULTY_HARD = 2;
|
||
|
// BOT_DIFFICULTY_UNFAIR = 3;
|
||
|
//};
|
||
|
//
|
||
|
//enum TFGameVersion
|
||
|
//{
|
||
|
// GAME_VERSION_CURRENT = 0;
|
||
|
// GAME_VERSION_STABLE = 1;
|
||
|
//};
|
||
|
|
||
|
//
|
||
|
// CTFLobbyMember
|
||
|
//
|
||
|
message CTFLobbyMember
|
||
|
{
|
||
|
enum ConnectState
|
||
|
{
|
||
|
INVALID = 0; // Dummy / sentinel value used for debugging
|
||
|
RESERVATION_PENDING = 1; // GC is telling gameserver it wants to add a player, and is asking gameserver to acknowledge
|
||
|
RESERVED = 2; // Gameserver has acknowledged reservation
|
||
|
CONNECTED = 3; // Is currently connected (and joined through matchmaking)
|
||
|
//CONNECTED_AD_HOC = 4; // Connected ad-hoc.
|
||
|
DISCONNECTED = 5; // Connected at somepoint via match making but is no longer connected
|
||
|
};
|
||
|
|
||
|
optional fixed64 id = 1 [ (key_field) = true ];
|
||
|
optional TF_GC_TEAM team = 3;
|
||
|
// optional bool connected_to_game_server = 4;
|
||
|
optional ConnectState connect_state = 13;
|
||
|
optional string name = 6;
|
||
|
// Deprecated, not used by clients or servers, moved to memcache object
|
||
|
// optional float latitude = 8; // approxmimate world location of this player
|
||
|
// optional float longitude = 9;
|
||
|
// optional bool ready = 10; // Is this player ready
|
||
|
optional TFLobbyReadyState ready_state = 11;
|
||
|
optional uint64 party_id = 12;
|
||
|
optional bool squad_surplus = 14;
|
||
|
optional uint32 badge_level = 15;
|
||
|
optional uint32 skillrating = 16 [ default = 10000 ];
|
||
|
optional uint32 last_connect_time = 17; // last time player was online
|
||
|
// Deprecated, abandons are handled by the gameserver match management logic now
|
||
|
// optional bool quitting_results_in_penalty = 18; // If true, then if the player quits, it wil result in a penalty of some sort.
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CTFLobbyGCPrivate
|
||
|
//
|
||
|
// Data stored in the lobby object that is private to the GC
|
||
|
// it will not be networked to clients
|
||
|
//
|
||
|
//message CTFLobbyGCPrivate
|
||
|
//{
|
||
|
// optional string search_key = 1; // key used to find servers, optional
|
||
|
// optional string pass_key = 2; // key used to find lobbies, optional
|
||
|
//}
|
||
|
|
||
|
/// cosmetic details for radiant/dire
|
||
|
//message CLobbyTeamDetails
|
||
|
//{
|
||
|
// optional string team_name = 1;
|
||
|
// optional string team_logo = 2;
|
||
|
//}
|
||
|
|
||
|
// pending player report that is waiting for a matchID
|
||
|
message CLobbyPendingPlayerReport
|
||
|
{
|
||
|
optional uint32 account_id = 1;
|
||
|
optional fixed32 date = 2;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Match sign out message (deprecated)
|
||
|
//
|
||
|
// message CMsgGameMatchSignOut
|
||
|
// {
|
||
|
// // Team definition
|
||
|
// message CTeam
|
||
|
// {
|
||
|
// // Player on a team
|
||
|
// message CPlayer
|
||
|
// {
|
||
|
// optional fixed64 account_id = 1;
|
||
|
// optional uint32 fake_client_id = 2;
|
||
|
// optional uint32 hero_id = 3;
|
||
|
// repeated uint32 items = 4;
|
||
|
// optional uint32 gold = 5;
|
||
|
// optional uint32 kills = 6;
|
||
|
// optional uint32 deaths = 7;
|
||
|
// optional uint32 assists = 8;
|
||
|
// optional uint32 leaver_status = 9;
|
||
|
// optional uint32 last_hits = 10;
|
||
|
// optional uint32 denies = 11;
|
||
|
// optional uint32 gold_per_min = 12;
|
||
|
// optional uint32 xp_per_minute = 13;
|
||
|
// optional uint32 gold_spent = 14;
|
||
|
// optional uint32 level = 15;
|
||
|
// optional uint32 hero_damage = 16;
|
||
|
// optional uint32 tower_damage = 17;
|
||
|
// optional uint32 hero_healing = 18;
|
||
|
// optional uint32 time_last_seen = 19;
|
||
|
// optional uint32 support_ability_value = 20;
|
||
|
// optional uint64 party_id = 21;
|
||
|
// optional bool idle_in_fountain = 22;
|
||
|
// optional bool logged_in_elsewhere = 23;
|
||
|
// optional float scaled_kills = 24;
|
||
|
// optional float scaled_deaths = 25;
|
||
|
// optional float scaled_assists = 26;
|
||
|
// };
|
||
|
//
|
||
|
// repeated CPlayer players = 1;
|
||
|
// }
|
||
|
//
|
||
|
// optional uint64 match_id = 1 [ (key_field) = true ];
|
||
|
// optional uint32 duration = 2;
|
||
|
// optional bool good_guys_win = 3;
|
||
|
// optional fixed32 date = 4;
|
||
|
// repeated uint32 num_players = 5; // Number of players per-team
|
||
|
// repeated CTeam teams = 6; // Two teams per match
|
||
|
// optional string computer_name = 7; // Which computer submitted stats
|
||
|
// repeated uint32 tower_status = 8; // Which towers were destroyed per-team
|
||
|
// repeated uint32 barracks_status = 9; // Which barracks were destroyed per-team
|
||
|
// optional uint32 cluster = 10; // sv_cluster setting, this is the data center cluster the game was played on
|
||
|
// optional string server_addr = 11; // string representing the server address
|
||
|
// optional uint32 first_blood_time = 12;
|
||
|
// optional float game_balance = 13; // average team balance over the game - 0.0 = completely balanced 1.0 = complete imbalance (should be impossible)
|
||
|
// };
|
||
|
|
||
|
//
|
||
|
// CSOTFGameServerLobby
|
||
|
//
|
||
|
message CSOTFGameServerLobby
|
||
|
{
|
||
|
optional uint64 lobby_id = 1 [ (key_field) = true ];
|
||
|
repeated CTFLobbyMember members = 2; // members assigned to this lobby
|
||
|
// Moved to GC-only CTFMemcachedLobby
|
||
|
// repeated CTFLobbyMember left_members = 7; // members who purposefully quit the lobby (declined the rejoin request or clicked the 'finish game' button at game end)
|
||
|
optional fixed64 leader_id = 11;
|
||
|
optional fixed64 server_id = 6 [default = 0 ]; // game server assigned to this lobby
|
||
|
//optional uint32 game_mode = 3;
|
||
|
repeated fixed64 pending_invites = 10;
|
||
|
enum State
|
||
|
{
|
||
|
UNKNOWN = 0; // Broken/bad lobby state. Lobbies can be in this state if we go down and restore from
|
||
|
// memcache during their setup, for instance
|
||
|
SERVERSETUP = 1; // selecting a server and getting it ready
|
||
|
RUN = 2; // server is ready, connect to it and play!
|
||
|
// POSTGAME = 3; // game is over, server is uploading stats, will signal when its free
|
||
|
// READYUP = 4; // waiting for all players to ready up
|
||
|
// NOTREADY = 5; // lobby wasn't ready
|
||
|
// SERVERASSIGN = 6; // selecting a server for a MATCH lobby, occurs before ready up
|
||
|
}
|
||
|
optional State state = 4 [ default = UNKNOWN ];
|
||
|
optional string connect = 5; // connect string usually something like "ip:port", only valid during state RUN
|
||
|
//REMOVED optional string search_key = 8 [ (hidden) = true ]; // key used to find servers, optional
|
||
|
// optional CTFLobbyGCPrivate gc_private = 9 [ (hidden) = true ]; // private lobby data on the GC not sent to clients or servers
|
||
|
enum LobbyType
|
||
|
{
|
||
|
INVALID = -1;
|
||
|
MATCH = 0; // lobby was created by the matchmaking system
|
||
|
PRACTICE = 1; // practice lobby with members chosen by the players
|
||
|
TOURNAMENT = 2; // special type of practice lobby where we record stats and only allow tournament flagged players in
|
||
|
TUTORIAL = 3;
|
||
|
}
|
||
|
optional LobbyType lobby_type = 12;
|
||
|
optional bool allow_cheats = 13;
|
||
|
//optional bool fill_with_bots = 14;
|
||
|
//optional bool intro_mode = 15;
|
||
|
optional string game_name = 16; // practice/tournament lobbies can have custom game names (shown in the Watch tab, etc.)
|
||
|
//repeated CLobbyTeamDetails team_details = 17; // cosmetic details for radiant/dire
|
||
|
//optional uint32 tutorial_lesson = 18; // tutorial lobbies set the lesson to start on
|
||
|
//optional uint32 tournament_id = 19; // If this is a tournament game, which tournament
|
||
|
//optional uint32 tournament_game_id = 20;// If this is a tournament game, which game in the tournament
|
||
|
optional uint32 server_region = 21 [ default = 0 ]; // region to use for the server, 0 means automatic using geo location avg distance
|
||
|
optional TF_GC_GameState game_state = 22; // This isn't set by the lobby, but is networked up from the gameserver when it changes
|
||
|
// hidden since we don't need to network to clients, they get it via packet entities
|
||
|
optional uint32 num_spectators = 23; // sent up from the game server
|
||
|
//optional uint32 tower_state = 24; // bitfield describing destroyed state of the towers in the map
|
||
|
//optional uint32 matchgroup = 25; // DEPRECATED. No longer used. Use match_group below instead.
|
||
|
optional float readyup_remaining_time = 26; // remaining time left in READYUP in seconds
|
||
|
// DEPRECATED, handled by gameserver management logic now
|
||
|
// optional bool leaver_detected = 27; // if set, a player has been detected as a leaver. other players can safely abandon without getting a leaver count
|
||
|
//optional TF_CM_PICK cm_pick = 28 [ default = TF_CM_RANDOM ]; // which team gets to pick first in CM mode
|
||
|
// repeated CLobbyPendingPlayerReport pending_player_reports = 29 [ (hidden) = true ]; // player feedback reports that are waiting for this lobby's matchID (assigned on match signout)
|
||
|
optional bool allow_spectating = 31 [ default = true ]; // option for practice games to allow them to show up on the spectator list
|
||
|
optional uint32 average_rank = 32; // average rank of the players (skillrating in TF)
|
||
|
optional fixed64 load_game_lobby_id = 33; // if set, the server will try to load a match lobby/save number
|
||
|
optional uint32 load_game_save_number = 34;
|
||
|
//optional TFBotDifficulty bot_difficulty = 36 [ default = BOT_DIFFICULTY_MEDIUM ];
|
||
|
//optional TFGameVersion game_version = 37 [ default = GAME_VERSION_CURRENT ];
|
||
|
optional string mannup_tour_name = 42; // MvM tour we're playing for bragging rights. (Should not be set if not playing for bragging rights.)
|
||
|
optional string map_name = 38; // Map we're currently playing
|
||
|
optional string mission_name = 39; // Challenge we're currently playing
|
||
|
optional uint32 match_group = 41;
|
||
|
optional uint64 match_id = 30 [ default = 0 ]; // if this lobby has signed out, this is its matchID
|
||
|
optional fixed32 replay_salt = 35; // if this lobby has signed out, this is its replay salt
|
||
|
optional uint32 formed_time = 36; // timestamp of when we created this lobby
|
||
|
optional uint32 flags = 43; // general bitfield (see tf_matchmaking_shared.h for flags, e.g. LOBBY_FLAG_LOWPRIORITY)
|
||
|
optional bool late_join_eligible = 44; // If this lobby is entered into the late join system
|
||
|
// What the proper-size of this match should be, passed from the GC so it doesn't need to be hard-coded on clients
|
||
|
// per match group.
|
||
|
// Should be set at match creation time if applicable, but may not be present.
|
||
|
optional uint32 fixed_match_size = 45;
|
||
|
enum WarMatch
|
||
|
{
|
||
|
NOPE = 0;
|
||
|
INVADERS_ARE_PYRO = 1;
|
||
|
INVADERS_ARE_HEAVY = 2;
|
||
|
};
|
||
|
optional WarMatch is_war_match = 46 [ default = NOPE ];
|
||
|
repeated uint32 next_maps_for_vote = 47;
|
||
|
// When certain actions are taken on the lobby, this is incremented, to determine if server heartbeats are aware of
|
||
|
// the most recent version.
|
||
|
optional uint32 lobby_mm_version = 48;
|
||
|
};
|
||
|
|
||
|
|
||
|
message CMsgExitMatchmaking
|
||
|
{
|
||
|
// This parameter guards a race condition where we ask to leave in parallel with a match being assigned.
|
||
|
optional bool explicit_abandon = 1;
|
||
|
// These are an additional guard against the same race condition
|
||
|
optional uint64 party_id = 2;
|
||
|
optional uint64 lobby_id = 3;
|
||
|
};
|
||
|
|
||
|
message CMsgAcceptInvite
|
||
|
{
|
||
|
optional uint64 party_id = 1;
|
||
|
optional fixed64 steamid_lobby = 2;
|
||
|
optional uint32 client_version = 3 [ default = 1225 ];
|
||
|
};
|
||
|
|
||
|
message CMsgAcceptInviteResponse
|
||
|
{
|
||
|
optional int32 result_code = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CMsgReadyUp - sent to acknowledge lobby readiness
|
||
|
//
|
||
|
message CMsgReadyUp
|
||
|
{
|
||
|
optional TFLobbyReadyState state = 1;
|
||
|
};
|
||
|
|
||
|
// request how many people are searching in each matchgroup
|
||
|
message CMsgMatchmakingSearchCountRequest
|
||
|
{
|
||
|
};
|
||
|
|
||
|
message CMsgMatchmakingSearchCountResponse
|
||
|
{
|
||
|
repeated uint32 searching_players_by_group = 1;
|
||
|
};
|
||
|
|
||
|
message CMsgKickedFromMatchmakingQueue
|
||
|
{
|
||
|
};
|
||
|
|
||
|
// Deprecated
|
||
|
// message CMsgTFPlayerFailedToConnect
|
||
|
// {
|
||
|
// repeated fixed64 failed_loaders = 1;
|
||
|
// };
|
||
|
|
||
|
//// game client wants to abandon his current game (be removed from the lobby)
|
||
|
//message CMsgAbandonCurrentGame
|
||
|
//{
|
||
|
//};
|
||
|
|
||
|
//// sent from server to GC when a player has been AFK/disconnected too long
|
||
|
//message CMsgLeaverDetected
|
||
|
//{
|
||
|
// optional fixed64 steam_id = 1;
|
||
|
// optional uint32 leaver_status = 2; // TFLeaverStatus_t
|
||
|
//};
|
||
|
//
|
||
|
//message CMsgLeaverDetectedResponse
|
||
|
//{
|
||
|
// optional uint32 result = 1;
|
||
|
//};
|
||
|
|
||
|
// GC Chat
|
||
|
|
||
|
// for identifying special channel types
|
||
|
enum ChatChannelType_t
|
||
|
{
|
||
|
ChatChannelType_Regional = 0;
|
||
|
ChatChannelType_Custom = 1;
|
||
|
ChatChannelType_Party = 2;
|
||
|
ChatChannelType_Lobby = 3;
|
||
|
};
|
||
|
|
||
|
message CMsgTFJoinChatChannel
|
||
|
{
|
||
|
optional string persona_name = 1;
|
||
|
optional string channel_name = 2;
|
||
|
optional string password = 3;
|
||
|
optional ChatChannelType_t channel_type = 4;
|
||
|
};
|
||
|
|
||
|
message CMsgTFLeaveChatChannel
|
||
|
{
|
||
|
optional string channel_name = 1;
|
||
|
};
|
||
|
|
||
|
message CMsgTFJoinChatChannelResponse
|
||
|
{
|
||
|
message ChatMember
|
||
|
{
|
||
|
optional fixed64 steam_id = 1;
|
||
|
optional string persona_name = 2;
|
||
|
};
|
||
|
optional uint32 response = 1;
|
||
|
optional string channel_name = 2;
|
||
|
optional fixed64 channel_id = 3;
|
||
|
optional uint32 max_members = 4;
|
||
|
repeated ChatMember members = 5;
|
||
|
};
|
||
|
|
||
|
message CMsgTFOtherJoinedChatChannel
|
||
|
{
|
||
|
optional fixed64 channel_id = 1;
|
||
|
optional string persona_name = 2;
|
||
|
optional fixed64 steam_id = 3;
|
||
|
};
|
||
|
|
||
|
message CMsgTFOtherLeftChatChannel
|
||
|
{
|
||
|
optional fixed64 channel_id = 1;
|
||
|
optional fixed64 steam_id = 2;
|
||
|
};
|
||
|
|
||
|
message CMsgTFRequestDefaultChatChannel
|
||
|
{
|
||
|
};
|
||
|
|
||
|
message CMsgTFRequestDefaultChatChannelResponse
|
||
|
{
|
||
|
optional string channel_name = 1;
|
||
|
optional fixed64 channel_id = 2;
|
||
|
};
|
||
|
|
||
|
message CMsgTFRequestChatChannelList
|
||
|
{
|
||
|
};
|
||
|
|
||
|
message CMsgTFRequestChatChannelListResponse
|
||
|
{
|
||
|
message ChatChannel
|
||
|
{
|
||
|
optional string channel_name = 1;
|
||
|
optional uint32 num_members = 2;
|
||
|
optional ChatChannelType_t channel_type = 3;
|
||
|
}
|
||
|
repeated ChatChannel channels = 1;
|
||
|
};
|
||
|
|
||
|
enum ServerMatchmakingState
|
||
|
{
|
||
|
ServerMatchmakingState_INVALID = 0; // Dummy value used for sentinel / debugging
|
||
|
ServerMatchmakingState_NOT_PARTICIPATING = 1;
|
||
|
ServerMatchmakingState_EMPTY = 2;
|
||
|
// Running a matchmaking match, have room for late joiners
|
||
|
ServerMatchmakingState_ACTIVE_MATCH_REQUESTING_LATE_JOIN = 3;
|
||
|
// Running a matchmaking match
|
||
|
ServerMatchmakingState_ACTIVE_MATCH = 4;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CMsgGameServerMatchmakingStatus - server status and connected players
|
||
|
//
|
||
|
message CMsgGameServerMatchmakingStatus
|
||
|
{
|
||
|
|
||
|
optional uint32 server_version = 16 [ default = 1225 ];
|
||
|
optional ServerMatchmakingState matchmaking_state = 1 [ default = ServerMatchmakingState_INVALID ];
|
||
|
optional TF_MatchmakingMode matchmaking_mode = 2; // Which pool do we want to be in?
|
||
|
optional string map = 3; // Current map
|
||
|
optional string tags = 4; // Current tags
|
||
|
optional uint32 bot_count = 5; // Number of bots
|
||
|
optional uint32 num_spectators = 6;
|
||
|
optional uint32 max_players = 7; // Advertised max number of players
|
||
|
optional uint32 slots_free = 8; // Biggest possible lobby we could accept right now
|
||
|
optional uint32 server_region = 9; // Region value that matches regions.txt in the GC
|
||
|
optional float server_loadavg = 10; // current load average
|
||
|
optional bool server_trusted = 11; // server requests to be put into the trusted pool
|
||
|
optional bool server_dedicated = 12; // Is this a dedicated server? (As opposed to a listen server)
|
||
|
optional uint32 strict = 17; // Current value of tf_mm_strict
|
||
|
|
||
|
enum PlayerConnectState
|
||
|
{
|
||
|
INVALID = 0; // Dummy / sentinel value used for debugging
|
||
|
CONNECTED = 1; // Is currently connected
|
||
|
RESERVED = 2; // I have a reservation ready for this guy and am acknowledging that you are expecting him
|
||
|
};
|
||
|
|
||
|
message Player
|
||
|
{
|
||
|
optional fixed64 steam_id = 1;
|
||
|
optional PlayerConnectState connect_state = 2;
|
||
|
}
|
||
|
repeated Player players = 13;
|
||
|
optional TF_GC_GameState game_state = 14;
|
||
|
|
||
|
//
|
||
|
// Particular event that prompted us to send this message, if any
|
||
|
//
|
||
|
|
||
|
enum Event
|
||
|
{
|
||
|
None = 0;
|
||
|
MvMVictory = 1;
|
||
|
MvMDefeat = 2;
|
||
|
AcknowledgePlayers = 3;
|
||
|
};
|
||
|
optional Event event = 15 [ default = None ];
|
||
|
|
||
|
// MvM metrics, possibly interesting for quality adjustments
|
||
|
optional uint32 mvm_wave = 18; // Current MvM wave number
|
||
|
optional uint32 mvm_credits_acquired = 19; // Cash collected
|
||
|
optional uint32 mvm_credits_dropped = 20; // Cash failed to collect and lost
|
||
|
|
||
|
// optional uint32 skillrating_force_average = 21; // Servers can force their skillrating average
|
||
|
// optional uint32 ladder_game_type = 22;
|
||
|
|
||
|
optional sint32 match_group = 23 [ default = -1 ]; // The current match group. -1 if none. Type sint since it'll be negative often
|
||
|
// Echo the last lobby version back with our heartbeat. GC uses this to reason about the last update we had a chance
|
||
|
// to respond to.
|
||
|
optional uint32 lobby_mm_version = 24;
|
||
|
};
|
||
|
|
||
|
////
|
||
|
//// CMsgPingListRequest - GC is requesting client to ping some game servers
|
||
|
////
|
||
|
//message CMsgPingListRequest
|
||
|
//{
|
||
|
//
|
||
|
// message Address
|
||
|
// {
|
||
|
// required fixed32 ip = 1;
|
||
|
// required uint32 port = 2;
|
||
|
// };
|
||
|
//
|
||
|
// optional uint32 server_pool = 1; // which pool do these servers belong to?
|
||
|
// repeated Address servers = 2;
|
||
|
//};
|
||
|
//
|
||
|
////
|
||
|
//// CMsgPingListResponse - Client replies with list of servers
|
||
|
////
|
||
|
//message CMsgPingListResponse
|
||
|
//{
|
||
|
//
|
||
|
// message Server
|
||
|
// {
|
||
|
// required fixed32 ip = 1;
|
||
|
// required uint32 port = 2;
|
||
|
// required uint32 ping_ms = 3; // ping time, in MS
|
||
|
// };
|
||
|
//
|
||
|
// optional uint32 server_pool = 1; // which pool do these servers belong to?
|
||
|
// repeated Server servers = 2;
|
||
|
//};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCMatchmakingProgress
|
||
|
// Server is sending party estimate of wait times, etc
|
||
|
//
|
||
|
message CMsgMatchmakingProgress
|
||
|
{
|
||
|
optional uint32 avg_wait_time_new = 4; // Average wait time for a new game for people with similar search criteria
|
||
|
optional uint32 avg_wait_time_join_late = 5; // Average wait time for a late join for people with similar search criteria
|
||
|
optional uint32 your_wait_time = 6; // Time that we think you have been waiting
|
||
|
|
||
|
optional uint32 matching_worldwide_searching_players = 8;
|
||
|
optional uint32 matching_near_you_searching_players = 9;
|
||
|
optional uint32 total_worldwide_searching_players = 13;
|
||
|
optional uint32 total_near_you_searching_players = 14;
|
||
|
|
||
|
optional uint32 matching_worldwide_active_players = 15;
|
||
|
optional uint32 matching_near_you_active_players = 16;
|
||
|
optional uint32 total_worldwide_active_players = 17;
|
||
|
optional uint32 total_near_you_active_players = 18;
|
||
|
|
||
|
optional uint32 matching_worldwide_empty_gameservers = 19;
|
||
|
optional uint32 matching_near_you_empty_gameservers = 20;
|
||
|
optional uint32 total_worldwide_empty_gameservers = 21;
|
||
|
optional uint32 total_near_you_empty_gameservers = 22;
|
||
|
|
||
|
optional uint32 urgency_pct = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCMvMVictoryInfo
|
||
|
//
|
||
|
// Server is letting players know who got what at the end of MvM
|
||
|
//
|
||
|
message CMsgMvMVictoryInfo
|
||
|
{
|
||
|
enum GrantReason
|
||
|
{
|
||
|
INVALID = 0;
|
||
|
BADGE_LEVELED = 1;
|
||
|
SQUAD_SURPLUS = 2;
|
||
|
MANN_UP = 3;
|
||
|
HELP_A_NOOB = 4;
|
||
|
};
|
||
|
|
||
|
message Item
|
||
|
{
|
||
|
optional GrantReason grant_reason = 1; // why are we receiving this?
|
||
|
optional bytes item_data = 2; // buffer that can be parsed by CEconItem::BParseCreateFromMessage
|
||
|
optional fixed64 squad_surplus_claimer_steam_id = 3; // for squad surplus, whose voucher is responsible for this?
|
||
|
};
|
||
|
|
||
|
message Player
|
||
|
{
|
||
|
optional fixed64 steam_id = 1;
|
||
|
//optional string player_name = 2;
|
||
|
|
||
|
optional bool badge_granted = 3;
|
||
|
optional bool badge_progress_updated = 4;
|
||
|
optional bool badge_leveled = 5;
|
||
|
optional uint32 badge_level = 6;
|
||
|
optional uint32 badge_progress_bits = 7;
|
||
|
repeated Item items = 8;
|
||
|
optional bool voucher_missing = 9;
|
||
|
optional uint32 badge_points = 10;
|
||
|
};
|
||
|
|
||
|
repeated Player players = 1;
|
||
|
optional string tour_name = 2;
|
||
|
optional string mission_name = 3;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CGCMsgTFHelloResponse
|
||
|
//
|
||
|
message CGCMsgTFHelloResponse
|
||
|
{
|
||
|
optional uint32 version_check = 1;
|
||
|
repeated uint64 version_checksum = 2;
|
||
|
optional uint32 version_verbose = 3;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CGCMsgTFSync
|
||
|
//
|
||
|
message CGCMsgTFSync
|
||
|
{
|
||
|
optional bytes version_checksum = 1;
|
||
|
optional uint32 version_check = 2;
|
||
|
optional uint32 version_check_ex = 3;
|
||
|
optional uint32 version_check_ex2 = 4;
|
||
|
optional bytes version_checksum_ex = 5;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CGCMsgTFSync
|
||
|
//
|
||
|
message CGCMsgTFSyncEx
|
||
|
{
|
||
|
optional string version_checksum = 1;
|
||
|
optional bytes version_checksum_ex = 2;
|
||
|
optional uint32 version_check = 3;
|
||
|
};
|
||
|
|
||
|
// gameserver -> GC message used to notify GC of victory
|
||
|
message CMsgMvMVictory
|
||
|
{
|
||
|
optional uint32 legacy_mission_index = 1; // needed for the first prop, when old gameservers may report victory to a new GC. After we update the gameservers, delete it
|
||
|
optional string tour_name_mannup = 5; // Only present if we're playing for bragging rights (Mann Up)
|
||
|
optional string mission_name = 6;
|
||
|
|
||
|
message Player
|
||
|
{
|
||
|
optional fixed64 steam_id = 1;
|
||
|
optional bool squad_surplus = 2;
|
||
|
};
|
||
|
repeated Player players = 2;
|
||
|
|
||
|
optional uint64 lobby_id = 3;
|
||
|
optional fixed32 event_time = 4;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// Message used to tell the GameServer the GC received the VictoryMessage
|
||
|
message CMsgMvMMannUpVictoryReply
|
||
|
{
|
||
|
// No longer used
|
||
|
// optional uint32 result = 1; // EResult code
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// Game server is letting us know that it is booting the lobby off of the server
|
||
|
//
|
||
|
message CMsgGameServerKickingLobby
|
||
|
{
|
||
|
repeated fixed64 connected_players = 1; // list of players that are still connected
|
||
|
optional bool create_party = 2 [ default = true ];
|
||
|
optional uint64 lobby_id = 3;
|
||
|
optional uint64 match_id = 4;
|
||
|
};
|
||
|
|
||
|
// GC -> server; confirmation that we processed above reliable message
|
||
|
message CMsgGameServerKickingLobbyResponse
|
||
|
{};
|
||
|
|
||
|
//
|
||
|
// GC -> client: Leave your current game; I am about to put you into a party
|
||
|
//
|
||
|
message CMsgLeaveGameAndPrepareToJoinParty
|
||
|
{
|
||
|
optional fixed64 party_id = 1; // The party that has been created that you are now a member of
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// Server -> GC : Telling the GC this player abandoned a match, and should be removed from the lobby if applicable
|
||
|
//
|
||
|
message CMsgPlayerLeftMatch
|
||
|
{
|
||
|
optional fixed64 steam_id = 1;
|
||
|
optional TFMatchLeaveReason leave_reason = 2;
|
||
|
optional bool was_abandon = 3; // Player was not cleared to leave, this is abandoning
|
||
|
optional uint64 lobby_id = 4;
|
||
|
optional uint64 match_id = 5;
|
||
|
repeated CMsgTFXPSource xp_breakdown = 6;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// GC -> Server - empty confirmation of reliable message
|
||
|
//
|
||
|
message CMsgPlayerLeftMatchResponse
|
||
|
{};
|
||
|
|
||
|
//
|
||
|
// Server -> GC : Telling the GC this player was vote-kicked after leaving a match, e.g. they left before it passed
|
||
|
//
|
||
|
message CMsgPlayerVoteKickedAfterLeavingMatch
|
||
|
{
|
||
|
optional fixed64 steam_id = 1;
|
||
|
optional fixed64 lobby_id = 2;
|
||
|
optional fixed64 match_id = 3;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// GC -> Server - empty confirmation of reliable message
|
||
|
//
|
||
|
message CMsgPlayerVoteKickedAfterLeavingMatchResponse
|
||
|
{};
|
||
|
|
||
|
//
|
||
|
// Server -> GC : Telling the GC that players in this lobby are safe to leave
|
||
|
//
|
||
|
// Deprecated
|
||
|
// message CMsgSetLobbySafeToLeave
|
||
|
// {
|
||
|
// optional fixed64 lobby_id = 1;
|
||
|
// };
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_Halloween_ServerBossEvent (Server -> GC)
|
||
|
//
|
||
|
message CMsgHalloween_ServerBossEvent
|
||
|
{
|
||
|
optional uint32 event_counter = 1; // uint8
|
||
|
optional uint32 timestamp = 2; // sent up from server for consistency
|
||
|
optional uint32 boss_type = 3; // uint8
|
||
|
optional uint32 boss_level = 4; // uint16
|
||
|
optional uint32 event_type = 5; // uint8
|
||
|
optional uint32 players_involved = 6; // uint8
|
||
|
optional float elapsed_time = 7;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_Halloween_Merasmus2012 (Server -> GC)
|
||
|
//
|
||
|
message CMsgHalloween_Merasmus2012
|
||
|
{
|
||
|
optional uint32 event_counter = 1; // uint8
|
||
|
optional fixed32 time_submitted = 2; // sent up from server for consistency
|
||
|
optional bool is_valve_server = 3;
|
||
|
optional uint32 boss_level= 4;
|
||
|
optional uint32 spawned_health = 5;
|
||
|
optional uint32 remaining_health = 6; // 0 == Boss was killed
|
||
|
optional uint32 life_time = 7; // Amount of time in seconds, boss was alive for
|
||
|
optional uint32 bomb_kills = 8; // Kills from Bombs
|
||
|
optional uint32 staff_kills = 9; // kills from staff attack
|
||
|
optional uint32 pvp_kills = 10; // Number of kills from players while Boss is out (Jerk factor)
|
||
|
optional uint32 prophunt_time1 = 11;
|
||
|
optional uint32 prophunt_time2 = 12;
|
||
|
optional uint32 dmg_scout = 13; // Amount of damage done by each class
|
||
|
optional uint32 dmg_sniper = 14;
|
||
|
optional uint32 dmg_soldier = 15;
|
||
|
optional uint32 dmg_demo = 16;
|
||
|
optional uint32 dmg_medic = 17;
|
||
|
optional uint32 dmg_heavy = 18;
|
||
|
optional uint32 dmg_pyro = 19;
|
||
|
optional uint32 dmg_spy = 20;
|
||
|
optional uint32 dmg_engineer = 21;
|
||
|
optional uint32 scout_count = 22; // Class and player break down at the point of boss despawn
|
||
|
optional uint32 sniper_count = 23;
|
||
|
optional uint32 solider_count = 24;
|
||
|
optional uint32 demo_count = 25;
|
||
|
optional uint32 medic_count = 26;
|
||
|
optional uint32 heavy_count = 27;
|
||
|
optional uint32 pyro_count = 28;
|
||
|
optional uint32 spy_count = 29;
|
||
|
optional uint32 engineer_count = 30;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_UpdateMerasmusItem
|
||
|
// Client -> GC. Request to update the itemlevel of the merasmus hat
|
||
|
message CMsgUpdateHalloweenMerasmusLootLevel
|
||
|
{
|
||
|
message Player
|
||
|
{
|
||
|
optional fixed64 steam_id = 1;
|
||
|
};
|
||
|
repeated Player players = 1;
|
||
|
|
||
|
optional uint32 merasmus_level = 2; // uint8
|
||
|
};
|
||
|
|
||
|
message CAttribute_String
|
||
|
{
|
||
|
optional string value = 1;
|
||
|
};
|
||
|
|
||
|
message CAttribute_DynamicRecipeComponent
|
||
|
{
|
||
|
optional uint32 def_index = 1;
|
||
|
optional uint32 item_quality = 2;
|
||
|
optional uint32 component_flags = 3;
|
||
|
optional string attributes_string = 4;
|
||
|
optional uint32 num_required = 5;
|
||
|
optional uint32 num_fulfilled = 6;
|
||
|
};
|
||
|
|
||
|
message CAttribute_DynamicRecipeComponent_COMPAT_NEVER_SERIALIZE_THIS_OUT
|
||
|
{
|
||
|
optional uint32 def_index = 1;
|
||
|
optional uint32 item_def = 2;
|
||
|
|
||
|
optional uint32 item_quality = 3;
|
||
|
|
||
|
optional uint32 component_flags = 4;
|
||
|
optional uint32 item_flags = 5;
|
||
|
|
||
|
optional string attributes_string = 6;
|
||
|
|
||
|
optional uint32 num_required = 7;
|
||
|
optional uint32 item_count = 8;
|
||
|
|
||
|
optional uint32 num_fulfilled = 9;
|
||
|
optional uint32 items_fulfilled = 10;
|
||
|
};
|
||
|
|
||
|
message CAttribute_ItemSlotCriteria
|
||
|
{
|
||
|
optional string tags = 1;
|
||
|
};
|
||
|
|
||
|
message CMsgSetItemSlotAttribute
|
||
|
{
|
||
|
optional uint64 item_id = 1;
|
||
|
optional uint64 slot_item_original_id = 2;
|
||
|
optional uint32 slot_index = 3;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CSOWarData
|
||
|
//
|
||
|
message CSOWarData
|
||
|
{
|
||
|
optional uint32 account_id = 1 [ (key_field) = true ]; // Account of who's data this belongs to
|
||
|
optional uint32 war_id = 2 [ (key_field) = true ]; // ID of the war
|
||
|
optional uint32 affiliation = 3; // Which side they're affiliated with
|
||
|
optional uint32 points_scored = 4; // How many points they've scored
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_War_IndividualUpdate
|
||
|
//
|
||
|
message CGCMsgGC_War_IndividualUpdate
|
||
|
{
|
||
|
optional fixed64 steam_id = 1; // Who scored
|
||
|
optional uint32 war_id = 2; // Which war
|
||
|
optional uint32 score = 3; // How many points did they score
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_War_JoinWar
|
||
|
//
|
||
|
message CGCMsgGC_War_JoinWar
|
||
|
{
|
||
|
optional uint32 affiliation = 1; // Which side we're joining
|
||
|
optional uint32 war_id = 2; // Which war
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_War_RequestGlobalStats
|
||
|
//
|
||
|
message CGCMsgGC_War_RequestGlobalStats
|
||
|
{
|
||
|
optional uint32 war_id = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_War_GlobalStatsResponse
|
||
|
//
|
||
|
message CGCMsgGC_War_GlobalStatsResponse
|
||
|
{
|
||
|
message SideScore
|
||
|
{
|
||
|
optional uint32 side = 1;
|
||
|
optional uint64 score = 2;
|
||
|
};
|
||
|
|
||
|
repeated SideScore side_scores = 1;
|
||
|
optional uint32 war_id = 2;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_DuckLeaderboard_IndividualUpdate
|
||
|
//
|
||
|
message CGCMsgGC_PlayerDuckLeaderboard_IndividualUpdate
|
||
|
{
|
||
|
//optional fixed64 steam_id = 1; // Who scored
|
||
|
optional uint32 score = 2;
|
||
|
optional uint32 type = 3;
|
||
|
optional bytes score_id = 4;
|
||
|
optional uint32 score_check = 5;
|
||
|
}
|
||
|
|
||
|
// k_EMsgGC_WorldItemPlacement_Attribute
|
||
|
message CAttribute_WorldItemPlacement
|
||
|
{
|
||
|
optional uint64 original_item_id = 1;
|
||
|
optional float pos_x = 2;
|
||
|
optional float pos_y = 3;
|
||
|
optional float pos_z = 4;
|
||
|
optional float ang_x = 5;
|
||
|
optional float ang_y = 6;
|
||
|
optional float ang_z = 7;
|
||
|
};
|
||
|
|
||
|
// k_EMsgGC_WorldItemPlacement_Update
|
||
|
message CGCMsg_WorldItemPlacement_Update
|
||
|
{
|
||
|
optional uint64 original_item_id = 1; // Passing INVALID_ITEM_ID will reset this attribute
|
||
|
optional float pos_x = 2;
|
||
|
optional float pos_y = 3;
|
||
|
optional float pos_z = 4;
|
||
|
optional float ang_x = 5;
|
||
|
optional float ang_y = 6;
|
||
|
optional float ang_z = 7;
|
||
|
optional bool force_remove_all = 8; // Reset every attribute of this type on the owning item (make separate msg?)
|
||
|
optional string attrib_name = 9; // The attribute we're applying the update to
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CMsgAcknowledgeXP
|
||
|
//
|
||
|
message CMsgAcknowledgeXP
|
||
|
{
|
||
|
// Message clients sent to the GC to acknowledge any pending XP sources
|
||
|
optional int32 match_group = 1;
|
||
|
optional uint32 predicted_experience = 2;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// CMsgTFXPSource
|
||
|
//
|
||
|
message CMsgTFXPSource
|
||
|
{
|
||
|
enum XPSourceType
|
||
|
{
|
||
|
SOURCE_SCORE = 0;
|
||
|
SOURCE_OBJECTIVE_BONUS = 1;
|
||
|
SOURCE_COMPLETED_MATCH = 2;
|
||
|
SOURCE_COMPETITIVE_ABANDON = 3;
|
||
|
SOURCE_COMPETITIVE_WIN = 4;
|
||
|
SOURCE_COMPETITIVE_LOSS = 5;
|
||
|
SOURCE_AUTOBALANCE_BONUS = 6;
|
||
|
|
||
|
// Make sure this is at the end!
|
||
|
NUM_SOURCE_TYPES = 7;
|
||
|
};
|
||
|
|
||
|
optional XPSourceType type = 1 [ (key_field) = true ];
|
||
|
optional int32 amount = 2;
|
||
|
optional int32 match_group = 3;
|
||
|
optional uint32 account_id = 4 [ (key_field) = true ];
|
||
|
optional uint64 match_id = 5 [ (key_field) = true ];
|
||
|
}
|
||
|
|
||
|
message CMsgTFXPSourceBreakdown
|
||
|
{
|
||
|
repeated CMsgTFXPSource sources = 1;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// Client send this in response to client welcome This is separate from hello, which is only sent if we don't have a
|
||
|
// session and haven't heard from the GC, as keep-alive.
|
||
|
message CMsgTFClientInit
|
||
|
{
|
||
|
optional uint32 client_version = 1;
|
||
|
optional int32 language = 2; // ELanguage
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CMsgGCNotification
|
||
|
//
|
||
|
message CMsgGCNotification
|
||
|
{
|
||
|
// Message GC sends to clients when they have a pending notification
|
||
|
enum NotificationType
|
||
|
{
|
||
|
NOTIFICATION_REPORTED_PLAYER_BANNED = 0;
|
||
|
NOTIFICATION_CUSTOM_STRING = 1;
|
||
|
NOTIFICATION_MM_BAN_DUE_TO_EXCESSIVE_REPORTS = 2;
|
||
|
NOTIFICATION_REPORTED_PLAYER_WAS_BANNED = 3;
|
||
|
// A must-confirm-as-seen pop-up notification with a custom support message. If the string is a localization
|
||
|
// token, comes from the *GC* localized strings table, and is sent down based on client's current locale
|
||
|
NOTIFICATION_SUPPORT_MESSAGE = 4;
|
||
|
|
||
|
// Make sure this is at the end
|
||
|
NOTIFICATION_NUM_TYPES = 5;
|
||
|
};
|
||
|
|
||
|
optional uint64 notification_id = 1 [(key_field) = true ];
|
||
|
optional uint32 account_id = 2;
|
||
|
// 0 -> doesn't expire
|
||
|
optional fixed32 expiration_time = 3;
|
||
|
optional NotificationType type = 4 [ default = NOTIFICATION_CUSTOM_STRING ];
|
||
|
optional string notification_string = 5;
|
||
|
}
|
||
|
|
||
|
message CMsgGCNotificationQueue
|
||
|
{
|
||
|
repeated CMsgGCNotification notifications = 1;
|
||
|
}
|
||
|
|
||
|
// k_EMsgGC_NotificationAcknowledge
|
||
|
message CMsgNotificationAcknowledge
|
||
|
{
|
||
|
// Message client sends to GC upon receipt of their notification queue
|
||
|
optional uint32 account_id = 1;
|
||
|
optional uint64 notification_id = 2;
|
||
|
}
|
||
|
|
||
|
// k_EMsgGC_NotificationAcknowledgeReply
|
||
|
message CMsgNotificationAcknowledgeReply
|
||
|
{
|
||
|
// Empty confirmation message that this was processed, and the server can stop trying to send it
|
||
|
}
|
||
|
|
||
|
// k_EMsgGC_Match_Result
|
||
|
message CMsgGC_Match_Result
|
||
|
{
|
||
|
enum Status
|
||
|
{
|
||
|
MATCH_SUCCEEDED = 0;
|
||
|
MATCH_FAILED_GC = 1;
|
||
|
MATCH_FAILED_TRUSTED = 2;
|
||
|
MATCH_FAILED_ABANDON = 3;
|
||
|
// Deprecated
|
||
|
// MATCH_FAILED_RATING = 4;
|
||
|
MATCH_FAILED_UNKNOWN = 5;
|
||
|
MATCH_FAILED_TIMEOUT = 6;
|
||
|
MATCH_FINISHED_ABANDON = 7; // When we allow games to continue after an abandon
|
||
|
};
|
||
|
|
||
|
optional uint64 match_id = 1 [ (key_field) = true ];
|
||
|
optional int32 match_group = 2;
|
||
|
optional Status status = 3;
|
||
|
optional uint32 duration = 4;
|
||
|
optional uint32 red_score = 5;
|
||
|
optional uint32 blue_score = 6;
|
||
|
optional uint32 winning_team = 7;
|
||
|
optional uint32 map_index = 8;
|
||
|
optional uint32 game_type = 9 [default = 0 ];
|
||
|
|
||
|
message Player
|
||
|
{
|
||
|
optional fixed64 steam_id = 1;
|
||
|
optional uint64 party_id = 2;
|
||
|
optional uint32 team = 3;
|
||
|
optional uint32 score = 4;
|
||
|
optional uint32 ping = 5;
|
||
|
optional uint32 flags = 6;
|
||
|
// Deprectated - ratings are now computed GC side, no need to send this up.
|
||
|
// optional uint32 rating = 7;
|
||
|
// optional int32 rating_change = 8;
|
||
|
optional uint32 rank = 9;
|
||
|
optional uint32 classes_played = 10; // bit field
|
||
|
optional uint32 kills = 11;
|
||
|
optional uint32 deaths = 12;
|
||
|
optional uint32 damage = 13;
|
||
|
optional uint32 healing = 14;
|
||
|
optional uint32 support = 15;
|
||
|
optional uint32 score_medal = 16;
|
||
|
optional uint32 kills_medal = 17;
|
||
|
optional uint32 damage_medal = 18;
|
||
|
optional uint32 healing_medal = 19;
|
||
|
optional uint32 support_medal = 20;
|
||
|
repeated CMsgTFXPSource xp_breakdown = 21;
|
||
|
optional uint32 leave_time = 22;
|
||
|
optional TFMatchLeaveReason leave_reason = 23;
|
||
|
optional uint32 connect_time = 24;
|
||
|
};
|
||
|
repeated Player players = 10;
|
||
|
|
||
|
// Deprecated -- handled GC-side
|
||
|
// optional uint32 red_skillrating = 11;
|
||
|
// optional uint32 blue_skillrating = 12;
|
||
|
optional uint32 win_reason = 13;
|
||
|
optional uint32 flags = 14; // bit field
|
||
|
// Deprecated - Unused
|
||
|
// optional uint32 server_version = 15;
|
||
|
optional uint32 bots = 16; // count of bots added during match
|
||
|
// Deprecrated - The reliable message queue for matches requires the new match get acknowledged before we send up
|
||
|
// its corresponding result, so this logic was removed.
|
||
|
// optional bool server_created = 17 [ default = false ];
|
||
|
};
|
||
|
|
||
|
message CMsgGC_Match_ResultResponse
|
||
|
{
|
||
|
// Empty confirmation message that this was processed, and the server can stop trying to send it
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// Data structure holding information for item preview
|
||
|
//
|
||
|
message CEconItemPreviewDataBlock
|
||
|
{
|
||
|
optional CSOEconItem econitem = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_Client2GCEconPreviewDataBlockRequest
|
||
|
//
|
||
|
message CMsgGC_Client2GCEconPreviewDataBlockRequest
|
||
|
{
|
||
|
// econ item asset preview integration with Steam Community params
|
||
|
optional uint64 param_s = 1;
|
||
|
optional uint64 param_a = 2;
|
||
|
optional uint64 param_d = 3;
|
||
|
optional uint64 param_m = 4;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_Client2GCEconPreviewDataBlockResponse
|
||
|
//
|
||
|
message CMsgGC_Client2GCEconPreviewDataBlockResponse
|
||
|
{
|
||
|
optional CEconItemPreviewDataBlock iteminfo = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CSOTFLadderPlayerStats
|
||
|
//
|
||
|
message CSOTFLadderPlayerStats
|
||
|
{
|
||
|
optional uint32 account_id = 1 [ (key_field) = true ];
|
||
|
optional int32 match_group = 2 [ (key_field) = true ];
|
||
|
optional uint32 season_id = 3 [ (key_field) = true ];
|
||
|
// Deprecated, now stored separately from ladder data
|
||
|
// optional uint32 rating = 4;
|
||
|
// optional uint32 last_ackd_rating = 31;
|
||
|
// optional int32 last_rating_change = 5;
|
||
|
optional uint32 rank = 6;
|
||
|
optional uint32 highest_rank = 7;
|
||
|
optional uint32 experience = 8; // Used to determine season level, which is different from (skill) rank
|
||
|
optional uint32 last_ackd_experience = 32;
|
||
|
// Stats - season total
|
||
|
optional uint32 games = 9;
|
||
|
optional uint32 score = 10;
|
||
|
optional uint32 kills = 11;
|
||
|
optional uint32 deaths = 12;
|
||
|
optional uint32 damage = 13;
|
||
|
optional uint32 healing = 14;
|
||
|
optional uint32 support = 15;
|
||
|
// Medals - season total
|
||
|
optional uint32 score_bronze = 16;
|
||
|
optional uint32 score_silver = 17;
|
||
|
optional uint32 score_gold = 18;
|
||
|
optional uint32 kills_bronze = 19;
|
||
|
optional uint32 kills_silver = 20;
|
||
|
optional uint32 kills_gold = 21;
|
||
|
optional uint32 damage_bronze = 22;
|
||
|
optional uint32 damage_silver = 23;
|
||
|
optional uint32 damage_gold = 24;
|
||
|
optional uint32 healing_bronze = 25;
|
||
|
optional uint32 healing_silver = 26;
|
||
|
optional uint32 healing_gold = 27;
|
||
|
optional uint32 support_bronze = 28;
|
||
|
optional uint32 support_silver = 29;
|
||
|
optional uint32 support_gold = 30;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CSOTFRatingData
|
||
|
//
|
||
|
// !! Shared object - keep in sync with CSchRatingData and CTFRatingData's adapters
|
||
|
message CSOTFRatingData
|
||
|
{
|
||
|
optional uint32 account_id = 1 [ (key_field) = true ];
|
||
|
optional int32 rating_type = 2 [ (key_field) = true ]; // int16 in the db
|
||
|
// Corresponds to MMRatingData_t
|
||
|
optional uint32 rating_primary = 3;
|
||
|
optional uint32 rating_secondary = 4;
|
||
|
optional uint32 rating_tertiary = 5;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCVoteKickPlayerRequest
|
||
|
//
|
||
|
message CMsgGC_TFVoteKickPlayerRequest
|
||
|
{
|
||
|
optional uint32 account_id = 1;
|
||
|
optional uint64 target_id = 2;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCVoteKickPlayerRequestResponse
|
||
|
//
|
||
|
message CMsgGC_VoteKickPlayerRequestResponse
|
||
|
{
|
||
|
optional bool allowed = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_DailyCompetitiveStatsRollup
|
||
|
//
|
||
|
message CMsgGC_DailyCompetitiveStatsRollup
|
||
|
{
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_DailyCompetitiveStatsRollup_Response
|
||
|
//
|
||
|
message CMsgGC_DailyCompetitiveStatsRollup_Response
|
||
|
{
|
||
|
message RankBucketEntry
|
||
|
{
|
||
|
optional uint32 rank = 1;
|
||
|
optional uint32 records = 2;
|
||
|
optional uint32 avg_score = 3;
|
||
|
optional uint32 stdev_score = 4;
|
||
|
optional uint32 avg_kills = 5;
|
||
|
optional uint32 stdev_kills = 6;
|
||
|
optional uint32 avg_damage = 7;
|
||
|
optional uint32 stdev_damage = 8;
|
||
|
optional uint32 avg_healing = 9;
|
||
|
optional uint32 stdev_healing = 10;
|
||
|
optional uint32 avg_support = 11;
|
||
|
optional uint32 stdev_support = 12;
|
||
|
};
|
||
|
repeated RankBucketEntry rankdata = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_ReportPlayer
|
||
|
//
|
||
|
message CMsgGC_ReportPlayer
|
||
|
{
|
||
|
enum EReason
|
||
|
{
|
||
|
kReason_INVALID = 0;
|
||
|
kReason_CHEATING = 1;
|
||
|
kReason_IDLE = 2;
|
||
|
kReason_HARASSMENT = 3;
|
||
|
kReason_GRIEFING = 4;
|
||
|
|
||
|
// add more reasons above this and update the count
|
||
|
kReason_COUNT = 5;
|
||
|
};
|
||
|
optional uint32 account_id_target = 1;
|
||
|
optional EReason reason = 2;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// CSOTFMatchResultPlayerStats
|
||
|
//
|
||
|
message CSOTFMatchResultPlayerStats
|
||
|
{
|
||
|
optional uint64 match_id = 1 [ (key_field) = true ];
|
||
|
optional uint32 account_id = 2 [ (key_field) = true ];
|
||
|
optional int32 match_group = 3 [ (key_field) = true ];
|
||
|
optional uint32 endtime = 4;
|
||
|
optional uint32 season_id = 5;
|
||
|
optional uint32 status = 6;
|
||
|
optional uint32 party_id = 7;
|
||
|
optional uint32 team = 8;
|
||
|
optional uint32 score = 9;
|
||
|
optional uint32 ping = 10;
|
||
|
optional uint32 flags = 11;
|
||
|
optional uint32 display_rating = 12;
|
||
|
optional int32 display_rating_change = 13;
|
||
|
optional uint32 rank = 14;
|
||
|
optional uint32 classes_played = 15;
|
||
|
optional uint32 kills = 16;
|
||
|
optional uint32 deaths = 17;
|
||
|
optional uint32 damage = 18;
|
||
|
optional uint32 healing = 19;
|
||
|
optional uint32 support = 20;
|
||
|
optional uint32 score_medal = 21;
|
||
|
optional uint32 kills_medal = 22;
|
||
|
optional uint32 damage_medal = 23;
|
||
|
optional uint32 healing_medal = 24;
|
||
|
optional uint32 support_medal = 25;
|
||
|
optional uint32 map_index = 26;
|
||
|
};
|
||
|
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCRequestMatchMakerStats
|
||
|
//
|
||
|
message CMsgGCRequestMatchMakerStats
|
||
|
{};
|
||
|
|
||
|
message CMsgGCDataCenterPopulation
|
||
|
{
|
||
|
optional string name = 1; // data center name
|
||
|
optional float health_ratio = 2; // population health ratio with best ping in the data center
|
||
|
};
|
||
|
|
||
|
message CMsgGCMatchGroupDataCenterPopulation
|
||
|
{
|
||
|
repeated CMsgGCDataCenterPopulation data_center_population = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCMatchMakerStatsResponse
|
||
|
//
|
||
|
message CMsgGCMatchMakerStatsResponse
|
||
|
{
|
||
|
repeated uint32 map_count = 1;
|
||
|
|
||
|
repeated CMsgGCMatchGroupDataCenterPopulation matchgroup_data_center_population = 2;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCMatchHistoryLoad
|
||
|
//
|
||
|
message CMsgGCMatchHistoryLoad
|
||
|
{
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGCDataCenterPing_Update
|
||
|
//
|
||
|
message CMsgGCDataCenterPing_Update
|
||
|
{
|
||
|
enum Status
|
||
|
{
|
||
|
Invalid = 0;
|
||
|
Normal = 1;
|
||
|
Unreachable = 2; // Value is stale or not provided, DC is unreachable
|
||
|
FallbackToDCPing = 3; // Couldn't ping router directly, this is a less-accurate DC ping value
|
||
|
};
|
||
|
message PingEntry
|
||
|
{
|
||
|
optional string name = 1; // data center name
|
||
|
optional uint32 ping = 2; // ping to the data center
|
||
|
// If omitted, assume we have a normal ping.
|
||
|
optional Status ping_status = 3 [ default = Normal ];
|
||
|
};
|
||
|
repeated PingEntry pingdata = 1;
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_KickPlayerFromLobby
|
||
|
//
|
||
|
message CMsgGC_KickPlayerFromLobby
|
||
|
{
|
||
|
optional uint64 targetID = 1; // kick target ID
|
||
|
};
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_RematchRequest
|
||
|
// DEPRECATED - New path is NewMatchForLobby
|
||
|
//
|
||
|
// message CMsgGCRematchRequest
|
||
|
// {
|
||
|
// message PartyEntry
|
||
|
// {
|
||
|
// optional uint64 party_id = 1; // party's ID
|
||
|
// optional uint32 team = 2; // party's assigned team
|
||
|
// optional uint64 leader_steam_id = 3; // party leader's steamID
|
||
|
// };
|
||
|
|
||
|
// repeated PartyEntry party = 1; // all of the parties who want a rematch
|
||
|
// optional uint32 match_group = 2; // match group that we want
|
||
|
// optional CMsgCasualMatchmakingSearchCriteria casual_criteria = 3; // casual criteria for the new match
|
||
|
// };
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_RematchRequestResponse
|
||
|
// DEPRECATED - New path is NewMatchForLobby
|
||
|
//
|
||
|
// message CMsgGCRematchRequestResponse
|
||
|
// {
|
||
|
// optional bool success = 1; // Did we succeed?
|
||
|
// }
|
||
|
|
||
|
enum SurveyQuestionType
|
||
|
{
|
||
|
QUESTION_MATCH_QUALITY = 0;
|
||
|
QUESTION_MAP_QUALITY = 1;
|
||
|
QUESTION_COMP_INQUIRY = 2;
|
||
|
QUESTION_CASUAL_INQUIRY = 3;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_SurveyQuestionRequest
|
||
|
//
|
||
|
message CMsgGCSurveyRequest
|
||
|
{
|
||
|
optional SurveyQuestionType question_type = 1;
|
||
|
optional uint64 match_id = 2;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_SurveyQuestionResponse
|
||
|
//
|
||
|
message CMsgGCSurveyResponse
|
||
|
{
|
||
|
optional SurveyQuestionType question_type = 1;
|
||
|
optional uint64 match_id = 2;
|
||
|
optional int32 response = 3;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_NewMatchForLobbyRequest
|
||
|
//
|
||
|
message CMsgGCNewMatchForLobbyRequest
|
||
|
{
|
||
|
optional uint64 current_match_id = 1;
|
||
|
optional uint32 next_map_id = 2;
|
||
|
optional uint64 lobby_id = 3;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_NewMatchForLobbyResponse
|
||
|
//
|
||
|
message CMsgGCNewMatchForLobbyResponse
|
||
|
{
|
||
|
optional bool success = 1;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_ChangeMatchPlayerTeamsRequest
|
||
|
//
|
||
|
message CMsgGCChangeMatchPlayerTeamsRequest
|
||
|
{
|
||
|
message Member
|
||
|
{
|
||
|
optional uint64 member_id = 1;
|
||
|
optional TF_GC_TEAM new_team = 2 [ default = TF_GC_TEAM_NOTEAM ];
|
||
|
}
|
||
|
|
||
|
optional uint64 match_id = 1;
|
||
|
optional uint64 lobby_id = 2;
|
||
|
repeated Member member = 3;
|
||
|
}
|
||
|
|
||
|
//
|
||
|
// k_EMsgGC_ChangeMatchPlayerTeamsResponse
|
||
|
//
|
||
|
message CMsgGCChangeMatchPlayerTeamsResponse
|
||
|
{
|
||
|
optional bool success = 1;
|
||
|
}
|
||
|
|
||
|
// End of File
|