mirror of
https://github.com/moodle/moodle.git
synced 2025-08-04 16:36:37 +02:00
MDL-47162 core_message: debug whenever courseid is missing
Instead of silently defaulting to SITEID when courseid (coming from message_send()/\core\message\manager::send_message()) is missing, now a debugging message is shown to allow developers to fix their messages to, always, include courseid. Raw creation of events via message_sent::create() missing other[courseid] leads to coding exception since now (there shouldn't be any legacy use, as far as they are always created via create_from_ids() when sending a message. Updated upgrade.txt notes a little bit, added references the 3.6 final deprecation issue (MDL-55449) and covered with unit tests.
This commit is contained in:
parent
9d0e8a4f6d
commit
a29bcf7819
5 changed files with 78 additions and 5 deletions
|
@ -50,6 +50,7 @@ class manager {
|
|||
*
|
||||
* NOTE: to be used from message_send() only.
|
||||
*
|
||||
* @todo MDL-55449 Drop support for stdClass in Moodle 3.6
|
||||
* @param \core\message\message $eventdata fully prepared event data for processors
|
||||
* @param \stdClass $savemessage the message saved in 'message' table
|
||||
* @param array $processorlist list of processors for target user
|
||||
|
@ -58,11 +59,13 @@ class manager {
|
|||
public static function send_message($eventdata, \stdClass $savemessage, array $processorlist) {
|
||||
global $CFG;
|
||||
|
||||
// TODO MDL-55449 Drop support for stdClass in Moodle 3.6.
|
||||
if (!($eventdata instanceof \stdClass) && !($eventdata instanceof message)) {
|
||||
// Not a valid object.
|
||||
throw new \coding_exception('Message should be of type stdClass or \core\message\message');
|
||||
}
|
||||
|
||||
// TODO MDL-55449 Drop support for stdClass in Moodle 3.6.
|
||||
if ($eventdata instanceof \stdClass) {
|
||||
if (!isset($eventdata->courseid)) {
|
||||
$eventdata->courseid = null;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue