Your IP : 192.168.165.1


Current Path : C:/xampp/htdocs/moodle/mod/h5pactivity/classes/external/
Upload File :
Current File : C:/xampp/htdocs/moodle/mod/h5pactivity/classes/external/h5pactivity_summary_exporter.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/>.

/**
 * Class for exporting h5p activity data.
 *
 * @package    mod_h5pactivity
 * @since      Moodle 3.9
 * @copyright  2020 Carlos Escobedo <carlos@moodle.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
namespace mod_h5pactivity\external;

use core\external\exporter;
use renderer_base;
use external_util;
use external_files;
use core_h5p\factory;
use core_h5p\api;

/**
 * Class for exporting h5p activity data.
 *
 * @copyright  2020 Carlos Escobedo <carlos@moodle.com>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class h5pactivity_summary_exporter extends exporter {

    /**
     * Properties definition.
     *
     * @return array
     */
    protected static function define_properties() {

        return [
            'id' => [
                'type' => PARAM_INT,
                'description' => 'The primary key of the record.',
            ],
            'course' => [
                'type' => PARAM_INT,
                'description' => 'Course id this h5p activity is part of.',
            ],
            'name' => [
                'type' => PARAM_TEXT,
                'description' => 'The name of the activity module instance.',
            ],
            'timecreated' => [
                'type' => PARAM_INT,
                'description' => 'Timestamp of when the instance was added to the course.',
                'optional' => true,
            ],
            'timemodified' => [
                'type' => PARAM_INT,
                'description' => 'Timestamp of when the instance was last modified.',
                'optional' => true,
            ],
            'intro' => [
                'default' => '',
                'type' => PARAM_RAW,
                'description' => 'H5P activity description.',
                'null' => NULL_ALLOWED,
            ],
            'introformat' => [
                'choices' => [FORMAT_HTML, FORMAT_MOODLE, FORMAT_PLAIN, FORMAT_MARKDOWN],
                'type' => PARAM_INT,
                'default' => FORMAT_MOODLE,
                'description' => 'The format of the intro field.',
            ],
            'grade' => [
                'type' => PARAM_INT,
                'default' => 0,
                'description' => 'The maximum grade for submission.',
                'optional' => true,
            ],
            'displayoptions' => [
                'type' => PARAM_INT,
                'default' => 0,
                'description' => 'H5P Button display options.',
            ],
            'enabletracking' => [
                'type' => PARAM_INT,
                'default' => 1,
                'description' => 'Enable xAPI tracking.',
            ],
            'grademethod' => [
                'type' => PARAM_INT,
                'default' => 1,
                'description' => 'Which H5P attempt is used for grading.',
            ],
            'contenthash' => [
                'type' => PARAM_ALPHANUM,
                'description' => 'Sha1 hash of file content.',
                'optional' => true,
            ],
        ];
    }

    /**
     * Related objects definition.
     *
     * @return array
     */
    protected static function define_related() {
        return [
            'context' => 'context',
            'factory' => 'core_h5p\\factory'
        ];
    }

    /**
     * Other properties definition.
     *
     * @return array
     */
    protected static function define_other_properties() {
        return [
            'coursemodule' => [
                'type' => PARAM_INT
            ],
            'context' => [
                'type' => PARAM_INT
            ],
            'introfiles' => [
                'type' => external_files::get_properties_for_exporter(),
                'multiple' => true
            ],
            'package' => [
                'type' => external_files::get_properties_for_exporter(),
                'multiple' => true
            ],
            'deployedfile' => [
                'optional' => true,
                'description' => 'H5P file deployed.',
                'type' => [
                    'filename' => array(
                        'type' => PARAM_FILE,
                        'description' => 'File name.',
                        'optional' => true,
                        'null' => NULL_NOT_ALLOWED,
                    ),
                    'filepath' => array(
                        'type' => PARAM_PATH,
                        'description' => 'File path.',
                        'optional' => true,
                        'null' => NULL_NOT_ALLOWED,
                    ),
                    'filesize' => array(
                        'type' => PARAM_INT,
                        'description' => 'File size.',
                        'optional' => true,
                        'null' => NULL_NOT_ALLOWED,
                    ),
                    'fileurl' => array(
                        'type' => PARAM_URL,
                        'description' => 'Downloadable file url.',
                        'optional' => true,
                        'null' => NULL_NOT_ALLOWED,
                    ),
                    'timemodified' => array(
                        'type' => PARAM_INT,
                        'description' => 'Time modified.',
                        'optional' => true,
                        'null' => NULL_NOT_ALLOWED,
                    ),
                    'mimetype' => array(
                        'type' => PARAM_RAW,
                        'description' => 'File mime type.',
                        'optional' => true,
                        'null' => NULL_NOT_ALLOWED,
                    )
                ]
            ],
        ];
    }

    /**
     * Assign values to the defined other properties.
     *
     * @param renderer_base $output The output renderer object.
     * @return array
     */
    protected function get_other_values(renderer_base $output) {
        $context = $this->related['context'];
        $factory = $this->related['factory'];

        $values = [
            'coursemodule' => $context->instanceid,
            'context' => $context->id,
        ];

        $values['introfiles'] = external_util::get_area_files($context->id, 'mod_h5pactivity', 'intro', false, false);

        $values['package'] = external_util::get_area_files($context->id, 'mod_h5pactivity', 'package', false, true);

        // Only if this H5P activity has been deployed, return the exported file.
        $fileh5p = api::get_export_info_from_context_id($context->id, $factory, 'mod_h5pactivity', 'package');
        if ($fileh5p) {
            $values['deployedfile'] = $fileh5p;
        }

        return $values;
    }

    /**
     * Get the formatting parameters for the intro.
     *
     * @return array with the formatting parameters
     */
    protected function get_format_parameters_for_intro() {
        return [
            'component' => 'mod_h5pactivity',
            'filearea' => 'intro',
            'options' => ['noclean' => true],
        ];
    }

    /**
     * Get the formatting parameters for the package.
     *
     * @return array with the formatting parameters
     */
    protected function get_format_parameters_for_package() {
        return [
            'component' => 'mod_h5pactivity',
            'filearea' => 'package',
            'itemid' => 0,
            'options' => ['noclean' => true],
        ];
    }
}