Software /
code /
prosody-modules
File
mod_list_inactive/mod_list_inactive.lua @ 1762:e6c7fe1be6cd
mod_log_rate: Log sink that reports the rate of log messages to statsmanager
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Wed, 27 May 2015 13:31:33 +0200 |
parent | 1497:d1836dfa4ae4 |
child | 1766:e4c3d335b07f |
line wrap: on
line source
-- Copyright (C) 2012-2013 Kim Alvefur local um = require "core.usermanager"; local sm = require "core.storagemanager"; local dm_load = require "util.datamanager".load; local jid_join = require"util.jid".join; local multipliers = { d = 86400, -- day w = 604800, -- week m = 2629746, -- month y = 31556952, -- year } local output_formats = { default = "%s", event = "%s %s", delete = "user:delete%q -- %s" } function module.command(arg) local items = {}; local host = arg[1]; assert(hosts[host], "Host "..tostring(host).." does not exist"); sm.initialize_host(host); um.initialize_host(host); local max_age, unit = assert(arg[2], "No time range given"):match("^(%d*)%s*([dwmy]?)"); max_age = os.time() - ( tonumber(max_age) or 1 ) * ( multipliers[unit] or 1 ); local output = assert(output_formats[arg[3] or "default"], "No such output format: "..tostring(arg[3] or "default")); for user in um.users(host) do local last_active = dm_load(user, host, "lastlog"); local last_action = last_active and last_active.event or "?" last_active = last_active and last_active.timestamp or 0; if last_active < max_age then print(output:format(jid_join(user, host), last_action)); end end end