moduleapi: Add module:once() to execute a function after module load/startup

It is a common pattern for modules to do something like check for
prosody.start_time, and execute code immediately if it is present, or wait for
the server-started event if it isn't yet. For example, this allows you to run
code after all other modules/hosts have been loaded, that are going to be
loaded.

Such code can now be replaced with a simple call to this method.
This commit is contained in:
Matthew Wild 2023-04-01 11:59:50 +01:00
parent 5ce1fe2603
commit 05c6704075

View file

@ -693,4 +693,9 @@ function api:may(action, context, peek)
end
end
-- Execute a function, once, but only after startup is complete
function api:once(f)
return prosody.started:next(f);
end
return api;