Esempio n. 1
0
 public static bool AddPromoItems(out SteamInventoryResult_t pResultHandle, SteamItemDef_t[] pArrayItemDefs, uint unArrayLength)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_AddPromoItems(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle, pArrayItemDefs, unArrayLength));
 }
Esempio n. 2
0
 /// <summary>
 /// <para> Returns item definition ids and their prices in the user's local currency.</para>
 /// <para> Need to call RequestPrices() first.</para>
 /// </summary>
 public static bool GetItemsWithPrices(SteamItemDef_t[] pArrayItemDefs, ulong[] pPrices, uint unArrayLength)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_GetItemsWithPrices(CSteamGameServerAPIContext.GetSteamInventory(), pArrayItemDefs, pPrices, unArrayLength));
 }
Esempio n. 3
0
 /// <summary>
 /// <para> AddPromoItem() / AddPromoItems() are restricted versions of GrantPromoItems(). Instead of</para>
 /// <para> scanning for all eligible promotional items, the check is restricted to a single item</para>
 /// <para> definition or set of item definitions. This can be useful if your game has custom UI for</para>
 /// <para> showing a specific promo item to the user.</para>
 /// </summary>
 public static bool AddPromoItem(out SteamInventoryResult_t pResultHandle, SteamItemDef_t itemDef)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_AddPromoItem(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle, itemDef));
 }
Esempio n. 4
0
 /// <summary>
 /// <para> ITEM DEFINITIONS</para>
 /// <para> Item definitions are a mapping of "definition IDs" (integers between 1 and 1000000)</para>
 /// <para> to a set of string properties. Some of these properties are required to display items</para>
 /// <para> on the Steam community web site. Other properties can be defined by applications.</para>
 /// <para> Use of these functions is optional; there is no reason to call LoadItemDefinitions</para>
 /// <para> if your game hardcodes the numeric definition IDs (eg, purple face mask = 20, blue</para>
 /// <para> weapon mod = 55) and does not allow for adding new item types without a client patch.</para>
 /// <para> LoadItemDefinitions triggers the automatic load and refresh of item definitions.</para>
 /// <para> Every time new item definitions are available (eg, from the dynamic addition of new</para>
 /// <para> item types while players are still in-game), a SteamInventoryDefinitionUpdate_t</para>
 /// <para> callback will be fired.</para>
 /// </summary>
 public static bool LoadItemDefinitions()
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_LoadItemDefinitions(CSteamGameServerAPIContext.GetSteamInventory()));
 }
Esempio n. 5
0
 /// <summary>
 /// <para> Request the list of "eligible" promo items that can be manually granted to the given</para>
 /// <para> user.  These are promo items of type "manual" that won't be granted automatically.</para>
 /// <para> An example usage of this is an item that becomes available every week.</para>
 /// </summary>
 public static SteamAPICall_t RequestEligiblePromoItemDefinitionsIDs(CSteamID steamID)
 {
     InteropHelp.TestIfAvailableGameServer();
     return((SteamAPICall_t)NativeMethods.ISteamInventory_RequestEligiblePromoItemDefinitionsIDs(CSteamGameServerAPIContext.GetSteamInventory(), steamID));
 }
Esempio n. 6
0
 /// <summary>
 /// <para> TransferItemQuantity() is intended for use with items which are "stackable" (can have</para>
 /// <para> quantity greater than one). It can be used to split a stack into two, or to transfer</para>
 /// <para> quantity from one stack into another stack of identical items. To split one stack into</para>
 /// <para> two, pass k_SteamItemInstanceIDInvalid for itemIdDest and a new item will be generated.</para>
 /// </summary>
 public static bool TransferItemQuantity(out SteamInventoryResult_t pResultHandle, SteamItemInstanceID_t itemIdSource, uint unQuantity, SteamItemInstanceID_t itemIdDest)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_TransferItemQuantity(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle, itemIdSource, unQuantity, itemIdDest));
 }
Esempio n. 7
0
 /// <summary>
 /// <para> Playtime credit must be consumed and turned into item drops by your game. Only item</para>
 /// <para> definitions which are marked as "playtime item generators" can be spawned. The call</para>
 /// <para> will return an empty result set if there is not enough playtime credit for a drop.</para>
 /// <para> Your game should call TriggerItemDrop at an appropriate time for the user to receive</para>
 /// <para> new items, such as between rounds or while the player is dead. Note that players who</para>
 /// <para> hack their clients could modify the value of "dropListDefinition", so do not use it</para>
 /// <para> to directly control rarity.</para>
 /// <para> See your Steamworks configuration to set playtime drop rates for individual itemdefs.</para>
 /// <para> The client library will suppress too-frequent calls to this method.</para>
 /// </summary>
 public static bool TriggerItemDrop(out SteamInventoryResult_t pResultHandle, SteamItemDef_t dropListDefinition)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_TriggerItemDrop(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle, dropListDefinition));
 }
Esempio n. 8
0
 /// <summary>
 /// <para> Submit the update request by handle</para>
 /// </summary>
 public static bool SubmitUpdateProperties(SteamInventoryUpdateHandle_t handle, out SteamInventoryResult_t pResultHandle)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_SubmitUpdateProperties(CSteamGameServerAPIContext.GetSteamInventory(), handle, out pResultHandle));
 }
Esempio n. 9
0
 /// <summary>
 /// <para> Returns true if the result belongs to the target steam ID, false if the</para>
 /// <para> result does not. This is important when using DeserializeResult, to verify</para>
 /// <para> that a remote player is not pretending to have a different user's inventory.</para>
 /// </summary>
 public static bool CheckResultSteamID(SteamInventoryResult_t resultHandle, CSteamID steamIDExpected)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_CheckResultSteamID(CSteamGameServerAPIContext.GetSteamInventory(), resultHandle, steamIDExpected));
 }
Esempio n. 10
0
 /// <summary>
 /// <para> Retrieves the price for the item definition id</para>
 /// <para> Returns false if there is no price stored for the item definition.</para>
 /// </summary>
 public static bool GetItemPrice(SteamItemDef_t iDefinition, out ulong pCurrentPrice, out ulong pBasePrice)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_GetItemPrice(CSteamGameServerAPIContext.GetSteamInventory(), iDefinition, out pCurrentPrice, out pBasePrice));
 }
Esempio n. 11
0
 /// <summary>
 /// <para> Create a request to update properties on items</para>
 /// </summary>
 public static SteamInventoryUpdateHandle_t StartUpdateProperties()
 {
     InteropHelp.TestIfAvailableGameServer();
     return((SteamInventoryUpdateHandle_t)NativeMethods.ISteamInventory_StartUpdateProperties(CSteamGameServerAPIContext.GetSteamInventory()));
 }
Esempio n. 12
0
 /// <summary>
 /// <para> Returns the number of items with prices.  Need to call RequestPrices() first.</para>
 /// </summary>
 public static uint GetNumItemsWithPrices()
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_GetNumItemsWithPrices(CSteamGameServerAPIContext.GetSteamInventory()));
 }
Esempio n. 13
0
 /// <summary>
 /// <para> Request current prices for all applicable item definitions</para>
 /// </summary>
 public static SteamAPICall_t RequestPrices()
 {
     InteropHelp.TestIfAvailableGameServer();
     return((SteamAPICall_t)NativeMethods.ISteamInventory_RequestPrices(CSteamGameServerAPIContext.GetSteamInventory()));
 }
Esempio n. 14
0
 /// <summary>
 /// <para> Copies the contents of a result set into a flat array. The specific</para>
 /// <para> contents of the result set depend on which query which was used.</para>
 /// </summary>
 public static bool GetResultItems(SteamInventoryResult_t resultHandle, SteamItemDetails_t[] pOutItemsArray, ref uint punOutItemsArraySize)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_GetResultItems(CSteamGameServerAPIContext.GetSteamInventory(), resultHandle, pOutItemsArray, ref punOutItemsArraySize));
 }
Esempio n. 15
0
 /// <summary>
 /// <para> ConsumeItem() removes items from the inventory, permanently. They cannot be recovered.</para>
 /// <para> Not for the faint of heart - if your game implements item removal at all, a high-friction</para>
 /// <para> UI confirmation process is highly recommended.</para>
 /// </summary>
 public static bool ConsumeItem(out SteamInventoryResult_t pResultHandle, SteamItemInstanceID_t itemConsume, uint unQuantity)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_ConsumeItem(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle, itemConsume, unQuantity));
 }
Esempio n. 16
0
 /// <summary>
 /// <para> Destroys a result handle and frees all associated memory.</para>
 /// </summary>
 public static void DestroyResult(SteamInventoryResult_t resultHandle)
 {
     InteropHelp.TestIfAvailableGameServer();
     NativeMethods.ISteamInventory_DestroyResult(CSteamGameServerAPIContext.GetSteamInventory(), resultHandle);
 }
Esempio n. 17
0
 /// <summary>
 /// <para> ExchangeItems() is an atomic combination of item generation and consumption.</para>
 /// <para> It can be used to implement crafting recipes or transmutations, or items which unpack</para>
 /// <para> themselves into other items (e.g., a chest).</para>
 /// <para> Exchange recipes are defined in the ItemDef, and explicitly list the required item</para>
 /// <para> types and resulting generated type.</para>
 /// <para> Exchange recipes are evaluated atomically by the Inventory Service; if the supplied</para>
 /// <para> components do not match the recipe, or do not contain sufficient quantity, the</para>
 /// <para> exchange will fail.</para>
 /// </summary>
 public static bool ExchangeItems(out SteamInventoryResult_t pResultHandle, SteamItemDef_t[] pArrayGenerate, uint[] punArrayGenerateQuantity, uint unArrayGenerateLength, SteamItemInstanceID_t[] pArrayDestroy, uint[] punArrayDestroyQuantity, uint unArrayDestroyLength)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_ExchangeItems(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle, pArrayGenerate, punArrayGenerateQuantity, unArrayGenerateLength, pArrayDestroy, punArrayDestroyQuantity, unArrayDestroyLength));
 }
Esempio n. 18
0
 /// <summary>
 /// <para> Captures the state of a subset of the current user's Steam inventory,</para>
 /// <para> identified by an array of item instance IDs. The results from this call</para>
 /// <para> can be serialized and passed to other players to "prove" that the current</para>
 /// <para> user owns specific items, without exposing the user's entire inventory.</para>
 /// <para> For example, you could call GetItemsByID with the IDs of the user's</para>
 /// <para> currently equipped cosmetic items and serialize this to a buffer, and</para>
 /// <para> then transmit this buffer to other players upon joining a game.</para>
 /// </summary>
 public static bool GetItemsByID(out SteamInventoryResult_t pResultHandle, SteamItemInstanceID_t[] pInstanceIDs, uint unCountInstanceIDs)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_GetItemsByID(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle, pInstanceIDs, unCountInstanceIDs));
 }
Esempio n. 19
0
 /// <summary>
 /// <para> TIMED DROPS AND PLAYTIME CREDIT</para>
 /// <para> Deprecated. Calling this method is not required for proper playtime accounting.</para>
 /// </summary>
 public static void SendItemDropHeartbeat()
 {
     InteropHelp.TestIfAvailableGameServer();
     NativeMethods.ISteamInventory_SendItemDropHeartbeat(CSteamGameServerAPIContext.GetSteamInventory());
 }
Esempio n. 20
0
 /// <summary>
 /// <para> RESULT SERIALIZATION AND AUTHENTICATION</para>
 /// <para> Serialized result sets contain a short signature which can't be forged</para>
 /// <para> or replayed across different game sessions. A result set can be serialized</para>
 /// <para> on the local client, transmitted to other players via your game networking,</para>
 /// <para> and deserialized by the remote players. This is a secure way of preventing</para>
 /// <para> hackers from lying about posessing rare/high-value items.</para>
 /// <para> Serializes a result set with signature bytes to an output buffer. Pass</para>
 /// <para> NULL as an output buffer to get the required size via punOutBufferSize.</para>
 /// <para> The size of a serialized result depends on the number items which are being</para>
 /// <para> serialized. When securely transmitting items to other players, it is</para>
 /// <para> recommended to use "GetItemsByID" first to create a minimal result set.</para>
 /// <para> Results have a built-in timestamp which will be considered "expired" after</para>
 /// <para> an hour has elapsed. See DeserializeResult for expiration handling.</para>
 /// </summary>
 public static bool SerializeResult(SteamInventoryResult_t resultHandle, byte[] pOutBuffer, out uint punOutBufferSize)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_SerializeResult(CSteamGameServerAPIContext.GetSteamInventory(), resultHandle, pOutBuffer, out punOutBufferSize));
 }
Esempio n. 21
0
 /// <summary>
 /// <para> Deprecated. This method is not supported.</para>
 /// </summary>
 public static bool TradeItems(out SteamInventoryResult_t pResultHandle, CSteamID steamIDTradePartner, SteamItemInstanceID_t[] pArrayGive, uint[] pArrayGiveQuantity, uint nArrayGiveLength, SteamItemInstanceID_t[] pArrayGet, uint[] pArrayGetQuantity, uint nArrayGetLength)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_TradeItems(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle, steamIDTradePartner, pArrayGive, pArrayGiveQuantity, nArrayGiveLength, pArrayGet, pArrayGetQuantity, nArrayGetLength));
 }
Esempio n. 22
0
 /// <summary>
 /// <para> Deserializes a result set and verifies the signature bytes. Returns false</para>
 /// <para> if bRequireFullOnlineVerify is set but Steam is running in Offline mode.</para>
 /// <para> Otherwise returns true and then delivers error codes via GetResultStatus.</para>
 /// <para> The bRESERVED_MUST_BE_FALSE flag is reserved for future use and should not</para>
 /// <para> be set to true by your game at this time.</para>
 /// <para> DeserializeResult has a potential soft-failure mode where the handle status</para>
 /// <para> is set to k_EResultExpired. GetResultItems() still succeeds in this mode.</para>
 /// <para> The "expired" result could indicate that the data may be out of date - not</para>
 /// <para> just due to timed expiration (one hour), but also because one of the items</para>
 /// <para> in the result set may have been traded or consumed since the result set was</para>
 /// <para> generated. You could compare the timestamp from GetResultTimestamp() to</para>
 /// <para> ISteamUtils::GetServerRealTime() to determine how old the data is. You could</para>
 /// <para> simply ignore the "expired" result code and continue as normal, or you</para>
 /// <para> could challenge the player with expired data to send an updated result set.</para>
 /// </summary>
 public static bool DeserializeResult(out SteamInventoryResult_t pOutResultHandle, byte[] pBuffer, uint unBufferSize, bool bRESERVED_MUST_BE_FALSE = false)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_DeserializeResult(CSteamGameServerAPIContext.GetSteamInventory(), out pOutResultHandle, pBuffer, unBufferSize, bRESERVED_MUST_BE_FALSE));
 }
Esempio n. 23
0
 /// <summary>
 /// <para> INVENTORY ASYNC RESULT MANAGEMENT</para>
 /// <para> Asynchronous inventory queries always output a result handle which can be used with</para>
 /// <para> GetResultStatus, GetResultItems, etc. A SteamInventoryResultReady_t callback will</para>
 /// <para> be triggered when the asynchronous result becomes ready (or fails).</para>
 /// <para> Find out the status of an asynchronous inventory result handle. Possible values:</para>
 /// <para>  k_EResultPending - still in progress</para>
 /// <para>  k_EResultOK - done, result ready</para>
 /// <para>  k_EResultExpired - done, result ready, maybe out of date (see DeserializeResult)</para>
 /// <para>  k_EResultInvalidParam - ERROR: invalid API call parameters</para>
 /// <para>  k_EResultServiceUnavailable - ERROR: service temporarily down, you may retry later</para>
 /// <para>  k_EResultLimitExceeded - ERROR: operation would exceed per-user inventory limits</para>
 /// <para>  k_EResultFail - ERROR: unknown / generic error</para>
 /// </summary>
 public static EResult GetResultStatus(SteamInventoryResult_t resultHandle)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_GetResultStatus(CSteamGameServerAPIContext.GetSteamInventory(), resultHandle));
 }
Esempio n. 24
0
 /// <summary>
 /// <para> GrantPromoItems() checks the list of promotional items for which the user may be eligible</para>
 /// <para> and grants the items (one time only).  On success, the result set will include items which</para>
 /// <para> were granted, if any. If no items were granted because the user isn't eligible for any</para>
 /// <para> promotions, this is still considered a success.</para>
 /// </summary>
 public static bool GrantPromoItems(out SteamInventoryResult_t pResultHandle)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_GrantPromoItems(CSteamGameServerAPIContext.GetSteamInventory(), out pResultHandle));
 }
Esempio n. 25
0
 /// <summary>
 /// <para> Starts the purchase process for the given item definitions.  The callback SteamInventoryStartPurchaseResult_t</para>
 /// <para> will be posted if Steam was able to initialize the transaction.</para>
 /// <para> Once the purchase has been authorized and completed by the user, the callback SteamInventoryResultReady_t</para>
 /// <para> will be posted.</para>
 /// </summary>
 public static SteamAPICall_t StartPurchase(SteamItemDef_t[] pArrayItemDefs, uint[] punArrayQuantity, uint unArrayLength)
 {
     InteropHelp.TestIfAvailableGameServer();
     return((SteamAPICall_t)NativeMethods.ISteamInventory_StartPurchase(CSteamGameServerAPIContext.GetSteamInventory(), pArrayItemDefs, punArrayQuantity, unArrayLength));
 }
Esempio n. 26
0
 /// <summary>
 /// <para> After handling a SteamInventoryEligiblePromoItemDefIDs_t call result, use this</para>
 /// <para> function to pull out the list of item definition ids that the user can be</para>
 /// <para> manually granted via the AddPromoItems() call.</para>
 /// </summary>
 public static bool GetEligiblePromoItemDefinitionIDs(CSteamID steamID, SteamItemDef_t[] pItemDefIDs, ref uint punItemDefIDsArraySize)
 {
     InteropHelp.TestIfAvailableGameServer();
     return(NativeMethods.ISteamInventory_GetEligiblePromoItemDefinitionIDs(CSteamGameServerAPIContext.GetSteamInventory(), steamID, pItemDefIDs, ref punItemDefIDsArraySize));
 }