Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.0.x will end 8 May 2023 (12 months).
  • Bug fixes for security issues in 4.0.x will end 13 November 2023 (18 months).
  • PHP version: minimum PHP 7.3.0 Note: the minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is also supported.
/admin/cli/ -> cron.php (source)

Differences Between: [Versions 39 and 400] [Versions 400 and 402] [Versions 400 and 403]

   1  <?php
   2  
   3  // This file is part of Moodle - http://moodle.org/
   4  //
   5  // Moodle is free software: you can redistribute it and/or modify
   6  // it under the terms of the GNU General Public License as published by
   7  // the Free Software Foundation, either version 3 of the License, or
   8  // (at your option) any later version.
   9  //
  10  // Moodle is distributed in the hope that it will be useful,
  11  // but WITHOUT ANY WARRANTY; without even the implied warranty of
  12  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  13  // GNU General Public License for more details.
  14  //
  15  // You should have received a copy of the GNU General Public License
  16  // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
  17  
  18  /**
  19   * CLI cron
  20   *
  21   * This script looks through all the module directories for cron.php files
  22   * and runs them.  These files can contain cleanup functions, email functions
  23   * or anything that needs to be run on a regular basis.
  24   *
  25   * @package    core
  26   * @subpackage cli
  27   * @copyright  2009 Petr Skoda (http://skodak.org)
  28   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  29   */
  30  
  31  define('CLI_SCRIPT', true);
  32  
  33  require(__DIR__.'/../../config.php');
  34  require_once($CFG->libdir.'/clilib.php');      // cli only functions
  35  require_once($CFG->libdir.'/cronlib.php');
  36  
  37  // now get cli options
  38  list($options, $unrecognized) = cli_get_params(
  39      [
  40          'help' => false,
  41          'stop' => false,
  42          'list' => false,
  43          'force' => false,
  44          'enable' => false,
  45          'disable' => false,
  46          'disable-wait' => false,
  47      ], [
  48          'h' => 'help',
  49          's' => 'stop',
  50          'l' => 'list',
  51          'f' => 'force',
  52          'e' => 'enable',
  53          'd' => 'disable',
  54          'w' => 'disable-wait',
  55      ]
  56  );
  57  
  58  if ($unrecognized) {
  59      $unrecognized = implode("\n  ", $unrecognized);
  60      cli_error(get_string('cliunknowoption', 'admin', $unrecognized));
  61  }
  62  
  63  if ($options['help']) {
  64      $help =
  65  "Execute periodic cron actions.
  66  
  67  Options:
  68  -h, --help               Print out this help
  69  -s, --stop               Notify all other running cron processes to stop after the current task
  70  -l, --list               Show the list of currently running tasks and how long they have been running
  71  -f, --force              Execute task even if cron is disabled
  72  -e, --enable             Enable cron
  73  -d, --disable            Disable cron
  74  -w, --disable-wait=600   Disable cron and wait until all tasks finished or fail after N seconds (optional param)
  75  
  76  Example:
  77  \$sudo -u www-data /usr/bin/php admin/cli/cron.php
  78  ";
  79  
  80      echo $help;
  81      die;
  82  }
  83  
  84  if ($options['stop']) {
  85      // By clearing the caches this signals to other running processes
  86      // to exit after finishing the current task.
  87      \core\task\manager::clear_static_caches();
  88      die;
  89  }
  90  
  91  if ($options['enable']) {
  92      set_config('cron_enabled', 1);
  93      mtrace('Cron has been enabled for the site.');
  94      exit(0);
  95  }
  96  
  97  if ($options['disable']) {
  98      set_config('cron_enabled', 0);
  99      \core\task\manager::clear_static_caches();
 100      mtrace('Cron has been disabled for the site.');
 101      exit(0);
 102  }
 103  
 104  if ($options['list']) {
 105      $tasks = \core\task\manager::get_running_tasks();
 106      mtrace('The list of currently running tasks:');
 107      $format = "%7s %-12s %-9s %-20s %-52s\n";
 108      printf ($format,
 109          'PID',
 110          'HOST',
 111          'TYPE',
 112          'TIME',
 113          'CLASSNAME'
 114      );
 115      foreach ($tasks as $task) {
 116          printf ($format,
 117              $task->pid,
 118              substr($task->hostname, 0, 12),
 119              $task->type,
 120              format_time(time() - $task->timestarted),
 121              substr($task->classname, 0, 52)
 122          );
 123      }
 124      exit(0);
 125  }
 126  
 127  if ($wait = $options['disable-wait']) {
 128      $started = time();
 129      if (true === $wait) {
 130          // Default waiting time.
 131          $waitsec = 600;
 132      } else {
 133          $waitsec = $wait;
 134          $wait = true;
 135      }
 136  
 137      set_config('cron_enabled', 0);
 138      \core\task\manager::clear_static_caches();
 139      mtrace('Cron has been disabled for the site.');
 140      mtrace('Allocating '. format_time($waitsec) . ' for the tasks to finish.');
 141  
 142      $lastcount = 0;
 143      while ($wait) {
 144          $tasks = \core\task\manager::get_running_tasks();
 145  
 146          if (count($tasks) == 0) {
 147              mtrace('');
 148              mtrace('All scheduled and adhoc tasks finished.');
 149              exit(0);
 150          }
 151  
 152          if (time() - $started >= $waitsec) {
 153              mtrace('');
 154              mtrace('Wait time ('. format_time($waitsec) . ') elapsed, but ' . count($tasks) . ' task(s) still running.');
 155              mtrace('Exiting with code 1.');
 156              exit(1);
 157          }
 158  
 159          if (count($tasks) !== $lastcount) {
 160              mtrace('');
 161              mtrace(count($tasks) . " tasks currently running.", '');
 162              $lastcount = count($tasks);
 163          } else {
 164              mtrace('.', '');
 165          }
 166  
 167          sleep(1);
 168      }
 169  }
 170  
 171  if (!get_config('core', 'cron_enabled') && !$options['force']) {
 172      mtrace('Cron is disabled. Use --force to override.');
 173      exit(1);
 174  }
 175  
 176  \core\local\cli\shutdown::script_supports_graceful_exit();
 177  
 178  cron_run();