Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are supported too.
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * A scheduled task.
 *
 * @package    core
 * @copyright  2013 onwards Martin Dougiamas  http://dougiamas.com
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
namespace core\task;

defined('MOODLE_INTERNAL') || die();

require_once($CFG->dirroot . '/calendar/lib.php');

/**
 * Simple task to run the calendar cron.
 */
class calendar_cron_task extends scheduled_task {

    /**
     * Get a descriptive name for this task (shown to admins).
     *
     * @return string
     */
    public function get_name() {
        return get_string('taskcalendarcron', 'admin');
    }

    /**
     * Do the job.
     * Throw exceptions on errors (the job will be retried).
     */
    public function execute() {
        global $CFG, $DB;

        require_once($CFG->libdir . '/bennu/bennu.inc.php');

        $time = time();
        $sql = "SELECT *
                  FROM {event_subscriptions}
                 WHERE pollinterval > 0
                   AND lastupdated + pollinterval < :time";
        $subscriptions = $DB->get_records_sql($sql, array('time' => $time));
        foreach ($subscriptions as $sub) {
            mtrace("Updating calendar subscription {$sub->name} in course {$sub->courseid}");
            try {
                $log = calendar_update_subscription_events($sub->id);
< mtrace(trim(strip_tags($log)));
> mtrace($log['eventsimported'] . ' events were imported'); > mtrace($log['eventsskipped'] . ' events were skipped'); > mtrace($log['eventsupdated'] . ' events were updated'); > mtrace($log['eventsdeleted'] . ' events were deleted'); > if ($log['haserror']) { > mtrace('Failed to add event'); > foreach ($log['errors'] as $error) { > mtrace(trim(strip_tags($error))); > } > }
} catch (\moodle_exception $ex) { mtrace('Error updating calendar subscription: ' . $ex->getMessage()); } } return true; } }