MDL-40060 mod_book: Replace add_to_log with events
[moodle.git] / mod / book / show.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  * Show/hide book chapter
19  *
20  * @package    mod_book
21  * @copyright  2004-2010 Petr Skoda {@link http://skodak.org}
22  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  */
25 require(dirname(__FILE__).'/../../config.php');
26 require_once(dirname(__FILE__).'/locallib.php');
28 $id        = required_param('id', PARAM_INT);        // Course Module ID
29 $chapterid = required_param('chapterid', PARAM_INT); // Chapter ID
31 $cm = get_coursemodule_from_id('book', $id, 0, false, MUST_EXIST);
32 $course = $DB->get_record('course', array('id'=>$cm->course), '*', MUST_EXIST);
33 $book = $DB->get_record('book', array('id'=>$cm->instance), '*', MUST_EXIST);
35 require_login($course, false, $cm);
36 require_sesskey();
38 $context = context_module::instance($cm->id);
39 require_capability('mod/book:edit', $context);
41 $PAGE->set_url('/mod/book/show.php', array('id'=>$id, 'chapterid'=>$chapterid));
43 $chapter = $DB->get_record('book_chapters', array('id'=>$chapterid, 'bookid'=>$book->id), '*', MUST_EXIST);
45 // Switch hidden state.
46 $chapter->hidden = $chapter->hidden ? 0 : 1;
48 // Update record.
49 $DB->update_record('book_chapters', $chapter);
50 $params = array(
51     'context' => $context,
52     'objectid' => $chapter->id
53 );
54 $event = \mod_book\event\chapter_updated::create($params);
55 $event->add_record_snapshot('book_chapters', $chapter);
56 $event->trigger();
58 // Change visibility of subchapters too.
59 if (!$chapter->subchapter) {
60     $chapters = $DB->get_records('book_chapters', array('bookid'=>$book->id), 'pagenum', 'id, subchapter, hidden');
61     $found = 0;
62     foreach ($chapters as $ch) {
63         if ($ch->id == $chapter->id) {
64             $found = 1;
65         } else if ($found and $ch->subchapter) {
66             $ch->hidden = $chapter->hidden;
67             $DB->update_record('book_chapters', $ch);
69             $params = array(
70                 'context' => $context,
71                 'objectid' => $ch->id
72             );
73             $event = \mod_book\event\chapter_updated::create($params);
74             $event->trigger();
76         } else if ($found) {
77             break;
78         }
79     }
80 }
82 // MDL-39963 Decide what to do with those logs.
83 add_to_log($course->id, 'course', 'update mod', '../mod/book/view.php?id='.$cm->id, 'book '.$book->id);
84 add_to_log($course->id, 'book', 'update', 'view.php?id='.$cm->id, $book->id, $cm->id);
86 book_preload_chapters($book); // fix structure
87 $DB->set_field('book', 'revision', $book->revision+1, array('id'=>$book->id));
89 redirect('view.php?id='.$cm->id.'&chapterid='.$chapter->id);