db/tasks.php
If a plugin wants to configure scheduled task, two items are required:
- a class extending the \core\task\scheduled_taskclass; and
- the db/tasks.phpfile containing its initial configuration.
The general format of the file is as follows:
$tasks = [
    // First task configuration.
    [ ... ],
    // Second task configuration.
    [ ... ],
];
Each task configuration entry has a number of possible properties, described below.
Task configuration entries
Classname
The classname contains the fully-qualified class name where the scheduled task is located.
$tasks = [
    [
        'classname' => 'mod_example\task\do_something',
        // ...
    ]
]
Blocking
Tasks can be configured to block the execution of all other tasks by setting the blocking property to a truthy value.
Whilst this feature is available its use is strongly discouraged and will not be accepted in Moodle core.
$tasks = [
    [
        'classname' => 'mod_example\task\do_something',
        'blocking' => 1,
        // ...
    ],
];
Date and time fields
The following date and time fields are available:
- month
- day
- dayofweek
- hour
- month
Each of these fields accepts one, or more values, and the format for each field is described as:
<fieldlist> := <range>(/<step>)(,<fieldlist>)
<step>      := int
<range>     := <any>|<int>|<min-max>|<random>
<any>       := *
<min-max>   := int-int
<random>    := R
A fixed random value can be selected by using a value of R. By specifying this option, a random day or time is chosen when the task is installed or updated. The same value will be used each time the task is scheduled.
If no value is specified then the following defaults are used:
- Month: *(Every month)
- Day: *(Every day)
- Day of the week: *(Every day of the week)
- Hour: *(Every hour)
- Minute: *(Every minute)
If either field is set to * then use the other field, otherwise the soonest value is used.
Examples
$tasks = [
    [
        'classname' => 'mod_example\task\do_something',
        // Every month.
        'month' => '*',
        // Every day.
        'day' => '*',
        // A fixed random hour and minute.
        'hour' => 'R',
        'month' => 'R',
    ],
];
$tasks = [
    [
        'classname' => 'mod_example\task\do_something',
        // At two intervals in the hour.
        'minute' => '5, 35',
    ],
];
Disabled tasks
You can create a task that defaults to disabled by setting the field disabled to 1. Unless the administrator manually enables your task, it will not run.
This is useful if a task is only required in certain situations and shouldn't run on every server that has your plugin installed.