Difference between revisions of "WebAPI/GetPlayerItems"

From Team Fortress Wiki
Jump to: navigation, search
(Urgh)
(Documented equipped indexes. What's that Robin? Oh no don't worry about responding to the mail, I wanted to sift through my backpack feed manually anyway and get confused by an off-by-one error.)
Line 20: Line 20:
  
 
;'''num_backpack_slots''': The number of backpack slots this user has.
 
;'''num_backpack_slots''': The number of backpack slots this user has.
 +
 
;'''items''': An object containing a list of associative arrays.
 
;'''items''': An object containing a list of associative arrays.
 +
 
:;'''id''': The unique ID of the specific item.
 
:;'''id''': The unique ID of the specific item.
 +
 
:;'''original_id''': The ID of the item before it was customized, traded, or otherwise changed.
 
:;'''original_id''': The ID of the item before it was customized, traded, or otherwise changed.
 +
 
:;'''defindex''': The defindex of the item, as found in the item array returned from [[../GetSchema|GetSchema]].
 
:;'''defindex''': The defindex of the item, as found in the item array returned from [[../GetSchema|GetSchema]].
 +
 
:;'''level''': The arbitrary "level" value of the item as displayed in the inventory.
 
:;'''level''': The arbitrary "level" value of the item as displayed in the inventory.
 +
 
:;'''quantity''': The number of "uses" an item has, generally only has a value in excess of '1' on "usable items", such as the [[Dueling Mini-Game]].
 
:;'''quantity''': The number of "uses" an item has, generally only has a value in excess of '1' on "usable items", such as the [[Dueling Mini-Game]].
 +
 
:;'''flag_cannot_trade''': A boolean value that is true if the item cannot be traded. This is true for items granted by an [[achievement]], [[purchase]]d items, and certain [[promotional items]].
 
:;'''flag_cannot_trade''': A boolean value that is true if the item cannot be traded. This is true for items granted by an [[achievement]], [[purchase]]d items, and certain [[promotional items]].
:;'''inventory''': An inventory token as described [[#Inventory_Token|here]], or '0' if the item has been awarded and not yet found (placed in the backpack).
+
 
 +
:;'''inventory''' (<span style="color: red;">Partially deprecated</span><ref>Assume fields for equipped classes to be incorrect, favor '''equipped'''</ref>): An inventory token as described [[#Inventory_Token|here]], or '0' if the item has been awarded and not yet found (placed in the backpack).
 +
 
 
:;'''quality''': The [[Rarity|quality]] of the item (see definition in [[../GetSchema|GetSchema]]).
 
:;'''quality''': The [[Rarity|quality]] of the item (see definition in [[../GetSchema|GetSchema]]).
 +
 
:;'''custom_name''' ''(<span style="color: red;">Optional</span>)'': The item's custom name if it has one.
 
:;'''custom_name''' ''(<span style="color: red;">Optional</span>)'': The item's custom name if it has one.
 +
 
:;'''custom_desc''' ''(<span style="color: red;">Optional</span>)'': The item's custom description if it has one.
 
:;'''custom_desc''' ''(<span style="color: red;">Optional</span>)'': The item's custom description if it has one.
 +
 
:;'''contained_item''' ''(<span style="color: red;">Optional</span>)'': All the information for the item that this item contains for gift-wrapped items.
 
:;'''contained_item''' ''(<span style="color: red;">Optional</span>)'': All the information for the item that this item contains for gift-wrapped items.
 +
 
:;'''style''' ''(<span style="color: red;">Optional</span>)'': An integer that can be used as an index to the item's [[../GetSchema#styles|style list]].
 
:;'''style''' ''(<span style="color: red;">Optional</span>)'': An integer that can be used as an index to the item's [[../GetSchema#styles|style list]].
 +
 
:;'''attributes''' ''(<span style="color: red;">Optional</span>)'': If the item has additional effects to the ones normally associated with it as described in GetSchema, contains a list of associative arrays.
 
:;'''attributes''' ''(<span style="color: red;">Optional</span>)'': If the item has additional effects to the ones normally associated with it as described in GetSchema, contains a list of associative arrays.
 
::;'''defindex''': The index to the attributes definition in the schema, e.g. 133 for the medal number attribute for the [[Gentle Manne's Service Medal]].
 
::;'''defindex''': The index to the attributes definition in the schema, e.g. 133 for the medal number attribute for the [[Gentle Manne's Service Medal]].
Line 40: Line 54:
 
:::;'''steamid''': The specified user's unique 64-bit Steam ID.
 
:::;'''steamid''': The specified user's unique 64-bit Steam ID.
 
:::;'''personaname''': The specified user's current name on Steam.
 
:::;'''personaname''': The specified user's current name on Steam.
 +
 
:;'''equipped''' ''(<span style="color: red;">Optional</span>)'': If the item is equipped, contains an array of equip information
 
:;'''equipped''' ''(<span style="color: red;">Optional</span>)'': If the item is equipped, contains an array of equip information
 
::;'''class''': The class the weapon is equipped to (numeric index).
 
::;'''class''': The class the weapon is equipped to (numeric index).
 +
:::;0: Scout
 +
:::;1: Scout <ref>This is probably the correct mapping for the scout and all equipped fields with 0 in it will probably have this as well. I'm guessing this is either an off-by-one bug or a workaround of it</ref>
 +
:::;2: Sniper
 +
:::;3: Soldier
 +
:::;4: Demoman
 +
:::;5: Medic
 +
:::;6: Heavy
 +
:::;7: Pyro
 +
:::;8: Spy
 +
:::;9: Engineer
 
::;'''slot''': The slot the weapon is equipped in (numeric index).
 
::;'''slot''': The slot the weapon is equipped in (numeric index).
 +
:::;0: Primary
 +
:::;1: Secondary
 +
:::;2: Melee
 +
:::;7: Head
 +
:::;8: Misc 1
 +
:::;9: Action
 +
:::;10: Misc 2
 +
 +
== Notes ==
 +
<references/>
  
== Inventory token ==
+
=== Inventory token ===
 
The '''inventory token''' is a combination of class loadout flags and position in the player's backpack. This unsigned 32-bit integer is split into two two-byte words. The high word contains flags for each class. 1-bit in a class's slot indicates that the item is equipped in the appropriate loadout slot for that class. The low word contains the backpack position with '0' if the item has been awarded, but not yet found (placed in the backpack), '1' being the upper left slot, '2' the second slot from the left on the top row, etc. Here it is visually:
 
The '''inventory token''' is a combination of class loadout flags and position in the player's backpack. This unsigned 32-bit integer is split into two two-byte words. The high word contains flags for each class. 1-bit in a class's slot indicates that the item is equipped in the appropriate loadout slot for that class. The low word contains the backpack position with '0' if the item has been awarded, but not yet found (placed in the backpack), '1' being the upper left slot, '2' the second slot from the left on the top row, etc. Here it is visually:
  

Revision as of 13:11, 6 November 2011

This documentation is for version v0001 of the WebAPI (GetPlayerItems). This method returns the specified player's backpack content.

URL

http://api.steampowered.com/IEconItems_<ID>/GetPlayerItems/v0001/

See the ID list for a valid ID.

Method-specific parameters

SteamID
The 64-bit ID of the user the backpack will be retrieved for.

Status codes

  • 1: OK. Data returned as specified below.
  • 8 ("SteamID parameter was missing"): The "steamID" parameter of the URL was not included, or if present was not a valid SteamID64 value.
  • 15 ("Permission denied"): The player's profile is set to "Private".
  • 18 ("Unknown account"): The "steamID" parameter was not registered to an account.

Result data

A list of the player's items is returned as follows:

num_backpack_slots
The number of backpack slots this user has.
items
An object containing a list of associative arrays.
id
The unique ID of the specific item.
original_id
The ID of the item before it was customized, traded, or otherwise changed.
defindex
The defindex of the item, as found in the item array returned from GetSchema.
level
The arbitrary "level" value of the item as displayed in the inventory.
quantity
The number of "uses" an item has, generally only has a value in excess of '1' on "usable items", such as the Dueling Mini-Game.
flag_cannot_trade
A boolean value that is true if the item cannot be traded. This is true for items granted by an achievement, purchased items, and certain promotional items.
inventory (Partially deprecated[1])
An inventory token as described here, or '0' if the item has been awarded and not yet found (placed in the backpack).
quality
The quality of the item (see definition in GetSchema).
custom_name (Optional)
The item's custom name if it has one.
custom_desc (Optional)
The item's custom description if it has one.
contained_item (Optional)
All the information for the item that this item contains for gift-wrapped items.
style (Optional)
An integer that can be used as an index to the item's style list.
attributes (Optional)
If the item has additional effects to the ones normally associated with it as described in GetSchema, contains a list of associative arrays.
defindex
The index to the attributes definition in the schema, e.g. 133 for the medal number attribute for the Gentle Manne's Service Medal.
value
The value for this attribute for this item, e.g. the medal number for the Gentle Manne's Service Medal.
float_value (Optional)
The floating point value for this attribute if it has one.
account_info (Optional)
Set on attributes with a Steam ID as the value.
steamid
The specified user's unique 64-bit Steam ID.
personaname
The specified user's current name on Steam.
equipped (Optional)
If the item is equipped, contains an array of equip information
class
The class the weapon is equipped to (numeric index).
0
Scout
1
Scout [2]
2
Sniper
3
Soldier
4
Demoman
5
Medic
6
Heavy
7
Pyro
8
Spy
9
Engineer
slot
The slot the weapon is equipped in (numeric index).
0
Primary
1
Secondary
2
Melee
7
Head
8
Misc 1
9
Action
10
Misc 2

Notes

  1. Assume fields for equipped classes to be incorrect, favor equipped
  2. This is probably the correct mapping for the scout and all equipped fields with 0 in it will probably have this as well. I'm guessing this is either an off-by-one bug or a workaround of it

Inventory token

The inventory token is a combination of class loadout flags and position in the player's backpack. This unsigned 32-bit integer is split into two two-byte words. The high word contains flags for each class. 1-bit in a class's slot indicates that the item is equipped in the appropriate loadout slot for that class. The low word contains the backpack position with '0' if the item has been awarded, but not yet found (placed in the backpack), '1' being the upper left slot, '2' the second slot from the left on the top row, etc. Here it is visually:


  ┌─────────────────────────────────────────────────────────────── Always '1'
  │ ┌─┬─┬─┬─┬─┬─────────────────────────────────────────────────── Unused
  │ │ │ │ │ │ │ ┌───────────────────────────────────────────────── Engineer 
  │ │ │ │ │ │ │ │ ┌─────────────────────────────────────────────── Spy 
  │ │ │ │ │ │ │ │ │ ┌───────────────────────────────────────────── Pyro 
  │ │ │ │ │ │ │ │ │ │ ┌─────────────────────────────────────────── Heavy 
  │ │ │ │ │ │ │ │ │ │ │ ┌───────────────────────────────────────── Medic 
  │ │ │ │ │ │ │ │ │ │ │ │ ┌─────────────────────────────────────── Demoman 
  │ │ │ │ │ │ │ │ │ │ │ │ │ ┌───────────────────────────────────── Soldier 
  │ │ │ │ │ │ │ │ │ │ │ │ │ │ ┌─────────────────────────────────── Sniper (or Atlas)
  │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ┌───────────────────────────────── Scout (or P-Body)
  │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ ┌─┬─┬─┬─┬─┬─┬─┬─┬─┬─┬─┬─┬─┬─┬─┬─ Backpack position 
  │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │ │
  0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0

Examples:

  1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1  Equipped Pyro item 
                                                                   in backpack slot 9
  1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 1  Unequipped item 
                                                                   in backpack slot 41
  1 0 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 0  Equipped by Pyro and Engineer
                                                                   in backpack slot 42