. /** * Ajax point of entry for messaging API. * * @package core_message * @copyright 2015 Frédéric Massart - FMCorz.net * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ define('AJAX_SCRIPT', true); require('../config.php'); require_once($CFG->libdir . '/filelib.php'); require_once(__DIR__ . '/lib.php'); // Only real logged in users. require_login(null, false, null, true, true); if (isguestuser()) { throw new require_login_exception('Guests are not allowed here.'); } // Messaging needs to be enabled. if (empty($CFG->messaging)) { throw new moodle_exception('disabled', 'core_message'); } $PAGE->set_context(null); require_sesskey(); $action = optional_param('action', null, PARAM_ALPHA); $response = null; switch ($action) { // Sending a message. case 'sendmessage': $userid = required_param('userid', PARAM_INT); if (empty($userid) || isguestuser($userid) || $userid == $USER->id) { // Cannot send messags to self, nobody or a guest. throw new coding_exception('Invalid user to send the message to'); } $message = required_param('message', PARAM_RAW); $user2 = core_user::get_user($userid); // Only attempt to send the message if we have permission to message // the recipient. if (message_can_post_message($user2, $USER)) { $messageid = message_post_message($USER, $user2, $message, FORMAT_MOODLE); if (!$messageid) { throw new moodle_exception('errorwhilesendingmessage', 'core_message'); } } else { throw new moodle_exception('unabletomessageuser', 'core_message'); } $response = array(); break; } if ($response !== null) { echo json_encode($response); exit(); } throw new coding_exception('Invalid request');