mirrored from git://git.moodle.org/moodle.git
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
MDL-60811 enrol_self: Add bulk action for self enrollment on users page
- Loading branch information
1 parent
39fab18
commit ebaf979
Showing
8 changed files
with
360 additions
and
0 deletions.
There are no files selected for viewing
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
<?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/>. | ||
|
||
/** | ||
* The form to confirm the intention to bulk delete users enrolments. | ||
* | ||
* @package enrol_self | ||
* @copyright 2018 Farhan Karmali | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
|
||
defined('MOODLE_INTERNAL') || die(); | ||
|
||
require_once("$CFG->dirroot/enrol/bulkchange_forms.php"); | ||
|
||
/** | ||
* The form to confirm the intention to bulk delete users enrolments. | ||
* | ||
* @package enrol_self | ||
* @copyright 2018 Farhan Karmali | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
class enrol_self_deleteselectedusers_form extends enrol_bulk_enrolment_confirm_form { | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,99 @@ | ||
<?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/>. | ||
|
||
/** | ||
* A bulk operation for the self enrolment plugin to delete selected users enrolments. | ||
* | ||
* @package enrol_self | ||
* @copyright 2018 Farhan Karmali | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
|
||
defined('MOODLE_INTERNAL') || die(); | ||
|
||
/** | ||
* A bulk operation for the self enrolment plugin to delete selected users enrolments. | ||
* | ||
* @package enrol_self | ||
* @copyright 2018 Farhan Karmali | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
class enrol_self_deleteselectedusers_operation extends enrol_bulk_enrolment_operation { | ||
|
||
/** | ||
* Returns the title to display for this bulk operation. | ||
* | ||
* @return string | ||
*/ | ||
public function get_identifier() { | ||
return 'deleteselectedusers'; | ||
} | ||
|
||
/** | ||
* Returns the identifier for this bulk operation. This is the key used when the plugin | ||
* returns an array containing all of the bulk operations it supports. | ||
* | ||
* @return string | ||
*/ | ||
public function get_title() { | ||
return get_string('deleteselectedusers', 'enrol_manual'); | ||
} | ||
|
||
/** | ||
* Returns a enrol_bulk_enrolment_operation extension form to be used | ||
* in collecting required information for this operation to be processed. | ||
* | ||
* @param string|moodle_url|null $defaultaction | ||
* @param mixed $defaultcustomdata | ||
* @return enrol_manual_editselectedusers_form | ||
*/ | ||
public function get_form($defaultaction = null, $defaultcustomdata = null) { | ||
global $CFG; | ||
if (!array($defaultcustomdata)) { | ||
$defaultcustomdata = array(); | ||
} | ||
$defaultcustomdata['title'] = $this->get_title(); | ||
$defaultcustomdata['message'] = get_string('confirmbulkdeleteenrolment', 'enrol_self'); | ||
$defaultcustomdata['button'] = get_string('unenrolusers', 'enrol_self'); | ||
return new enrol_self_deleteselectedusers_form($defaultaction, $defaultcustomdata); | ||
} | ||
|
||
/** | ||
* Processes the bulk operation request for the given userids with the provided properties. | ||
* | ||
* @param course_enrolment_manager $manager | ||
* @param array $users | ||
* @param stdClass $properties The data returned by the form. | ||
*/ | ||
public function process(course_enrolment_manager $manager, array $users, stdClass $properties) { | ||
global $DB; | ||
|
||
if (!has_capability("enrol/self:unenrol", $manager->get_context())) { | ||
return false; | ||
} | ||
foreach ($users as $user) { | ||
foreach ($user->enrolments as $enrolment) { | ||
$plugin = $enrolment->enrolmentplugin; | ||
$instance = $enrolment->enrolmentinstance; | ||
if ($plugin->allow_unenrol_user($instance, $enrolment)) { | ||
$plugin->unenrol_user($instance, $user->id); | ||
} | ||
} | ||
} | ||
return true; | ||
} | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
<?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/>. | ||
|
||
/** | ||
* The form to collect required information when bulk editing users enrolments. | ||
* | ||
* @package enrol_self | ||
* @copyright 2018 Farhan Karmali | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
|
||
defined('MOODLE_INTERNAL') || die(); | ||
|
||
require_once("$CFG->dirroot/enrol/bulkchange_forms.php"); | ||
|
||
/** | ||
* The form to collect required information when bulk editing users enrolments. | ||
* | ||
* @package enrol_self | ||
* @copyright 2018 Farhan Karmali | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
class enrol_self_editselectedusers_form extends enrol_bulk_enrolment_change_form { | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,163 @@ | ||
<?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/>. | ||
|
||
/** | ||
* A bulk operation for the manual enrolment plugin to edit selected users. | ||
* | ||
* @package enrol_self | ||
* @copyright 2018 Farhan Karmali | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
|
||
defined('MOODLE_INTERNAL') || die(); | ||
|
||
/** | ||
* A bulk operation for the manual enrolment plugin to edit selected users. | ||
* | ||
* @package enrol_self | ||
* @copyright 2018 Farhan Karmali | ||
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later | ||
*/ | ||
class enrol_self_editselectedusers_operation extends enrol_bulk_enrolment_operation { | ||
|
||
/** | ||
* Returns the title to display for this bulk operation. | ||
* | ||
* @return string | ||
*/ | ||
public function get_title() { | ||
return get_string('editselectedusers', 'enrol_self'); | ||
} | ||
|
||
/** | ||
* Returns the identifier for this bulk operation. This is the key used when the plugin | ||
* returns an array containing all of the bulk operations it supports. | ||
*/ | ||
public function get_identifier() { | ||
return 'editselectedusers'; | ||
} | ||
|
||
/** | ||
* Processes the bulk operation request for the given userids with the provided properties. | ||
* | ||
* @param course_enrolment_manager $manager | ||
* @param array $users | ||
* @param stdClass $properties The data returned by the form. | ||
*/ | ||
public function process(course_enrolment_manager $manager, array $users, stdClass $properties) { | ||
global $DB, $USER; | ||
|
||
if (!has_capability("enrol/self:manage", $manager->get_context())) { | ||
return false; | ||
} | ||
|
||
// Get all of the user enrolment id's. | ||
$ueids = array(); | ||
$instances = array(); | ||
foreach ($users as $user) { | ||
foreach ($user->enrolments as $enrolment) { | ||
$ueids[] = $enrolment->id; | ||
if (!array_key_exists($enrolment->id, $instances)) { | ||
$instances[$enrolment->id] = $enrolment; | ||
} | ||
} | ||
} | ||
|
||
// Check that each instance is manageable by the current user. | ||
foreach ($instances as $instance) { | ||
if (!$this->plugin->allow_manage($instance)) { | ||
return false; | ||
} | ||
} | ||
|
||
// Collect the known properties. | ||
$status = $properties->status; | ||
$timestart = $properties->timestart; | ||
$timeend = $properties->timeend; | ||
|
||
list($ueidsql, $params) = $DB->get_in_or_equal($ueids, SQL_PARAMS_NAMED); | ||
|
||
$updatesql = array(); | ||
if ($status == ENROL_USER_ACTIVE || $status == ENROL_USER_SUSPENDED) { | ||
$updatesql[] = 'status = :status'; | ||
$params['status'] = (int)$status; | ||
} | ||
if (!empty($timestart)) { | ||
$updatesql[] = 'timestart = :timestart'; | ||
$params['timestart'] = (int)$timestart; | ||
} | ||
if (!empty($timeend)) { | ||
$updatesql[] = 'timeend = :timeend'; | ||
$params['timeend'] = (int)$timeend; | ||
} | ||
if (empty($updatesql)) { | ||
return true; | ||
} | ||
|
||
// Update the modifierid. | ||
$updatesql[] = 'modifierid = :modifierid'; | ||
$params['modifierid'] = (int)$USER->id; | ||
|
||
// Update the time modified. | ||
$updatesql[] = 'timemodified = :timemodified'; | ||
$params['timemodified'] = time(); | ||
|
||
// Build the SQL statement. | ||
$updatesql = join(', ', $updatesql); | ||
$sql = "UPDATE {user_enrolments} | ||
SET $updatesql | ||
WHERE id $ueidsql"; | ||
|
||
if ($DB->execute($sql, $params)) { | ||
foreach ($users as $user) { | ||
foreach ($user->enrolments as $enrolment) { | ||
$enrolment->courseid = $enrolment->enrolmentinstance->courseid; | ||
$enrolment->enrol = 'self'; | ||
// Trigger event. | ||
$event = \core\event\user_enrolment_updated::create( | ||
array( | ||
'objectid' => $enrolment->id, | ||
'courseid' => $enrolment->courseid, | ||
'context' => context_course::instance($enrolment->courseid), | ||
'relateduserid' => $user->id, | ||
'other' => array('enrol' => 'self') | ||
) | ||
); | ||
$event->trigger(); | ||
} | ||
} | ||
// Delete cached course contacts for this course because they may be affected. | ||
cache::make('core', 'coursecontacts')->delete($manager->get_context()->instanceid); | ||
return true; | ||
} | ||
|
||
return false; | ||
} | ||
|
||
/** | ||
* Returns a enrol_bulk_enrolment_operation extension form to be used | ||
* in collecting required information for this operation to be processed. | ||
* | ||
* @param string|moodle_url|null $defaultaction | ||
* @param mixed $defaultcustomdata | ||
* @return enrol_self_editselectedusers_form | ||
*/ | ||
public function get_form($defaultaction = null, $defaultcustomdata = null) { | ||
global $CFG; | ||
return new enrol_self_editselectedusers_form($defaultaction, $defaultcustomdata); | ||
} | ||
} | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters