Skip to content

Commit

Permalink
MDL-69549 mod_folder: Content export implementation
Browse files Browse the repository at this point in the history
  • Loading branch information
andrewnicols committed Oct 15, 2020
1 parent deb400c commit 1e6f816
Showing 1 changed file with 61 additions and 0 deletions.
61 changes: 61 additions & 0 deletions mod/folder/classes/content/exporter.php
@@ -0,0 +1,61 @@
<?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/>.

/**
* Content export definition.
*
* @package mod_folder
* @copyright 2020 Andrew Nicols <andrew@nicols.co.uk>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
namespace mod_folder\content;

use core\content\export\exportable_items\exportable_filearea;
use core\content\export\exporters\abstract_mod_exporter;

/**
* A class which assists a component to export content.
*
* @copyright 2020 Andrew Nicols <andrew@nicols.co.uk>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class exporter extends abstract_mod_exporter {

/**
* Get the exportable items for mod_folder.
*
* @param bool $includeuserdata Whether to include user data, in addition to shared content.
* @return \core\content\export\exportable_item[]
*/
public function get_exportables(bool $includeuserdata = false): array {
$contentitems = [];

$contentitems[] = new exportable_filearea(
$this->get_context(),
$this->get_component(),
get_string('foldercontent', 'mod_folder'),

// The files held in mod_folder are stored in the 'content' filearea, under itemid 0.
'content',
0,

// The itemid is used in the URL when accessing.
0
);

return $contentitems;
}
}

0 comments on commit 1e6f816

Please sign in to comment.