MDL-51637 forum: Make forum_get_discussions_paginated return group post

This commit is contained in:
Juan Leyva 2015-10-02 10:21:33 +02:00
parent 74fad2ce3d
commit 4f3a2d2103
4 changed files with 159 additions and 7 deletions

View File

@ -647,7 +647,7 @@ class mod_forum_external extends external_api {
require_capability('mod/forum:viewdiscussion', $modcontext, null, true, 'noviewdiscussionspermission', 'forum'); require_capability('mod/forum:viewdiscussion', $modcontext, null, true, 'noviewdiscussionspermission', 'forum');
$sort = 'd.' . $sortby . ' ' . $sortdirection; $sort = 'd.' . $sortby . ' ' . $sortdirection;
$alldiscussions = forum_get_discussions($cm, $sort, true, -1, -1, true, $page, $perpage); $alldiscussions = forum_get_discussions($cm, $sort, true, -1, -1, true, $page, $perpage, FORUM_POSTS_ALL_USER_GROUPS);
if ($alldiscussions) { if ($alldiscussions) {
$canviewfullname = has_capability('moodle/site:viewfullnames', $modcontext); $canviewfullname = has_capability('moodle/site:viewfullnames', $modcontext);

View File

@ -64,6 +64,11 @@ if (!defined('FORUM_CRON_USER_CACHE')) {
define('FORUM_CRON_USER_CACHE', 5000); define('FORUM_CRON_USER_CACHE', 5000);
} }
/**
* FORUM_POSTS_ALL_USER_GROUPS - All the posts in groups where the user is enrolled.
*/
define('FORUM_POSTS_ALL_USER_GROUPS', -2);
/// STANDARD FUNCTIONS /////////////////////////////////////////////////////////// /// STANDARD FUNCTIONS ///////////////////////////////////////////////////////////
/** /**
@ -2595,9 +2600,12 @@ function forum_count_discussions($forum, $cm, $course) {
* @param bool $userlastmodified * @param bool $userlastmodified
* @param int $page * @param int $page
* @param int $perpage * @param int $perpage
* @param int $groupid if groups enabled, get discussions for this group overriding the current group.
* Use FORUM_POSTS_ALL_USER_GROUPS for all the user groups
* @return array * @return array
*/ */
function forum_get_discussions($cm, $forumsort="d.timemodified DESC", $fullpost=true, $unused=-1, $limit=-1, $userlastmodified=false, $page=-1, $perpage=0) { function forum_get_discussions($cm, $forumsort="d.timemodified DESC", $fullpost=true, $unused=-1, $limit=-1,
$userlastmodified=false, $page=-1, $perpage=0, $groupid = -1) {
global $CFG, $DB, $USER; global $CFG, $DB, $USER;
$timelimit = ''; $timelimit = '';
@ -2637,13 +2645,28 @@ function forum_get_discussions($cm, $forumsort="d.timemodified DESC", $fullpost=
} }
$groupmode = groups_get_activity_groupmode($cm); $groupmode = groups_get_activity_groupmode($cm);
$currentgroup = groups_get_activity_group($cm);
if ($groupmode) { if ($groupmode) {
if (empty($modcontext)) { if (empty($modcontext)) {
$modcontext = context_module::instance($cm->id); $modcontext = context_module::instance($cm->id);
} }
// Special case, we received a groupid to override currentgroup.
if ($groupid > 0) {
$course = get_course($cm->course);
if (!groups_group_visible($groupid, $course, $cm)) {
// User doesn't belong to this group, return nothing.
return array();
}
$currentgroup = $groupid;
} else if ($groupid === -1) {
$currentgroup = groups_get_activity_group($cm);
} else {
// Get discussions for all groups current user can see.
$currentgroup = null;
}
if ($groupmode == VISIBLEGROUPS or has_capability('moodle/site:accessallgroups', $modcontext)) { if ($groupmode == VISIBLEGROUPS or has_capability('moodle/site:accessallgroups', $modcontext)) {
if ($currentgroup) { if ($currentgroup) {
$groupselect = "AND (d.groupid = ? OR d.groupid = -1)"; $groupselect = "AND (d.groupid = ? OR d.groupid = -1)";
@ -2653,8 +2676,19 @@ function forum_get_discussions($cm, $forumsort="d.timemodified DESC", $fullpost=
} }
} else { } else {
//seprate groups without access all // Separate groups.
if ($currentgroup) {
// Get discussions for all groups current user can see.
if ($currentgroup === null) {
$mygroups = array_keys(groups_get_all_groups($cm->course, $USER->id, $cm->groupingid, 'g.id'));
if (empty($mygroups)) {
$groupselect = "AND d.groupid = -1";
} else {
list($insqlgroups, $inparamsgroups) = $DB->get_in_or_equal($mygroups);
$groupselect = "AND (d.groupid = -1 OR d.groupid $insqlgroups)";
$params = array_merge($params, $inparamsgroups);
}
} else if ($currentgroup) {
$groupselect = "AND (d.groupid = ? OR d.groupid = -1)"; $groupselect = "AND (d.groupid = ? OR d.groupid = -1)";
$params[] = $currentgroup; $params[] = $currentgroup;
} else { } else {
@ -2664,8 +2698,6 @@ function forum_get_discussions($cm, $forumsort="d.timemodified DESC", $fullpost=
} else { } else {
$groupselect = ""; $groupselect = "";
} }
if (empty($forumsort)) { if (empty($forumsort)) {
$forumsort = "d.timemodified DESC"; $forumsort = "d.timemodified DESC";
} }

View File

@ -1878,4 +1878,121 @@ class mod_forum_lib_testcase extends advanced_testcase {
} }
/**
* Test forum_get_discussions
*/
public function test_forum_get_discussions_with_groups() {
global $DB;
$this->resetAfterTest(true);
// Create course to add the module.
$course = self::getDataGenerator()->create_course(array('groupmode' => VISIBLEGROUPS, 'groupmodeforce' => 0));
$user1 = self::getDataGenerator()->create_user();
$user2 = self::getDataGenerator()->create_user();
$user3 = self::getDataGenerator()->create_user();
$role = $DB->get_record('role', array('shortname' => 'student'), '*', MUST_EXIST);
self::getDataGenerator()->enrol_user($user1->id, $course->id, $role->id);
self::getDataGenerator()->enrol_user($user2->id, $course->id, $role->id);
self::getDataGenerator()->enrol_user($user3->id, $course->id, $role->id);
// Forum forcing separate gropus.
$record = new stdClass();
$record->course = $course->id;
$forum = self::getDataGenerator()->create_module('forum', $record, array('groupmode' => SEPARATEGROUPS));
$cm = get_coursemodule_from_instance('forum', $forum->id);
// Create groups.
$group1 = self::getDataGenerator()->create_group(array('courseid' => $course->id));
$group2 = self::getDataGenerator()->create_group(array('courseid' => $course->id));
$group3 = self::getDataGenerator()->create_group(array('courseid' => $course->id));
// Add the user1 to g1 and g2 groups.
groups_add_member($group1->id, $user1->id);
groups_add_member($group2->id, $user1->id);
// Add the user 2 and 3 to only one group.
groups_add_member($group1->id, $user2->id);
groups_add_member($group3->id, $user3->id);
// Add a few discussions.
$record = array();
$record['course'] = $course->id;
$record['forum'] = $forum->id;
$record['userid'] = $user1->id;
$record['groupid'] = $group1->id;
$discussiong1u1 = self::getDataGenerator()->get_plugin_generator('mod_forum')->create_discussion($record);
$record['groupid'] = $group2->id;
$discussiong2u1 = self::getDataGenerator()->get_plugin_generator('mod_forum')->create_discussion($record);
$record['userid'] = $user2->id;
$record['groupid'] = $group1->id;
$discussiong1u2 = self::getDataGenerator()->get_plugin_generator('mod_forum')->create_discussion($record);
$record['userid'] = $user3->id;
$record['groupid'] = $group3->id;
$discussiong3u3 = self::getDataGenerator()->get_plugin_generator('mod_forum')->create_discussion($record);
self::setUser($user1);
// Test retrieve discussions not passing the groupid parameter. We will receive only first group discussions.
$discussions = forum_get_discussions($cm);
self::assertCount(2, $discussions);
foreach ($discussions as $discussion) {
self::assertEquals($group1->id, $discussion->groupid);
}
// Get all my discussions.
$discussions = forum_get_discussions($cm, '', true, -1, -1, false, -1, 0, 0);
self::assertCount(3, $discussions);
// Get all my g1 discussions.
$discussions = forum_get_discussions($cm, '', true, -1, -1, false, -1, 0, $group1->id);
self::assertCount(2, $discussions);
foreach ($discussions as $discussion) {
self::assertEquals($group1->id, $discussion->groupid);
}
// Get all my g2 discussions.
$discussions = forum_get_discussions($cm, '', true, -1, -1, false, -1, 0, $group2->id);
self::assertCount(1, $discussions);
$discussion = array_shift($discussions);
self::assertEquals($group2->id, $discussion->groupid);
self::assertEquals($user1->id, $discussion->userid);
self::assertEquals($discussiong2u1->id, $discussion->discussion);
// Get all my g3 discussions (I'm not enrolled in that group).
$discussions = forum_get_discussions($cm, '', true, -1, -1, false, -1, 0, $group3->id);
self::assertCount(0, $discussions);
// This group does not exist.
$discussions = forum_get_discussions($cm, '', true, -1, -1, false, -1, 0, $group3->id + 1000);
self::assertCount(0, $discussions);
self::setUser($user2);
// Test retrieve discussions not passing the groupid parameter. We will receive only first group discussions.
$discussions = forum_get_discussions($cm);
self::assertCount(2, $discussions);
foreach ($discussions as $discussion) {
self::assertEquals($group1->id, $discussion->groupid);
}
// Get all my viewable discussions.
$discussions = forum_get_discussions($cm, '', true, -1, -1, false, -1, 0, 0);
self::assertCount(2, $discussions);
foreach ($discussions as $discussion) {
self::assertEquals($group1->id, $discussion->groupid);
}
// Get all my g2 discussions (I'm not enrolled in that group).
$discussions = forum_get_discussions($cm, '', true, -1, -1, false, -1, 0, $group2->id);
self::assertCount(0, $discussions);
// Get all my g3 discussions (I'm not enrolled in that group).
$discussions = forum_get_discussions($cm, '', true, -1, -1, false, -1, 0, $group3->id);
self::assertCount(0, $discussions);
}
} }

View File

@ -4,6 +4,9 @@ information provided here is intended especially for developers.
=== 3.0 === === 3.0 ===
* External function get_forums_by_courses now returns and additional field "cancreatediscussions" that indicates if the user * External function get_forums_by_courses now returns and additional field "cancreatediscussions" that indicates if the user
can create discussions in the forum. can create discussions in the forum.
* A new optional parameter (groupid) has been added to get_forum_discussions.
This parameter can override the automatically calculated current group.
* New constant FORUM_POSTS_ALL_USER_GROUPS, to be used as parameter in functions where we'd need to retrieve all the user posts.
=== 2.8 === === 2.8 ===
* The following functions have all been marked as deprecated. Many of * The following functions have all been marked as deprecated. Many of