2022-04-11 17:02:16 +02:00
|
|
|
mod_cron - Execute scheduled tasks
|
|
|
|
==================================
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
* Requires: ejabberd 19.08 or higher
|
|
|
|
* http://www.ejabberd.im/mod_cron
|
|
|
|
* Author: Badlop
|
2013-04-15 12:03:14 +02:00
|
|
|
|
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
This module allows advanced ejabberd administrators to schedule tasks for
|
2013-04-15 12:03:14 +02:00
|
|
|
periodic and automatic execution. This module is a similar concept than the
|
2022-04-11 17:02:16 +02:00
|
|
|
*nix's cron program.
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
Each time a scheduled task finishes its execution, a message is printed in the
|
2013-04-15 12:03:14 +02:00
|
|
|
ejabberd log file.
|
|
|
|
|
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
Basic Configuration
|
|
|
|
-------------------
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
Add the module to your `ejabberd.yml`, on the `modules` section:
|
|
|
|
```yaml
|
2015-01-28 17:12:59 +01:00
|
|
|
modules:
|
|
|
|
mod_cron: {}
|
2022-04-11 17:02:16 +02:00
|
|
|
```
|
|
|
|
|
|
|
|
Then, using the `tasks` option, you can add a list of tasks.
|
|
|
|
For each task there are options to define _when_ to run it,
|
|
|
|
and options to define _what_ to run.
|
|
|
|
|
|
|
|
When
|
|
|
|
----
|
|
|
|
|
|
|
|
Those options determine when a task is ran:
|
|
|
|
|
|
|
|
* `time: integer()`
|
|
|
|
|
|
|
|
* `units: seconds | minutes | hours | days`
|
|
|
|
|
|
|
|
Indicates the time unit to use.
|
|
|
|
|
|
|
|
* `timer_type: interval | fixed`
|
|
|
|
|
|
|
|
Default value is `interval`.
|
|
|
|
Fixed timers occur at a fixed time
|
|
|
|
after the [minute|hour|day] e.g. every hour on the 5th minute (1:05PM, 2:05PM etc).
|
|
|
|
Interval timers occur every interval (starting on an even unit) e.g. every 10 minutes
|
|
|
|
starting at 1PM, 1:10PM, 1:20PM etc.
|
|
|
|
Fixed timers are the equivalent of unix cron's comma syntax e.g. `"2 * * *"`
|
|
|
|
and interval timers are the `/` syntax e.g. `"*/5 * * *"`.
|
|
|
|
|
|
|
|
What
|
|
|
|
----
|
|
|
|
|
|
|
|
You can define a task to run some ejabberd API (either in command or in ctl syntax),
|
|
|
|
or any arbitrary erlang function.
|
|
|
|
|
|
|
|
### Command
|
|
|
|
|
|
|
|
Use the option `command` and provide `arguments` in the correct format:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
command: delete_old_mam_messages
|
|
|
|
arguments:
|
|
|
|
- "all"
|
|
|
|
- 0
|
|
|
|
```
|
|
|
|
|
|
|
|
This requires a recent ejabberd version that includes
|
|
|
|
[this commit](https://github.com/processone/ejabberd/commit/10481ed895016893ee9dc3fe23cd937fdc46ded6),
|
|
|
|
and `api_permissions` configured to allow mod_cron, for example:
|
|
|
|
|
|
|
|
```yaml
|
|
|
|
api_permissions:
|
|
|
|
"console commands":
|
|
|
|
from:
|
|
|
|
- ejabberd_ctl
|
|
|
|
- mod_cron
|
|
|
|
who: all
|
|
|
|
what: "*"
|
|
|
|
```
|
|
|
|
|
|
|
|
### Ctl
|
|
|
|
|
|
|
|
Use the option `ctl` and provide all `arguments` with quotes:
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
```yaml
|
|
|
|
ctl: delete_old_mam_messages
|
|
|
|
arguments:
|
|
|
|
- "all"
|
|
|
|
- "0"
|
|
|
|
```
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
### Erlang Function
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
Use `module`, `function`, and provide `arguments` in the correct format:
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
```yaml
|
|
|
|
module: ejabberd_auth
|
|
|
|
function: try_register
|
|
|
|
arguments:
|
|
|
|
- "user1"
|
|
|
|
- "localhost"
|
|
|
|
- "somepass"
|
|
|
|
```
|
2015-02-11 23:26:35 +01:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
Please note the arguments in string format will be converted to binaries.
|
|
|
|
If the function expects strings, you can add the option `args_type: string`:
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
```yaml
|
|
|
|
module: mnesia
|
|
|
|
function: backup
|
|
|
|
args_type: string
|
|
|
|
arguments:
|
|
|
|
- "/var/log/ejabberd/mnesia.backup"
|
|
|
|
```
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
Example Tasks
|
|
|
|
-------------
|
|
|
|
|
|
|
|
Those example tasks show how to specify arguments in the basic erlang formats:
|
|
|
|
```yaml
|
2015-01-28 17:12:59 +01:00
|
|
|
modules:
|
|
|
|
mod_cron:
|
|
|
|
tasks:
|
2022-04-11 17:02:16 +02:00
|
|
|
- time: 30
|
|
|
|
units: seconds
|
|
|
|
module: erlang
|
|
|
|
function: is_integer
|
|
|
|
arguments:
|
|
|
|
- 123456
|
|
|
|
- time: 31
|
|
|
|
units: seconds
|
|
|
|
module: erlang
|
|
|
|
function: is_float
|
|
|
|
arguments:
|
|
|
|
- 123.456
|
|
|
|
- time: 32
|
|
|
|
units: seconds
|
|
|
|
module: erlang
|
|
|
|
function: is_atom
|
|
|
|
arguments:
|
|
|
|
- 'this_is_atom'
|
|
|
|
- time: 33
|
|
|
|
units: seconds
|
|
|
|
module: erlang
|
|
|
|
function: is_atom
|
|
|
|
arguments:
|
|
|
|
- this_is_atom_too
|
|
|
|
- time: 34
|
2015-01-28 17:12:59 +01:00
|
|
|
units: seconds
|
2022-04-11 17:02:16 +02:00
|
|
|
module: erlang
|
|
|
|
function: is_binary
|
|
|
|
arguments:
|
|
|
|
- "Keep this as a binary"
|
|
|
|
- time: 35
|
|
|
|
units: seconds
|
|
|
|
module: erlang
|
|
|
|
function: is_list
|
2022-01-05 12:45:41 +01:00
|
|
|
args_type: string
|
|
|
|
arguments:
|
2022-04-11 17:02:16 +02:00
|
|
|
- "Convert this as a string"
|
|
|
|
```
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
It is even possible to pass an argument that is a list of elements, see:
|
|
|
|
```yaml
|
|
|
|
modules:
|
|
|
|
mod_cron:
|
|
|
|
tasks:
|
|
|
|
- time: 36
|
|
|
|
units: seconds
|
|
|
|
module: io
|
|
|
|
function: format
|
|
|
|
args_type: string
|
|
|
|
arguments:
|
|
|
|
- "log message, integer: ~p, float: ~p, atom: ~p, binary: ~p~n~n"
|
|
|
|
- - 12345678
|
|
|
|
- 123.456
|
|
|
|
- atom_this_is
|
|
|
|
- "this is a binary"
|
|
|
|
```
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-12 11:33:33 +02:00
|
|
|
If you don't need to provide arguments at all,
|
|
|
|
you can remove `arguments`, or provide it with an empty list:
|
|
|
|
```yaml
|
|
|
|
modules:
|
|
|
|
mod_cron:
|
|
|
|
tasks:
|
|
|
|
- time: 10
|
|
|
|
units: seconds
|
|
|
|
command: connected_users
|
|
|
|
- time: 15
|
|
|
|
units: seconds
|
|
|
|
ctl: delete_expired_pubsub_items
|
|
|
|
- time: 20
|
|
|
|
units: seconds
|
|
|
|
module: mod_pubsub
|
|
|
|
function: delete_expired_items
|
|
|
|
arguments: []
|
|
|
|
```
|
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
ejabberd Commands
|
|
|
|
-----------------
|
2013-04-15 12:03:14 +02:00
|
|
|
|
|
|
|
This module provides two new commands that can be executed using ejabberdctl:
|
2015-01-28 17:12:59 +01:00
|
|
|
* cron_list: list scheduled tasks
|
|
|
|
* cron_del taskid: delete this task from the schedule
|
2013-04-15 12:03:14 +02:00
|
|
|
|
2022-04-11 17:02:16 +02:00
|
|
|
Web Admin
|
|
|
|
---------
|
2013-04-15 12:03:14 +02:00
|
|
|
|
|
|
|
This module provides a page in the Host section of the Web Admin.
|
|
|
|
Currently that page only allows to view the tasks scheduled for that host.
|