WoW:API GetAuctionItemInfo: Difference between revisions
(saleStatus return value added) |
m (Move page script moved page API GetAuctionItemInfo to API GetAuctionItemInfo without leaving a redirect) |
||
(3 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
{{wowapi}} | {{wowapi}} | ||
Retrieves info about one item in the current retrieved list of items from the Auction House. | Retrieves info about one item in the current retrieved list of items from the Auction House. | ||
name, texture, count, quality, canUse, level, | local name, texture, count, quality, canUse, level, levelColHeader, minBid, | ||
minIncrement, buyoutPrice, bidAmount, highBidder, bidderFullName, owner, | |||
ownerFullName, saleStatus, itemId, hasAllInfo = GetAuctionItemInfo("type", index) | |||
==Parameters== | == Parameters == | ||
===Arguments=== | === Arguments === | ||
:;type : String - | :;type | ||
:: String - One of the following: | |||
:::*"list" - An item up for auction, the "Browse" tab in the dialog. | :::*"list" - An item up for auction, the "Browse" tab in the dialog. | ||
:::*"bidder" - An item the player has bid on, the "Bids" tab in the dialog. | :::*"bidder" - An item the player has bid on, the "Bids" tab in the dialog. | ||
:::*"owner" - An item the player has up for auction, the "Auctions" tab in the dialog. | :::*"owner" - An item the player has up for auction, the "Auctions" tab in the dialog. | ||
:;index : Integer - The index of the item in the list to retrieve info from (normally 1-50, inclusive) | :;index | ||
===Returns=== | :: Integer - The index of the item in the list to retrieve info from (normally 1-50, inclusive) | ||
:;name : | === Returns === | ||
:;texture : | :;name | ||
:;count : | :: (string) the name of the item | ||
:;quality : an index into the [[API ITEM_QUALITY_COLORS|ITEM_QUALITY_COLORS]] array | :;texture | ||
:;canUse : | :: (string) the name of the texture of the item | ||
:;level : | :;count | ||
:;minBid : the starting bid price | :: (number) the amount of items in the auction item, zero if item is "sold" in the "owner" auctions | ||
:;minIncrement : the minimum amount of item at which to put the next bid | :;quality | ||
:;buyoutPrice : zero if no buy out, otherwise it contains the buyout price of the auction item | :: (number) an index into the [[API ITEM_QUALITY_COLORS|ITEM_QUALITY_COLORS]] array | ||
:;bidAmount : the current highest bid, zero if no one has bid yet | :;canUse | ||
:;highBidder : | :: (boolean) true if the user can use the item, false if not | ||
:;owner : the player that is selling the item | :;level | ||
:;saleStatus : 1 for sold 0 for unsold | :: (number) the level required to use the item | ||
:;levelColHeader | |||
:: unknown | |||
:;minBid | |||
:: (number) the starting bid price | |||
:;minIncrement | |||
:: (number) the minimum amount of item at which to put the next bid | |||
:;buyoutPrice | |||
:: (number) zero if no buy out, otherwise it contains the buyout price of the auction item | |||
:;bidAmount | |||
:: (number) the current highest bid, zero if no one has bid yet | |||
:;highBidder | |||
:: (boolean) true if the current player is the highest bidder, otherwise nil | |||
:;bidderFullName | |||
:: (string) the full name of the highest bidder if in the same [[Connected Realm]], otherwise nil (added 5.4.0) | |||
:;owner | |||
:: the player that is selling the item | |||
:;ownerFullName | |||
:: (string) the full name of the owner if in the same [[Connected Realm]], otherwise nil (added 5.4.0) | |||
:;saleStatus | |||
:: 1 for sold 0 for unsold | |||
:;itemId | |||
:: (number) the item id | |||
:;hasAllInfo | |||
:: (boolean) true if all infos where retrieved | |||
==Example== | == Example == | ||
local name, texture, count, quality, canUse, level, | local name, texture, count, quality, canUse, level, levelColHeader, minBid, minIncrement, | ||
buyoutPrice, bidAmount, highBidder, highBidderFullName, owner, ownerFullName, | |||
saleStatus, itemId, hasAllInfo = GetAuctionItemInfo("owner", 1); | |||
Retrieves info about the first item in the list of your currently auctioned items. | Retrieves info about the first item in the list of your currently auctioned items. | ||
== | == Details == | ||
Note that the 'owner' field can be 'nil'. This happens because the auction listing internally contains player GUIDs rather than names, and the WoW client does not query the server for names until GetAuctionItemInfo is actually called for the item, and the result takes one [[RTT]] to arrive. The 'GUID to name' mapping is then stored in a name resolution cache, which gets cleared upon log-out, not UI reload. | |||
Note that the | |||
Blizzard's standard auction house view overcomes this problem by reacting to AUCTION_ITEM_LIST_UPDATE and re-querying the items. | Blizzard's standard auction house view overcomes this problem by reacting to AUCTION_ITEM_LIST_UPDATE and re-querying the items. | ||
However, this event-driven approach does not really work for e.g. scanner engines. There, the correct solution is to re-query items with nil owners for a short time (a low number of seconds). There IS a possibility that it NEVER returns something - this happens when someone puts something up for auction and then deletes his character. | However, this event-driven approach does not really work for e.g. scanner engines. There, the correct solution is to re-query items with nil owners for a short time (a low number of seconds). There IS a possibility that it NEVER returns something - this happens when someone puts something up for auction and then deletes his character. | ||
Also note that these GUID-to-name queries cause client-to-server bandwidth; 14 bytes each (in 2.3.2). For a normal 50-item page this is of course negligeable, but for a full-AH scan on a medium-size server, you easily generate enough traffic to disconnect yourself if you do not throttle the rate at which you send queries. See [[ChatThrottleLib]] for information on client-to-server bandwidth. | |||
== Notes == | |||
* 'bidderFullName' and 'ownerFullName' return values were added {{Patch 5.4.0|t=inline}}, in order to support [[Connected Realms]]. |
Latest revision as of 04:45, 15 August 2023
← WoW API < GetAuctionItemInfo
Retrieves info about one item in the current retrieved list of items from the Auction House.
local name, texture, count, quality, canUse, level, levelColHeader, minBid, minIncrement, buyoutPrice, bidAmount, highBidder, bidderFullName, owner, ownerFullName, saleStatus, itemId, hasAllInfo = GetAuctionItemInfo("type", index)
Parameters[edit]
Arguments[edit]
- type
- String - One of the following:
- "list" - An item up for auction, the "Browse" tab in the dialog.
- "bidder" - An item the player has bid on, the "Bids" tab in the dialog.
- "owner" - An item the player has up for auction, the "Auctions" tab in the dialog.
- index
- Integer - The index of the item in the list to retrieve info from (normally 1-50, inclusive)
Returns[edit]
- name
- (string) the name of the item
- texture
- (string) the name of the texture of the item
- count
- (number) the amount of items in the auction item, zero if item is "sold" in the "owner" auctions
- quality
- (number) an index into the ITEM_QUALITY_COLORS array
- canUse
- (boolean) true if the user can use the item, false if not
- level
- (number) the level required to use the item
- levelColHeader
- unknown
- minBid
- (number) the starting bid price
- minIncrement
- (number) the minimum amount of item at which to put the next bid
- buyoutPrice
- (number) zero if no buy out, otherwise it contains the buyout price of the auction item
- bidAmount
- (number) the current highest bid, zero if no one has bid yet
- highBidder
- (boolean) true if the current player is the highest bidder, otherwise nil
- bidderFullName
- (string) the full name of the highest bidder if in the same Connected Realm, otherwise nil (added 5.4.0)
- owner
- the player that is selling the item
- ownerFullName
- (string) the full name of the owner if in the same Connected Realm, otherwise nil (added 5.4.0)
- saleStatus
- 1 for sold 0 for unsold
- itemId
- (number) the item id
- hasAllInfo
- (boolean) true if all infos where retrieved
Example[edit]
local name, texture, count, quality, canUse, level, levelColHeader, minBid, minIncrement, buyoutPrice, bidAmount, highBidder, highBidderFullName, owner, ownerFullName, saleStatus, itemId, hasAllInfo = GetAuctionItemInfo("owner", 1);
Retrieves info about the first item in the list of your currently auctioned items.
Details[edit]
Note that the 'owner' field can be 'nil'. This happens because the auction listing internally contains player GUIDs rather than names, and the WoW client does not query the server for names until GetAuctionItemInfo is actually called for the item, and the result takes one RTT to arrive. The 'GUID to name' mapping is then stored in a name resolution cache, which gets cleared upon log-out, not UI reload.
Blizzard's standard auction house view overcomes this problem by reacting to AUCTION_ITEM_LIST_UPDATE and re-querying the items.
However, this event-driven approach does not really work for e.g. scanner engines. There, the correct solution is to re-query items with nil owners for a short time (a low number of seconds). There IS a possibility that it NEVER returns something - this happens when someone puts something up for auction and then deletes his character.
Also note that these GUID-to-name queries cause client-to-server bandwidth; 14 bytes each (in 2.3.2). For a normal 50-item page this is of course negligeable, but for a full-AH scan on a medium-size server, you easily generate enough traffic to disconnect yourself if you do not throttle the rate at which you send queries. See ChatThrottleLib for information on client-to-server bandwidth.
Notes[edit]
- 'bidderFullName' and 'ownerFullName' return values were added Template:Patch 5.4.0, in order to support Connected Realms.