Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.0.x will end 8 May 2023 (12 months).
  • Bug fixes for security issues in 4.0.x will end 13 November 2023 (18 months).
  • PHP version: minimum PHP 7.3.0 Note: the minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is also supported.

Differences Between: [Versions 310 and 400] [Versions 39 and 400] [Versions 400 and 401] [Versions 400 and 402] [Versions 400 and 403]

\core_h5p\framework class

Copyright: 2019 Mihail Geshoski <mihail@moodle.com>
License: http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
File Size: 1682 lines (69 kb)
Included or required:0 times
Referenced: 0 times
Includes or requires: 0 files

Defines 1 class


Class: framework  - X-Ref

Moodle's implementation of the H5P framework interface.

getPlatformInfo()   X-Ref
Returns info for the current platform.
Implements getPlatformInfo.

return: array An associative array containing:

fetchExternalData($url, $data = null, $blocking = true, $stream = null)   X-Ref
Fetches a file from a remote server using HTTP GET.
Implements fetchExternalData.

return: string The content (response body). NULL if something went wrong
param: string $url Where you want to get or send data
param: array $data Data to post to the URL
param: bool $blocking Set to 'FALSE' to instantly time out (fire and forget)
param: string $stream Path to where the file should be saved

setLibraryTutorialUrl($libraryname, $url)   X-Ref
Set the tutorial URL for a library. All versions of the library is set.
Implements setLibraryTutorialUrl.

param: string $libraryname
param: string $url

setErrorMessage($message, $code = null)   X-Ref
Set an error message.
Implements setErrorMessage.

param: string $message The error message
param: string $code An optional code

setInfoMessage($message)   X-Ref
Set an info message.
Implements setInfoMessage.

param: string $message The info message

getMessages($type)   X-Ref
Return messages.
Implements getMessages.

return: string[] Array of messages
param: string $type The message type, e.g. 'info' or 'error'

t($message, $replacements = array()   X-Ref
Translation function.
The purpose of this function is to map the strings used in the core h5p methods
and replace them with the translated ones. If a translation for a particular string
is not available, the default message (key) will be returned.
Implements t.

return: string Translated string or the english string if a translation is not available
param: string $message The english string to be translated
param: array $replacements An associative array of replacements to make after translation

getLibraryFileUrl($libraryfoldername, $filename)   X-Ref
Get URL to file in the specifimake_pluginfile_urlc library.
Implements getLibraryFileUrl.

return: string URL to file
param: string $libraryfoldername The name or path of the library's folder
param: string $filename The file name

getUploadedH5pFolderPath($setpath = null)   X-Ref
Get the Path to the last uploaded h5p.
Implements getUploadedH5PFolderPath.

return: string Path to the folder where the last uploaded h5p for this session is located
param: string $setpath The path to the folder of the last uploaded h5p

getUploadedH5pPath($setpath = null)   X-Ref
Get the path to the last uploaded h5p file.
Implements getUploadedH5PPath.

return: string Path to the last uploaded h5p
param: string $setpath The path to the last uploaded h5p

loadAddons()   X-Ref
Load addon libraries.
Implements loadAddons.

return: array The array containing the addon libraries

getLibraryConfig($libraries = null)   X-Ref
Load config for libraries.
Implements getLibraryConfig.

return: array|null The library config if it exists, null otherwise
param: array|null $libraries List of libraries

loadLibraries()   X-Ref
Get a list of the current installed libraries.
Implements loadLibraries.

return: array Associative array containing one entry per machine name.

getAdminUrl()   X-Ref
Returns the URL to the library admin page.
Implements getAdminUrl.

return: string URL to admin page

getLibraryId($machinename, $majorversion = null, $minorversion = null)   X-Ref
Return the library's ID.
Implements getLibraryId.

return: int|bool Identifier, or false if non-existent
param: string $machinename The librarys machine name
param: string $majorversion Major version number for library (optional)
param: string $minorversion Minor version number for library (optional)

getWhitelist($islibrary, $defaultcontentwhitelist, $defaultlibrarywhitelist)   X-Ref
Get allowed file extension list.
Implements getWhitelist.

The default extension list is part of h5p, but admins should be allowed to modify it.

return: string A string containing the allowed file extensions separated by whitespace.
param: boolean $islibrary TRUE if this is the whitelist for a library. FALSE if it is the whitelist
param: string $defaultcontentwhitelist A string of file extensions separated by whitespace.
param: string $defaultlibrarywhitelist A string of file extensions separated by whitespace.

isPatchedLibrary($library)   X-Ref
Is the library a patched version of an existing library?
Implements isPatchedLibrary.

return: boolean TRUE if the library is a patched version of an existing library FALSE otherwise
param: array $library An associative array containing:

isInDevMode()   X-Ref
Is H5P in development mode?
Implements isInDevMode.

return: boolean TRUE if H5P development mode is active FALSE otherwise

mayUpdateLibraries()   X-Ref
Is the current user allowed to update libraries?
Implements mayUpdateLibraries.

return: boolean TRUE if the user is allowed to update libraries,

get_file()   X-Ref
Get the .h5p file.

return: stored_file The .h5p file.

set_file(\stored_file $file)   X-Ref
Set the .h5p file.

param: stored_file $file The .h5p file.

saveLibraryData(&$librarydata, $new = true)   X-Ref
Store data about a library.
Implements saveLibraryData.

Also fills in the libraryId in the libraryData object if the object is new.

param: array $librarydata Associative array containing:
param: bool $new Whether it is a new or existing library.

insertContent($content, $contentmainid = null)   X-Ref
Insert new content.
Implements insertContent.

return: int The ID of the newly inserted content
param: array $content An associative array containing:
param: int $contentmainid Main id for the content if this is a system that supports versions

updateContent($content, $contentmainid = null)   X-Ref
Update old content or insert new content.
Implements updateContent.

return: int The ID of the newly inserted or updated content
param: array $content An associative array containing:
param: int $contentmainid Main id for the content if this is a system that supports versions

resetContentUserData($contentid)   X-Ref
Resets marked user data for the given content.
Implements resetContentUserData.

param: int $contentid The h5p content id

saveLibraryDependencies($libraryid, $dependencies, $dependencytype)   X-Ref
Save what libraries a library is depending on.
Implements saveLibraryDependencies.

param: int $libraryid Library Id for the library we're saving dependencies for
param: array $dependencies List of dependencies as associative arrays containing:
param: string $dependencytype The type of dependency

copyLibraryUsage($contentid, $copyfromid, $contentmainid = null)   X-Ref
Give an H5P the same library dependencies as a given H5P.
Implements copyLibraryUsage.

param: int $contentid Id identifying the content
param: int $copyfromid Id identifying the content to be copied
param: int $contentmainid Main id for the content, typically used in frameworks

deleteContentData($contentid)   X-Ref
Deletes content data.
Implements deleteContentData.

param: int $contentid Id identifying the content

deleteLibraryUsage($contentid)   X-Ref
Delete what libraries a content item is using.
Implements deleteLibraryUsage.

param: int $contentid Content Id of the content we'll be deleting library usage for

saveLibraryUsage($contentid, $librariesinuse)   X-Ref
Saves what libraries the content uses.
Implements saveLibraryUsage.

param: int $contentid Id identifying the content
param: array $librariesinuse List of libraries the content uses

getLibraryUsage($id, $skipcontent = false)   X-Ref
Get number of content/nodes using a library, and the number of dependencies to other libraries.
Implements getLibraryUsage.

return: array The array contains two elements, keyed by 'content' and 'libraries'.
param: int $id Library identifier
param: boolean $skipcontent Optional. Set as true to get number of content instances for library

loadLibrary($machinename, $majorversion, $minorversion)   X-Ref
Loads a library.
Implements loadLibrary.

return: array|bool Returns FALSE if the library does not exist
param: string $machinename The library's machine name
param: int $majorversion The library's major version
param: int $minorversion The library's minor version

loadLibrarySemantics($name, $majorversion, $minorversion)   X-Ref
Loads library semantics.
Implements loadLibrarySemantics.

return: string The library's semantics as json
param: string $name Machine name for the library
param: int $majorversion The library's major version
param: int $minorversion The library's minor version

alterLibrarySemantics(&$semantics, $name, $majorversion, $minorversion)   X-Ref
Makes it possible to alter the semantics, adding custom fields, etc.
Implements alterLibrarySemantics.

param: array $semantics Associative array representing the semantics
param: string $name The library's machine name
param: int $majorversion The library's major version
param: int $minorversion The library's minor version

deleteLibraryDependencies($libraryid)   X-Ref
Delete all dependencies belonging to given library.
Implements deleteLibraryDependencies.

param: int $libraryid Library identifier

lockDependencyStorage()   X-Ref
Start an atomic operation against the dependency storage.
Implements lockDependencyStorage.


unlockDependencyStorage()   X-Ref
Start an atomic operation against the dependency storage.
Implements unlockDependencyStorage.


deleteLibrary($library)   X-Ref
Delete a library from database and file system.
Implements deleteLibrary.

param: stdClass $library Library object with id, name, major version and minor version

loadContent($id)   X-Ref
Load content.
Implements loadContent.

return: array Associative array containing:
param: int $id Content identifier

loadContentDependencies($id, $type = null)   X-Ref
Load dependencies for the given content of the given type.
Implements loadContentDependencies.

return: array List of associative arrays containing:
param: int $id Content identifier
param: int $type The dependency type

getOption($name, $default = false)   X-Ref
Get stored setting.
Implements getOption.

To avoid updating the cache libraries when using the Hub selector,
{@see \Moodle\H5PEditorAjax::isContentTypeCacheUpdated}, the setting content_type_cache_updated_at
always return the current time.

return: mixed Return  Whatever has been stored as the setting
param: string $name Identifier for the setting
param: string $default Optional default value if settings is not set

setOption($name, $value)   X-Ref
Stores the given setting.
For example when did we last check h5p.org for updates to our libraries.
Implements setOption.

param: string $name Identifier for the setting
param: mixed $value Data Whatever we want to store as the setting

updateContentFields($id, $fields)   X-Ref
This will update selected fields on the given content.
Implements updateContentFields().

param: int $id Content identifier
param: array $fields Content fields, e.g. filtered

clearFilteredParameters($libraryids)   X-Ref
Will clear filtered params for all the content that uses the specified.
libraries. This means that the content dependencies will have to be rebuilt and the parameters re-filtered.
Implements clearFilteredParameters().

param: array $libraryids Array of library ids

getNumNotFiltered()   X-Ref
Get number of contents that has to get their content dependencies rebuilt.
and parameters re-filtered.
Implements getNumNotFiltered().

return: int The number of contents that has to get their content dependencies rebuilt

getNumContent($libraryid, $skip = null)   X-Ref
Get number of contents using library as main library.
Implements getNumContent().

return: int The number of contents using library as main library
param: int $libraryid The library ID
param: array $skip The array of h5p content ID's that should be ignored

isContentSlugAvailable($slug)   X-Ref
Determines if content slug is used.
Implements isContentSlugAvailable.

return: boolean Whether the content slug is used
param: string $slug The content slug

getLibraryStats($type)   X-Ref
Generates statistics from the event log per library.
Implements getLibraryStats.

return: array Number values indexed by library name and version
param: string $type Type of event to generate stats for

getNumAuthors()   X-Ref
Aggregate the current number of H5P authors.
Implements getNumAuthors.

return: int The current number of H5P authors

saveCachedAssets($key, $libraries)   X-Ref
Stores hash keys for cached assets, aggregated JavaScripts and
stylesheets, and connects it to libraries so that we know which cache file
to delete when a library is updated.
Implements saveCachedAssets.

param: string $key Hash key for the given libraries
param: array $libraries List of dependencies(libraries) used to create the key

deleteCachedAssets($libraryid)   X-Ref
Locate hash keys for given library and delete them.
Used when cache file are deleted.
Implements deleteCachedAssets.

return: array List of hash keys removed
param: int $libraryid Library identifier

getLibraryContentCount()   X-Ref
Get the amount of content items associated to a library.
Implements getLibraryContentCount.

return array The number of content items associated to a library

afterExportCreated($content, $filename)   X-Ref
Will trigger after the export file is created.
Implements afterExportCreated.

param: array $content The content
param: string $filename The file name

hasPermission($permission, $id = null)   X-Ref
Check whether a user has permissions to execute an action, such as embed H5P content.
Implements hasPermission.

return: boolean true if the user can execute the action defined in $permission; false otherwise
param: H5PPermission $permission Permission type
param: int $id Id need by platform to determine permission

replaceContentTypeCache($contenttypecache)   X-Ref
Replaces existing content type cache with the one passed in.
Implements replaceContentTypeCache.

param: object $contenttypecache Json with an array called 'libraries' containing the new content type cache

libraryHasUpgrade($library)   X-Ref
Checks if the given library has a higher version.
Implements libraryHasUpgrade.

return: boolean Whether the library has a higher version
param: array $library An associative array containing:

get_language()   X-Ref
Get current H5P language code.

return: string Language Code

set_message(string $type, string $newmessage = null, string $code = null)   X-Ref
Store messages until they can be printed to the current user.

param: string $type Type of messages, e.g. 'info', 'error', etc
param: string $newmessage The message
param: string $code The message code

library_parameter_values_to_csv(array $librarydata, string $key, string $searchparam = 'path')   X-Ref
Convert list of library parameter values to csv.

return: string Library parameter values separated by ', '
param: array $librarydata Library data as found in library.json files
param: string $key Key that should be found in $librarydata
param: string $searchparam The library parameter (Default: 'path')

get_latest_library_version(string $machinename)   X-Ref
Get the latest library version.

return: stdClass|null An object with the latest library version
param: string $machinename The library's machine name