Software /
code /
prosody-modules
File
mod_discodot/mod_discodot.tl @ 6193:e977174082ee
mod_invites_register_api: Use set_password() for password resets
Previously the code relied on the (weird) behaviour of create_user(), which
would update the password for a user account if it already existed. This has
several issues, and we plan to deprecate this behaviour of create_user().
The larger issue is that this route does not trigger the user-password-changed
event, which can be a security problem. For example, it did not disconnect
existing user sessions (this occurs in mod_c2s in response to the event).
Switching to set_password() is the right thing to do
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Thu, 06 Feb 2025 10:24:30 +0000 |
parent | 4577:253df0798996 |
line wrap: on
line source
local cm = require"core.configmanager"; local function format_host(host:string, conf:{string:any}) : string if host == "*" then return "Global"; end local component_module = conf["component_module"]; if component_module is string then if component_module == "component" then return string.format("Component %q", host); else return string.format("Component %q %q", host, component_module); end else return string.format("VirtualHost %q", host); end end function module.command(arg : { string }) : integer local config : { string : { string : any } } = cm.getconfig(); print"digraph \"prosody\" {" for host, conf in pairs(config) do print(string.format("%q [label=%q]", host, format_host(host, conf))); local parent = host:match("%.(.*)"); if parent and rawget(config, parent) then print(string.format("%q -> %q", parent, host)); end local disco_items = conf["disco_items"] if disco_items is { { string, string } } then for _, pair in ipairs(disco_items) do print(string.format("%q -> %q", host, pair[1])); end end end print"}" return 0 end