| Moodle PHP Documentation 4.4
    Moodle 4.4.9+ (Build: 20250711) (4ea86454947) | 
The mod_forum discussion viewed event class. More...
 
  
| Public Member Functions | |
| __get ($name) | |
| Magic getter for read only access. | |
| __isset ($name) | |
| Is data property set? | |
| __set ($name, $value) | |
| Magic setter. | |
| add_record_snapshot ($tablename, $record) | |
| Add cached data that will be most probably used in event observers. | |
| can_view ($user_or_id=null) | |
| This method was originally intended for granular access control on the event level, unfortunately the proper implementation would be too expensive in many cases. | |
| get_context () | |
| Returns event context. | |
| get_data () | |
| Return standardised event data as array. | |
| get_description () | |
| Returns description of what happened. | |
| get_logextra () | |
| Return auxiliary data that was stored in logs. | |
| get_record_snapshot ($tablename, $id) | |
| Returns cached record or fetches data from database if not cached. | |
| get_url () | |
| Get URL related to the action. | |
| getIterator () | |
| Create an iterator because magic vars can't be seen by 'foreach'. | |
| is_dispatched () | |
| Used from event manager to prevent direct access. | |
| is_restored () | |
| Was this event restored? | |
| is_triggered () | |
| Was this event already triggered? | |
| trigger () | |
| Trigger event. | |
| Static Public Member Functions | |
| static | create (array $data=null) | 
| Create new event. | |
| static | get_explanation () | 
| Get an explanation of what the class does. | |
| static | get_name () | 
| Return localised event name. | |
| static | get_name_with_info () | 
| Returns the event name complete with metadata information. | |
| static | get_objectid_mapping () | 
| This is used when restoring course logs where it is required that we map the objectid to it's new value in the new course. | |
| static | get_other_mapping () | 
| This is used when restoring course logs where it is required that we map the information in 'other' to it's new value in the new course. | |
| static | get_static_info () | 
| Get static information about an event. | |
| static | is_deprecated () | 
| Whether this event has been marked as deprecated. | |
| static | restore (array $data, array $logextra) | 
| Restore event from existing historic data. | |
| static | restore_legacy ($legacy) | 
| Create fake event from legacy log data. | |
| Public Attributes | |
| const | LEVEL_OTHER = 0 | 
| Other level. | |
| const | LEVEL_PARTICIPATING = 2 | 
| Participating level. | |
| const | LEVEL_TEACHING = 1 | 
| Teaching level. | |
| const | NOT_FOUND = -31338 | 
| The value used when an id can not be found during a restore. | |
| const | NOT_MAPPED = -31337 | 
| The value used when an id can not be mapped during a restore. | |
| const | USER_NOTLOGGEDIN = 0 | 
| User id to use when the user is not logged in. | |
| const | USER_OTHER = -1 | 
| User id to use when actor is not an actual user but system, cli or cron. | |
| Protected Member Functions | |
| init () | |
| Init method. | |
| validate_before_trigger () | |
| Validate all properties right before triggering the event. | |
| validate_data () | |
| Custom validation. | |
| Static Protected Member Functions | |
| static | restore_unknown (array $data, array $logextra) | 
| Restore unknown event. | |
| Protected Attributes | |
| context | $context | 
| of this event | |
| array | $data | 
| event data | |
| array | $logextra | 
| the format is standardised by logging API | |
The mod_forum discussion viewed event class.
| 
 | inherited | 
Magic getter for read only access.
| string | $name | 
| mixed | 
| 
 | inherited | 
Is data property set?
| string | $name | 
| bool | 
| 
 | inherited | 
Magic setter.
Note: we must not allow modification of data from outside, after trigger() the data MUST NOT CHANGE!!!
| string | $name | |
| mixed | $value | 
| coding_exception | 
| 
 | finalinherited | 
Add cached data that will be most probably used in event observers.
This is used to improve performance, but it is required for data that was just deleted.
| string | $tablename | |
| stdClass | $record | 
| coding_exception | if used after ::trigger() | 
| 
 | inherited | 
This method was originally intended for granular access control on the event level, unfortunately the proper implementation would be too expensive in many cases.
| int | stdClass | $user_or_id | ID of the user. | 
| bool | True if the user can view the event, false otherwise. | 
Reimplemented in mod_feedback\event\response_deleted, and mod_feedback\event\response_submitted.
| 
 | staticfinalinherited | 
Create new event.
The optional data keys as: 1/ objectid - the id of the object specified in class name 2/ context - the context of this event 3/ other - the other data describing the event, can not contain objects 4/ relateduserid - the id of user which is somehow related to this event
| array | $data | 
| core\event\base | returns instance of new event | 
| coding_exception | 
| 
 | inherited | 
Returns event context.
| context | 
| 
 | inherited | 
Return standardised event data as array.
| array | All elements are scalars except the 'other' field which is array. | 
| mod_forum\event\discussion_viewed::get_description | ( | ) | 
| 
 | staticinherited | 
Get an explanation of what the class does.
By default returns the phpdocs from the child event class. Ideally this should be overridden to return a translatable get_string style markdown. e.g. return new lang_string('eventyourspecialevent', 'plugin_type');
| string | An explanation of the event formatted in markdown style. | 
| 
 | inherited | 
Return auxiliary data that was stored in logs.
List of standard properties:
| array | the format is standardised by logging API | 
| 
 | static | 
| 
 | staticinherited | 
Returns the event name complete with metadata information.
This includes information about whether the event has been deprecated so should not be used in all situations - for example within reports themselves.
If overriding this function, please ensure that you call the parent version too.
| string | 
| 
 | static | 
This is used when restoring course logs where it is required that we map the objectid to it's new value in the new course.
Does nothing in the base class except display a debugging message warning the user that the event does not contain the required functionality to map this information. For events that do not store an objectid this won't be called, so no debugging message will be displayed.
Example of usage:
return array('db' => 'assign_submissions', 'restore' => 'submission');
If the objectid can not be mapped during restore set the value to core\event\base\NOT_MAPPED, example -
return array('db' => 'some_table', 'restore' => core\event\base\NOT_MAPPED);
Note - it isn't necessary to specify the 'db' and 'restore' values in this case, so you can also use -
return core\event\base\NOT_MAPPED;
The 'db' key refers to the database table and the 'restore' key refers to the name of the restore element the objectid is associated with. In many cases these will be the same.
| string | the name of the restore mapping the objectid links to | 
Reimplemented from core\event\base.
| 
 | staticinherited | 
This is used when restoring course logs where it is required that we map the information in 'other' to it's new value in the new course.
Does nothing in the base class except display a debugging message warning the user that the event does not contain the required functionality to map this information. For events that do not store any other information this won't be called, so no debugging message will be displayed.
Example of usage:
$othermapped = array(); $othermapped['discussionid'] = array('db' => 'forum_discussions', 'restore' => 'forum_discussion'); $othermapped['forumid'] = array('db' => 'forum', 'restore' => 'forum'); return $othermapped;
If an id can not be mapped during restore we set it to core\event\base\NOT_MAPPED, example -
$othermapped = array(); $othermapped['someid'] = array('db' => 'some_table', 'restore' => core\event\base\NOT_MAPPED); return $othermapped;
Note - it isn't necessary to specify the 'db' and 'restore' values in this case, so you can also use -
$othermapped = array(); $othermapped['someid'] = core\event\base\NOT_MAPPED; return $othermapped;
The 'db' key refers to the database table and the 'restore' key refers to the name of the restore element the other value is associated with. In many cases these will be the same.
| array | an array of other values and their corresponding mapping | 
Reimplemented in core\event\assessable_uploaded, core\event\badge_awarded, core\event\badge_criteria_created, core\event\badge_criteria_deleted, core\event\badge_criteria_updated, core\event\badge_revoked, core\event\blog_association_deleted, core\event\blog_entries_viewed, core\event\config_log_created, core\event\contentbank_content_created, core\event\contentbank_content_deleted, core\event\contentbank_content_updated, core\event\contentbank_content_uploaded, core\event\contentbank_content_viewed, core\event\course_backup_created, core\event\course_completed, core\event\course_module_deleted, core\event\course_updated, core\event\course_user_report_viewed, core\event\course_viewed, core\event\group_message_sent, core\event\grouping_group_assigned, core\event\grouping_group_unassigned, core\event\message_deleted, core\event\message_sent, core\event\message_viewed, core\event\notification_sent, core\event\question_base, core\event\question_moved, core\event\section_viewed, core\event\tag_created, core\event\tag_deleted, core\event\tag_flagged, core\event\tag_unflagged, core\event\tag_updated, core\event\url_blocked, core\event\user_deleted, core\event\user_enrolment_created, core\event\user_enrolment_updated, core\event\user_graded, core\event\user_list_viewed, core\event\user_loggedout, core\event\user_login_failed, core\event\user_password_updated, core\event\webservice_service_created, core\event\webservice_token_created, mod_assign\event\feedback_viewed, mod_assign\event\grading_form_viewed, mod_assign\event\group_override_created, mod_assign\event\group_override_deleted, mod_assign\event\group_override_updated, mod_assign\event\marker_updated, mod_assign\event\remove_submission_form_viewed, mod_assign\event\submission_form_viewed, mod_assign\event\submission_viewed, mod_assign\event\user_override_created, mod_assign\event\user_override_deleted, mod_assign\event\user_override_updated, mod_assign\event\workflow_state_updated, mod_chat\event\sessions_viewed, mod_choice\event\answer_created, mod_choice\event\answer_deleted, mod_choice\event\report_viewed, mod_data\event\field_created, mod_data\event\field_deleted, mod_data\event\field_updated, mod_feedback\event\response_deleted, mod_feedback\event\response_submitted, mod_forum\event\assessable_uploaded, mod_forum\event\discussion_lock_updated, mod_forum\event\discussion_moved, mod_forum\event\discussion_pinned, mod_forum\event\discussion_unpinned, mod_forum\event\readtracking_disabled, mod_forum\event\readtracking_enabled, mod_forum\event\subscription_created, mod_forum\event\subscription_deleted, mod_forum\event\user_report_viewed, mod_glossary\event\course_module_viewed, mod_glossary\event\entry_created, mod_glossary\event\entry_deleted, mod_glossary\event\entry_updated, mod_lesson\event\group_override_created, mod_lesson\event\group_override_deleted, mod_lesson\event\group_override_updated, mod_lesson\event\highscore_added, mod_lesson\event\highscores_viewed, mod_lesson\event\user_override_created, mod_lesson\event\user_override_deleted, mod_lesson\event\user_override_updated, mod_quiz\event\attempt_abandoned, mod_quiz\event\attempt_becameoverdue, mod_quiz\event\attempt_deleted, mod_quiz\event\attempt_manual_grading_completed, mod_quiz\event\attempt_preview_started, mod_quiz\event\attempt_reopened, mod_quiz\event\attempt_reviewed, mod_quiz\event\attempt_submitted, mod_quiz\event\attempt_summary_viewed, mod_quiz\event\group_override_created, mod_quiz\event\group_override_deleted, mod_quiz\event\group_override_updated, mod_quiz\event\page_break_created, mod_quiz\event\page_break_deleted, mod_quiz\event\quiz_grade_item_created, mod_quiz\event\quiz_grade_item_deleted, mod_quiz\event\quiz_grade_item_updated, mod_quiz\event\quiz_grade_updated, mod_quiz\event\report_viewed, mod_quiz\event\section_break_created, mod_quiz\event\section_title_updated, mod_quiz\event\slot_deleted, mod_quiz\event\slot_displaynumber_updated, mod_quiz\event\slot_moved, mod_quiz\event\slot_requireprevious_updated, mod_quiz\event\user_override_created, mod_quiz\event\user_override_deleted, mod_quiz\event\user_override_updated, mod_scorm\event\report_viewed, mod_scorm\event\tracks_viewed, mod_survey\event\course_module_viewed, mod_survey\event\report_viewed, mod_wiki\event\page_deleted, mod_wiki\event\page_diff_viewed, mod_wiki\event\page_locks_deleted, mod_wiki\event\page_updated, mod_wiki\event\page_version_restored, mod_wiki\event\page_version_viewed, mod_wiki\event\page_viewed, mod_workshop\event\assessment_evaluated, mod_workshop\event\assessment_reevaluated, mod_workshop\event\phase_automatically_switched, mod_workshop\event\submission_assessed, mod_workshop\event\submission_created, mod_workshop\event\submission_deleted, mod_workshop\event\submission_reassessed, mod_workshop\event\submission_updated, quizaccess_seb\event\access_prevented, quizaccess_seb\event\template_created, quizaccess_seb\event\template_deleted, quizaccess_seb\event\template_disabled, quizaccess_seb\event\template_enabled, quizaccess_seb\event\template_updated, report_log\event\report_viewed, report_log\event\user_report_viewed, report_outline\event\report_viewed, report_stats\event\report_viewed, and tool_langimport\event\langpack_updated.
| 
 | finalinherited | 
Returns cached record or fetches data from database if not cached.
| string | $tablename | |
| int | $id | 
| stdClass | 
| coding_exception | if used after ::restore() | 
| 
 | staticfinalinherited | 
Get static information about an event.
This is used in reports and is not for general use.
| array | Static information about the event. | 
| mod_forum\event\discussion_viewed::get_url | ( | ) | 
| 
 | inherited | 
Create an iterator because magic vars can't be seen by 'foreach'.
| ArrayIterator | 
| 
 | protected | 
| 
 | staticinherited | 
Whether this event has been marked as deprecated.
Events cannot be deprecated in the normal fashion as they must remain to support historical data. Once they are deprecated, there is no way to trigger the event, so it does not make sense to list it in some parts of the UI (e.g. Event Monitor).
| boolean | 
Reimplemented in core\event\course_module_instances_list_viewed, and core\event\role_capabilities_updated.
| 
 | finalinherited | 
Used from event manager to prevent direct access.
| bool | 
| 
 | finalinherited | 
Was this event restored?
| bool | 
| 
 | finalinherited | 
Was this event already triggered?
| bool | 
| 
 | staticfinalinherited | 
Restore event from existing historic data.
| array | $data | |
| array | $logextra | the format is standardised by logging API | 
| bool|core::event::base | 
| 
 | staticfinalinherited | 
Create fake event from legacy log data.
| stdClass | $legacy | 
| base | 
| 
 | staticfinalprotectedinherited | 
Restore unknown event.
| array | $data | |
| array | $logextra | 
| unknown_logged | 
| 
 | protectedinherited | 
Validate all properties right before triggering the event.
This throws coding exceptions for fatal problems and debugging for minor problems.
| coding_exception | 
Reimplemented in core\event\url_blocked.
| 
 | protected | 
Custom validation.
| coding_exception | 
| void | 
Reimplemented from core\event\base.
| 
 | inherited | 
Participating level.
Any event that is performed by a user, and is related (or could be related) to his learning experience.
| 
 | inherited | 
Teaching level.
Any event that is performed by someone (typically a teacher) and has a teaching value, anything that is affecting the learning experience/environment of the students.