2004-09-12 15:06:29 +00:00
|
|
|
<?php // $Id$
|
2003-07-21 03:16:19 +00:00
|
|
|
|
|
|
|
/// This page prints reports and info about chats
|
|
|
|
|
|
|
|
require_once("../../config.php");
|
|
|
|
require_once("lib.php");
|
|
|
|
|
2004-02-24 06:35:57 +00:00
|
|
|
require_variable($id); // Course module ID
|
2004-02-24 07:21:52 +00:00
|
|
|
optional_variable($groupid, ""); // Group
|
2004-01-16 13:14:42 +00:00
|
|
|
optional_variable($start, ""); // Start of period
|
|
|
|
optional_variable($end, ""); // End of period
|
|
|
|
optional_variable($deletesession, ""); // Delete a session
|
|
|
|
optional_variable($confirmdelete, ""); // End of period
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2004-02-24 06:35:57 +00:00
|
|
|
if (! $cm = get_record("course_modules", "id", $id)) {
|
|
|
|
error("Course Module ID was incorrect");
|
|
|
|
}
|
|
|
|
if (! $chat = get_record("chat", "id", $cm->instance)) {
|
2003-07-21 03:16:19 +00:00
|
|
|
error("Course module is incorrect");
|
|
|
|
}
|
|
|
|
if (! $course = get_record("course", "id", $chat->course)) {
|
|
|
|
error("Course is misconfigured");
|
|
|
|
}
|
|
|
|
|
|
|
|
require_login($course->id);
|
|
|
|
|
2003-11-28 15:37:27 +00:00
|
|
|
$isteacher = isteacher($course->id);
|
2004-01-16 13:14:42 +00:00
|
|
|
$isteacheredit = isteacheredit($course->id);
|
2003-11-28 15:37:27 +00:00
|
|
|
|
|
|
|
if (isguest() or (!$isteacher and !$chat->studentlogs)) {
|
2003-11-03 10:22:24 +00:00
|
|
|
error("You can not view these chat reports");
|
2003-07-21 03:16:19 +00:00
|
|
|
}
|
|
|
|
|
2004-02-24 06:35:57 +00:00
|
|
|
add_to_log($course->id, "chat", "report", "report.php?id=$cm->id", "$chat->id", "$cm->id");
|
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");
|
2004-01-16 13:14:42 +00:00
|
|
|
$strdeletesession = get_string("deletesession", "chat");
|
|
|
|
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2004-10-19 10:34:02 +00:00
|
|
|
/// Print a session if one has been specified
|
2003-07-21 04:08:32 +00:00
|
|
|
|
2004-01-16 13:14:42 +00:00
|
|
|
if ($start and $end and !$confirmdelete) { // Show a full transcript
|
2003-07-21 04:08:32 +00:00
|
|
|
|
2004-11-23 02:05:47 +00:00
|
|
|
if (!empty($groupid)) {
|
2004-02-24 07:21:52 +00:00
|
|
|
$groupselect = " AND groupid = '$currentgroup'";
|
2004-09-16 17:13:57 +00:00
|
|
|
$groupparam = "&groupid=$currentgroup";
|
2004-02-24 07:21:52 +00:00
|
|
|
} else {
|
|
|
|
$groupselect = "";
|
|
|
|
$groupparam = "";
|
|
|
|
}
|
|
|
|
|
2004-08-21 20:20:58 +00:00
|
|
|
print_header_simple("$chat->name: $strchatreport", "",
|
|
|
|
"<a href=\"index.php?id=$course->id\">$strchats</a> ->
|
2003-07-21 04:08:32 +00:00
|
|
|
<a href=\"view.php?id=$cm->id\">$chat->name</a> ->
|
2004-02-24 06:35:57 +00:00
|
|
|
<a href=\"report.php?id=$cm->id\">$strchatreport</a>",
|
2003-07-21 04:08:32 +00:00
|
|
|
"", "", true, "", navmenu($course, $cm));
|
|
|
|
|
2004-01-16 13:14:42 +00:00
|
|
|
if ($deletesession and $isteacheredit) {
|
|
|
|
notice_yesno(get_string("deletesessionsure", "chat"),
|
2004-09-16 17:13:57 +00:00
|
|
|
"report.php?id=$cm->id&deletesession=1&confirmdelete=1&start=$start&end=$end$groupparam",
|
2004-02-24 06:35:57 +00:00
|
|
|
"report.php?id=$cm->id");
|
2004-01-16 13:14:42 +00:00
|
|
|
}
|
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
if (!$messages = get_records_select("chat_messages", "chatid = $chat->id AND
|
2003-07-21 05:08:46 +00:00
|
|
|
timestamp >= '$start' AND
|
2004-02-24 07:21:52 +00:00
|
|
|
timestamp <= '$end' $groupselect", "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");
|
|
|
|
}
|
|
|
|
|
2004-01-16 13:14:42 +00:00
|
|
|
if (!$deletesession or !$isteacheredit) {
|
2004-02-24 06:35:57 +00:00
|
|
|
print_continue("report.php?id=$cm->id");
|
2004-01-16 13:14:42 +00:00
|
|
|
}
|
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
print_footer($course);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// Print the Sessions display
|
|
|
|
|
2004-08-21 20:20:58 +00:00
|
|
|
print_header_simple("$chat->name: $strchatreport", "",
|
|
|
|
"<a href=\"index.php?id=$course->id\">$strchats</a> ->
|
2003-07-21 03:16:19 +00:00
|
|
|
<a href=\"view.php?id=$cm->id\">$chat->name</a> -> $strchatreport",
|
|
|
|
"", "", true, "", navmenu($course, $cm));
|
|
|
|
|
2004-02-24 07:00:13 +00:00
|
|
|
print_heading($chat->name.": ".get_string("sessions", "chat"));
|
|
|
|
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2004-02-24 06:35:57 +00:00
|
|
|
/// Check to see if groups are being used here
|
|
|
|
if ($groupmode = groupmode($course, $cm)) { // Groups are being used
|
|
|
|
$currentgroup = setup_and_print_groups($course, $groupmode, "report.php?id=$cm->id");
|
|
|
|
} else {
|
|
|
|
$currentgroup = false;
|
|
|
|
}
|
|
|
|
|
2004-11-23 02:05:47 +00:00
|
|
|
if (!empty($currentgroup)) {
|
2004-02-24 06:35:57 +00:00
|
|
|
$groupselect = " AND groupid = '$currentgroup'";
|
2004-09-16 17:13:57 +00:00
|
|
|
$groupparam = "&groupid=$currentgroup";
|
2004-02-24 06:35:57 +00:00
|
|
|
} else {
|
|
|
|
$groupselect = "";
|
|
|
|
$groupparam = "";
|
|
|
|
}
|
2003-07-21 03:16:19 +00:00
|
|
|
|
2004-01-16 13:14:42 +00:00
|
|
|
/// Delete a session if one has been specified
|
|
|
|
|
|
|
|
if ($deletesession and $isteacheredit and $confirmdelete and $start and $end) {
|
|
|
|
delete_records_select("chat_messages", "chatid = $chat->id AND
|
|
|
|
timestamp >= '$start' AND
|
2004-02-24 06:35:57 +00:00
|
|
|
timestamp <= '$end' $groupselect");
|
2004-01-16 13:14:42 +00:00
|
|
|
$strdeleted = get_string("deleted");
|
|
|
|
notify("$strdeleted: ".userdate($start)." --> ". userdate($end));
|
|
|
|
unset($deletesession);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// Get the messages
|
|
|
|
|
|
|
|
if (empty($messages)) { /// May have already got them above
|
2004-02-24 06:35:57 +00:00
|
|
|
if (!$messages = get_records_select("chat_messages", "chatid = '$chat->id' $groupselect", "timestamp DESC")) {
|
2004-01-16 13:14:42 +00:00
|
|
|
print_heading(get_string("nomessages", "chat"));
|
|
|
|
print_footer($course);
|
|
|
|
exit;
|
|
|
|
}
|
2003-07-21 03:16:19 +00:00
|
|
|
}
|
|
|
|
|
2004-01-16 13:14:42 +00:00
|
|
|
/// Show all the sessions
|
2003-07-21 04:08:32 +00:00
|
|
|
|
|
|
|
$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
|
|
|
|
2004-12-08 13:47:06 +00:00
|
|
|
$messagesleft = count($messages);
|
|
|
|
|
2003-07-21 04:08:32 +00:00
|
|
|
foreach ($messages as $message) { // We are walking BACKWARDS through the messages
|
2004-12-08 13:47:06 +00:00
|
|
|
|
|
|
|
$messagesleft --; // Countdown
|
|
|
|
|
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
|
|
|
}
|
2004-12-08 13:47:06 +00:00
|
|
|
if ((($lasttime - $message->timestamp) < $sessiongap) and $messagesleft) { // 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-11-28 15:37:27 +00:00
|
|
|
echo " ".fullname($user, $isteacher);
|
2003-07-21 05:31:23 +00:00
|
|
|
echo " ($usermessagecount)<br />";
|
2003-07-21 03:37:53 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-01-16 13:14:42 +00:00
|
|
|
echo "<p align=\"right\">";
|
2004-09-16 17:13:57 +00:00
|
|
|
echo "<a href=\"report.php?id=$cm->id&start=$sessionstart&end=$sessionend$groupparam\">$strseesession</a>";
|
2004-01-16 13:14:42 +00:00
|
|
|
if ($isteacheredit) {
|
2004-09-16 17:13:57 +00:00
|
|
|
echo "<br /><a href=\"report.php?id=$cm->id&start=$sessionstart&end=$sessionend&deletesession=1$groupparam\">$strdeletesession</a>";
|
2004-01-16 13:14:42 +00:00
|
|
|
}
|
|
|
|
echo "</p>";
|
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);
|
|
|
|
|
|
|
|
?>
|