view mod_list_inactive/mod_list_inactive.lua @ 1444:56c394b9e60d

mod_rawdebug: Adds a telnet command for enabling logging of entire stanzas that are sent and received
author Kim Alvefur <zash@zash.se>
date Mon, 23 Jun 2014 20:22:19 +0200
parents 589991b148e8
children cccb151a4cc5
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 multipliers = {
	d = 86400, -- day
	w = 604800, -- week
	m = 2629746, -- month
	y = 31556952, -- year
}

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 );
	for user in um.users(host) do
		local last_active = dm_load(user, host, "lastlog");
		last_active = last_active and last_active.timestamp or 0;
		local bare = user.."@"..host;
		if last_active < max_age then
			print(("user:delete%q"):format(bare));
		end
	end
end