File Converters
File converters are an important tool to support other plugins with file conversion supported between a wide range of file formats. File converters are accessed using the File conversion API and are typically consumed by other plugins rather than by the user directly.
File structure
File converter plugins are located in the /file/converter
directory.
Each plugin is in a separate subdirectory and consists of a number of mandatory files and any other files the developer is going to use.
View an example directory layout for the `fileconverter_unoconv` plugin.
files/converter/unoconv
├── classes
│ ├── converter.php
│ └── privacy
│ └── provider.php
├── lang
│ └── en
│ └── fileconverter_unoconv.php
├── settings.php
└── version.php
Some of the important files for the fileconverter plugintype are described below. See the common plugin files documentation for details of other files which may be useful in your plugin.
Converter class
File conversion implementation
File path: /classes/converter.php
The classes/converter.php
class must be defined in the correct namespace for your plugin, and must implement the \core_files\converter_interface
interface.
It is responsible for converting files
View example
<?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/>.
/**
* File conversion implementation for the plugintype_example plugin.
*
* @package plugintype_example
* @copyright Year, You Name <your@email.address>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace fileconverter_myexample;
class converter implements core_filesconverter_interface {
// ...
}
are_requirements_met()
This function informs the File Converter API whether the system requirements of the plugin are met. That is whether appropriate API keys are present, and the API might be available.
It should be lightweight to call and cache where required.
public static function are_requirements_met() {
return extension_loaded('my_php_extension');
}
start_document_conversion() and poll_conversion_status()
The start_document_conversion()
function starts a conversion, whilst poll_conversion_status
should poll for any status update. The following apply:
- If any failures occur, it should set the conversion status to
\core_files\conversion::STATUS_FAILED
and immediately return. There is no need to update the$conversion
record in this situation. - When the conversion process starts, the status should be set to
\core_files\conversion::STATUS_IN_PROGRESS
and the record must be updated. This ensures that, should the process take a long time, the current status is accurately reflected. - Upon successful completion, the status should be updated to
\core_files\conversion::STATUS_COMPLETE
and the newly created\stored_file
should be stored against the conversion using either thestore_destfile_from_string
orstore_destfile_from_path
function as appropriate.
supports()
This function allows the plugin to answer whether it supports conversion between two formats. It is typically only used internally by the File Conversion subsystem.
class converter implements \core_files\converter_interface {
// ...
public static function supports($from, $to) {
// This plugin supports conversion from doc and docx to pdf only.
if ($from !== 'doc' && $from !== 'docx') {
return false;
}
return $to === 'pdf';
}
}
if (\fileconverter_example::supports('jpg', 'pdf')) {
// ...
}
get_supported_conversion()
This function is used purely for information purposes to display possible conversions to an administrator.
See also
- Using the File Converter API