You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
273 lines
11 KiB
273 lines
11 KiB
2 years ago
|
<?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/>.
|
||
|
|
||
|
/**
|
||
|
* Forum Exporter factory.
|
||
|
*
|
||
|
* @package mod_forum
|
||
|
* @copyright 2019 Ryan Wyllie <ryan@moodle.com>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
|
||
|
namespace mod_forum\local\factories;
|
||
|
|
||
|
defined('MOODLE_INTERNAL') || die();
|
||
|
|
||
|
use mod_forum\local\entities\discussion as discussion_entity;
|
||
|
use mod_forum\local\entities\forum as forum_entity;
|
||
|
use mod_forum\local\entities\post as post_entity;
|
||
|
use mod_forum\local\entities\post_read_receipt_collection as post_read_receipt_collection_entity;
|
||
|
use mod_forum\local\factories\legacy_data_mapper as legacy_data_mapper_factory;
|
||
|
use mod_forum\local\factories\manager as manager_factory;
|
||
|
use mod_forum\local\factories\url as url_factory;
|
||
|
use mod_forum\local\factories\vault as vault_factory;
|
||
|
use mod_forum\local\exporters\forum as forum_exporter;
|
||
|
use mod_forum\local\exporters\discussion as discussion_exporter;
|
||
|
use mod_forum\local\exporters\discussion_summaries as discussion_summaries_exporter;
|
||
|
use mod_forum\local\exporters\post as post_exporter;
|
||
|
use mod_forum\local\exporters\posts as posts_exporter;
|
||
|
use context;
|
||
|
use rating;
|
||
|
use stdClass;
|
||
|
|
||
|
/**
|
||
|
* The exporter factory class used to fetch an instance of the different exporter types.
|
||
|
*
|
||
|
* See:
|
||
|
* https://designpatternsphp.readthedocs.io/en/latest/Creational/SimpleFactory/README.html
|
||
|
*
|
||
|
* @copyright 2019 Ryan Wyllie <ryan@moodle.com>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
class exporter {
|
||
|
/** @var legacy_data_mapper_factory The factory to fetch a legacy data mapper */
|
||
|
private $legacydatamapperfactory;
|
||
|
|
||
|
/** @var manager_factory The factory to fetch a new manager */
|
||
|
private $managerfactory;
|
||
|
|
||
|
/** @var url_factory The factory to create urls */
|
||
|
private $urlfactory;
|
||
|
|
||
|
/** @var vault_factory The vault factory */
|
||
|
private $vaultfactory;
|
||
|
|
||
|
/**
|
||
|
* Constructor for the exporter factory.
|
||
|
*
|
||
|
* @param legacy_data_mapper_factory $legacydatamapperfactory The factory to fetch a legacy data mapper instance
|
||
|
* @param manager_factory $managerfactory The factory fo fetch a manager instance
|
||
|
* @param url_factory $urlfactory The factory to create urls
|
||
|
* @param vault_factory $vaultfactory The vault factory
|
||
|
*/
|
||
|
public function __construct(legacy_data_mapper_factory $legacydatamapperfactory, manager_factory $managerfactory,
|
||
|
url_factory $urlfactory, vault_factory $vaultfactory) {
|
||
|
$this->legacydatamapperfactory = $legacydatamapperfactory;
|
||
|
$this->managerfactory = $managerfactory;
|
||
|
$this->urlfactory = $urlfactory;
|
||
|
$this->vaultfactory = $vaultfactory;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Construct a new forum exporter for the specified user and forum.
|
||
|
*
|
||
|
* @param stdClass $user The user viewing the forum
|
||
|
* @param forum_entity $forum The forum being viewed
|
||
|
* @param int $currentgroup The group currently being viewed
|
||
|
* @return forum_exporter
|
||
|
*/
|
||
|
public function get_forum_exporter(
|
||
|
stdClass $user,
|
||
|
forum_entity $forum,
|
||
|
?int $currentgroup
|
||
|
) : forum_exporter {
|
||
|
return new forum_exporter($forum, [
|
||
|
'legacydatamapperfactory' => $this->legacydatamapperfactory,
|
||
|
'capabilitymanager' => $this->managerfactory->get_capability_manager($forum),
|
||
|
'urlfactory' => $this->urlfactory,
|
||
|
'user' => $user,
|
||
|
'currentgroup' => $currentgroup,
|
||
|
'vaultfactory' => $this->vaultfactory,
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fetch the structure of the forum exporter.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function get_forum_export_structure() : array {
|
||
|
return forum_exporter::read_properties_definition();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Construct a new discussion exporter for the specified user and forum discussion.
|
||
|
*
|
||
|
* @param stdClass $user The user viewing the forum
|
||
|
* @param forum_entity $forum The forum being viewed
|
||
|
* @param discussion_entity $discussion The discussion being viewed
|
||
|
* @param stdClass[] $groupsbyid The list of groups in the forum
|
||
|
* @return discussion_exporter
|
||
|
*/
|
||
|
public function get_discussion_exporter(
|
||
|
stdClass $user,
|
||
|
forum_entity $forum,
|
||
|
discussion_entity $discussion,
|
||
|
array $groupsbyid = [],
|
||
|
array $favouriteids = []
|
||
|
) : discussion_exporter {
|
||
|
return new discussion_exporter($discussion, [
|
||
|
'context' => $forum->get_context(),
|
||
|
'forum' => $forum,
|
||
|
'capabilitymanager' => $this->managerfactory->get_capability_manager($forum),
|
||
|
'urlfactory' => $this->urlfactory,
|
||
|
'user' => $user,
|
||
|
'legacydatamapperfactory' => $this->legacydatamapperfactory,
|
||
|
'latestpostid' => null,
|
||
|
'groupsbyid' => $groupsbyid,
|
||
|
'favouriteids' => $favouriteids
|
||
|
]);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fetch the structure of the discussion exporter.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function get_discussion_export_structure() {
|
||
|
return discussion_exporter::read_properties_definition();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Construct a new discussion summaries exporter for the specified user and set of discussions.
|
||
|
*
|
||
|
* @param stdClass $user The user viewing the forum
|
||
|
* @param forum_entity $forum The forum being viewed
|
||
|
* @param discussion_summary_entity[] $discussions The set of discussion summaries to export
|
||
|
* @param stdClass[] $groupsbyauthorid The set of groups in an associative array for each author
|
||
|
* @param stdClass[] $groupsbyid The set of groups in the forum in an associative array for each group
|
||
|
* @param int[] $discussionreplycount The number of replies for each discussion
|
||
|
* @param int[] $discussionunreadcount The number of unread posts for each discussion
|
||
|
* @param int[] $latestpostids The latest post id for each discussion
|
||
|
* @param int[] $postauthorcontextids The context ids for the first and last post authors (indexed by author id)
|
||
|
* @param int[] $favourites The list of discussion ids that have been favourited
|
||
|
* @return discussion_summaries_exporter
|
||
|
*/
|
||
|
public function get_discussion_summaries_exporter(
|
||
|
stdClass $user,
|
||
|
forum_entity $forum,
|
||
|
array $discussions,
|
||
|
array $groupsbyid = [],
|
||
|
array $groupsbyauthorid = [],
|
||
|
array $discussionreplycount = [],
|
||
|
array $discussionunreadcount = [],
|
||
|
array $latestpostids = [],
|
||
|
array $postauthorcontextids = [],
|
||
|
array $favourites = [],
|
||
|
array $latestauthors = []
|
||
|
) : discussion_summaries_exporter {
|
||
|
return new discussion_summaries_exporter(
|
||
|
$discussions,
|
||
|
$groupsbyid,
|
||
|
$groupsbyauthorid,
|
||
|
$discussionreplycount,
|
||
|
$discussionunreadcount,
|
||
|
$latestpostids,
|
||
|
$postauthorcontextids,
|
||
|
[
|
||
|
'legacydatamapperfactory' => $this->legacydatamapperfactory,
|
||
|
'context' => $forum->get_context(),
|
||
|
'forum' => $forum,
|
||
|
'capabilitymanager' => $this->managerfactory->get_capability_manager($forum),
|
||
|
'urlfactory' => $this->urlfactory,
|
||
|
'user' => $user,
|
||
|
'favouriteids' => $favourites,
|
||
|
'latestauthors' => $latestauthors
|
||
|
]
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fetch the structure of the discussion summaries exporter.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function get_discussion_summaries_export_structure() {
|
||
|
return discussion_summaries_exporter::read_properties_definition();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Construct a new post exporter for the specified user and set of post.
|
||
|
*
|
||
|
* @param stdClass $user The user viewing the forum
|
||
|
* @param forum_entity $forum The forum being viewed
|
||
|
* @param discussion_entity $discussion The discussion that the post is in
|
||
|
* @param post_entity[] $posts The set of posts to be exported
|
||
|
* @param author_entity[] $authorsbyid List of authors indexed by author id
|
||
|
* @param int[] $authorcontextids List of authors context ids indexed by author id
|
||
|
* @param array $attachmentsbypostid List of attachments for each post indexed by post id
|
||
|
* @param array $groupsbyauthorid List of groups for the post authors indexed by author id
|
||
|
* @param post_read_receipt_collection_entity|null $readreceiptcollection Details of read receipts for each post
|
||
|
* @param array $tagsbypostid List of tags for each post indexed by post id
|
||
|
* @param rating[] $ratingbypostid List of ratings for each post indexed by post id
|
||
|
* @param bool $includehtml Include some pre-constructed HTML in the export
|
||
|
* @return post_exporter
|
||
|
*/
|
||
|
public function get_posts_exporter(
|
||
|
stdClass $user,
|
||
|
forum_entity $forum,
|
||
|
discussion_entity $discussion,
|
||
|
array $posts,
|
||
|
array $authorsbyid = [],
|
||
|
array $authorcontextids = [],
|
||
|
array $attachmentsbypostid = [],
|
||
|
array $groupsbyauthorid = [],
|
||
|
post_read_receipt_collection_entity $readreceiptcollection = null,
|
||
|
array $tagsbypostid = [],
|
||
|
array $ratingbypostid = [],
|
||
|
bool $includehtml = false
|
||
|
) : posts_exporter {
|
||
|
return new posts_exporter(
|
||
|
$posts,
|
||
|
$authorsbyid,
|
||
|
$authorcontextids,
|
||
|
$attachmentsbypostid,
|
||
|
$groupsbyauthorid,
|
||
|
$tagsbypostid,
|
||
|
$ratingbypostid,
|
||
|
[
|
||
|
'capabilitymanager' => $this->managerfactory->get_capability_manager($forum),
|
||
|
'urlfactory' => $this->urlfactory,
|
||
|
'forum' => $forum,
|
||
|
'discussion' => $discussion,
|
||
|
'user' => $user,
|
||
|
'context' => $forum->get_context(),
|
||
|
'readreceiptcollection' => $readreceiptcollection,
|
||
|
'includehtml' => $includehtml
|
||
|
]
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fetch the structure of the posts exporter.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function get_posts_export_structure() {
|
||
|
return posts_exporter::read_properties_definition();
|
||
|
}
|
||
|
}
|