2 // This file is part of Moodle - http://moodle.org/
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 // GNU General Public License for more details.
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>.
21 * @copyright 2019 Bas Brands <bas@moodle.com>
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
24 defined('MOODLE_INTERNAL') ||
die();
26 use core_h5p\local\library\autoloader
;
29 * Serve the files from the core_h5p file areas.
34 * @param stdClass $course the course object
35 * @param stdClass $cm the course module object
36 * @param stdClass $context the newmodule's context
37 * @param string $filearea the name of the file area
38 * @param array $args extra arguments (itemid, path)
39 * @param bool $forcedownload whether or not force download
40 * @param array $options additional options affecting the file serving
42 * @return bool Returns false if we don't find a file.
44 function core_h5p_pluginfile($course, $cm, $context, string $filearea, array $args, bool $forcedownload,
45 array $options = []) : bool {
48 // Require classes from H5P third party library
49 autoloader
::register();
51 $filesettingsset = false;
55 return false; // Invalid file area.
57 case \core_h5p\file_storage
::LIBRARY_FILEAREA
:
58 if ($context->contextlevel
!= CONTEXT_SYSTEM
) {
59 return false; // Invalid context because the libraries are loaded always in the context system.
64 // The files that can be delivered to this function are unfortunately out of our control. Some of the
65 // references are embedded into the JavaScript of the files and we have no ability to inject an item id.
66 // We also don't know the location of the item id when we do include it, so we look for the first numeric
67 // value and try to serve that file.
68 foreach ($args as $key => $value) {
69 if (is_numeric($value)) {
76 if (!isset($itemid)) {
77 // We didn't find an item id to use, so we fall back to retrieving the record using all the other
78 // fields. The combination of component, filearea, filepath, and filename is enough for a unique
80 $filename = array_pop($args);
81 $filepath = '/' . implode('/', $args) . '/';
82 $itemid = $DB->get_field('files', 'itemid', [
83 'component' => \core_h5p\file_storage
::COMPONENT
,
84 'filearea' => \core_h5p\file_storage
::LIBRARY_FILEAREA
,
85 'filepath' => $filepath,
86 'filename' => $filename
88 $filesettingsset = true;
91 case \core_h5p\file_storage
::CONTENT_FILEAREA
:
92 if ($context->contextlevel
!= CONTEXT_SYSTEM
) {
93 return false; // Invalid context because the content files are loaded always in the context system.
95 $itemid = array_shift($args);
97 case \core_h5p\file_storage
::EDITOR_FILEAREA
:
98 case \core_h5p\file_storage
::CACHED_ASSETS_FILEAREA
:
99 case \core_h5p\file_storage
::EXPORT_FILEAREA
:
104 if (!$filesettingsset) {
105 $filename = array_pop($args);
106 $filepath = (!$args ?
'/' : '/' . implode('/', $args) . '/');
109 $fs = get_file_storage();
110 $file = $fs->get_file($context->id
, \core_h5p\file_storage
::COMPONENT
, $filearea, $itemid, $filepath, $filename);
112 return false; // No such file.
115 send_stored_file($file, null, 0, $forcedownload, $options);