. /* * Handling all ajax request for comments API */ require_once('../config.php'); require_once($CFG->libdir.'/commentlib.php'); $courseid = optional_param('courseid', SITEID, PARAM_INT); $contextid = optional_param('contextid', SYSCONTEXTID, PARAM_INT); $context = get_context_instance_by_id($contextid); if ($context->contextlevel == CONTEXT_MODULE) { $cm = get_coursemodule_from_id('', $context->instanceid); } else { $cm = null; } require_login($courseid, true, $cm); $err = new stdclass; if (!confirm_sesskey()) { print_error('invalidsesskey'); } if (!isloggedin()){ print_error('loggedinnot'); } if (isguestuser()) { print_error('loggedinnot'); } $action = optional_param('action', '', PARAM_ALPHA); $area = optional_param('area', '', PARAM_ALPHAEXT); $commentid = optional_param('commentid', -1, PARAM_INT); $content = optional_param('content', '', PARAM_RAW); $itemid = optional_param('itemid', '', PARAM_INT); $returnurl = optional_param('returnurl', '', PARAM_URL); $cmt = new stdclass; $cmt->contextid = $contextid; $cmt->courseid = $courseid; $cmt->area = $area; $cmt->itemid = $itemid; $comment = new comment($cmt); switch ($action) { case 'add': $cmt = $comment->add($content); if (!empty($cmt) && is_object($cmt)) { redirect($returnurl, get_string('pageshouldredirect'), 0); } else if ($cmt === COMMENT_ERROR_DB) { print_error('dbupdatefailed'); } else if ($cmt === COMMENT_ERROR_MODULE_REJECT) { print_error('modulererejectcomment'); } else if ($cmt === COMMENT_ERROR_INSUFFICIENT_CAPS) { print_error('nopermissiontocomment'); } break; default: exit; }