3 // This file is part of Moodle - http://moodle.org/
5 // Moodle is free software: you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation, either version 3 of the License, or
8 // (at your option) any later version.
10 // Moodle is distributed in the hope that it will be useful,
11 // but WITHOUT ANY WARRANTY; without even the implied warranty of
12 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 // GNU General Public License for more details.
15 // You should have received a copy of the GNU General Public License
16 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
19 * Subscribe to or unsubscribe from a forum or manage forum subscription mode
21 * This script can be used by either individual users to subscribe to or
22 * unsubscribe from a forum (no 'mode' param provided), or by forum managers
23 * to control the subscription mode (by 'mode' param).
24 * This script can be called from a link in email so the sesskey is not
25 * required parameter. However, if sesskey is missing, the user has to go
26 * through a confirmation page that redirects the user back with the
30 * @copyright 1999 onwards Martin Dougiamas {@link http://moodle.com}
31 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
34 require(__DIR__
.'/../../config.php');
35 require_once($CFG->dirroot
.'/mod/forum/lib.php');
37 $id = required_param('id', PARAM_INT
); // The forum to set subscription on.
38 $mode = optional_param('mode', null, PARAM_INT
); // The forum's subscription mode.
39 $user = optional_param('user', 0, PARAM_INT
); // The userid of the user to subscribe, defaults to $USER.
40 $discussionid = optional_param('d', null, PARAM_INT
); // The discussionid to subscribe.
41 $sesskey = optional_param('sesskey', null, PARAM_RAW
);
42 $returnurl = optional_param('returnurl', null, PARAM_LOCALURL
);
44 $url = new moodle_url('/mod/forum/subscribe.php', array('id'=>$id));
45 if (!is_null($mode)) {
46 $url->param('mode', $mode);
49 $url->param('user', $user);
51 if (!is_null($sesskey)) {
52 $url->param('sesskey', $sesskey);
54 if (!is_null($discussionid)) {
55 $url->param('d', $discussionid);
56 if (!$discussion = $DB->get_record('forum_discussions', array('id' => $discussionid, 'forum' => $id))) {
57 print_error('invaliddiscussionid', 'forum');
62 $forum = $DB->get_record('forum', array('id' => $id), '*', MUST_EXIST
);
63 $course = $DB->get_record('course', array('id' => $forum->course
), '*', MUST_EXIST
);
64 $cm = get_coursemodule_from_instance('forum', $forum->id
, $course->id
, false, MUST_EXIST
);
65 $context = context_module
::instance($cm->id
);
69 if (!has_capability('mod/forum:managesubscriptions', $context)) {
70 print_error('nopermissiontosubscribe', 'forum');
72 $user = $DB->get_record('user', array('id' => $user), '*', MUST_EXIST
);
77 if (isset($cm->groupmode
) && empty($course->groupmodeforce
)) {
78 $groupmode = $cm->groupmode
;
80 $groupmode = $course->groupmode
;
83 $issubscribed = \mod_forum\subscriptions
::is_subscribed($user->id
, $forum, $discussionid, $cm);
85 // For a user to subscribe when a groupmode is set, they must have access to at least one group.
86 if ($groupmode && !$issubscribed && !has_capability('moodle/site:accessallgroups', $context)) {
87 if (!groups_get_all_groups($course->id
, $USER->id
)) {
88 print_error('cannotsubscribe', 'forum');
92 require_login($course, false, $cm);
94 if (is_null($mode) and !is_enrolled($context, $USER, '', true)) { // Guests and visitors can't subscribe - only enrolled
95 $PAGE->set_title($course->shortname
);
96 $PAGE->set_heading($course->fullname
);
98 echo $OUTPUT->header();
99 echo $OUTPUT->confirm(get_string('subscribeenrolledonly', 'forum').'<br /><br />'.get_string('liketologin'),
100 get_login_url(), new moodle_url('/mod/forum/view.php', array('f'=>$id)));
101 echo $OUTPUT->footer();
104 // There should not be any links leading to this place, just redirect.
106 new moodle_url('/mod/forum/view.php', array('f'=>$id)),
107 get_string('subscribeenrolledonly', 'forum'),
109 \core\output\notification
::NOTIFY_ERROR
114 $returnto = optional_param('backtoindex',0,PARAM_INT
)
115 ?
"index.php?id=".$course->id
119 $returnto = $returnurl;
122 if (!is_null($mode) and has_capability('mod/forum:managesubscriptions', $context)) {
125 case FORUM_CHOOSESUBSCRIBE
: // 0
126 \mod_forum\subscriptions
::set_subscription_mode($forum->id
, FORUM_CHOOSESUBSCRIBE
);
129 get_string('everyonecannowchoose', 'forum'),
131 \core\output\notification
::NOTIFY_SUCCESS
134 case FORUM_FORCESUBSCRIBE
: // 1
135 \mod_forum\subscriptions
::set_subscription_mode($forum->id
, FORUM_FORCESUBSCRIBE
);
138 get_string('everyoneisnowsubscribed', 'forum'),
140 \core\output\notification
::NOTIFY_SUCCESS
143 case FORUM_INITIALSUBSCRIBE
: // 2
144 \mod_forum\subscriptions
::set_subscription_mode($forum->id
, FORUM_INITIALSUBSCRIBE
);
145 if ($forum->forcesubscribe
<> FORUM_INITIALSUBSCRIBE
) {
146 // Reload the forum again to get the updated forcesubscribe field.
147 $forum = $DB->get_record('forum', array('id' => $id), '*', MUST_EXIST
);
148 $users = \mod_forum\subscriptions
::get_potential_subscribers($context, 0, 'u.id, u.email', '');
149 foreach ($users as $user) {
150 \mod_forum\subscriptions
::subscribe_user($user->id
, $forum, $context);
155 get_string('everyoneisnowsubscribed', 'forum'),
157 \core\output\notification
::NOTIFY_SUCCESS
160 case FORUM_DISALLOWSUBSCRIBE
: // 3
161 \mod_forum\subscriptions
::set_subscription_mode($forum->id
, FORUM_DISALLOWSUBSCRIBE
);
164 get_string('noonecansubscribenow', 'forum'),
166 \core\output\notification
::NOTIFY_SUCCESS
170 print_error(get_string('invalidforcesubscribe', 'forum'));
174 if (\mod_forum\subscriptions
::is_forcesubscribed($forum)) {
177 get_string('everyoneisnowsubscribed', 'forum'),
179 \core\output\notification
::NOTIFY_SUCCESS
183 $info = new stdClass();
184 $info->name
= fullname($user);
185 $info->forum
= format_string($forum->name
);
188 if (is_null($sesskey)) {
189 // We came here via link in email.
190 $PAGE->set_title($course->shortname
);
191 $PAGE->set_heading($course->fullname
);
192 echo $OUTPUT->header();
194 $viewurl = new moodle_url('/mod/forum/view.php', array('f' => $id));
197 $a->forum
= format_string($forum->name
);
198 $a->discussion
= format_string($discussion->name
);
199 echo $OUTPUT->confirm(get_string('confirmunsubscribediscussion', 'forum', $a),
200 $PAGE->url
, $viewurl);
202 echo $OUTPUT->confirm(get_string('confirmunsubscribe', 'forum', format_string($forum->name
)),
203 $PAGE->url
, $viewurl);
205 echo $OUTPUT->footer();
209 if ($discussionid === null) {
210 if (\mod_forum\subscriptions
::unsubscribe_user($user->id
, $forum, $context, true)) {
213 get_string('nownotsubscribed', 'forum', $info),
215 \core\output\notification
::NOTIFY_SUCCESS
218 print_error('cannotunsubscribe', 'forum', get_local_referer(false));
221 if (\mod_forum\subscriptions
::unsubscribe_user_from_discussion($user->id
, $discussion, $context)) {
222 $info->discussion
= $discussion->name
;
225 get_string('discussionnownotsubscribed', 'forum', $info),
227 \core\output\notification
::NOTIFY_SUCCESS
230 print_error('cannotunsubscribe', 'forum', get_local_referer(false));
234 } else { // subscribe
235 if (\mod_forum\subscriptions
::subscription_disabled($forum) && !has_capability('mod/forum:managesubscriptions', $context)) {
236 print_error('disallowsubscribe', 'forum', get_local_referer(false));
238 if (!has_capability('mod/forum:viewdiscussion', $context)) {
239 print_error('noviewdiscussionspermission', 'forum', get_local_referer(false));
241 if (is_null($sesskey)) {
242 // We came here via link in email.
243 $PAGE->set_title($course->shortname
);
244 $PAGE->set_heading($course->fullname
);
245 echo $OUTPUT->header();
247 $viewurl = new moodle_url('/mod/forum/view.php', array('f' => $id));
250 $a->forum
= format_string($forum->name
);
251 $a->discussion
= format_string($discussion->name
);
252 echo $OUTPUT->confirm(get_string('confirmsubscribediscussion', 'forum', $a),
253 $PAGE->url
, $viewurl);
255 echo $OUTPUT->confirm(get_string('confirmsubscribe', 'forum', format_string($forum->name
)),
256 $PAGE->url
, $viewurl);
258 echo $OUTPUT->footer();
262 if ($discussionid == null) {
263 \mod_forum\subscriptions
::subscribe_user($user->id
, $forum, $context, true);
266 get_string('nowsubscribed', 'forum', $info),
268 \core\output\notification
::NOTIFY_SUCCESS
271 $info->discussion
= $discussion->name
;
272 \mod_forum\subscriptions
::subscribe_user_to_discussion($user->id
, $discussion, $context);
275 get_string('discussionnowsubscribed', 'forum', $info),
277 \core\output\notification
::NOTIFY_SUCCESS