forked from PukunuiAustralia/moodle-courseformat_grid
-
Notifications
You must be signed in to change notification settings - Fork 55
/
Copy pathobserver.php
74 lines (69 loc) · 2.58 KB
/
observer.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
<?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/>.
/**
* Grid Format.
*
* @package format_grid
* @copyright © 2017-onwards G J Barnard based upon work done by Marina Glancy.
* @author G J Barnard - {@link https://about.me/gjbarnard} and
* {@link https://moodle.org/user/profile.php?id=442195}
* @author Based on code originally written by Paul Krix and Julian Ridden.
* @license https://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace format_grid;
/**
* Event observers supported by this format.
*/
class observer {
/**
* Observer for the event course_content_deleted.
*
* Deletes the settings entry for the given course upon course deletion.
*
* @param \core\event\course_content_deleted $event
*/
public static function course_content_deleted(\core\event\course_content_deleted $event) {
if (class_exists('format_grid', false)) {
// If class format_grid was never loaded, this is definitely not a course in 'Grid' format.
self::delete_images($event->objectid);
}
}
/**
* Observer for the event course_restored.
*
* Deletes the settings entry for the given course upon course restoration.
*
* @param \core\event\course_restored $event
*/
public static function course_restored(\core\event\course_restored $event) {
global $DB;
$format = $DB->get_field('course', 'format', ['id' => $event->objectid]);
// If not in the grid format, then don't need the images etc.
if ($format != 'grid') {
// Then delete the images.
self::delete_images($event->objectid);
}
}
/**
* Deletes the images for the given course.
*
* @param int $courseid Course id.
*/
protected static function delete_images($courseid) {
// Delete any images associated with the course.
toolbox::delete_images($courseid);
}
}