421 lines
17 KiB
Lua
421 lines
17 KiB
Lua
-- ------------------------------------------------------------------------------ --
|
|
-- TradeSkillMaster --
|
|
-- https://tradeskillmaster.com --
|
|
-- All Rights Reserved - Detailed license information included with addon. --
|
|
-- ------------------------------------------------------------------------------ --
|
|
|
|
--- Public TSM API functions
|
|
-- @module TSM_API
|
|
|
|
local _, TSM = ...
|
|
local Money = TSM.Include("Util.Money")
|
|
local ItemString = TSM.Include("Util.ItemString")
|
|
local ItemInfo = TSM.Include("Service.ItemInfo")
|
|
local CustomPrice = TSM.Include("Service.CustomPrice")
|
|
local Inventory = TSM.Include("Service.Inventory")
|
|
TSM_API = {}
|
|
local private = {}
|
|
|
|
|
|
|
|
-- ============================================================================
|
|
-- UI
|
|
-- ============================================================================
|
|
|
|
--- Checks if a TSM UI is currently visible.
|
|
-- @within UI
|
|
-- @tparam string uiName A string which represents the UI ("AUCTION", "CRAFTING", "MAILING", or "VENDORING")
|
|
-- @treturn boolean Whether or not the TSM UI is visible
|
|
function TSM_API.IsUIVisible(uiName)
|
|
private.CheckCallMethod(uiName)
|
|
if uiName == "AUCTION" then
|
|
return TSM.UI.AuctionUI.IsVisible()
|
|
elseif uiName == "CRAFTING" then
|
|
return TSM.UI.CraftingUI.IsVisible()
|
|
elseif uiName == "MAILING" then
|
|
return TSM.UI.MailingUI.IsVisible()
|
|
elseif uiName == "VENDORING" then
|
|
return TSM.UI.VendoringUI.IsVisible()
|
|
else
|
|
error("Invalid uiName: "..tostring(uiName), 2)
|
|
end
|
|
end
|
|
|
|
|
|
|
|
-- ============================================================================
|
|
-- Groups
|
|
-- ============================================================================
|
|
|
|
--- Gets a current list of TSM group paths.
|
|
-- @within Group
|
|
-- @tparam table result A table to store the result in
|
|
-- @treturn table The passed table, populated with group paths
|
|
function TSM_API.GetGroupPaths(result)
|
|
private.CheckCallMethod(result)
|
|
if type(result) ~= "table" then
|
|
error("Invalid 'result' argument type (must be a table): "..tostring(result), 2)
|
|
end
|
|
for _, groupPath in TSM.Groups.GroupIterator() do
|
|
tinsert(result, groupPath)
|
|
end
|
|
return result
|
|
end
|
|
|
|
--- Formats a TSM group path into a human-readable form
|
|
-- @within Group
|
|
-- @tparam string path The group path to be formatted
|
|
-- @treturn string The formatted group path
|
|
function TSM_API.FormatGroupPath(path)
|
|
private.CheckCallMethod(path)
|
|
if type(path) ~= "string" then
|
|
error("Invalid 'path' argument type (must be a string): "..tostring(path), 2)
|
|
elseif path == "" then
|
|
error("Invalid 'path' argument (empty string)", 2)
|
|
end
|
|
return TSM.Groups.Path.Format(path)
|
|
end
|
|
|
|
--- Splits a TSM group path into its parent path and group name components.
|
|
-- @within Group
|
|
-- @tparam string path The group path to be split
|
|
-- @treturn string The path of the parent group or nil if the specified path has no parent
|
|
-- @treturn string The name of the group
|
|
function TSM_API.SplitGroupPath(path)
|
|
private.CheckCallMethod(path)
|
|
if type(path) ~= "string" then
|
|
error("Invalid 'path' argument type (must be a string): "..tostring(path), 2)
|
|
elseif path == "" then
|
|
error("Invalid 'path' argument (empty string)", 2)
|
|
end
|
|
local parentPath, groupName = TSM.Groups.Path.Split(path)
|
|
if parentPath == TSM.CONST.ROOT_GROUP_PATH then
|
|
parentPath = nil
|
|
end
|
|
return parentPath, groupName
|
|
end
|
|
|
|
--- Gets the path to the group which a specific item is in.
|
|
-- @within Group
|
|
-- @tparam string itemString The TSM item string to get the group path of
|
|
-- @treturn string The path to the group which the item is in, or nil if it's not in a group
|
|
function TSM_API.GetGroupPathByItem(itemString)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
local path = TSM.Groups.GetPathByItem(itemString)
|
|
return path ~= TSM.CONST.ROOT_GROUP_PATH and path or nil
|
|
end
|
|
|
|
|
|
|
|
-- ============================================================================
|
|
-- Profiles
|
|
-- ============================================================================
|
|
|
|
--- Gets a current list of TSM profiles.
|
|
-- @within Profile
|
|
-- @tparam table result A table to store the result in
|
|
-- @treturn table The passed table, populated with group paths
|
|
function TSM_API.GetProfiles(result)
|
|
private.CheckCallMethod(result)
|
|
for _, profileName in TSM.db:ProfileIterator() do
|
|
tinsert(result, profileName)
|
|
end
|
|
return result
|
|
end
|
|
|
|
--- Gets the active TSM profile.
|
|
-- @within Profile
|
|
-- @treturn string The name of the currently active profile
|
|
function TSM_API.GetActiveProfile()
|
|
return TSM.db:GetCurrentProfile()
|
|
end
|
|
|
|
--- Sets the active TSM profile.
|
|
-- @within Profile
|
|
-- @tparam string profile The name of the profile to make active
|
|
function TSM_API.SetActiveProfile(profile)
|
|
private.CheckCallMethod(profile)
|
|
if type(profile) ~= "string" then
|
|
error("Invalid 'profile' argument type (must be a string): "..tostring(profile), 2)
|
|
elseif not TSM.db:ProfileExists(profile) then
|
|
error("Profile does not exist: "..profile, 2)
|
|
elseif profile == TSM.db:GetCurrentProfile() then
|
|
error("Profile is already active: "..profile, 2)
|
|
end
|
|
return TSM.db:SetProfile(profile)
|
|
end
|
|
|
|
|
|
|
|
-- ============================================================================
|
|
-- Prices
|
|
-- ============================================================================
|
|
|
|
--- Gets a list of price source keys which can be used in TSM custom prices.
|
|
-- @within Price
|
|
-- @tparam table result A table to store the result in
|
|
-- @treturn table The passed table, populated with price source keys
|
|
function TSM_API.GetPriceSourceKeys(result)
|
|
private.CheckCallMethod(result)
|
|
if type(result) ~= "table" then
|
|
error("Invalid 'result' argument type (must be a table): "..tostring(result), 2)
|
|
end
|
|
for key in CustomPrice.Iterator() do
|
|
tinsert(result, key)
|
|
end
|
|
return result
|
|
end
|
|
|
|
--- Gets the localized description of a given price source key.
|
|
-- @within Price
|
|
-- @tparam string key The price source key
|
|
-- @treturn string The localized description
|
|
function TSM_API.GetPriceSourceDescription(key)
|
|
private.CheckCallMethod(key)
|
|
if type(key) ~= "string" then
|
|
error("Invalid 'key' argument type (must be a string): "..tostring(key), 2)
|
|
end
|
|
local result = CustomPrice.GetDescription(key)
|
|
if not result then
|
|
error("Unknown price source key: "..tostring(key), 2)
|
|
end
|
|
return result
|
|
end
|
|
|
|
--- Gets whether or not a custom price string is valid.
|
|
-- @within Price
|
|
-- @tparam string customPriceStr The custom price string
|
|
-- @treturn boolean Whether or not the custom price is valid
|
|
-- @treturn string The (localized) error message or nil if the custom price was valid
|
|
function TSM_API.IsCustomPriceValid(customPriceStr)
|
|
private.CheckCallMethod(customPriceStr)
|
|
if type(customPriceStr) ~= "string" then
|
|
error("Invalid 'customPriceStr' argument type (must be a string): "..tostring(customPriceStr), 2)
|
|
end
|
|
return CustomPrice.Validate(customPriceStr)
|
|
end
|
|
|
|
--- Evalulates a custom price string or price source key for a given item
|
|
-- @within Price
|
|
-- @tparam string customPriceStr The custom price string or price source key to get the value of
|
|
-- @tparam string itemString The TSM item string to get the value for
|
|
-- @treturn number The value in copper or nil if the custom price string is not valid
|
|
-- @treturn string The (localized) error message if the custom price string is not valid or nil if it is valid
|
|
function TSM_API.GetCustomPriceValue(customPriceStr, itemString)
|
|
private.CheckCallMethod(customPriceStr)
|
|
if type(customPriceStr) ~= "string" then
|
|
error("Invalid 'customPriceStr' argument type (must be a string): "..tostring(customPriceStr), 2)
|
|
end
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
return CustomPrice.GetValue(customPriceStr, itemString)
|
|
end
|
|
|
|
|
|
|
|
-- ============================================================================
|
|
-- Money
|
|
-- ============================================================================
|
|
|
|
--- Converts a money value to a formatted, human-readable string.
|
|
-- @within Money
|
|
-- @tparam number value The money value in copper to be converted
|
|
-- @treturn string The formatted money string
|
|
function TSM_API.FormatMoneyString(value)
|
|
private.CheckCallMethod(value)
|
|
if type(value) ~= "number" then
|
|
error("Invalid 'value' argument type (must be a number): "..tostring(value), 2)
|
|
end
|
|
local result = Money.ToString(value)
|
|
assert(result)
|
|
return result
|
|
end
|
|
|
|
--- Converts a formatted, human-readable money string to a value.
|
|
-- @within Money
|
|
-- @tparam string str The formatted money string
|
|
-- @treturn number The money value in copper
|
|
function TSM_API.ParseMoneyString(str)
|
|
private.CheckCallMethod(str)
|
|
if type(str) ~= "string" then
|
|
error("Invalid 'str' argument type (must be a string): "..tostring(str), 2)
|
|
end
|
|
local result = Money.FromString(str)
|
|
assert(result)
|
|
return result
|
|
end
|
|
|
|
|
|
|
|
-- ============================================================================
|
|
-- Item
|
|
-- ============================================================================
|
|
|
|
--- Converts an item to a TSM item string.
|
|
-- @within Item
|
|
-- @tparam string item Either an item link, TSM item string, or WoW item string
|
|
-- @treturn string The TSM item string or nil if the specified item could not be converted
|
|
function TSM_API.ToItemString(item)
|
|
private.CheckCallMethod(item)
|
|
if type(item) ~= "string" then
|
|
error("Invalid 'item' argument type (must be a string): "..tostring(item), 2)
|
|
end
|
|
return ItemString.Get(item)
|
|
end
|
|
|
|
--- Gets an item's name from a given TSM item string.
|
|
-- @within Item
|
|
-- @tparam string itemString The TSM item string
|
|
-- @treturn string The name of the item or nil if it couldn't be determined
|
|
function TSM_API.GetItemName(itemString)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
return ItemInfo.GetName(itemString)
|
|
end
|
|
|
|
--- Gets an item link from a given TSM item string.
|
|
-- @within Item
|
|
-- @tparam string itemString The TSM item string
|
|
-- @treturn string The item link or an "[Unknown Item]" link
|
|
function TSM_API.GetItemLink(itemString)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
local result = ItemInfo.GetLink(itemString)
|
|
assert(result)
|
|
return result
|
|
end
|
|
|
|
|
|
|
|
-- ============================================================================
|
|
-- Inventory
|
|
-- ============================================================================
|
|
|
|
--- Gets the quantity of an item in a character's bags.
|
|
-- @within Inventory
|
|
-- @tparam string itemString The TSM item string (note that inventory data is tracked per base item)
|
|
-- @tparam ?string character The character to get data for (defaults to the current character if not set)
|
|
-- @tparam ?string factionrealm The factionrealm to get data for (defaults to the current factionrealm if not set)
|
|
-- @treturn number The quantity of the specified item
|
|
function TSM_API.GetBagQuantity(itemString, character, factionrealm)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
assert(character == nil or type(character) == "string")
|
|
assert(factionrealm == nil or type(factionrealm) == "string")
|
|
return Inventory.GetBagQuantity(itemString, character, factionrealm)
|
|
end
|
|
|
|
--- Gets the quantity of an item in a character's bank.
|
|
-- @within Inventory
|
|
-- @tparam string itemString The TSM item string (note that inventory data is tracked per base item)
|
|
-- @tparam ?string character The character to get data for (defaults to the current character if not set)
|
|
-- @tparam ?string factionrealm The factionrealm to get data for (defaults to the current factionrealm if not set)
|
|
-- @treturn number The quantity of the specified item
|
|
function TSM_API.GetBankQuantity(itemString, character, factionrealm)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
assert(character == nil or type(character) == "string")
|
|
assert(factionrealm == nil or type(factionrealm) == "string")
|
|
return Inventory.GetBankQuantity(itemString, character, factionrealm)
|
|
end
|
|
|
|
--- Gets the quantity of an item in a character's reagent bank.
|
|
-- @within Inventory
|
|
-- @tparam string itemString The TSM item string (note that inventory data is tracked per base item)
|
|
-- @tparam ?string character The character to get data for (defaults to the current character if not set)
|
|
-- @tparam ?string factionrealm The factionrealm to get data for (defaults to the current factionrealm if not set)
|
|
-- @treturn number The quantity of the specified item
|
|
function TSM_API.GetReagentBankQuantity(itemString, character, factionrealm)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
assert(character == nil or type(character) == "string")
|
|
assert(factionrealm == nil or type(factionrealm) == "string")
|
|
return Inventory.GetReagentBankQuantity(itemString, character, factionrealm)
|
|
end
|
|
|
|
--- Gets the quantity of an item posted to the auction house by a character.
|
|
-- @within Inventory
|
|
-- @tparam string itemString The TSM item string (note that inventory data is tracked per base item)
|
|
-- @tparam ?string character The character to get data for (defaults to the current character if not set)
|
|
-- @tparam ?string factionrealm The factionrealm to get data for (defaults to the current factionrealm if not set)
|
|
-- @treturn number The quantity of the specified item
|
|
function TSM_API.GetAuctionQuantity(itemString, character, factionrealm)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
assert(character == nil or type(character) == "string")
|
|
assert(factionrealm == nil or type(factionrealm) == "string")
|
|
return Inventory.GetAuctionQuantity(itemString, character, factionrealm)
|
|
end
|
|
|
|
--- Gets the quantity of an item in a character's mailbox.
|
|
-- @within Inventory
|
|
-- @tparam string itemString The TSM item string (note that inventory data is tracked per base item)
|
|
-- @tparam ?string character The character to get data for (defaults to the current character if not set)
|
|
-- @tparam ?string factionrealm The factionrealm to get data for (defaults to the current factionrealm if not set)
|
|
-- @treturn number The quantity of the specified item
|
|
function TSM_API.GetMailQuantity(itemString, character, factionrealm)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
assert(character == nil or type(character) == "string")
|
|
assert(factionrealm == nil or type(factionrealm) == "string")
|
|
return Inventory.GetMailQuantity(itemString, character, factionrealm)
|
|
end
|
|
|
|
--- Gets the quantity of an item in a guild's bank.
|
|
-- @within Inventory
|
|
-- @tparam string itemString The TSM item string (note that inventory data is tracked per base item)
|
|
-- @tparam ?string guild The guild to get data for (defaults to the current character's guild if not set)
|
|
-- @treturn number The quantity of the specified item
|
|
function TSM_API.GetGuildQuantity(itemString, guild)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
assert(guild == nil or type(guild) == "string")
|
|
return Inventory.GetGuildQuantity(itemString, guild)
|
|
end
|
|
|
|
--- Get some total quantities for an item.
|
|
-- @within Inventory
|
|
-- @tparam string itemString The TSM item string (note that inventory data is tracked per base item)
|
|
-- @treturn number The total quantity the current player has (bags, bank, reagent bank, and mail)
|
|
-- @treturn number The total quantity alt characters have (bags, bank, reagent bank, and mail)
|
|
-- @treturn number The total quantity the current player has on the auction house
|
|
-- @treturn number The total quantity alt characters have on the auction house
|
|
function TSM_API.GetPlayerTotals(itemString)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
return Inventory.GetPlayerTotals(itemString)
|
|
end
|
|
|
|
--- Get the total number of items in all tracked guild banks.
|
|
-- @within Inventory
|
|
-- @tparam string itemString The TSM item string (note that inventory data is tracked per base item)
|
|
-- @treturn number The total quantity in all tracked guild banks
|
|
function TSM_API.GetGuildTotal(itemString)
|
|
private.CheckCallMethod(itemString)
|
|
itemString = private.ValidateTSMItemString(itemString)
|
|
return Inventory.GetGuildTotal(itemString)
|
|
end
|
|
|
|
|
|
|
|
-- ============================================================================
|
|
-- Private Helper Functions
|
|
-- ============================================================================
|
|
|
|
function private.ValidateTSMItemString(itemString)
|
|
if type(itemString) ~= "string" or not strmatch(itemString, "[ip]:%d+") then
|
|
error("Invalid 'itemString' argument type (must be a TSM item string): "..tostring(itemString), 3)
|
|
end
|
|
local newItemString = ItemString.Get(itemString)
|
|
if not newItemString then
|
|
error("Invalid TSM itemString: "..itemString, 3)
|
|
end
|
|
return newItemString
|
|
end
|
|
|
|
function private.CheckCallMethod(firstArg)
|
|
if firstArg == TSM_API then
|
|
error("Invalid usage of colon operator to call TSM_API function", 3)
|
|
end
|
|
end
|