moodle/mod/chat/report.php

278 lines
11 KiB
PHP
Raw Normal View History

<?php
/// This page prints reports and info about chats
require_once('../../config.php');
require_once('lib.php');
$id = required_param('id', PARAM_INT);
$start = optional_param('start', 0, PARAM_INT); // Start of period
$end = optional_param('end', 0, PARAM_INT); // End of period
$deletesession = optional_param('deletesession', 0, PARAM_BOOL);
$confirmdelete = optional_param('confirmdelete', 0, PARAM_BOOL);
$show_all = optional_param('show_all', 0, PARAM_BOOL);
$url = new moodle_url('/mod/chat/report.php', array('id'=>$id));
if ($start !== 0) {
$url->param('start', $start);
}
if ($end !== 0) {
$url->param('end', $end);
}
if ($deletesession !== 0) {
$url->param('deletesession', $deletesession);
}
if ($confirmdelete !== 0) {
$url->param('confirmdelete', $confirmdelete);
}
$PAGE->set_url($url);
if (! $cm = get_coursemodule_from_id('chat', $id)) {
2008-06-06 08:46:48 +00:00
print_error('invalidcoursemodule');
}
2008-06-08 15:49:36 +00:00
if (! $chat = $DB->get_record('chat', array('id'=>$cm->instance))) {
2008-06-06 08:46:48 +00:00
print_error('invalidcoursemodule');
}
2008-06-08 15:49:36 +00:00
if (! $course = $DB->get_record('course', array('id'=>$chat->course))) {
2008-06-06 08:46:48 +00:00
print_error('coursemisconf');
}
2006-08-09 13:45:49 +00:00
$context = get_context_instance(CONTEXT_MODULE, $cm->id);
require_login($course->id, false, $cm);
2008-06-18 01:45:01 +00:00
require_capability('mod/chat:readlog', $context);
if (empty($chat->studentlogs) && !has_capability('mod/chat:readlog', $context)) {
notice(get_string('nopermissiontoseethechatlog', 'chat'));
}
add_to_log($course->id, 'chat', 'report', "report.php?id=$cm->id", $chat->id, $cm->id);
$strchats = get_string('modulenameplural', 'chat');
$strchat = get_string('modulename', 'chat');
$strchatreport = get_string('chatreport', 'chat');
$strseesession = get_string('seesession', 'chat');
$strdeletesession = get_string('deletesession', 'chat');
2004-01-16 13:14:42 +00:00
$navlinks = array();
2008-06-18 01:45:01 +00:00
/// Print a session if one has been specified
2004-01-16 13:14:42 +00:00
if ($start and $end and !$confirmdelete) { // Show a full transcript
$PAGE->navbar->add($strchatreport);
$PAGE->set_title(format_string($chat->name).": $strchatreport");
echo $OUTPUT->header();
/// Check to see if groups are being used here
$groupmode = groups_get_activity_groupmode($cm);
$currentgroup = groups_get_activity_group($cm, true);
groups_print_activity_menu($cm, $CFG->wwwroot . "/mod/chat/report.php?id=$cm->id");
2008-06-08 15:49:36 +00:00
$params = array('currentgroup'=>$currentgroup, 'chatid'=>$chat->id, 'start'=>$start, 'end'=>$end);
// If the user is allocated to a group, only show messages from people
// in the same group, or no group
if ($currentgroup) {
$groupselect = " AND (groupid = :currentgroup OR groupid = 0)";
2004-02-24 07:21:52 +00:00
} else {
$groupselect = "";
}
if ($deletesession and has_capability('mod/chat:deletelog', $context)) {
echo $OUTPUT->confirm(get_string('deletesessionsure', 'chat'),
"report.php?id=$cm->id&deletesession=1&confirmdelete=1&start=$start&end=$end",
"report.php?id=$cm->id");
2004-01-16 13:14:42 +00:00
}
2008-06-18 01:45:01 +00:00
if (!$messages = $DB->get_records_select('chat_messages', "chatid = :chatid AND timestamp >= :start AND timestamp <= :end $groupselect", $params, "timestamp ASC")) {
echo $OUTPUT->heading(get_string('nomessages', 'chat'));
} else {
echo '<p class="boxaligncenter">'.userdate($start).' --> '. userdate($end).'</p>';
echo $OUTPUT->box_start('center');
$participates = array();
foreach ($messages as $message) { // We are walking FORWARDS through messages
if (!isset($participates[$message->userid])) {
$participates[$message->userid] = true;
}
$formatmessage = chat_format_message($message, $course->id, $USER);
if (isset($formatmessage->html)) {
echo $formatmessage->html;
}
}
$participated_cap = array_key_exists($USER->id, $participates) && has_capability('mod/chat:exportparticipatedsession', $context);
if (has_capability('mod/chat:exportsession', $context) || $participated_cap) {
require_once($CFG->libdir . '/portfoliolib.php');
$buttonoptions = array(
'id' => $cm->id,
'start' => $start,
'end' => $end,
);
$button = new portfolio_add_button();
$button->set_callback_options('chat_portfolio_caller', $buttonoptions, '/mod/chat/locallib.php');
$button->render();
}
echo $OUTPUT->box_end();
}
if (!$deletesession or !has_capability('mod/chat:deletelog', $context)) {
echo $OUTPUT->continue_button("report.php?id=$cm->id");
2004-01-16 13:14:42 +00:00
}
echo $OUTPUT->footer();
exit;
}
/// Print the Sessions display
$PAGE->navbar->add($strchatreport);
$PAGE->set_title(format_string($chat->name).": $strchatreport");
echo $OUTPUT->header();
echo $OUTPUT->heading(format_string($chat->name).': '.get_string('sessions', 'chat'));
2004-02-24 07:00:13 +00:00
/// Check to see if groups are being used here
if ($groupmode = groups_get_activity_groupmode($cm)) { // Groups are being used
$currentgroup = groups_get_activity_group($cm, true);
groups_print_activity_menu($cm, $CFG->wwwroot . "/mod/chat/report.php?id=$cm->id");
} else {
$currentgroup = false;
}
2008-06-08 15:49:36 +00:00
$params = array('currentgroup'=>$currentgroup, 'chatid'=>$chat->id, 'start'=>$start, 'end'=>$end);
// If the user is allocated to a group, only show discussions with people in
// the same group, or no group
if (!empty($currentgroup)) {
$groupselect = " AND (groupid = :currentgroup OR groupid = 0)";
} else {
$groupselect = "";
}
2004-01-16 13:14:42 +00:00
/// Delete a session if one has been specified
if ($deletesession and has_capability('mod/chat:deletelog', $context) and $confirmdelete and $start and $end and confirm_sesskey()) {
2008-06-08 15:49:36 +00:00
$DB->delete_records_select('chat_messages', "chatid = :chatid AND timestamp >= :start AND
timestamp <= :end $groupselect", $params);
$strdeleted = get_string('deleted');
echo $OUTPUT->notification("$strdeleted: ".userdate($start).' --> '. userdate($end));
2004-01-16 13:14:42 +00:00
unset($deletesession);
}
/// Get the messages
if (empty($messages)) { /// May have already got them above
2008-06-08 15:49:36 +00:00
if (!$messages = $DB->get_records_select('chat_messages', "chatid = :chatid $groupselect", $params, "timestamp DESC")) {
echo $OUTPUT->heading(get_string('nomessages', 'chat'));
echo $OUTPUT->footer();
2004-01-16 13:14:42 +00:00
exit;
}
}
if ($show_all) {
echo $OUTPUT->heading(get_string('listing_all_sessions', 'chat') .
'&nbsp;<a href="report.php?id='.$cm->id.'&amp;show_all=0">' .
get_string('list_complete_sessions', 'chat') . '</a>');
}
2004-01-16 13:14:42 +00:00
/// Show all the sessions
$sessiongap = 5 * 60; // 5 minutes silence means a new session
$sessionend = 0;
$sessionstart = 0;
$sessionusers = array();
$lasttime = 0;
$complete_sessions = 0;
$messagesleft = count($messages);
foreach ($messages as $message) { // We are walking BACKWARDS through the messages
$messagesleft --; // Countdown
2003-07-21 03:37:53 +00:00
if (!$lasttime) {
$lasttime = $message->timestamp;
}
2003-07-21 03:37:53 +00:00
if (!$sessionend) {
$sessionend = $message->timestamp;
}
if ((($lasttime - $message->timestamp) < $sessiongap) and $messagesleft) { // Same session
if ($message->userid and !$message->system) { // Remember user and count messages
if (empty($sessionusers[$message->userid])) {
$sessionusers[$message->userid] = 1;
} else {
$sessionusers[$message->userid] ++;
}
2003-07-21 03:37:53 +00:00
}
} else {
2003-07-21 03:37:53 +00:00
$sessionstart = $lasttime;
$is_complete = ($sessionend - $sessionstart > 60 and count($sessionusers) > 1);
if ($show_all or $is_complete) {
echo '<p align="center">'.userdate($sessionstart).' --> '. userdate($sessionend).'</p>';
echo $OUTPUT->box_start();
arsort($sessionusers);
foreach ($sessionusers as $sessionuser => $usermessagecount) {
2008-06-08 15:49:36 +00:00
if ($user = $DB->get_record('user', array('id'=>$sessionuser))) {
$OUTPUT->user_picture($user, array('courseid'=>$course->id));
echo '&nbsp;'.fullname($user, true); // XXX TODO use capability instead of true
2003-07-21 05:31:23 +00:00
echo "&nbsp;($usermessagecount)<br />";
2003-07-21 03:37:53 +00:00
}
}
echo '<p align="right">';
echo "<a href=\"report.php?id=$cm->id&amp;start=$sessionstart&amp;end=$sessionend\">$strseesession</a>";
if (has_capability('mod/chat:exportsession', $context)
|| (array_key_exists($USER->id, $sessionusers)
&& has_capability('mod/chat:exportparticipatedsession', $context))) {
require_once($CFG->libdir . '/portfoliolib.php');
$buttonoptions = array(
'id' => $cm->id,
'start' => $sessionstart,
'end' => $sessionend,
);
$button = new portfolio_add_button();
$button->set_callback_options('chat_portfolio_caller', $buttonoptions, '/mod/chat/locallib.php');
$button->render(PORTFOLIO_ADD_TEXT_LINK);
}
if (has_capability('mod/chat:deletelog', $context)) {
echo "<br /><a href=\"report.php?id=$cm->id&amp;start=$sessionstart&amp;end=$sessionend&amp;deletesession=1\">$strdeletesession</a>";
2004-01-16 13:14:42 +00:00
}
echo '</p>';
echo $OUTPUT->box_end();
2003-07-21 03:37:53 +00:00
}
if ($is_complete) {
$complete_sessions++;
}
2003-07-21 03:37:53 +00:00
$sessionend = $message->timestamp;
$sessionusers = array();
$sessionusers[$message->userid] = 1;
}
2003-07-21 03:37:53 +00:00
$lasttime = $message->timestamp;
}
if (has_capability('mod/chat:exportsession', $context)) {
require_once($CFG->libdir . '/portfoliolib.php');
$button = new portfolio_add_button();
$button->set_callback_options('chat_portfolio_caller', array('id' => $cm->id), '/mod/chat/locallib.php');
$button->render(null, get_string('addalltoportfolio', 'portfolio'));
}
if (!$show_all and $complete_sessions == 0) {
echo $OUTPUT->heading(get_string('no_complete_sessions_found', 'chat') .
'&nbsp;<a href="report.php?id='.$cm->id.'&amp;show_all=1">' .
get_string('list_all_sessions', 'chat') .
'</a>');
}
/// Finish the page
echo $OUTPUT->footer();