e7cca967ac318edb1ff04320b8808a7497ad7650
[moodle.git] / user / messageselect.php
1 <?php
3 // This file is part of Moodle - http://moodle.org/
4 //
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.
9 //
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.
14 //
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/>.
18 /**
19  * This file is part of the User section Moodle
20  *
21  * @copyright 1999 Martin Dougiamas  http://dougiamas.com
22  * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  * @package user
24  */
26 require_once('../config.php');
27 require_once($CFG->dirroot.'/message/lib.php');
29 $id = required_param('id',PARAM_INT);
30 $messagebody = optional_param('messagebody','',PARAM_CLEANHTML);
31 $send = optional_param('send','',PARAM_BOOL);
32 $preview = optional_param('preview','',PARAM_BOOL);
33 $edit = optional_param('edit','',PARAM_BOOL);
34 $returnto = optional_param('returnto','',PARAM_LOCALURL);
35 $format = optional_param('format',FORMAT_MOODLE,PARAM_INT);
36 $deluser = optional_param('deluser',0,PARAM_INT);
38 $url = new moodle_url('/user/messageselect.php', array('id'=>$id));
39 if ($messagebody !== '') {
40     $url->param('messagebody', $messagebody);
41 }
42 if ($send !== '') {
43     $url->param('send', $send);
44 }
45 if ($preview !== '') {
46     $url->param('preview', $preview);
47 }
48 if ($edit !== '') {
49     $url->param('edit', $edit);
50 }
51 if ($returnto !== '') {
52     $url->param('returnto', $returnto);
53 }
54 if ($format !== FORMAT_MOODLE) {
55     $url->param('format', $format);
56 }
57 if ($deluser !== 0) {
58     $url->param('deluser', $deluser);
59 }
60 $PAGE->set_url($url);
61 $PAGE->set_context(get_context_instance(CONTEXT_SYSTEM));
63 if (!$course = $DB->get_record('course', array('id'=>$id))) {
64     print_error('invalidcourseid');
65 }
67 require_login();
69 $coursecontext = get_context_instance(CONTEXT_COURSE, $id);   // Course context
70 $systemcontext = get_context_instance(CONTEXT_SYSTEM);   // SYSTEM context
71 require_capability('moodle/course:bulkmessaging', $coursecontext);
73 if (empty($SESSION->emailto)) {
74     $SESSION->emailto = array();
75 }
76 if (!array_key_exists($id,$SESSION->emailto)) {
77     $SESSION->emailto[$id] = array();
78 }
80 if ($deluser) {
81     if (array_key_exists($id,$SESSION->emailto) && array_key_exists($deluser,$SESSION->emailto[$id])) {
82         unset($SESSION->emailto[$id][$deluser]);
83     }
84 }
86 if (empty($SESSION->emailselect[$id]) || $messagebody) {
87     $SESSION->emailselect[$id] = array('messagebody' => $messagebody);
88 }
90 $messagebody = $SESSION->emailselect[$id]['messagebody'];
92 $count = 0;
94 if (($data = data_submitted()) && confirm_sesskey()) {
95     foreach ($data as $k => $v) {
96         if (preg_match('/^(user|teacher)(\d+)$/',$k,$m)) {
97             if (!array_key_exists($m[2],$SESSION->emailto[$id])) {
98                 if ($user = $DB->get_record_select('user', "id = ?", array($m[2]), 'id,firstname,lastname,idnumber,email,mailformat,lastaccess, lang, maildisplay')) {
99                     $SESSION->emailto[$id][$m[2]] = $user;
100                     $count++;
101                 }
102             }
103         }
104     }
107 $strtitle = get_string('coursemessage');
109 $link = null;
110 if (has_capability('moodle/course:viewparticipants', $coursecontext) || has_capability('moodle/site:viewparticipants', $systemcontext)) {
111     $link = new moodle_url("/user/index.php", array('id'=>$course->id));
113 $PAGE->navbar->add(get_string('participants'), $link);
114 $PAGE->navbar->add($strtitle);
115 $PAGE->set_title($strtitle);
116 $PAGE->set_heading($strtitle);
117 echo $OUTPUT->header();
118 // if messaging is disabled on site, we can still allow users with capabilities to send emails instead
119 if (empty($CFG->messaging)) {
120     echo $OUTPUT->notification(get_string('messagingdisabled','message'));
123 if ($count) {
124     if ($count == 1) {
125         $heading = get_string('addedrecip','moodle',$count);
126     } else {
127         $heading = get_string('addedrecips','moodle',$count);
128     }
129     echo $OUTPUT->heading($heading);
132 if (!empty($messagebody) && !$edit && !$deluser && ($preview || $send)) {
133     if (count($SESSION->emailto[$id])) {
134         if (!empty($preview)) {
135             echo '<form method="post" action="messageselect.php" style="margin: 0 20px;">
136 <input type="hidden" name="returnto" value="'.s($returnto).'" />
137 <input type="hidden" name="id" value="'.$id.'" />
138 <input type="hidden" name="format" value="'.$format.'" />
139 <input type="hidden" name="sesskey" value="' . sesskey() . '" />
140 ';
141             echo "<h3>".get_string('previewhtml')."</h3><div class=\"messagepreview\">\n".format_text($messagebody,$format)."\n</div>\n";
142             echo '<p align="center"><input type="submit" name="send" value="'.get_string('sendmessage', 'message').'" />'."\n";
143             echo '<input type="submit" name="edit" value="'.get_string('update').'" /></p>';
144             echo "\n</form>";
145         } else if (!empty($send) && require_sesskey()) {
146             $good = 1;
147             foreach ($SESSION->emailto[$id] as $user) {
148                 $good = $good && message_post_message($USER,$user,$messagebody,$format);
149             }
150             if (!empty($good)) {
151                 echo $OUTPUT->heading(get_string('messagedselectedusers'));
152                 unset($SESSION->emailto[$id]);
153                 unset($SESSION->emailselect[$id]);
154             } else {
155                 echo $OUTPUT->heading(get_string('messagedselectedusersfailed'));
156             }
157             echo '<p align="center"><a href="index.php?id='.$id.'">'.get_string('backtoparticipants').'</a></p>';
158         }
159         echo $OUTPUT->footer();
160         exit;
161     } else {
162         echo $OUTPUT->notification(get_string('nousersyet'));
163     }
166 echo '<p align="center"><a href="'.$returnto.'">'.get_string("keepsearching").'</a>'.((count($SESSION->emailto[$id])) ? ', '.get_string('usemessageform') : '').'</p>';
168 if ((!empty($send) || !empty($preview) || !empty($edit)) && (empty($messagebody))) {
169     echo $OUTPUT->notification(get_string('allfieldsrequired'));
172 if (count($SESSION->emailto[$id])) {
173     $usehtmleditor = can_use_html_editor();
174     require("message.html");
177 echo $OUTPUT->footer();