bf7f9577e225bed11a100b20cbe5c4e6db65f020
[moodle.git] / lib / classes / task / calendar_cron_task.php
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
17 /**
18  * A scheduled task.
19  *
20  * @package    core
21  * @copyright  2013 onwards Martin Dougiamas  http://dougiamas.com
22  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  */
24 namespace core\task;
26 defined('MOODLE_INTERNAL') || die();
28 require_once($CFG->libdir . '/cronlib.php');
30 /**
31  * Simple task to run the calendar cron.
32  */
33 class calendar_cron_task extends scheduled_task {
35     /**
36      * Get a descriptive name for this task (shown to admins).
37      *
38      * @return string
39      */
40     public function get_name() {
41         return get_string('taskcalendarcron', 'admin');
42     }
44     /**
45      * Do the job.
46      * Throw exceptions on errors (the job will be retried).
47      */
48     public function execute() {
49         global $CFG, $DB;
51         require_once($CFG->libdir . '/bennu/bennu.inc.php');
53         mtrace('Updating calendar subscriptions:');
54         cron_trace_time_and_memory();
56         $time = time();
57         $sql = "SELECT *
58                   FROM {event_subscriptions}
59                  WHERE pollinterval > 0
60                    AND lastupdated + pollinterval < :time";
61         $subscriptions = $DB->get_records_sql($sql, array('time' => $time));
62         foreach ($subscriptions as $sub) {
63             mtrace("Updating calendar subscription {$sub->name} in course {$sub->courseid}");
64             try {
65                 $log = calendar_update_subscription_events($sub->id);
66                 mtrace(trim(strip_tags($log)));
67             } catch (\moodle_exception $ex) {
68                 mtrace('Error updating calendar subscription: ' . $ex->getMessage());
69             }
70         }
72         mtrace('Finished updating calendar subscriptions.');
74         return true;
75     }
77 }