Skip to content

Commit

Permalink
Merge branch 'wip-MDL-44640-master' of https://github.com/marinaglanc…
Browse files Browse the repository at this point in the history
  • Loading branch information
danpoltawski committed Sep 29, 2015
2 parents eb89f7c + 7fdc469 commit b33662e
Show file tree
Hide file tree
Showing 16 changed files with 459 additions and 8 deletions.
1 change: 1 addition & 0 deletions enrol/cohort/edit.php
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,7 @@
$instance->customint2 = $groupid;
}
$DB->update_record('enrol', $instance);
\core\event\enrol_instance_updated::create_from_record($instance)->trigger();
} else {
// Create a new group for the cohort if requested.
if ($data->customint2 == COHORT_CREATE_GROUP) {
Expand Down
1 change: 1 addition & 0 deletions enrol/guest/lib.php
Original file line number Diff line number Diff line change
Expand Up @@ -332,6 +332,7 @@ public function course_updated($inserted, $course, $data) {
$instance->password = $data->{'enrol_guest_password_'.$i};
}
$DB->update_record('enrol', $instance);
\core\event\enrol_instance_updated::create_from_record($instance)->trigger();

if ($reset) {
$context = context_course::instance($course->id);
Expand Down
8 changes: 4 additions & 4 deletions enrol/manual/edit.php
Original file line number Diff line number Diff line change
Expand Up @@ -92,13 +92,13 @@
$instance->notifyall = $data->notifyall;
$instance->expirythreshold = $data->expirythreshold;
$instance->timemodified = time();
$markdirty = ($instance->status != $data->status);
$instance->status = $data->status;

$DB->update_record('enrol', $instance);
\core\event\enrol_instance_updated::create_from_record($instance)->trigger();

// Use standard API to update instance status.
if ($instance->status != $data->status) {
$instance = $DB->get_record('enrol', array('id'=>$instance->id));
$plugin->update_status($instance, $data->status);
if ($markdirty) {
$context->mark_dirty();
}

Expand Down
26 changes: 26 additions & 0 deletions enrol/meta/classes/observer.php
Original file line number Diff line number Diff line change
Expand Up @@ -204,4 +204,30 @@ public static function course_deleted(\core\event\course_deleted $event) {

return true;
}

/**
* Triggered via enrol_instance_updated event.
*
* @param \core\event\enrol_instance_updated $event
* @return boolean
*/
public static function enrol_instance_updated(\core\event\enrol_instance_updated $event) {
global $DB;

if (!enrol_is_enabled('meta')) {
// This is slow, let enrol_meta_sync() deal with disabled plugin.
return true;
}

// Does anything want to sync with this parent?
$affectedcourses = $DB->get_fieldset_sql('SELECT DISTINCT courseid FROM {enrol} '.
'WHERE customint1 = ? AND enrol = ?',
array($event->courseid, 'meta'));

foreach ($affectedcourses as $courseid) {
enrol_meta_sync($courseid);
}

return true;
}
}
4 changes: 4 additions & 0 deletions enrol/meta/db/events.php
Original file line number Diff line number Diff line change
Expand Up @@ -52,4 +52,8 @@
'eventname' => '\core\event\course_deleted',
'callback' => 'enrol_meta_observer::course_deleted',
),
array(
'eventname' => '\core\event\enrol_instance_updated',
'callback' => 'enrol_meta_observer::enrol_instance_updated',
),
);
11 changes: 11 additions & 0 deletions enrol/meta/tests/plugin_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -847,6 +847,16 @@ public function test_timeend() {
// Disable manual enrolment in course1 and make sure all user enrolments in course2 are suspended.
$manplugin->update_status($manual1, ENROL_INSTANCE_DISABLED);
$allsuspendedenrolemnts = array_combine(array_keys($expectedenrolments), array_fill(0, 5, ENROL_USER_SUSPENDED));
$enrolmentstatuses = $DB->get_records_menu('user_enrolments', array('enrolid' => $meta2id), '', 'userid, status');
$this->assertEquals($allsuspendedenrolemnts, $enrolmentstatuses);

$manplugin->update_status($manual1, ENROL_INSTANCE_ENABLED);
$enrolments = $DB->get_records('user_enrolments', array('enrolid' => $meta2id), '', 'userid, timestart, timeend, status');
$this->assertEquals($expectedenrolments, $enrolments);

// Disable events and repeat the same for course3 (testing sync):
$sink = $this->redirectEvents();
$manplugin->update_status($manual1, ENROL_INSTANCE_DISABLED);
enrol_meta_sync($course3->id);
$enrolmentstatuses = $DB->get_records_menu('user_enrolments', array('enrolid' => $meta3id), '', 'userid, status');
$this->assertEquals($allsuspendedenrolemnts, $enrolmentstatuses);
Expand All @@ -855,5 +865,6 @@ public function test_timeend() {
enrol_meta_sync($course3->id);
$enrolments = $DB->get_records('user_enrolments', array('enrolid' => $meta3id), '', 'userid, timestart, timeend, status');
$this->assertEquals($expectedenrolments, $enrolments);
$sink->close();
}
}
2 changes: 1 addition & 1 deletion enrol/meta/version.php
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@

defined('MOODLE_INTERNAL') || die();

$plugin->version = 2015051100; // The current plugin version (Date: YYYYMMDDXX)
$plugin->version = 2015082400; // The current plugin version (Date: YYYYMMDDXX)
$plugin->requires = 2015050500; // Requires this Moodle version
$plugin->component = 'enrol_meta'; // Full name of the plugin (used for diagnostics)
$plugin->cron = 60*60; // run cron every hour by default, it is not out-of-sync often
1 change: 1 addition & 0 deletions enrol/paypal/edit.php
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,7 @@
$instance->enrolenddate = $data->enrolenddate;
$instance->timemodified = time();
$DB->update_record('enrol', $instance);
\core\event\enrol_instance_updated::create_from_record($instance)->trigger();

if ($reset) {
$context->mark_dirty();
Expand Down
1 change: 1 addition & 0 deletions enrol/self/edit.php
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,7 @@
$instance->enrolenddate = $data->enrolenddate;
$instance->timemodified = time();
$DB->update_record('enrol', $instance);
\core\event\enrol_instance_updated::create_from_record($instance)->trigger();

if ($reset) {
$context->mark_dirty();
Expand Down
60 changes: 60 additions & 0 deletions enrol/tests/enrollib_test.php
Original file line number Diff line number Diff line change
Expand Up @@ -362,4 +362,64 @@ public function test_user_enrolment_deleted_event() {
$this->assertEventLegacyLogData($expected, $event);
$this->assertEventContextNotUsed($event);
}

/**
* Test enrol_instance_created, enrol_instance_updated and enrol_instance_deleted events.
*/
public function test_instance_events() {
global $DB;

$this->resetAfterTest(true);

$selfplugin = enrol_get_plugin('self');
$studentrole = $DB->get_record('role', array('shortname' => 'student'));

$course = $this->getDataGenerator()->create_course();

// Creating enrol instance.
$sink = $this->redirectEvents();
$instanceid = $selfplugin->add_instance($course, array('status' => ENROL_INSTANCE_ENABLED,
'name' => 'Test instance 1',
'customint6' => 1,
'roleid' => $studentrole->id));
$events = $sink->get_events();
$sink->close();

$this->assertCount(1, $events);
$event = array_pop($events);
$this->assertInstanceOf('\core\event\enrol_instance_created', $event);
$this->assertEquals(context_course::instance($course->id), $event->get_context());
$this->assertEquals('self', $event->other['enrol']);
$this->assertEventContextNotUsed($event);

// Updating enrol instance.
$instance = $DB->get_record('enrol', array('id' => $instanceid));
$sink = $this->redirectEvents();
$selfplugin->update_status($instance, ENROL_INSTANCE_DISABLED);

$events = $sink->get_events();
$sink->close();

$this->assertCount(1, $events);
$event = array_pop($events);
$this->assertInstanceOf('\core\event\enrol_instance_updated', $event);
$this->assertEquals(context_course::instance($course->id), $event->get_context());
$this->assertEquals('self', $event->other['enrol']);
$this->assertEventContextNotUsed($event);

// Deleting enrol instance.
$instance = $DB->get_record('enrol', array('id' => $instanceid));
$sink = $this->redirectEvents();
$selfplugin->delete_instance($instance);

$events = $sink->get_events();
$sink->close();

$this->assertCount(1, $events);
$event = array_pop($events);
$this->assertInstanceOf('\core\event\enrol_instance_deleted', $event);
$this->assertEquals(context_course::instance($course->id), $event->get_context());
$this->assertEquals('self', $event->other['enrol']);
$this->assertEventContextNotUsed($event);
}
}
6 changes: 6 additions & 0 deletions enrol/upgrade.txt
Original file line number Diff line number Diff line change
@@ -1,6 +1,12 @@
This files describes API changes in /enrol/* - plugins,
information provided here is intended especially for developers.

=== 3.0 ===

* Added new events enrol_instance_created, enrol_instance_updated and
enrol_instance_deleted . Always trigger them when changing records in the
DB table 'enrol'.

=== 2.9 ===

* External function core_enrol_external::get_users_courses now returns additional optional fields:
Expand Down
3 changes: 3 additions & 0 deletions lang/en/enrol.php
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,9 @@
$string['enrolcandidatesmatching'] = 'Matching not enrolled users';
$string['enrolcohort'] = 'Enrol cohort';
$string['enrolcohortusers'] = 'Enrol users';
$string['eventenrolinstancecreated'] = 'Enrolment instance created';
$string['eventenrolinstancedeleted'] = 'Enrolment instance deleted';
$string['eventenrolinstanceupdated'] = 'Enrolment instance updated';
$string['enrollednewusers'] = 'Successfully enrolled {$a} new users';
$string['enrolledusers'] = 'Enrolled users';
$string['enrolledusersmatching'] = 'Matching enrolled users';
Expand Down
109 changes: 109 additions & 0 deletions lib/classes/event/enrol_instance_created.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,109 @@
<?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/>.

/**
* Enrol instance created event.
*
* @package core
* @copyright 2015 Marina Glancy
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/

namespace core\event;
defined('MOODLE_INTERNAL') || die();

/**
* Enrol instance created event class.
*
* @property-read array $other {
* Extra information about event.
*
* - string enrol: name of enrol method
* }
*
* @package core
* @since Moodle 2.9
* @copyright 2015 Marina Glancy
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class enrol_instance_created extends base {

/**
* Api to Create new event from enrol object.
*
* @param \stdClass $enrol record from DB table 'enrol'
* @return \core\event\base returns instance of new event
*/
public static final function create_from_record($enrol) {
$event = static::create(array(
'context' => \context_course::instance($enrol->courseid),
'objectid' => $enrol->id,
'other' => array('enrol' => $enrol->enrol)
));
return $event;
}

/**
* Returns description of what happened.
*
* @return string
*/
public function get_description() {
return "The user with id '$this->userid' created the instance of enrolment method '" .
$this->other['enrol'] . "' with id '$this->objectid'.";
}

/**
* Return localised event name.
*
* @return string
*/
public static function get_name() {
return get_string('eventenrolinstancecreated', 'enrol');
}

/**
* Get URL related to the action
*
* @return \moodle_url
*/
public function get_url() {
return new \moodle_url('/enrol/instances.php', array('id' => $this->courseid));
}

/**
* Init method.
*
* @return void
*/
protected function init() {
$this->data['crud'] = 'c';
$this->data['edulevel'] = self::LEVEL_OTHER;
$this->data['objecttable'] = 'enrol';
}

/**
* custom validations
*
* Throw \coding_exception notice in case of any problems.
*/
protected function validate_data() {
parent::validate_data();
if (!isset($this->other['enrol'])) {
throw new \coding_exception('The \'enrol\' value must be set in other.');
}
}
}
Loading

0 comments on commit b33662e

Please sign in to comment.