mirror of
https://gh.llkk.cc/https://github.com/h5p/moodle-mod_hvp.git
synced 2026-03-04 13:36:41 +08:00
236 lines
7.1 KiB
PHP
236 lines
7.1 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/>.
|
|
|
|
/**
|
|
* The mod_hvp content user data.
|
|
*
|
|
* @package mod_hvp
|
|
* @since Moodle 2.7
|
|
* @copyright 2016 Joubel AS
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
namespace mod_hvp;
|
|
|
|
defined('MOODLE_INTERNAL') || die();
|
|
|
|
/**
|
|
* Class content_user_data handles user data and corresponding db operations.
|
|
*
|
|
* @package mod_hvp
|
|
*/
|
|
class content_user_data {
|
|
|
|
/**
|
|
* Retrieves ajax parameters for content and update or delete
|
|
* user data depending on params.
|
|
*
|
|
* @throws \coding_exception
|
|
*/
|
|
public static function handle_ajax() {
|
|
// Query String Parameters.
|
|
$contentid = required_param('content_id', PARAM_INT);
|
|
$dataid = required_param('data_type', PARAM_RAW);
|
|
$subcontentid = required_param('sub_content_id', PARAM_INT);
|
|
|
|
// Form Data.
|
|
$data = optional_param('data', null, PARAM_RAW);
|
|
$preload = optional_param('preload', null, PARAM_INT);
|
|
$invalidate = optional_param('invalidate', null, PARAM_INT);
|
|
|
|
if ($contentid === null || $dataid === null || $subcontentid === null) {
|
|
// Missing parameters.
|
|
\H5PCore::ajaxError(get_string('missingparameters', 'hvp'));
|
|
return;
|
|
}
|
|
|
|
// Saving data.
|
|
if ($data !== null && $preload !== null && $invalidate !== null) {
|
|
self::store_data($contentid, $subcontentid, $dataid, $data, $preload, $invalidate);
|
|
} else {
|
|
self::fetch_existing_data($contentid, $subcontentid, $dataid);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Stores content user data
|
|
*
|
|
* @param $contentid
|
|
* @param $subcontentid
|
|
* @param $dataid
|
|
* @param $data
|
|
* @param $preload
|
|
* @param $invalidate
|
|
*/
|
|
private static function store_data($contentid, $subcontentid, $dataid, $data, $preload, $invalidate) {
|
|
// Validate token.
|
|
if (!\H5PCore::validToken('contentuserdata', required_param('token', PARAM_RAW))) {
|
|
\H5PCore::ajaxError(get_string('invalidtoken', 'hvp'));
|
|
return;
|
|
}
|
|
|
|
// Load course module for content to get context.
|
|
$cm = get_coursemodule_from_instance('hvp', $contentid);
|
|
if (!$cm) {
|
|
\H5PCore::ajaxError('No such content');
|
|
http_response_code(404);
|
|
return;
|
|
}
|
|
|
|
// Check permissions.
|
|
$context = \context_module::instance($cm->id);
|
|
if (!has_capability('mod/hvp:savecontentuserdata', $context)) {
|
|
\H5PCore::ajaxError(get_string('nopermissiontosavecontentuserdata', 'hvp'));
|
|
http_response_code(403);
|
|
return;
|
|
}
|
|
|
|
if ($data === '0') {
|
|
// Delete user data.
|
|
self::delete_user_data($contentid, $subcontentid, $dataid);
|
|
} else {
|
|
// Save user data.
|
|
self::save_user_data($contentid, $subcontentid, $dataid, $preload, $invalidate, $data);
|
|
}
|
|
\H5PCore::ajaxSuccess();
|
|
}
|
|
|
|
/**
|
|
* Return existing content user data
|
|
*
|
|
* @param $contentid
|
|
* @param $subcontentid
|
|
* @param $dataid
|
|
*/
|
|
private static function fetch_existing_data($contentid, $subcontentid, $dataid) {
|
|
// Fetch user data.
|
|
$userdata = self::get_user_data($contentid, $subcontentid, $dataid);
|
|
\H5PCore::ajaxSuccess($userdata ? $userdata->data : null);
|
|
}
|
|
|
|
/**
|
|
* Get user data for content.
|
|
*
|
|
* @param $contentid
|
|
* @param $subcontentid
|
|
* @param $dataid
|
|
*
|
|
* @return mixed
|
|
*/
|
|
public static function get_user_data($contentid, $subcontentid, $dataid) {
|
|
global $DB, $USER;
|
|
|
|
$result = $DB->get_record('hvp_content_user_data', array(
|
|
'user_id' => $USER->id,
|
|
'hvp_id' => $contentid,
|
|
'sub_content_id' => $subcontentid,
|
|
'data_id' => $dataid
|
|
)
|
|
);
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Save user data for specific content in database.
|
|
*
|
|
* @param $contentid
|
|
* @param $subcontentid
|
|
* @param $dataid
|
|
* @param $preload
|
|
* @param $invalidate
|
|
* @param $data
|
|
*/
|
|
public static function save_user_data($contentid, $subcontentid, $dataid, $preload, $invalidate, $data) {
|
|
global $DB, $USER;
|
|
|
|
// Determine if we should update or insert.
|
|
$update = self::get_user_data($contentid, $subcontentid, $dataid);
|
|
|
|
// Wash values to ensure 0 or 1.
|
|
$preload = ($preload === '0' || $preload === 0) ? 0 : 1;
|
|
$invalidate = ($invalidate === '0' || $invalidate === 0) ? 0 : 1;
|
|
|
|
// New data to be inserted.
|
|
$newdata = (object)array(
|
|
'user_id' => $USER->id,
|
|
'hvp_id' => $contentid,
|
|
'sub_content_id' => $subcontentid,
|
|
'data_id' => $dataid,
|
|
'data' => $data,
|
|
'preloaded' => $preload,
|
|
'delete_on_content_change' => $invalidate
|
|
);
|
|
|
|
// Does not exist.
|
|
if ($update === false) {
|
|
// Insert new data.
|
|
$DB->insert_record('hvp_content_user_data', $newdata);
|
|
} else {
|
|
// Get old data id.
|
|
$newdata->id = $update->id;
|
|
|
|
// Update old data.
|
|
$DB->update_record('hvp_content_user_data', $newdata);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Delete user data with specific content from database
|
|
*
|
|
* @param $contentid
|
|
* @param $subcontentid
|
|
* @param $dataid
|
|
*/
|
|
public static function delete_user_data($contentid, $subcontentid, $dataid) {
|
|
global $DB, $USER;
|
|
|
|
$DB->delete_records('hvp_content_user_data', array(
|
|
'user_id' => $USER->id,
|
|
'hvp_id' => $contentid,
|
|
'sub_content_id' => $subcontentid,
|
|
'data_id' => $dataid
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Load user data for specific content
|
|
*
|
|
* @param $contentid
|
|
* @return mixed User data for specific content if found, else null
|
|
*/
|
|
public static function load_pre_loaded_user_data($contentid) {
|
|
global $DB, $USER;
|
|
|
|
$preloadeduserdata = array(
|
|
'state' => '{}'
|
|
);
|
|
|
|
$results = $DB->get_records('hvp_content_user_data', array(
|
|
'user_id' => $USER->id,
|
|
'hvp_id' => $contentid,
|
|
'sub_content_id' => 0,
|
|
'preloaded' => 1
|
|
));
|
|
|
|
// Get data for data ids.
|
|
foreach ($results as $contentuserdata) {
|
|
$preloadeduserdata[$contentuserdata->data_id] = $contentuserdata->data;
|
|
}
|
|
|
|
return $preloadeduserdata;
|
|
}
|
|
}
|