course)) {
error("Could not find this course!");
}
if (! $cm = get_coursemodule_from_instance("forum", $forum->id, $course->id)) {
$cm->id = 0;
}
require_login($course->id);
if (!isteacher($course->id)) {
error("This page is for teachers only");
}
unset($SESSION->fromdiscussion);
add_to_log($course->id, "forum", "view subscribers", "subscribers.php?id=$forum->id", $forum->id, $cm->id);
if (isteacheredit($course->id)) {
if (isset($_GET['edit'])) {
if($edit == "on") {
$USER->subscriptionsediting = true;
} else {
$USER->subscriptionsediting = false;
}
}
} else {
$USER->subscriptionsediting = false;
}
$strunsubscribeshort = get_string("unsubscribeshort", "forum");
$strsubscribeall = get_string("subscribeall", "forum");
$strsubscribenone = get_string("subscribenone", "forum");
$strsubscribers = get_string("subscribers", "forum");
$strforums = get_string("forums", "forum");
if ($course->category) {
$navigation = "id\">$course->shortname ->
id\">$strforums ->
id\">$forum->name -> $strsubscribers";
} else {
$navigation = "id\">$strforums ->
id\">$forum->name -> $strsubscribers";
}
print_header("$course->shortname: $strsubscribers", "$course->fullname", "$navigation",
"", "", true, forum_update_subscriptions_button($course->id, $id));
if (empty($USER->subscriptionsediting)) { /// Display an overview of subscribers
/// Check to see if groups are being used in this forum
if ($groupmode = groupmode($course, $cm)) { // Groups are being used
$currentgroup = setup_and_print_groups($course, $groupmode, "subscribers.php?id=$forum->id");
} else {
$currentgroup = false;
}
if ($subscribe == 'all') {
if ($forum->type == 'teacher') {
$users = get_course_teachers($course->id);
} elseif ($currentgroup) {
$users = get_group_users($currentgroup);
} else {
$users = get_course_users($course->id);
}
if ($users) {
foreach ($users as $user) {
forum_subscribe($user->id, $forum->id);
}
}
} else if ($subscribe == 'none') {
if ($currentgroup) {
if ($users = get_group_users($currentgroup)) {
foreach ($users as $user) {
forum_unsubscribe($user->id, $forum->id);
}
}
} else {
delete_records("forum_subscriptions", "forum", $forum->id);
}
}
if ($unsubscribe) {
if ($user = get_record('user', 'id', $unsubscribe)) {
forum_unsubscribe($user->id, $forum->id);
$info->name = fullname($user);
$info->forum = $forum->name;
notify(get_string("nownotsubscribed", "forum", $info));
}
}
if (! $users = forum_subscribed_users($course, $forum, $currentgroup) ) {
if (!$forum->forcesubscribe) {
echo '
';
$options['id'] = $forum->id;
$options['subscribe'] = 'all';
print_single_button('subscribers.php', $options, $strsubscribeall);
echo '';
}
print_heading(get_string("nosubscribers", "forum"));
} else {
if (!$forum->forcesubscribe) {
echo '';
echo '';
$options['id'] = $forum->id;
$options['subscribe'] = 'all';
print_single_button('subscribers.php', $options, $strsubscribeall);
echo ' | ';
echo '';
$options['subscribe'] = 'none';
print_single_button('subscribers.php', $options, $strsubscribenone);
echo ' | ';
echo '
';
}
print_heading(get_string("subscribersto","forum", "'$forum->name'"));
echo '';
foreach ($users as $user) {
echo "";
print_user_picture($user->id, $course->id, $user->picture);
echo " | cellcontent\">";
echo "$user->firstname $user->lastname";
echo " | cellcontent\">";
echo "$user->email";
echo " | ";
echo "id&unsubscribe=$user->id\">$strunsubscribeshort";
echo " |
";
}
echo "
";
}
print_footer($course);
exit;
}
/// We are in editing mode.
if (!isteacheredit($course->id)) {
error("You must be an editing teacher in this course, or an admin");
}
$strexistingsubscribers = get_string("existingsubscribers", 'forum');
$strpotentialsubscribers = get_string("potentialsubscribers", 'forum');
$straddsubscriber = get_string("addsubscriber", 'forum');
$strremovesubscriber = get_string("removesubscriber", 'forum');
$strsearch = get_string("search");
$strsearchresults = get_string("searchresults");
$strshowall = get_string("showall");
$strsubscribers = get_string("subscribers", "forum");
$strforums = get_string("forums", "forum");
if ($frm = data_submitted()) {
/// A form was submitted so process the input
if (!empty($frm->add) and !empty($frm->addselect)) {
foreach ($frm->addselect as $addsubscriber) {
if (! forum_subscribe($addsubscriber, $id)) {
error("Could not add subscriber with id $addsubscriber to this forum!");
}
}
} else if (!empty($frm->remove) and !empty($frm->removeselect)) {
foreach ($frm->removeselect as $removesubscriber) {
if (! forum_unsubscribe($removesubscriber, $id)) {
error("Could not remove subscriber with id $removesubscriber from this forum!");
}
}
} else if (!empty($frm->showall)) {
unset($frm->searchtext);
$frm->previoussearch = 0;
}
}
$previoussearch = (!empty($frm->search) or ($frm->previoussearch == 1)) ;
/// Get all existing subscribers for this forum.
if (!$subscribers = forum_subscribed_users($course, $forum)) {
$subscribers = array();
}
$subscriberarray = array();
foreach ($subscribers as $subscriber) {
$subscriberarray[] = $subscriber->id;
}
$subscriberlist = implode(',', $subscriberarray);
unset($subscriberarray);
/// Get search results excluding any users already subscribed
switch ($CFG->dbtype) {
case "mysql":
$fullname = " CONCAT(u.firstname,\" \",u.lastname) ";
$LIKE = "LIKE";
break;
case "postgres7":
$fullname = " u.firstname||' '||u.lastname ";
$LIKE = "ILIKE";
break;
default:
$fullname = " u.firstname||\" \"||u.lastname ";
$LIKE = "ILIKE";
}
if (!empty($subscriberlist)) {
$except = " AND u.id NOT IN ($subscriberlist) ";
} else {
$except = '';
}
if (!empty($frm->searchtext) and $previoussearch) {
$searchusers = get_records_sql("SELECT u.id, u.firstname, u.lastname, u.email
FROM {$CFG->prefix}user u,
{$CFG->prefix}user_students s
WHERE s.course = '$course->id' AND s.userid = u.id AND u.deleted = '0'
AND ($fullname $LIKE '%$frm->searchtext%' OR u.email $LIKE '%$frm->searchtext%')
$except
UNION
SELECT u.id, u.firstname, u.lastname, u.email
FROM {$CFG->prefix}user u,
{$CFG->prefix}user_teachers s
WHERE s.course = '$course->id' AND s.userid = u.id AND u.deleted = '0'
AND ($fullname $LIKE '%$frm->searchtext%' OR u.email $LIKE '%$frm->searchtext%')
$except
ORDER BY u.firstname ASC, u.lastname ASC");
$usercount = count_records_sql("SELECT COUNT(*)
FROM {$CFG->prefix}user u,
{$CFG->prefix}user_students s
WHERE s.course = '$course->id' AND s.userid = u.id AND u.deleted = '0'
$except") +
count_records_sql("SELECT COUNT(*)
FROM {$CFG->prefix}user u,
{$CFG->prefix}user_teachers s
WHERE s.course = '$course->id' AND s.userid = u.id AND u.deleted = '0'
$except");
}
/// If no search results then get potential subscribers for this forum excluding users already subscribed
if (empty($searchusers)) {
if (!$users = get_records_sql("SELECT u.id, u.firstname, u.lastname, u.email
FROM {$CFG->prefix}user u,
{$CFG->prefix}user_students s
WHERE s.course = '$course->id' AND s.userid = u.id AND u.deleted = '0'
$except
UNION
SELECT u.id, u.firstname, u.lastname, u.email
FROM {$CFG->prefix}user u,
{$CFG->prefix}user_teachers s
WHERE s.course = '$course->id' AND s.userid = u.id AND u.deleted = '0'
$except
ORDER BY u.firstname ASC, u.lastname ASC")) {
$users = array();
}
$usercount = count($users);
}
$searchtext = (isset($frm->searchtext)) ? $frm->searchtext : "";
$previoussearch = ($previoussearch) ? '1' : '0';
print_simple_box_start("center", "", "$THEME->cellheading");
include('subscriber.html');
print_simple_box_end();
print_footer();
?>