Proyectos de Subversion Moodle

Rev

Autoría | Ultima modificación | Ver Log |

<?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
 * @copyright   2018 Joubel AS <contact@joubel.com>
 * @license     http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class content_user_data {

    /**
     * Retrieves ajax parameters for content and update or delete
     * user data depending on params.
     *
     * @throws \coding_exception
     * @throws \dml_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
     *
     * @throws \coding_exception
     * @throws \dml_exception
     */
    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;
        }

        if ($contentid === 0) {
            $context = \context::instance_by_id(required_param('contextId', PARAM_RAW));
        } else {
            // 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;
            }
            $context = \context_module::instance($cm->id);
        }

        // Check permissions.
        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
     *
     * @throws \dml_exception
     */
    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
     * @throws \dml_exception
     */
    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
     *
     * @throws \dml_exception
     */
    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
     *
     * @throws \dml_exception
     */
    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 array User data for specific content if found, else null
     * @throws \dml_exception
     */
    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;
    }
}