Count how many times who visit orgrimmar and display in alert
This commit is contained in:
@@ -19,20 +19,21 @@ function()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local timestamp = date("%Y-%m-%dT%H:%M:%S")
|
||||||
local player = aura_env.stinkies[name]
|
local player = aura_env.stinkies[name]
|
||||||
if not player then
|
if not player then
|
||||||
player = Player.new(name, guild, race, class, zone)
|
player = Player.new(name, guild, race, class, zone)
|
||||||
local timestamp = date("%Y-%m-%dT%H:%M:%S")
|
local existing = WeakAurasSaved.Cyka.WhoSniffer[name]
|
||||||
if not WeakAurasSaved.Cyka.WhoSniffer[name] then
|
|
||||||
WeakAurasSaved.Cyka.WhoSniffer[name] = {}
|
if not existing then WeakAurasSaved.Cyka.WhoSniffer[name] = {}
|
||||||
|
else
|
||||||
|
player.lastSeen = existing.lastSeen or "never"
|
||||||
|
player.firstSeen = existing.firstSeen or "never"
|
||||||
|
player.seenCount = existing.seenCount or 0
|
||||||
|
if player.lastSeen == "never" then
|
||||||
|
player.firstSeen = timestamp
|
||||||
|
end
|
||||||
end
|
end
|
||||||
WeakAurasSaved.Cyka.WhoSniffer[name][timestamp] = {
|
|
||||||
["name"] = name,
|
|
||||||
["guild"] = guild,
|
|
||||||
["race"] = race,
|
|
||||||
["class"] = class,
|
|
||||||
["zone"] = zone
|
|
||||||
}
|
|
||||||
|
|
||||||
local stinky = WeakAurasSaved.Cyka.stinkies[name]
|
local stinky = WeakAurasSaved.Cyka.stinkies[name]
|
||||||
if stinky then
|
if stinky then
|
||||||
@@ -42,9 +43,13 @@ function()
|
|||||||
end
|
end
|
||||||
|
|
||||||
aura_env.Notify(player)
|
aura_env.Notify(player)
|
||||||
|
player.lastSeen = timestamp
|
||||||
|
player.seenCount = player.seenCount + 1
|
||||||
|
WeakAurasSaved.Cyka.WhoSniffer[name] = player
|
||||||
end
|
end
|
||||||
player:Touch()
|
player.lastSeenInternal = GetTime()
|
||||||
player.zone = zone
|
player.zone = zone
|
||||||
|
player.lastSeen = timestamp
|
||||||
aura_env.stinkies[name] = player
|
aura_env.stinkies[name] = player
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@@ -3,22 +3,12 @@
|
|||||||
function(allstates)
|
function(allstates)
|
||||||
local now = GetTime()
|
local now = GetTime()
|
||||||
for k, v in pairs(aura_env.stinkies) do
|
for k, v in pairs(aura_env.stinkies) do
|
||||||
local ago = now - v.lastSeen
|
local ago = now - v.lastSeenInternal
|
||||||
if ago > aura_env.ttl then
|
if ago > aura_env.ttl then
|
||||||
allstates[k] = { show = false, changed = true }
|
allstates[k] = { show = false, changed = true }
|
||||||
aura_env.stinkies[k] = nil
|
aura_env.stinkies[k] = nil
|
||||||
PlaySoundFile("Interface\\Sounds\\Uncloak.ogg", "Master")
|
PlaySoundFile("Interface\\Sounds\\Uncloak.ogg", "Master")
|
||||||
aura_env.NotifyGone(v)
|
aura_env.NotifyGone(v)
|
||||||
|
|
||||||
local timestamp = date("%Y-%m-%dT%H:%M:%S")
|
|
||||||
WeakAurasSaved.Cyka.WhoSniffer[v.name][timestamp] = {
|
|
||||||
["name"] = v.name,
|
|
||||||
["guild"] = v.guild,
|
|
||||||
["race"] = v.race,
|
|
||||||
["class"] = v.class,
|
|
||||||
["zone"] = v.zone,
|
|
||||||
["left"] = true,
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
if allstates[k] then
|
if allstates[k] then
|
||||||
allstates[k].ago = string.format("%6.1fs", ago)
|
allstates[k].ago = string.format("%6.1fs", ago)
|
||||||
|
@@ -1,6 +1,11 @@
|
|||||||
if not WeakAurasSaved.Cyka then WeakAurasSaved.Cyka = {} end
|
if not WeakAurasSaved.Cyka then
|
||||||
if not WeakAurasSaved.Cyka.WhoSniffer then WeakAurasSaved.Cyka.WhoSniffer = {} end
|
WeakAurasSaved.Cyka = {}
|
||||||
|
end
|
||||||
|
if not WeakAurasSaved.Cyka.WhoSniffer then
|
||||||
|
WeakAurasSaved.Cyka.WhoSniffer = {}
|
||||||
|
end
|
||||||
|
|
||||||
|
aura_env.ttl = 6
|
||||||
aura_env.ignored = {"Maritza", "Goodbones"}
|
aura_env.ignored = {"Maritza", "Goodbones"}
|
||||||
|
|
||||||
---@class aura_env
|
---@class aura_env
|
||||||
@@ -23,6 +28,9 @@ aura_env.ignored = { "Maritza", "Goodbones" }
|
|||||||
---@param input string
|
---@param input string
|
||||||
---@return number
|
---@return number
|
||||||
local function utf8len(input)
|
local function utf8len(input)
|
||||||
|
if not input then
|
||||||
|
return 0
|
||||||
|
end
|
||||||
local len = 0
|
local len = 0
|
||||||
local i = 1
|
local i = 1
|
||||||
local n = #input
|
local n = #input
|
||||||
@@ -68,7 +76,9 @@ WHOQuery = {
|
|||||||
---@param filters WHOFilter[]
|
---@param filters WHOFilter[]
|
||||||
---@return WHOQuery
|
---@return WHOQuery
|
||||||
new = function(query, filters)
|
new = function(query, filters)
|
||||||
local self = setmetatable({}, { __index = WHOQuery })
|
local self = setmetatable({}, {
|
||||||
|
__index = WHOQuery
|
||||||
|
})
|
||||||
self.query = query
|
self.query = query
|
||||||
self.filters = filters
|
self.filters = filters
|
||||||
return self
|
return self
|
||||||
@@ -78,18 +88,23 @@ WHOQuery = {
|
|||||||
---@alias WHOFilter fun(name: string, guild: string, level: number, race: string, class: string, zone: string): boolean
|
---@alias WHOFilter fun(name: string, guild: string, level: number, race: string, class: string, zone: string): boolean
|
||||||
---@type WHOFilter
|
---@type WHOFilter
|
||||||
local NotSiegeOfOrgrimmarFilter = function(name, guild, level, race, class, zone)
|
local NotSiegeOfOrgrimmarFilter = function(name, guild, level, race, class, zone)
|
||||||
if not zone then return false end
|
if not zone then
|
||||||
|
return false
|
||||||
|
end
|
||||||
return zone ~= "Siege of Orgrimmar"
|
return zone ~= "Siege of Orgrimmar"
|
||||||
end
|
end
|
||||||
---@type WHOFilter
|
---@type WHOFilter
|
||||||
local AllianceFilter = function(name, guild, level, race, class, zone)
|
local AllianceFilter = function(name, guild, level, race, class, zone)
|
||||||
if not race then return false end
|
if not race then
|
||||||
if not aura_env.raceMap[race] then return false end
|
return false
|
||||||
|
end
|
||||||
|
if not aura_env.raceMap[race] then
|
||||||
|
return false
|
||||||
|
end
|
||||||
return aura_env.raceMap[race] == "Alliance"
|
return aura_env.raceMap[race] == "Alliance"
|
||||||
end
|
end
|
||||||
|
|
||||||
aura_env.messageQueue = {}
|
aura_env.messageQueue = {}
|
||||||
aura_env.ttl = 6
|
|
||||||
aura_env.whoQueryIdx = 1
|
aura_env.whoQueryIdx = 1
|
||||||
---@type table<number, WHOQuery>
|
---@type table<number, WHOQuery>
|
||||||
aura_env.whoQueries = {}
|
aura_env.whoQueries = {}
|
||||||
@@ -136,7 +151,10 @@ aura_env.stinkies = {}
|
|||||||
---@field race string
|
---@field race string
|
||||||
---@field class string
|
---@field class string
|
||||||
---@field zone string
|
---@field zone string
|
||||||
---@field lastSeen number
|
---@field lastSeenInternal number
|
||||||
|
---@field lastSeen string
|
||||||
|
---@field firstSeen string
|
||||||
|
---@field seenCount number
|
||||||
Player = {
|
Player = {
|
||||||
---@param name string
|
---@param name string
|
||||||
---@param guild string
|
---@param guild string
|
||||||
@@ -145,21 +163,25 @@ Player = {
|
|||||||
---@param zone string
|
---@param zone string
|
||||||
---@return Player
|
---@return Player
|
||||||
new = function(name, guild, race, class, zone)
|
new = function(name, guild, race, class, zone)
|
||||||
local self = setmetatable({}, { __index = Player })
|
local self = setmetatable({}, {
|
||||||
|
__index = Player
|
||||||
|
})
|
||||||
self.name = name
|
self.name = name
|
||||||
self.guild = guild
|
self.guild = guild
|
||||||
self.race = race
|
self.race = race
|
||||||
self.class = class
|
self.class = class
|
||||||
self.zone = zone
|
self.zone = zone
|
||||||
|
self.lastSeenInternal = GetTime()
|
||||||
|
self.lastSeen = "never"
|
||||||
|
self.firstSeen = "never"
|
||||||
|
self.seenCount = 0
|
||||||
return self
|
return self
|
||||||
end,
|
end,
|
||||||
Touch = function(self) self.lastSeen = GetTime() end,
|
|
||||||
ToString = function(self)
|
ToString = function(self)
|
||||||
local out = string.format("%s %s %s", padString(self.name, 16, true),
|
local out = string.format("%s %s %s\nFirst: %s Last: %s Seen: %3d", padString(self.name, 16, true),
|
||||||
padString(self.guild, 26, false),
|
padString(self.guild, 26, false), padString(self.zone, 26, false), padString(self.firstSeen, 10, true),
|
||||||
padString(self.zone, 26, false))
|
padString(self.lastSeen, 10, true), self.seenCount)
|
||||||
return
|
return string.format("|cFF%s%s|r", aura_env.classColors[self.class], out)
|
||||||
string.format("|cFF%s%s|r", aura_env.classColors[self.class], out)
|
|
||||||
end
|
end
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -190,8 +212,12 @@ end
|
|||||||
---@param deliminer string
|
---@param deliminer string
|
||||||
---@return string[], string|nil
|
---@return string[], string|nil
|
||||||
local function StrSplit(input, deliminer)
|
local function StrSplit(input, deliminer)
|
||||||
if not deliminer then return {}, "deliminer is nil" end
|
if not deliminer then
|
||||||
if not input then return {}, "input is nil" end
|
return {}, "deliminer is nil"
|
||||||
|
end
|
||||||
|
if not input then
|
||||||
|
return {}, "input is nil"
|
||||||
|
end
|
||||||
local parts = {}
|
local parts = {}
|
||||||
for part in string.gmatch(input, "([^" .. deliminer .. "]+)") do
|
for part in string.gmatch(input, "([^" .. deliminer .. "]+)") do
|
||||||
table.insert(parts, strtrim(part))
|
table.insert(parts, strtrim(part))
|
||||||
@@ -201,29 +227,42 @@ end
|
|||||||
|
|
||||||
---@type string[]
|
---@type string[]
|
||||||
local toNotify = StrSplit(aura_env.config.notify, ",")
|
local toNotify = StrSplit(aura_env.config.notify, ",")
|
||||||
for i, part in ipairs(toNotify) do toNotify[i] = strtrim(part) end
|
for i, part in ipairs(toNotify) do
|
||||||
|
toNotify[i] = strtrim(part)
|
||||||
|
end
|
||||||
---@type table<string, boolean>
|
---@type table<string, boolean>
|
||||||
local notifyFor = {}
|
local notifyFor = {}
|
||||||
local notifyForD = StrSplit(aura_env.config.notifyFor, ",")
|
local notifyForD = StrSplit(aura_env.config.notifyFor, ",")
|
||||||
for i, part in ipairs(notifyForD) do notifyFor[part] = true end
|
for i, part in ipairs(notifyForD) do
|
||||||
|
notifyFor[part] = true
|
||||||
|
end
|
||||||
|
|
||||||
---@param player Player
|
---@param player Player
|
||||||
aura_env.Notify = function(player)
|
aura_env.Notify = function(player)
|
||||||
if not notifyFor[player.zone] then return end
|
if not notifyFor[player.zone] then
|
||||||
local msg = string.format("%s of class %s and guild %s in %s", player.name,
|
return
|
||||||
player.class, player.guild, player.zone)
|
end
|
||||||
|
local msg = string.format("%s of class %s and guild %s in %s, first seen: %s, last seen: %s, times seen: %d",
|
||||||
|
player.name, player.class, player.guild, player.zone, player.firstSeen, player.lastSeen, player.seenCount)
|
||||||
for _, rec in ipairs(toNotify) do
|
for _, rec in ipairs(toNotify) do
|
||||||
table.insert(aura_env.messageQueue, { to = rec, message = msg })
|
table.insert(aura_env.messageQueue, {
|
||||||
|
to = rec,
|
||||||
|
message = msg
|
||||||
|
})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
---@param player Player
|
---@param player Player
|
||||||
aura_env.NotifyGone = function(player)
|
aura_env.NotifyGone = function(player)
|
||||||
if not notifyFor[player.zone] then return end
|
if not notifyFor[player.zone] then
|
||||||
local msg = string.format("%s of class %s and guild %s left %s",
|
return
|
||||||
player.name, player.class, player.guild,
|
end
|
||||||
|
local msg = string.format("%s of class %s and guild %s left %s", player.name, player.class, player.guild,
|
||||||
player.zone)
|
player.zone)
|
||||||
for _, rec in ipairs(toNotify) do
|
for _, rec in ipairs(toNotify) do
|
||||||
table.insert(aura_env.messageQueue, { to = rec, message = msg })
|
table.insert(aura_env.messageQueue, {
|
||||||
|
to = rec,
|
||||||
|
message = msg
|
||||||
|
})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Reference in New Issue
Block a user