Differences Between: [Versions 310 and 400] [Versions 311 and 400] [Versions 39 and 400] [Versions 400 and 401] [Versions 400 and 402] [Versions 400 and 403]
Base event class.
Copyright: | 2013 Petr Skoda {@link http://skodak.org} |
License: | http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later |
File Size: | 1004 lines (36 kb) |
Included or required: | 1 time |
Referenced: | 0 times |
Includes or requires: | 0 files |
base:: (1 method):
__construct()
name:: (34 methods):
create()
validate_data()
get_name()
get_name_with_info()
get_description()
can_view()
restore()
restore_unknown()
restore_legacy()
get_objectid_mapping()
get_objectid_mapping()
get_other_mapping()
get_other_mapping()
get_static_info()
get_explanation()
get_context()
get_url()
get_data()
get_logextra()
get_legacy_eventname()
get_legacy_eventdata()
get_legacy_logdata()
validate_before_trigger()
trigger()
is_triggered()
is_dispatched()
is_restored()
add_record_snapshot()
get_record_snapshot()
__get()
__set()
__isset()
getIterator()
is_deprecated()
name:: (34 methods):
create()
validate_data()
get_name()
get_name_with_info()
get_description()
can_view()
restore()
restore_unknown()
restore_legacy()
get_objectid_mapping()
get_objectid_mapping()
get_other_mapping()
get_other_mapping()
get_static_info()
get_explanation()
get_context()
get_url()
get_data()
get_logextra()
get_legacy_eventname()
get_legacy_eventdata()
get_legacy_logdata()
validate_before_trigger()
trigger()
is_triggered()
is_dispatched()
is_restored()
add_record_snapshot()
get_record_snapshot()
__get()
__set()
__isset()
getIterator()
is_deprecated()
__construct() X-Ref |
Private constructor, use create() or restore() methods instead. |
create(array $data = null) X-Ref |
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 return: \core\event\base returns instance of new event param: array $data |
validate_data() X-Ref |
Let developers validate their custom data (such as $this->data['other'], contextlevel, etc.). Throw \coding_exception or debugging() notice in case of any problems. |
get_name() X-Ref |
Returns localised general event name. Override in subclass, we can not make it static and abstract at the same time. return: string |
get_name_with_info() X-Ref |
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. return: string |
get_description() X-Ref |
Returns non-localised event description with id's for admin use only. return: string |
can_view($user_or_id = null) X-Ref |
This method was originally intended for granular access control on the event level, unfortunately the proper implementation would be too expensive in many cases. return: bool True if the user can view the event, false otherwise. param: int|\stdClass $user_or_id ID of the user. |
restore(array $data, array $logextra) X-Ref |
Restore event from existing historic data. return: bool|\core\event\base param: array $data param: array $logextra the format is standardised by logging API |
restore_unknown(array $data, array $logextra) X-Ref |
Restore unknown event. return: unknown_logged param: array $data param: array $logextra |
restore_legacy($legacy) X-Ref |
Create fake event from legacy log data. return: base param: \stdClass $legacy |
get_objectid_mapping() X-Ref |
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. return: string the name of the restore mapping the objectid links to |
get_objectid_mapping() X-Ref |
No description |
get_other_mapping() X-Ref |
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. return: array an array of other values and their corresponding mapping |
get_other_mapping() X-Ref |
No description |
get_static_info() X-Ref |
Get static information about an event. This is used in reports and is not for general use. return: array Static information about the event. |
get_explanation() X-Ref |
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'); return: string An explanation of the event formatted in markdown style. |
get_context() X-Ref |
Returns event context. return: \context |
get_url() X-Ref |
Returns relevant URL, override in subclasses. return: \moodle_url |
get_data() X-Ref |
Return standardised event data as array. return: array All elements are scalars except the 'other' field which is array. |
get_logextra() X-Ref |
Return auxiliary data that was stored in logs. List of standard properties: - origin: IP number, cli,cron - realuserid: id of the user when logged-in-as return: array the format is standardised by logging API |
get_legacy_eventname() X-Ref |
Does this event replace legacy event? Note: do not use directly! return: null|string legacy event name |
get_legacy_eventdata() X-Ref |
Legacy event data if get_legacy_eventname() is not empty. Note: do not use directly! return: mixed |
get_legacy_logdata() X-Ref |
Doest this event replace add_to_log() statement? Note: do not use directly! return: null|array of parameters to be passed to legacy add_to_log() function. |
validate_before_trigger() X-Ref |
Validate all properties right before triggering the event. This throws coding exceptions for fatal problems and debugging for minor problems. |
trigger() X-Ref |
Trigger event. |
is_triggered() X-Ref |
Was this event already triggered? return: bool |
is_dispatched() X-Ref |
Used from event manager to prevent direct access. return: bool |
is_restored() X-Ref |
Was this event restored? return: bool |
add_record_snapshot($tablename, $record) X-Ref |
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. param: string $tablename param: \stdClass $record |
get_record_snapshot($tablename, $id) X-Ref |
Returns cached record or fetches data from database if not cached. return: \stdClass param: string $tablename param: int $id |
__get($name) X-Ref |
Magic getter for read only access. return: mixed param: string $name |
__set($name, $value) X-Ref |
Magic setter. Note: we must not allow modification of data from outside, after trigger() the data MUST NOT CHANGE!!! param: string $name param: mixed $value |
__isset($name) X-Ref |
Is data property set? return: bool param: string $name |
getIterator() X-Ref |
Create an iterator because magic vars can't be seen by 'foreach'. return: \ArrayIterator |
is_deprecated() X-Ref |
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). return: boolean |
create(array $data = null) X-Ref |
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 return: \core\event\base returns instance of new event param: array $data |
validate_data() X-Ref |
Let developers validate their custom data (such as $this->data['other'], contextlevel, etc.). Throw \coding_exception or debugging() notice in case of any problems. |
get_name() X-Ref |
Returns localised general event name. Override in subclass, we can not make it static and abstract at the same time. return: string |
get_name_with_info() X-Ref |
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. return: string |
get_description() X-Ref |
Returns non-localised event description with id's for admin use only. return: string |
can_view($user_or_id = null) X-Ref |
This method was originally intended for granular access control on the event level, unfortunately the proper implementation would be too expensive in many cases. return: bool True if the user can view the event, false otherwise. param: int|\stdClass $user_or_id ID of the user. |
restore(array $data, array $logextra) X-Ref |
Restore event from existing historic data. return: bool|\core\event\base param: array $data param: array $logextra the format is standardised by logging API |
restore_unknown(array $data, array $logextra) X-Ref |
Restore unknown event. return: unknown_logged param: array $data param: array $logextra |
restore_legacy($legacy) X-Ref |
Create fake event from legacy log data. return: base param: \stdClass $legacy |
get_objectid_mapping() X-Ref |
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. return: string the name of the restore mapping the objectid links to |
get_objectid_mapping() X-Ref |
No description |
get_other_mapping() X-Ref |
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. return: array an array of other values and their corresponding mapping |
get_other_mapping() X-Ref |
No description |
get_static_info() X-Ref |
Get static information about an event. This is used in reports and is not for general use. return: array Static information about the event. |
get_explanation() X-Ref |
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'); return: string An explanation of the event formatted in markdown style. |
get_context() X-Ref |
Returns event context. return: \context |
get_url() X-Ref |
Returns relevant URL, override in subclasses. return: \moodle_url |
get_data() X-Ref |
Return standardised event data as array. return: array All elements are scalars except the 'other' field which is array. |
get_logextra() X-Ref |
Return auxiliary data that was stored in logs. List of standard properties: - origin: IP number, cli,cron - realuserid: id of the user when logged-in-as return: array the format is standardised by logging API |
get_legacy_eventname() X-Ref |
Does this event replace legacy event? Note: do not use directly! return: null|string legacy event name |
get_legacy_eventdata() X-Ref |
Legacy event data if get_legacy_eventname() is not empty. Note: do not use directly! return: mixed |
get_legacy_logdata() X-Ref |
Doest this event replace add_to_log() statement? Note: do not use directly! return: null|array of parameters to be passed to legacy add_to_log() function. |
validate_before_trigger() X-Ref |
Validate all properties right before triggering the event. This throws coding exceptions for fatal problems and debugging for minor problems. |
trigger() X-Ref |
Trigger event. |
is_triggered() X-Ref |
Was this event already triggered? return: bool |
is_dispatched() X-Ref |
Used from event manager to prevent direct access. return: bool |
is_restored() X-Ref |
Was this event restored? return: bool |
add_record_snapshot($tablename, $record) X-Ref |
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. param: string $tablename param: \stdClass $record |
get_record_snapshot($tablename, $id) X-Ref |
Returns cached record or fetches data from database if not cached. return: \stdClass param: string $tablename param: int $id |
__get($name) X-Ref |
Magic getter for read only access. return: mixed param: string $name |
__set($name, $value) X-Ref |
Magic setter. Note: we must not allow modification of data from outside, after trigger() the data MUST NOT CHANGE!!! param: string $name param: mixed $value |
__isset($name) X-Ref |
Is data property set? return: bool param: string $name |
getIterator() X-Ref |
Create an iterator because magic vars can't be seen by 'foreach'. return: \ArrayIterator |
is_deprecated() X-Ref |
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). return: boolean |