source-engine/game/shared/econ/econ_gcmessages.h
FluorescentCIAAfricanAmerican 3bf9df6b27 1
2020-04-22 12:56:21 -04:00

346 lines
7.7 KiB
C

//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose: This file defines all of our over-the-wire net protocols for the
// Game Coordinator for the item system. Note that we never use types
// with undefined length (like int). Always use an explicit type
// (like int32).
//
//=============================================================================
#ifndef ITEM_GCMESSAGES_H
#define ITEM_GCMESSAGES_H
#ifdef _WIN32
#pragma once
#endif
#include "econ_gcmessages.pb.h"
#pragma pack( push, 1 )
// generic zero-length message struct
struct MsgGCEmpty_t
{
};
// k_EMsgGCSetItemPosition
struct MsgGCSetItemPosition_t
{
uint64 m_unItemID;
uint32 m_unNewPosition;
};
// k_EMsgGCCraft
struct MsgGCCraft_t
{
int16 m_nRecipeDefIndex;
uint16 m_nItemCount;
// list of m_nItemCount uint64 item IDs
};
// k_EMsgGCDelete
struct MsgGCDelete_t
{
uint64 m_unItemID;
};
// k_EMsgGCCraftResponse
struct MsgGCStandardResponse_t
{
int16 m_nResponseIndex;
uint32 m_eResponse;
};
// k_EMsgGCVerifyCacheSubscription
struct MsgGCVerifyCacheSubscription_t
{
uint64 m_ulSteamID;
};
// k_EMsgGCNameItem
struct MsgGCNameItem_t
{
uint64 m_unToolItemID; // the Nametag item
uint64 m_unSubjectItemID; // the item to be renamed
bool m_bDescription;
// Varchar: Item name
};
// k_EMsgGCNameBaseItem
struct MsgGCNameBaseItem_t
{
uint64 m_unToolItemID; // the Nametag item
uint32 m_unBaseItemDefinitionID; // the base item definition to be renamed
bool m_bDescription;
// Varchar: Item name
};
// k_EMsgGCUnlockCrate
struct MsgGCUnlockCrate_t
{
uint64 m_unToolItemID; // the crate key
uint64 m_unSubjectItemID; // the crate to be decoded
};
// k_EMsgGCPaintItem
struct MsgGCPaintItem_t
{
uint64 m_unToolItemID; // the Paint Can item
uint64 m_unSubjectItemID; // the item to be painted
};
// k_EMsgGCGiftWrapItem
struct MsgGCGiftWrapItem_t
{
uint64 m_unToolItemID; // the Gift Wrap item
uint64 m_unSubjectItemID; // the item to be wrapped
};
// k_EMsgGCDeliverGift
struct MsgGCDeliverGift_t
{
uint64 m_unGiftID;
uint64 m_ulGiverSteamID;
uint64 m_ulTargetSteamID;
};
// k_EMsgGCUnwrapGiftRequest
struct MsgGCUnwrapGiftRequest_t
{
uint64 m_unItemID;
};
// k_EMsgGCMOTDRequest
struct MsgGCMOTDRequest_t
{
RTime32 m_nLastMOTDRequest; // Time at which the client last asked for MOTDs. GC will send back all MOTDs posted since.
int16 m_eLanguage;
};
// k_EMsgGCMOTDRequestResponse
struct MsgGCMOTDRequestResponse_t
{
int16 m_nEntries;
};
// k_EMsgGCCustomizeItemTexture
struct MsgGCCustomizeItemTexture_t
{
uint64 m_unToolItemID; // the tool
uint64 m_unSubjectItemID; // the item wants the texture
uint64 m_unImageUGCHandle; // cloud ID of image file (UGCHandle_t)
};
// k_EMsgGCSetItemStyle
struct MsgGCSetItemStyle_t
{
uint64 m_unItemID;
uint8 m_iStyle;
};
// k_EMsgGCItemPreviewCheckStatus
struct MsgGCCheckItemPreviewStatus_t
{
uint32 m_unItemDefIndex;
};
// k_EMsgGCItemPreviewCheckStatusResponse
struct MsgGCItemPreviewCheckStatusResponse_t
{
uint32 m_unItemDefIndex;
uint32 m_eResponse;
RTime32 m_timePreviewTime;
};
// k_EMsgGCItemPreviewRequest
struct MsgGCItemPreviewRequest_t
{
uint32 m_unItemDefIndex;
};
// k_EMsgGCItemPreviewRequestResponse
struct MsgGCItemPreviewRequestResponse_t
{
uint32 m_unItemDefIndex;
uint32 m_eResponse;
};
// k_EMsgGCItemPreviewExpire
struct MsgGCItemPreviewExpire_t
{
};
// k_EMsgGCItemPreviewExpireNotification
struct MsgGCItemPreviewExpireNotification_t
{
uint32 m_unItemDefIndex;
};
//-----------------------------------------------------------------------------
// k_EMsgGCUseItemResponse
enum EGCMsgUseItemResponse
{
k_EGCMsgUseItemResponse_ItemUsed = 0,
k_EGCMsgUseItemResponse_GiftNoOtherPlayers = 1,
k_EGCMsgUseItemResponse_ServerError = 2,
k_EGCMsgUseItemResponse_MiniGameAlreadyStarted = 3,
k_EGCMsgUseItemResponse_ItemUsed_ItemsGranted = 4,
k_EGCMsgUseItemResponse_CannotBeUsedByAccount = 5,
k_EGCMsgUseItemResponse_ForceSizeInt = 0x7FFFFFFF
};
// k_EMsgGCUseItemResponse
struct MsgGCUseItemResponse_t
{
uint32 m_eResponse;
};
// k_EMsgGCSpawnItem
struct MsgGCSpawnItem_t
{
uint64 m_ulInitiatorSteamID;
uint32 m_unItemDefinitionID;
// other data dynamically added:
// string of initiator name
};
// k_EMsgGCRespawnPostLoadoutChange
struct MsgGCRespawnPostLoadoutChange_t
{
uint64 m_ulInitiatorSteamID;
};
// k_EMsgGCRemoveItemName
struct MsgGCRemoveItemName_t
{
uint64 m_unItemID;
bool m_bDescription;
};
//-----------------------------------------------------------------------------
// Trading
// k_EMsgGCTrading_InitiateTradeRequest
struct MsgGCTrading_InitiateTradeRequest_t
{
uint32 m_unTradeRequestID;
uint64 m_ulOtherSteamID;
// @note player A's name as string when sent to party B
};
enum EGCMsgInitiateTradeResponse
{
k_EGCMsgInitiateTradeResponse_Accepted = 0,
k_EGCMsgInitiateTradeResponse_Declined = 1,
k_EGCMsgInitiateTradeResponse_VAC_Banned_Initiator = 2,
k_EGCMsgInitiateTradeResponse_VAC_Banned_Target = 3,
k_EGCMsgInitiateTradeResponse_Target_Already_Trading = 4,
k_EGCMsgInitiateTradeResponse_Disabled = 5,
k_EGCMsgInitiateTradeResponse_NotLoggedIn = 6,
k_EGCMsgInitiateTradeResponse_Cancel = 7,
k_EGCMsgInitiateTradeResponse_TooSoon = 8,
k_EGCMsgInitiateTradeResponse_TooSoonPenalty = 9,
k_EGCMsgInitiateTradeResponse_Trade_Banned_Initiator = 10,
k_EGCMsgInitiateTradeResponse_Trade_Banned_Target = 11,
k_EGCMsgInitiateTradeResponse_Free_Account_Initiator_DEPRECATED = 12, // free accounts can initiate trades now
k_EGCMsgInitiateTradeResponse_Shared_Account_Initiator= 13,
k_EGCMsgInitiateTradeResponse_Service_Unavailable = 14,
k_EGCMsgInitiateTradeResponse_Target_Blocked = 15,
k_EGCMsgInitiateTradeResponse_NeedVerifiedEmail = 16,
k_EGCMsgInitiateTradeResponse_NeedSteamGuard = 17,
k_EGCMsgInitiateTradeResponse_SteamGuardDuration = 18,
k_EGCMsgInitiateTradeResponse_TheyCannotTrade = 19,
k_EGCMsgInitiateTradeResponse_Recent_Password_Reset = 20,
k_EGCMsgInitiateTradeResponse_Using_New_Device = 21,
k_EGCMsgInitiateTradeResponse_Sent_Invalid_Cookie = 22,
k_EGCMsgInitiateTradeResponse_Count,
k_EGCMsgInitiateTradeResponse_ForceSizeInt = 0x7FFFFFFF
};
// k_EMsgGCTrading_InitiateTradeResponse
struct MsgGCTrading_InitiateTradeResponse_t
{
uint32 m_eResponse;
uint32 m_unTradeRequestID;
};
// k_EMsgGCTrading_StartSession
struct MsgGCTrading_StartSession_t
{
uint32 m_unSessionVersion;
uint64 m_ulSteamIDPartyA;
uint64 m_ulSteamIDPartyB;
// @note strings from player names will be added to the message
};
// k_EMsgGCTrading_CancelSession
struct MsgGCTrading_CancelSession_t
{
};
// k_EMsgGCUsedClaimCodeItem
struct MsgGCUsedClaimCodeItem_t
{
// string of URL
};
//-----------------------------------------------------------------------------
// ServerBrowser messages
enum EGCMsgServerBrowser
{
k_EGCMsgServerBrowser_FromServerBrowser = 0,
k_EGCMsgServerBrowser_FromAutoAskDialog = 1,
};
// k_EMsgGCServerBrowser_FavoriteServer
// k_EMsgGCServerBrowser_BlacklistServer
struct MsgGCServerBrowser_Server_t
{
uint32 m_unIP;
int m_usPort;
uint8 m_ubSource; // 0=serverbrowser, 1=auto-ask dialog
};
//-----------------------------------------------------------------------------
// Public facing loot lists.
// k_EMsgGC_RevolvingLootList
struct MsgGC_RevolvingLootList_t
{
uint8 m_usListID; // Id of this list.
// Var Data:
// Serialized Lootlist KV
};
// k_EMsgGCLookupAccount
struct MsgGCLookupAccount_t
{
uint16 m_uiFindType;
// Var Data
// string containing Persona / URL / etc
};
// k_EMsgGCLookupAccountName
struct MsgGCLookupAccountName_t
{
uint32 m_unAccountID;
};
// k_EMsgGCLookupAccountNameResponse
struct MsgGCLookupAccountNameResponse_t
{
uint32 m_unAccountID;
// string containing persona name
};
#pragma pack( pop )
#endif