From: skodak Date: Tue, 5 Feb 2008 10:52:20 +0000 (+0000) Subject: MDL-13335 rewritten caching in forum cron; merged from MOODLE_19_STABLE X-Git-Url: http://git.mjollnir.org/gw?a=commitdiff_plain;h=df1c2c71da91499cdc0fcc91c328fa6b7c9c8757;p=moodle.git MDL-13335 rewritten caching in forum cron; merged from MOODLE_19_STABLE --- diff --git a/mod/forum/lib.php b/mod/forum/lib.php index dd86b55465..8b9e303b13 100644 --- a/mod/forum/lib.php +++ b/mod/forum/lib.php @@ -220,7 +220,6 @@ function forum_cron() { $forums = array(); $courses = array(); $coursemodules = array(); - $postinfos = array(); $subscribedusers = array(); @@ -325,8 +324,10 @@ function forum_cron() { mtrace('Processing user '.$userto->id); - // we might want to add another layer - forums here (by checking array_keys($subscribedusers)) - // so that we can skip many posts + // init caches + $userto->viewfullnames = array(); + $userto->canpost = array(); + $userto->tracking = array(); foreach ($posts as $pid => $post) { @@ -354,13 +355,26 @@ function forum_cron() { // setup global $COURSE properly - needed for roles and languages course_setup($course); // More environment - // Get the context (from cache) - $modcontext = get_context_instance(CONTEXT_MODULE, $cm->id); // Cached already - $post->modcontext = $modcontext; - $post->viewfullnames = has_capability('moodle/site:viewfullnames', $modcontext); + // Fill caches + if (!isset($userto->viewfullnames[$forum->id])) { + $modcontext = get_context_instance(CONTEXT_MODULE, $cm->id); + $userto->viewfullnames[$forum->id] = has_capability('moodle/site:viewfullnames', $modcontext); + } + if (!isset($userto->canpost[$forum->id])) { + $modcontext = get_context_instance(CONTEXT_MODULE, $cm->id); + $userto->canpost[$forum->id] = forum_user_can_post($forum, $userto, null, $modcontext); + } + if (!isset($userfrom->groups[$forum->id])) { + if (!isset($userfrom->groups)) { + $userfrom->groups = array(); + $users[$userfrom->id]->groups = array(); + } + $userfrom->groups[$forum->id] = groups_get_all_groups($course->id, $userfrom->id, $cm->groupingid); + $users[$userfrom->id]->groups[$forum->id] = $userfrom->groups[$forum->id]; + } // Make sure groups allow this user to see this email - if ($discussion->groupid > 0 and $groupmode = groups_get_activity_groupmode($cm)) { // Groups are being used + if ($discussion->groupid > 0 and $groupmode = groups_get_activity_groupmode($cm, $course)) { // Groups are being used if (!groups_group_exists($discussion->groupid)) { // Can't find group continue; // Be safe and don't send it to anyone } @@ -430,9 +444,13 @@ function forum_cron() { } else { $mailcount[$post->id]++; + if (!isset($userto->tracking[$forum->id])) { + $userto->tracking[$forum->id] = !$CFG->forum_usermarksread + && forum_tp_can_track_forums($forum, $userto) + && forum_tp_is_tracked($forum, $userto->id); + } // Mark post as read if forum_usermarksread is set off - if (!$CFG->forum_usermarksread && forum_tp_can_track_forums($forum, $userto) && - forum_tp_is_tracked($forum, $userto->id)) { + if ($userto->tracking[$forum->id]) { if (!forum_tp_mark_post_read($userto->id, $post, $forum->id)) { mtrace("Error: mod/forum/cron.php: Could not mark post $post->id read for user $userto->id". " while sending email."); @@ -569,6 +587,11 @@ function forum_cron() { $USER = $userto; course_setup(SITEID); + // init caches + $userto->viewfullnames = array(); + $userto->canpost = array(); + $userto->tracking = array(); + $postsubject = get_string('digestmailsubject', 'forum', format_string($site->shortname, true)); $headerdata = new object(); @@ -585,6 +608,8 @@ function forum_cron() { $posthtml .= "\n\n"; $posthtml .= '

'.get_string('digestmailheader', 'forum', $headerdata).'



'; + $markread = array(); + foreach ($thesediscussions as $discussionid) { @set_time_limit(120); // to be reset for each post @@ -601,6 +626,15 @@ function forum_cron() { $canunsubscribe = ! forum_is_forcesubscribed($forum); $canreply = forum_user_can_post($forum, $userto); + // Fill caches + if (!isset($userto->viewfullnames[$forum->id])) { + $modcontext = get_context_instance(CONTEXT_MODULE, $cm->id); + $userto->viewfullnames[$forum->id] = has_capability('moodle/site:viewfullnames', $modcontext); + } + if (!isset($userto->canpost[$forum->id])) { + $modcontext = get_context_instance(CONTEXT_MODULE, $cm->id); + $userto->canpost[$forum->id] = forum_user_can_post($forum, $userto, null, $modcontext); + } $posttext .= "\n \n"; $posttext .= '====================================================================='; @@ -625,20 +659,27 @@ function forum_cron() { $postsarray = $discussionposts[$discussionid]; sort($postsarray); - // Create an empty array to use for marking read posts. - // (I'm sure there's already a structure I can use here, but I can't be sure.) - $markread = array(); - foreach ($postsarray as $postid) { $post = $posts[$postid]; if (array_key_exists($post->userid, $users)) { // we might know him/her already $userfrom = $users[$post->userid]; - } else if (!$userfrom = get_record('user', 'id', $post->userid)) { + } else if ($userfrom = get_record('user', 'id', $post->userid)) { + $users[$userfrom->id] = $userfrom; // fetch only once, we can add it to user list, it will be skipped anyway + } else { mtrace('Could not find user '.$post->userid); continue; } + if (!isset($userfrom->groups[$forum->id])) { + if (!isset($userfrom->groups)) { + $userfrom->groups = array(); + $users[$userfrom->id]->groups = array(); + } + $userfrom->groups[$forum->id] = groups_get_all_groups($course->id, $userfrom->id, $cm->groupingid); + $users[$userfrom->id]->groups[$forum->id] = $userfrom->groups[$forum->id]; + } + $userfrom->customheaders = array ("Precedence: Bulk"); if ($userto->maildigest == 2) { @@ -655,13 +696,17 @@ function forum_cron() { } else { // The full treatment $posttext .= forum_make_mail_text($course, $forum, $discussion, $post, $userfrom, $userto, true); - $posthtml .= forum_make_mail_post($post, $userfrom, $userto, $course, false, $canreply, true, false); + $posthtml .= forum_make_mail_post($course, $forum, $discussion, $post, $userfrom, $userto, false, $canreply, true, false); + + if (!isset($userto->tracking[$forum->id])) { + $userto->tracking[$forum->id] = !$CFG->forum_usermarksread + && forum_tp_can_track_forums($forum, $userto) + && forum_tp_is_tracked($forum, $userto->id); + } // Create an array of postid's for this user to mark as read. - if (!$CFG->forum_usermarksread && - forum_tp_can_track_forums($forum, $userto) && - forum_tp_is_tracked($forum, $userto->id)) { - $markread[$post->id]->post = $post; + if ($userto->tracking[$forum->id]) { + $markread[$post->id]->post = $post; $markread[$post->id]->forumid = $forum->id; } } @@ -692,14 +737,10 @@ function forum_cron() { $usermailcount++; // Mark post as read if forum_usermarksread is set off - if (!$CFG->forum_usermarksread && - forum_tp_can_track_forums($forum->id, $userto) && - forum_tp_is_tracked($forum->id, $userto->id)) { - foreach ($markread as $postinfo) { - if (!forum_tp_mark_post_read($userto->id, $postinfo->post, $postinfo->forumid)) { - mtrace("Error: mod/forum/cron.php: Could not mark post $postid read for user $userto->id". - " while sending digest email."); - } + foreach ($markread as $postinfo) { + if (!forum_tp_mark_post_read($userto->id, $postinfo->post, $postinfo->forumid)) { + mtrace("Error: mod/forum/cron.php: Could not mark post $postid read for user $userto->id". + " while sending digest email."); } } } @@ -745,18 +786,24 @@ function forum_cron() { function forum_make_mail_text($course, $forum, $discussion, $post, $userfrom, $userto, $bare = false) { global $CFG, $USER; - if (empty($post->viewfullnames)) { - if (empty($post->modcontext)) { - if (!$cm = get_coursemodule_from_instance('forum', $forum->id, $course->id)) { - error('Course Module ID was incorrect'); - } - $post->modcontext = get_context_instance(CONTEXT_MODULE, $cm->id); + if (!isset($userto->viewfullnames[$forum->id])) { + if (!$cm = get_coursemodule_from_instance('forum', $forum->id, $course->id)) { + error('Course Module ID was incorrect'); } - $post->viewfullnames = has_capability('moodle/site:viewfullnames', $post->modcontext, $userto->id); + $modcontext = get_context_instance(CONTEXT_MODULE, $cm->id); + $viewfullnames = has_capability('moodle/site:viewfullnames', $modcontext, $userto->id); + } else { + $viewfullnames = $userto->viewfullnames[$forum->id]; + } + + if (!isset($userto->canpost[$forum->id])) { + $canreply = forum_user_can_post($forum, $userto); + } else { + $canreply = $userto->canpost[$forum->id]; } $by = New stdClass; - $by->name = fullname($userfrom, $post->viewfullnames); + $by->name = fullname($userfrom, $viewfullnames); $by->date = userdate($post->modified, "", $userto->timezone); $strbynameondate = get_string('bynameondate', 'forum', $by); @@ -764,7 +811,6 @@ function forum_make_mail_text($course, $forum, $discussion, $post, $userfrom, $u $strforums = get_string('forums', 'forum'); $canunsubscribe = ! forum_is_forcesubscribed($forum); - $canreply = forum_user_can_post($forum, $userto); $posttext = ''; @@ -822,15 +868,13 @@ function forum_make_mail_html($course, $forum, $discussion, $post, $userfrom, $u return ''; } - if (empty($post->modcontext)) { - if (!$cm = get_coursemodule_from_instance('forum', $forum->id, $course->id)) { - error('Course Module ID was incorrect'); - } - $post->modcontext = get_context_instance(CONTEXT_MODULE, $cm->id); + if (!isset($userto->canpost[$forum->id])) { + $canreply = forum_user_can_post($forum, $userto); + } else { + $canreply = $userto->canpost[$forum->id]; } $strforums = get_string('forums', 'forum'); - $canreply = forum_user_can_post($forum, $userto, NULL, $post->modcontext); $canunsubscribe = ! forum_is_forcesubscribed($forum); $posthtml = ''; @@ -850,7 +894,7 @@ function forum_make_mail_html($course, $forum, $discussion, $post, $userfrom, $u $posthtml .= ' » '. format_string($discussion->name,true).''; } - $posthtml .= forum_make_mail_post($post, $userfrom, $userto, $course, false, $canreply, true, false); + $posthtml .= forum_make_mail_post($course, $forum, $discussion, $post, $userfrom, $userto, false, $canreply, true, false); if ($canunsubscribe) { $posthtml .= '