See Release Notes
Long Term Support Release
<?php require_once("../../config.php"); require_once("lib.php"); $id = required_param('id', PARAM_INT); // course module ID $confirm = optional_param('confirm', 0, PARAM_INT); // commit the operation? $entry = optional_param('entry', 0, PARAM_INT); // entry id $prevmode = required_param('prevmode', PARAM_ALPHA); $hook = optional_param('hook', '', PARAM_CLEAN); $url = new moodle_url('/mod/glossary/deleteentry.php', array('id'=>$id,'prevmode'=>$prevmode)); if ($confirm !== 0) { $url->param('confirm', $confirm); } if ($entry !== 0) { $url->param('entry', $entry); } if ($hook !== '') { $url->param('hook', $hook); } $PAGE->set_url($url); $strglossary = get_string("modulename", "glossary"); $strglossaries = get_string("modulenameplural", "glossary"); $stredit = get_string("edit"); $entrydeleted = get_string("entrydeleted","glossary"); if (! $cm = get_coursemodule_from_id('glossary', $id)) { print_error("invalidcoursemodule"); } if (! $course = $DB->get_record("course", array("id"=>$cm->course))) { print_error('coursemisconf'); } if (! $entry = $DB->get_record("glossary_entries", array("id"=>$entry))) { print_error('invalidentry'); } // Permission checks are based on the course module instance so make sure it is correct. if ($cm->instance != $entry->glossaryid) { print_error('invalidentry'); } require_login($course, false, $cm); $context = context_module::instance($cm->id);< $manageentries = has_capability('mod/glossary:manageentries', $context);if (! $glossary = $DB->get_record("glossary", array("id"=>$cm->instance))) { print_error('invalidid', 'glossary'); }< < $strareyousuredelete = get_string("areyousuredelete","glossary"); < < if (($entry->userid != $USER->id) and !$manageentries) { // guest id is never matched, no need for special check here < print_error('nopermissiontodelentry'); < } < $ineditperiod = ((time() - $entry->timecreated < $CFG->maxeditingtime) || $glossary->editalways); < if (!$ineditperiod and !$manageentries) { < print_error('errdeltimeexpired', 'glossary'); < }> // Throws an exception if the user cannot delete the entry. > mod_glossary_can_delete_entry($entry, $glossary, $context, false);/// If data submitted, then process and store. if ($confirm and confirm_sesskey()) { // the operation was confirmed.< // if it is an imported entry, just delete the relation < < $origentry = fullclone($entry); < if ($entry->sourceglossaryid) { < if (!$newcm = get_coursemodule_from_instance('glossary', $entry->sourceglossaryid)) { < print_error('invalidcoursemodule'); < } < $newcontext = context_module::instance($newcm->id); < < $entry->glossaryid = $entry->sourceglossaryid; < $entry->sourceglossaryid = 0; < $DB->update_record('glossary_entries', $entry); < < // move attachments too < $fs = get_file_storage(); < < if ($oldfiles = $fs->get_area_files($context->id, 'mod_glossary', 'attachment', $entry->id)) { < foreach ($oldfiles as $oldfile) { < $file_record = new stdClass(); < $file_record->contextid = $newcontext->id; < $fs->create_file_from_storedfile($file_record, $oldfile); < } < $fs->delete_area_files($context->id, 'mod_glossary', 'attachment', $entry->id); < $entry->attachment = '1'; < } else { < $entry->attachment = '0'; < } < $DB->update_record('glossary_entries', $entry); < < } else { < $fs = get_file_storage(); < $fs->delete_area_files($context->id, 'mod_glossary', 'attachment', $entry->id); < $DB->delete_records("comments", array('itemid'=>$entry->id, 'commentarea'=>'glossary_entry', 'contextid'=>$context->id)); < $DB->delete_records("glossary_alias", array("entryid"=>$entry->id)); < $DB->delete_records("glossary_entries", array("id"=>$entry->id)); < < // Update completion state < $completion = new completion_info($course); < if ($completion->is_enabled($cm) == COMPLETION_TRACKING_AUTOMATIC && $glossary->completionentries) { < $completion->update_state($cm, COMPLETION_INCOMPLETE, $entry->userid); < } < < //delete glossary entry ratings < require_once($CFG->dirroot.'/rating/lib.php'); < $delopt = new stdClass; < $delopt->contextid = $context->id; < $delopt->component = 'mod_glossary'; < $delopt->ratingarea = 'entry'; < $delopt->itemid = $entry->id; < $rm = new rating_manager(); < $rm->delete_ratings($delopt); < } < < // Delete cached RSS feeds. < if (!empty($CFG->enablerssfeeds)) { < require_once($CFG->dirroot.'/mod/glossary/rsslib.php'); < glossary_rss_delete_file($glossary); < } < < core_tag_tag::remove_all_item_tags('mod_glossary', 'glossary_entries', $origentry->id); < < $event = \mod_glossary\event\entry_deleted::create(array( < 'context' => $context, < 'objectid' => $origentry->id, < 'other' => array( < 'mode' => $prevmode, < 'hook' => $hook, < 'concept' => $origentry->concept < ) < )); < $event->add_record_snapshot('glossary_entries', $origentry); < $event->trigger(); < < // Reset caches. < if ($entry->usedynalink and $entry->approved) { < \mod_glossary\local\concept_cache::reset_glossary($glossary); < }> mod_glossary_delete_entry($entry, $glossary, $cm, $context, $course, $hook, $prevmode);redirect("view.php?id=$cm->id&mode=$prevmode&hook=$hook"); } else { // the operation has not been confirmed yet so ask the user to do so> $strareyousuredelete = get_string("areyousuredelete", "glossary");$PAGE->navbar->add(get_string('delete')); $PAGE->set_title($glossary->name); $PAGE->set_heading($course->fullname); echo $OUTPUT->header(); $areyousure = "<b>".format_string($entry->concept)."</b><p>$strareyousuredelete</p>"; $linkyes = 'deleteentry.php'; $linkno = 'view.php'; $optionsyes = array('id'=>$cm->id, 'entry'=>$entry->id, 'confirm'=>1, 'sesskey'=>sesskey(), 'prevmode'=>$prevmode, 'hook'=>$hook); $optionsno = array('id'=>$cm->id, 'mode'=>$prevmode, 'hook'=>$hook); echo $OUTPUT->confirm($areyousure, new moodle_url($linkyes, $optionsyes), new moodle_url($linkno, $optionsno)); echo $OUTPUT->footer(); }