. /** * Calendar event deleted event. * * @package core * @copyright 2014 onwards Ankit Agarwal * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace core\event; defined('MOODLE_INTERNAL') || die(); /** * Calendar event deleted event. * * @property-read array $other { * Extra information about the event. * * - int repeatid: id of the parent event if present, else 0. * - int timestart: timestamp for event time start. * - string name: name of the event. * } * * @package core * @since Moodle 2.7 * @copyright 2014 onwards Ankit Agarwal * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class calendar_event_deleted extends base { /** * Init method. * * @return void */ protected function init() { $this->data['crud'] = 'd'; $this->data['edulevel'] = self::LEVEL_OTHER; $this->data['objecttable'] = 'event'; } /** * Returns localised general event name. * * @return string */ public static function get_name() { return get_string('eventcalendareventdeleted', 'core_calendar'); } /** * Returns description of what happened. * * @return string */ public function get_description() { $eventname = s($this->other['name']); return "The user with id '$this->userid' deleted the event '$eventname' with id '$this->objectid'."; } /** * Custom validation. * * Throw \coding_exception notice in case of any problems. */ protected function validate_data() { parent::validate_data(); if (!isset($this->other['repeatid'])) { throw new \coding_exception('The \'repeatid\' value must be set in other.'); } if (empty($this->other['name'])) { throw new \coding_exception('The \'name\' value must be set in other.'); } if (!isset($this->other['timestart'])) { throw new \coding_exception('The \'timestart\' value must be set in other.'); } } }