2003-07-21 03:16:19 +00:00
|
|
|
<?PHP // $Id$
|
|
|
|
|
|
|
|
/// This page prints reports and info about chats
|
|
|
|
|
|
|
|
require_once("../../config.php");
|
|
|
|
require_once("lib.php");
|
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
require_variable($id); // Chat Module ID, or
|
|
|
|
optional_variable($start, 0); // Start of period
|
|
|
|
optional_variable($end, 0); // End of period
|
2003-07-21 03:16:19 +00:00
|
|
|
|
|
|
|
if (! $chat = get_record("chat", "id", $id)) {
|
|
|
|
error("Course module is incorrect");
|
|
|
|
}
|
|
|
|
if (! $course = get_record("course", "id", $chat->course)) {
|
|
|
|
error("Course is misconfigured");
|
|
|
|
}
|
|
|
|
if (! $cm = get_coursemodule_from_instance("chat", $chat->id, $course->id)) {
|
|
|
|
error("Course Module ID was incorrect");
|
|
|
|
}
|
|
|
|
|
|
|
|
require_login($course->id);
|
|
|
|
|
|
|
|
if (!isteacher($course->id) and !$chat->studentlogs) {
|
|
|
|
error("Only teachers are allowed to view these chat reports");
|
|
|
|
}
|
|
|
|
|
|
|
|
add_to_log($course->id, "chat", "view", "view.php?id=$cm->id", "$chat->id");
|
|
|
|
|
|
|
|
/// Print the page header
|
|
|
|
|
|
|
|
if ($course->category) {
|
2003-07-24 02:25:23 +00:00
|
|
|
$navigation = "<a href=\"../../course/view.php?id=$course->id\">$course->shortname</a> ->";
|
2003-07-21 03:16:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$strchats = get_string("modulenameplural", "chat");
|
|
|
|
$strchat = get_string("modulename", "chat");
|
|
|
|
$strchatreport = get_string("chatreport", "chat");
|
2003-07-21 04:20:01 +00:00
|
|
|
$strseesession = get_string("seesession", "chat");
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
/// Print a session if once has been specified
|
|
|
|
|
|
|
|
if ($start and $end) { // Show a full transcript
|
|
|
|
|
|
|
|
print_header("$course->shortname: $chat->name: $strchatreport", "$course->fullname",
|
|
|
|
"$navigation <a href=\"index.php?id=$course->id\">$strchats</a> ->
|
|
|
|
<a href=\"view.php?id=$cm->id\">$chat->name</a> ->
|
|
|
|
<a href=\"report.php?id=$chat->id\">$strchatreport</a>",
|
|
|
|
"", "", true, "", navmenu($course, $cm));
|
|
|
|
|
|
|
|
if (!$messages = get_records_select("chat_messages", "chatid = $chat->id AND
|
2003-07-21 05:08:46 +00:00
|
|
|
timestamp >= '$start' AND
|
|
|
|
timestamp <= '$end'", "timestamp ASC")) {
|
2003-07-21 04:08:32 +00:00
|
|
|
print_heading(get_string("nomessages", "chat"));
|
|
|
|
|
|
|
|
} else {
|
|
|
|
echo "<p align=\"center\">".userdate($start)." --> ". userdate($end)."</p>";
|
|
|
|
|
|
|
|
print_simple_box_start("center");
|
|
|
|
foreach ($messages as $message) { // We are walking FORWARDS through messages
|
2003-07-24 02:25:23 +00:00
|
|
|
$formatmessage = chat_format_message($message, $course->id);
|
2003-07-21 04:08:32 +00:00
|
|
|
echo $formatmessage->html;
|
|
|
|
}
|
|
|
|
print_simple_box_end("center");
|
|
|
|
}
|
|
|
|
|
|
|
|
print_continue("report.php?id=$chat->id");
|
|
|
|
print_footer($course);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// Print the Sessions display
|
|
|
|
|
2003-07-21 03:16:19 +00:00
|
|
|
print_header("$course->shortname: $chat->name: $strchatreport", "$course->fullname",
|
|
|
|
"$navigation <a href=\"index.php?id=$course->id\">$strchats</a> ->
|
|
|
|
<a href=\"view.php?id=$cm->id\">$chat->name</a> -> $strchatreport",
|
|
|
|
"", "", true, "", navmenu($course, $cm));
|
|
|
|
|
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
print_heading($chat->name.": ".get_string("sessions", "chat"));
|
2003-07-21 03:16:19 +00:00
|
|
|
|
|
|
|
if (!$messages = get_records("chat_messages", "chatid", $chat->id, "timestamp DESC")) {
|
|
|
|
print_heading(get_string("nomessages", "chat"));
|
|
|
|
print_footer($course);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
/// Show all the sessions
|
|
|
|
|
|
|
|
$sessiongap = 5 * 60; // 5 minutes silence means a new session
|
2003-07-21 03:37:53 +00:00
|
|
|
$sessionend = 0;
|
|
|
|
$sessionstart = 0;
|
2003-07-21 03:16:19 +00:00
|
|
|
$sessionusers = array();
|
2003-07-21 03:37:53 +00:00
|
|
|
$lasttime = 0;
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
foreach ($messages as $message) { // We are walking BACKWARDS through the messages
|
2003-07-21 03:37:53 +00:00
|
|
|
if (!$lasttime) {
|
|
|
|
$lasttime = $message->timestamp;
|
2003-07-21 03:16:19 +00:00
|
|
|
}
|
2003-07-21 03:37:53 +00:00
|
|
|
if (!$sessionend) {
|
|
|
|
$sessionend = $message->timestamp;
|
2003-07-21 03:16:19 +00:00
|
|
|
}
|
2003-07-21 03:37:53 +00:00
|
|
|
if (($lasttime - $message->timestamp) < $sessiongap) { // Same session
|
2003-07-21 04:08:32 +00:00
|
|
|
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
|
|
|
}
|
2003-07-21 03:16:19 +00:00
|
|
|
} else {
|
2003-07-21 03:37:53 +00:00
|
|
|
$sessionstart = $lasttime;
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2003-07-21 03:37:53 +00:00
|
|
|
if ($sessionend - $sessionstart > 60 and count($sessionusers) > 1) {
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
echo "<p align=\"center\">".userdate($sessionstart)." --> ". userdate($sessionend)."</p>";
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2003-07-21 03:37:53 +00:00
|
|
|
print_simple_box_start("center");
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
arsort($sessionusers);
|
|
|
|
foreach ($sessionusers as $sessionuser => $usermessagecount) {
|
2003-07-21 03:37:53 +00:00
|
|
|
if ($user = get_record("user", "id", $sessionuser)) {
|
|
|
|
print_user_picture($user->id, $course->id, $user->picture);
|
2003-07-21 04:08:32 +00:00
|
|
|
echo " $user->firstname $user->lastname";
|
2003-07-21 05:31:23 +00:00
|
|
|
echo " ($usermessagecount)<br />";
|
2003-07-21 03:37:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2003-07-21 04:20:01 +00:00
|
|
|
echo "<p align=\"right\"><a href=\"report.php?id=$chat->id&start=$sessionstart&end=$sessionend\">$strseesession</a>";
|
2003-07-21 03:37:53 +00:00
|
|
|
print_simple_box_end();
|
|
|
|
}
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2003-07-21 03:37:53 +00:00
|
|
|
$sessionend = $message->timestamp;
|
2003-07-21 03:16:19 +00:00
|
|
|
$sessionusers = array();
|
2003-07-21 04:08:32 +00:00
|
|
|
$sessionusers[$message->userid] = 1;
|
2003-07-21 03:16:19 +00:00
|
|
|
}
|
2003-07-21 03:37:53 +00:00
|
|
|
$lasttime = $message->timestamp;
|
2003-07-21 03:16:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Finish the page
|
|
|
|
print_footer($course);
|
|
|
|
|
|
|
|
?>
|