// Update 'viewed' state if required by completion system require_once $CFG->libdir . '/completionlib.php'; $completion = new completion_info($course); $completion->set_module_viewed($cm); if ($edit != -1 and $PAGE->user_allowed_editing()) { $USER->editing = $edit; } $wikipage = new page_wiki_view($wiki, $subwiki, $cm); $wikipage->set_gid($currentgroup); $wikipage->set_page($page); if ($pageid) { $event = \mod_wiki\event\page_viewed::create(array('context' => $context, 'objectid' => $pageid)); $event->add_record_snapshot('wiki_pages', $page); $event->trigger(); } else { if ($id) { $event = \mod_wiki\event\course_module_viewed::create(array('context' => $context, 'objectid' => $wiki->id)); $event->add_record_snapshot('wiki', $wiki); $event->trigger(); } else { if ($wid && $title) { $event = \mod_wiki\event\page_viewed::create(array('context' => $context, 'objectid' => $page->id, 'relateduserid' => $uid, 'other' => array('title' => $title, 'wid' => $wid, 'group' => $gid, 'groupanduser' => $groupanduser))); $event->add_record_snapshot('wiki_pages', $page); $event->add_record_snapshot('wiki', $wiki); $event->trigger(); } } } $wikipage->print_header(); $wikipage->print_content(); $wikipage->print_footer();
/** * Mark the activity completed (if required) and trigger the course_module_viewed event. * * @param stdClass $wiki Wiki object. * @param stdClass $course Course object. * @param stdClass $cm Course module object. * @param stdClass $context Context object. * @since Moodle 3.1 */ function wiki_view($wiki, $course, $cm, $context) { // Trigger course_module_viewed event. $params = array('context' => $context, 'objectid' => $wiki->id); $event = \mod_wiki\event\course_module_viewed::create($params); $event->add_record_snapshot('course_modules', $cm); $event->add_record_snapshot('course', $course); $event->add_record_snapshot('wiki', $wiki); $event->trigger(); // Completion. $completion = new completion_info($course); $completion->set_module_viewed($cm); }
/** * Test course_module_viewed event. */ public function test_course_module_viewed() { // There is no proper API to call or trigger this event, so simulating event // to check if event returns the right information. $this->setUp(); $context = context_module::instance($this->wiki->cmid); $params = array('context' => $context, 'objectid' => $this->wiki->id); $event = \mod_wiki\event\course_module_viewed::create($params); // Triggering and capturing the event. $sink = $this->redirectEvents(); $event->trigger(); $events = $sink->get_events(); $this->assertCount(1, $events); $event = reset($events); // Checking that the event contains the expected values. $this->assertInstanceOf('\\mod_wiki\\event\\course_module_viewed', $event); $this->assertEquals($context, $event->get_context()); $this->assertEquals($this->wiki->id, $event->objectid); $expected = array($this->course->id, 'wiki', 'view', 'view.php?id=' . $this->wiki->cmid, $this->wiki->id, $this->wiki->cmid); $this->assertEventLegacyLogData($expected, $event); $this->assertEventContextNotUsed($event); }