Skip to content

Commit

Permalink
MDL-66034 core_role: implement capability assigned event
Browse files Browse the repository at this point in the history
  • Loading branch information
lameze committed Aug 5, 2019
1 parent 414eca8 commit 7b0afca
Show file tree
Hide file tree
Showing 3 changed files with 112 additions and 0 deletions.
1 change: 1 addition & 0 deletions lang/en/role.php
Expand Up @@ -225,6 +225,7 @@
$string['errorexistsrolename'] = 'Role name already exists';
$string['errorexistsroleshortname'] = 'Role name already exists';
$string['errorroleshortnametoolong'] = 'The short name must not exceed 100 characters';
$string['eventcapabilityassigned'] = 'Capability assigned';
$string['eventroleallowassignupdated'] = 'Allow role assignment';
$string['eventroleallowoverrideupdated'] = 'Allow role override';
$string['eventroleallowswitchupdated'] = 'Allow role switch';
Expand Down
12 changes: 12 additions & 0 deletions lib/accesslib.php
Expand Up @@ -1379,6 +1379,18 @@ function assign_capability($capability, $permission, $roleid, $contextid, $overw
}
}

// Trigger capability_assigned event.
\core\event\capability_assigned::create([
'userid' => $cap->modifierid,
'context' => $context,
'objectid' => $roleid,
'other' => [
'capability' => $capability,
'oldpermission' => $existing->permission ?? CAP_INHERIT,
'permission' => $permission
]
])->trigger();

// Reset any cache of this role, including MUC.
accesslib_clear_role_cache($roleid);

Expand Down
99 changes: 99 additions & 0 deletions lib/classes/event/capability_assigned.php
@@ -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/>.

/**
* Capability assigned event.
*
* @package core
* @since Moodle 3.8
* @copyright 2019 Simey Lameze <simey@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/

namespace core\event;

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

/**
* Capability assigned event class.
*
* @package core
* @since Moodle 3.8
* @copyright 2019 Simey Lameze <simey@moodle.com>
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class capability_assigned extends base {
/**
* Initialise event parameters.
*/
protected function init() {
$this->data['objecttable'] = 'role_capabilities';
$this->data['crud'] = 'u';
$this->data['edulevel'] = self::LEVEL_OTHER;
}

/**
* Returns localised event name.
*
* @return string
*/
public static function get_name() {
return get_string('eventcapabilityassigned', 'role');
}

/**
* Returns non-localised event description with id's for admin use only.
*
* @return string
*/
public function get_description() {

$strpermissions = [
CAP_INHERIT => get_string('notset', 'role'),
CAP_ALLOW => get_string('allow', 'role'),
CAP_PREVENT => get_string('prevent', 'role'),
CAP_PROHIBIT => get_string('prohibit', 'role')
];

$capability = $this->other['capability'];
$oldpermission = $this->other['oldpermission'];
$permission = $this->other['permission'];

if ($oldpermission == CAP_INHERIT && $permission == CAP_ALLOW) {
$description = "The user id '$this->userid' assigned the '$capability' capability for " .
"role '$this->objectid' with '$strpermissions[$permission]' permission";
} else {
$description = "The user id '$this->userid' changed the '$capability' capability permission for " .
"role '$this->objectid' from '$strpermissions[$oldpermission]' to '$strpermissions[$permission]'";
}

return $description;
}

/**
* Returns relevant URL.
*
* @return \moodle_url
*/
public function get_url() {
if ($this->contextlevel == CONTEXT_SYSTEM) {
return new \moodle_url('/admin/roles/define.php', ['action' => 'edit', 'roleid' => $this->objectid]);
} else {
return new \moodle_url('/admin/roles/override.php', ['contextid' => $this->contextid,
'roleid' => $this->objectid]);
}
}
}

0 comments on commit 7b0afca

Please sign in to comment.