mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
Merge 13.0->trunk
This commit is contained in:
commit
4edcb2f344
2 changed files with 48 additions and 3 deletions
2
CHANGES
2
CHANGES
|
@ -10,6 +10,7 @@ TRUNK
|
|||
|
||||
- Add 'watch log' command to follow live debug logs at runtime (even if disabled)
|
||||
- mod_announce: Add shell commands to send messages to all users, online users, or limited by roles
|
||||
- New mod_account_activity plugin records last login/logout time of a user account
|
||||
|
||||
### Networking
|
||||
|
||||
|
@ -33,6 +34,7 @@ TRUNK
|
|||
- muc_room_allow_public = false restricts to admins
|
||||
- Commands to show occupants and affiliations in the Shell
|
||||
- Save 'reason' text supplied with affiliation change
|
||||
- Owners can set MUC avatars (functionality previously in community module mod_vcard_muc)
|
||||
|
||||
### Security and authentication
|
||||
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
local jid = require "util.jid";
|
||||
local jid = require "prosody.util.jid";
|
||||
local time = os.time;
|
||||
|
||||
local store = module:open_store(nil, "keyval+");
|
||||
|
@ -46,6 +46,49 @@ module:add_item("shell-command", {
|
|||
end;
|
||||
});
|
||||
|
||||
module:add_item("shell-command", {
|
||||
section = "user";
|
||||
section_desc = "View user activity data";
|
||||
name = "list_inactive";
|
||||
desc = "List inactive user accounts";
|
||||
args = {
|
||||
{ name = "host"; type = "string" };
|
||||
{ name = "duration"; type = "string" };
|
||||
};
|
||||
host_selector = "host";
|
||||
handler = function(self, host, duration) --luacheck: ignore 212/self
|
||||
local um = require "prosody.core.usermanager";
|
||||
local duration_sec = require "prosody.util.human.io".parse_duration(duration);
|
||||
if not duration_sec then
|
||||
return false, ("Invalid duration %q - try something like \"30d\""):format(duration);
|
||||
end
|
||||
|
||||
local now = os.time();
|
||||
local n_inactive, n_unknown = 0, 0;
|
||||
|
||||
for username in um.users(host) do
|
||||
local last_active = store:get_key(username, "timestamp");
|
||||
if not last_active then
|
||||
local created_at = um.get_account_info(username, host).created;
|
||||
if created_at and (now - created_at) > duration_sec then
|
||||
self.session.print(username, "");
|
||||
n_inactive = n_inactive + 1;
|
||||
elseif not created_at then
|
||||
n_unknown = n_unknown + 1;
|
||||
end
|
||||
elseif (now - last_active) > duration_sec then
|
||||
self.session.print(username, os.date("%Y-%m-%dT%T", last_active));
|
||||
n_inactive = n_inactive + 1;
|
||||
end
|
||||
end
|
||||
|
||||
if n_unknown > 0 then
|
||||
return true, ("%d accounts inactive since %s (%d unknown)"):format(n_inactive, os.date("%Y-%m-%dT%T", now - duration_sec), n_unknown);
|
||||
end
|
||||
return true, ("%d accounts inactive since %s"):format(n_inactive, os.date("%Y-%m-%dT%T", now - duration_sec));
|
||||
end;
|
||||
});
|
||||
|
||||
module:add_item("shell-command", {
|
||||
section = "migrate";
|
||||
section_desc = "Perform data migrations";
|
||||
|
@ -57,9 +100,9 @@ module:add_item("shell-command", {
|
|||
local lastlog2 = module:open_store("lastlog2", "keyval+");
|
||||
local n_updated, n_errors, n_skipped = 0, 0, 0;
|
||||
|
||||
local async = require "util.async";
|
||||
local async = require "prosody.util.async";
|
||||
|
||||
local p = require "util.promise".new(function (resolve)
|
||||
local p = require "prosody.util.promise".new(function (resolve)
|
||||
local async_runner = async.runner(function ()
|
||||
local n = 0;
|
||||
for username in lastlog2:items() do
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue