AutorÃa | Ultima modificación | Ver Log |
<?php// This file is part of Moodle - http://moodle.org///// Moodle is free software: you can redistribute it and/or modify// it under the terms of the GNU General Public License as published by// the Free Software Foundation, either version 3 of the License, or// (at your option) any later version.//// Moodle is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the// GNU General Public License for more details.//// You should have received a copy of the GNU General Public License// along with Moodle. If not, see <http://www.gnu.org/licenses/>.declare(strict_types=1);namespace mod_forum\completion;use core_completion\activity_custom_completion;/*** Activity custom completion subclass for the forum activity.** Class for defining mod_forum's custom completion rules and fetching the completion statuses* of the custom completion rules for a given forum instance and a user.** @package mod_forum* @copyright Simey Lameze <simey@moodle.com>* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later*/class custom_completion extends activity_custom_completion {/*** Fetches the completion state for a given completion rule.** @param string $rule The completion rule.* @return int The completion state.*/public function get_state(string $rule): int {global $DB;$this->validate_rule($rule);$userid = $this->userid;$forumid = $this->cm->instance;if (!$forum = $DB->get_record('forum', ['id' => $forumid])) {throw new \moodle_exception('Unable to find forum with id ' . $forumid);}$postcountparams = ['userid' => $userid, 'forumid' => $forumid];$postcountsql = "SELECT COUNT(*)FROM {forum_posts} fpJOIN {forum_discussions} fd ON fp.discussion = fd.idWHERE fp.userid = :useridAND fd.forum = :forumid";if ($rule == 'completiondiscussions') {$status = $forum->completiondiscussions <=$DB->count_records('forum_discussions', ['forum' => $forumid, 'userid' => $userid]);} else if ($rule == 'completionreplies') {$status = $forum->completionreplies <=$DB->get_field_sql($postcountsql . ' AND fp.parent <> 0', $postcountparams);} else if ($rule == 'completionposts') {$status = $forum->completionposts <= $DB->get_field_sql($postcountsql, $postcountparams);}return $status ? COMPLETION_COMPLETE : COMPLETION_INCOMPLETE;}/*** Fetch the list of custom completion rules that this module defines.** @return array*/public static function get_defined_custom_rules(): array {return ['completiondiscussions','completionreplies','completionposts',];}/*** Returns an associative array of the descriptions of custom completion rules.** @return array*/public function get_custom_rule_descriptions(): array {$completiondiscussions = $this->cm->customdata['customcompletionrules']['completiondiscussions'] ?? 0;$completionreplies = $this->cm->customdata['customcompletionrules']['completionreplies'] ?? 0;$completionposts = $this->cm->customdata['customcompletionrules']['completionposts'] ?? 0;return ['completiondiscussions' => get_string('completiondetail:discussions', 'forum', $completiondiscussions),'completionreplies' => get_string('completiondetail:replies', 'forum', $completionreplies),'completionposts' => get_string('completiondetail:posts', 'forum', $completionposts),];}/*** Returns an array of all completion rules, in the order they should be displayed to users.** @return array*/public function get_sort_order(): array {return ['completionview','completiondiscussions','completionreplies','completionposts','completionusegrade','completionpassgrade',];}}