. /** * Entity factory. * * @package mod_forum * @copyright 2019 Ryan Wyllie * @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\author as author_entity; use mod_forum\local\entities\discussion as discussion_entity; use mod_forum\local\entities\discussion_summary as discussion_summary_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\entities\sorter as sorter_entity; use stdClass; use context; use cm_info; use user_picture; use moodle_url; /** * Entity factory to create the forum entities. * * See: * https://designpatternsphp.readthedocs.io/en/latest/Creational/SimpleFactory/README.html * * @copyright 2019 Ryan Wyllie * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class entity { /** * Create a forum entity from a stdClass (legacy forum object). * * @param stdClass $record The forum record * @param context $context The forum module context * @param stdClass $coursemodule Course module record for the forum * @param stdClass $course Course the forum belongs to * @return forum_entity */ public function get_forum_from_stdclass( stdClass $record, context $context, stdClass $coursemodule, stdClass $course ) : forum_entity { // Note: cm_info::create loads a cm_info in the context of the current user which // creates hidden dependency on the logged in user (very bad) however it's the best // option to load some data we need which doesn't require the logged in user. // Only use properties which do not require the logged in user. $cm = \cm_info::create($coursemodule); return new forum_entity( $context, $coursemodule, $course, // This property is a general module property that isn't affected by the logged in user. $cm->effectivegroupmode, $record->id, $record->course, $record->type, $record->name, $record->intro, $record->introformat, $record->assessed, $record->assesstimestart, $record->assesstimefinish, $record->scale, $record->maxbytes, $record->maxattachments, $record->forcesubscribe, $record->trackingtype, $record->rsstype, $record->rssarticles, $record->timemodified, $record->warnafter, $record->blockafter, $record->blockperiod, $record->completiondiscussions, $record->completionreplies, $record->completionposts, $record->displaywordcount, $record->lockdiscussionafter, $record->duedate, $record->cutoffdate ); } /** * Create a discussion entity from an stdClass (legacy dicussion object). * * @param stdClass $record Discussion record * @return discussion_entity */ public function get_discussion_from_stdclass(stdClass $record) : discussion_entity { return new discussion_entity( $record->id, $record->course, $record->forum, $record->name, $record->firstpost, $record->userid, $record->groupid, $record->assessed, $record->timemodified, $record->usermodified, $record->timestart, $record->timeend, $record->pinned, $record->timelocked ); } /** * Create a post entity from an stdClass (legacy post object). * * @param stdClass $record The post record * @return post_entity */ public function get_post_from_stdclass(stdClass $record) : post_entity { return new post_entity( $record->id, $record->discussion, $record->parent, $record->userid, $record->created, $record->modified, $record->mailed, $record->subject, $record->message, $record->messageformat, $record->messagetrust, $record->attachment, $record->totalscore, $record->mailnow, $record->deleted, $record->privatereplyto ); } /** * Create an author entity from a user record. * * @param stdClass $record The user record * @return author_entity */ public function get_author_from_stdclass(stdClass $record) : author_entity { return new author_entity( $record->id, $record->picture, $record->firstname, $record->lastname, fullname($record), $record->email, $record->middlename, $record->firstnamephonetic, $record->lastnamephonetic, $record->alternatename, $record->imagealt ); } /** * Create a discussion summary enttiy from stdClasses. * * @param stdClass $discussion The discussion record * @param stdClass $firstpost A post record for the first post in the discussion * @param stdClass $firstpostauthor A user record for the author of the first post * @param stdClass $latestpostauthor A user record for the author of the latest post in the discussion * @return discussion_summary_entity */ public function get_discussion_summary_from_stdclass( stdClass $discussion, stdClass $firstpost, stdClass $firstpostauthor, stdClass $latestpostauthor ) : discussion_summary_entity { $firstpostauthorentity = $this->get_author_from_stdclass($firstpostauthor); return new discussion_summary_entity( $this->get_discussion_from_stdclass($discussion), $this->get_post_from_stdclass($firstpost, $firstpostauthorentity), $firstpostauthorentity, $this->get_author_from_stdclass($latestpostauthor) ); } /** * Create a post read receipt collection entity from a list of read receipt records. * * @param array $records A list of read receipt records. * @return post_read_receipt_collection_entity */ public function get_post_read_receipt_collection_from_stdclasses(array $records) : post_read_receipt_collection_entity { return new post_read_receipt_collection_entity($records); } /** * Create a sorter entity to sort post entities. * * @return sorter_entity */ public function get_posts_sorter() : sorter_entity { return new sorter_entity( // Get id function for a post_entity. function(post_entity $post) { return $post->get_id(); }, // Get parent id function for a post_entity. function(post_entity $post) { return $post->get_parent_id(); } ); } /** * Create a sorter entity to sort exported posts. * * @return sorter_entity */ public function get_exported_posts_sorter() : sorter_entity { return new sorter_entity( // Get id function for an exported post. function(stdClass $post) { return $post->id; }, // Get parent id function for an exported post. function(stdClass $post) { return $post->parentid; } ); } }