mirror of
https://github.com/moodle/moodle.git
synced 2025-01-19 14:27:22 +01:00
141 lines
5.3 KiB
PHP
141 lines
5.3 KiB
PHP
<?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/>.
|
|
|
|
/**
|
|
* This page receives ajax rating submissions
|
|
*
|
|
* It is similar to rate.php. Unlike rate.php a return url is NOT required.
|
|
*
|
|
* @package moodlecore
|
|
* @copyright 2010 Andrew Davis
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
require_once('../config.php');
|
|
require_once('lib.php');
|
|
|
|
$contextid = required_param('contextid', PARAM_INT);
|
|
$itemid = required_param('itemid', PARAM_INT);
|
|
$scaleid = required_param('scaleid', PARAM_INT);
|
|
$userrating = required_param('rating', PARAM_INT);
|
|
$rateduserid = required_param('rateduserid', PARAM_INT);//which user is being rated. Required to update their grade
|
|
$aggregationmethod = optional_param('aggregation', PARAM_INT);//we're going to calculate the aggregate and return it to the client
|
|
|
|
$result = new stdClass;
|
|
|
|
//if session has expired and its an ajax request so we cant do a page redirect
|
|
if( !isloggedin() ){
|
|
$result->error = get_string('sessionerroruser', 'error');
|
|
echo json_encode($result);
|
|
die();
|
|
}
|
|
|
|
list($context, $course, $cm) = get_context_info_array($contextid);
|
|
require_login($course, false, $cm);
|
|
|
|
//check the module rating permissions
|
|
//doing this check here rather than within rating_manager::get_ratings so we can return a json error response
|
|
$pluginrateallowed = true;
|
|
$pluginpermissionsarray = null;
|
|
if ($context->contextlevel==CONTEXT_MODULE) {
|
|
$plugintype = 'mod';
|
|
$pluginname = $cm->modname;
|
|
$rm = new rating_manager();
|
|
$pluginpermissionsarray = $rm->get_plugin_permissions_array($context->id, $plugintype, $pluginname);
|
|
$pluginrateallowed = $pluginpermissionsarray['rate'];
|
|
}
|
|
|
|
if (!$pluginrateallowed || !has_capability('moodle/rating:rate',$context)) {
|
|
$result->error = get_string('ratepermissiondenied', 'ratings');
|
|
echo json_encode($result);
|
|
die();
|
|
}
|
|
|
|
$userid = $USER->id;
|
|
|
|
$PAGE->set_url('/lib/rate.php', array(
|
|
'contextid'=>$contextid
|
|
));
|
|
|
|
//todo how can we validate the forum post,glossary entry or whatever id?
|
|
//how do we know where to look for the item? how we we work from module to forum_posts, glossary_entries etc?
|
|
|
|
$ratingoptions = new stdclass;
|
|
$ratingoptions->context = $context;
|
|
$ratingoptions->itemid = $itemid;
|
|
$ratingoptions->scaleid = $scaleid;
|
|
$ratingoptions->userid = $userid;
|
|
$rating = new rating($ratingoptions);
|
|
|
|
$rating->update_rating($userrating);
|
|
|
|
//Future possible enhancement: add a setting to turn grade updating off for those who don't want them in gradebook
|
|
//note that this would need to be done in both rate.php and rate_ajax.php
|
|
if(true){
|
|
if ($context->contextlevel==CONTEXT_MODULE) {
|
|
//tell the module that its grades have changed
|
|
if ( $modinstance = $DB->get_record($cm->modname, array('id' => $cm->instance)) ) {
|
|
$modinstance->cmidnumber = $cm->id; //MDL-12961
|
|
$functionname = $cm->modname.'_update_grades';
|
|
require_once("../mod/{$cm->modname}/lib.php");
|
|
if(function_exists($functionname)) {
|
|
$functionname($modinstance, $rateduserid);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
//object to return to client as json
|
|
$result = new stdClass;
|
|
$result->success = true;
|
|
|
|
|
|
//need to retrieve the updated item to get its new aggregate value
|
|
$item = new stdclass();
|
|
$item->id = $rating->itemid;
|
|
$items = array($item);
|
|
|
|
//most of $ratingoptions variables are set correctly
|
|
$ratingoptions->items = $items;
|
|
$ratingoptions->aggregate = $aggregationmethod;
|
|
|
|
$rm = new rating_manager();
|
|
$items = $rm->get_ratings($ratingoptions);
|
|
|
|
//for custom scales return text not the value
|
|
//this scales weirdness will go away when scales are refactored
|
|
$scalearray = null;
|
|
$aggregatetoreturn = round($items[0]->rating->aggregate,1);
|
|
if($rating->scaleid < 0 ) { //if its a scale (not numeric)
|
|
$scalerecord = $DB->get_record('scale', array('id' => -$rating->scaleid));
|
|
if ($scalerecord) {
|
|
$scalearray = explode(',', $scalerecord->scale);
|
|
}
|
|
$aggregatetoreturn = $scalearray[$aggregatetoreturn-1];
|
|
}
|
|
|
|
//See if the user has permission to see the rating aggregate
|
|
//we could do this check as "if $userid==$rateduserid" but going to the database to determine item owner id seems more secure
|
|
//if we accept the item owner user id from the http request a user could alter the URL and erroneously get access to the rating aggregate
|
|
if (($userid==$items[0]->rating->itemuserid && has_capability('moodle/rating:view',$context) && $pluginpermissionsarray['view'])
|
|
|| ($userid!=$items[0]->rating->itemuserid && has_capability('moodle/rating:viewany',$context) && $pluginpermissionsarray['viewany'])) {
|
|
$result->aggregate = $aggregatetoreturn;
|
|
$result->count = $items[0]->rating->count;
|
|
$result->itemid = $rating->itemid;
|
|
}
|
|
|
|
echo json_encode($result); |