MDL-70159 tool_capability: order capabilities by their name.

This commit is contained in:
Paul Holden 2020-08-18 09:01:14 +01:00
parent ed2400457b
commit 20905a1481
5 changed files with 105 additions and 60 deletions

View File

@ -40,7 +40,7 @@ admin_externalpage_setup('toolcapability');
// Prepare the list of capabilities to choose from. // Prepare the list of capabilities to choose from.
$capabilitychoices = array(); $capabilitychoices = array();
foreach ($context->get_capabilities() as $cap) { foreach ($context->get_capabilities('name') as $cap) {
$capabilitychoices[$cap->name] = $cap->name . ': ' . get_capability_string($cap->name); $capabilitychoices[$cap->name] = $cap->name . ': ' . get_capability_string($cap->name);
} }

View File

@ -4873,6 +4873,9 @@ function role_change_permission($roleid, $context, $capname, $permission) {
*/ */
abstract class context extends stdClass implements IteratorAggregate { abstract class context extends stdClass implements IteratorAggregate {
/** @var string Default sorting of capabilities in {@see get_capabilities} */
protected const DEFAULT_CAPABILITY_SORT = 'contextlevel, component, name';
/** /**
* The context id * The context id
* Can be accessed publicly through $context->id * Can be accessed publicly through $context->id
@ -5559,9 +5562,10 @@ abstract class context extends stdClass implements IteratorAggregate {
/** /**
* Returns array of relevant context capability records. * Returns array of relevant context capability records.
* *
* @param string $sort SQL order by snippet for sorting returned capabilities sensibly for display
* @return array * @return array
*/ */
public abstract function get_capabilities(); public abstract function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT);
/** /**
* Recursive function which, given a context, find all its children context ids. * Recursive function which, given a context, find all its children context ids.
@ -6186,8 +6190,10 @@ class context_helper extends context {
/** /**
* not used * not used
*
* @param string $sort
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
} }
} }
@ -6247,18 +6253,13 @@ class context_system extends context {
/** /**
* Returns array of relevant context capability records. * Returns array of relevant context capability records.
* *
* @param string $sort
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
global $DB; global $DB;
$sort = 'ORDER BY contextlevel,component,name'; // To group them sensibly for display return $DB->get_records('capabilities', [], $sort);
$params = array();
$sql = "SELECT *
FROM {capabilities}";
return $DB->get_records_sql($sql.' '.$sort, $params);
} }
/** /**
@ -6522,21 +6523,17 @@ class context_user extends context {
/** /**
* Returns array of relevant context capability records. * Returns array of relevant context capability records.
* *
* @param string $sort
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
global $DB; global $DB;
$sort = 'ORDER BY contextlevel,component,name'; // To group them sensibly for display
$extracaps = array('moodle/grade:viewall'); $extracaps = array('moodle/grade:viewall');
list($extra, $params) = $DB->get_in_or_equal($extracaps, SQL_PARAMS_NAMED, 'cap'); list($extra, $params) = $DB->get_in_or_equal($extracaps, SQL_PARAMS_NAMED, 'cap');
$sql = "SELECT *
FROM {capabilities}
WHERE contextlevel = ".CONTEXT_USER."
OR name $extra";
return $records = $DB->get_records_sql($sql.' '.$sort, $params); return $DB->get_records_select('capabilities', "contextlevel = :level OR name {$extra}",
$params + ['level' => CONTEXT_USER], $sort);
} }
/** /**
@ -6702,19 +6699,18 @@ class context_coursecat extends context {
/** /**
* Returns array of relevant context capability records. * Returns array of relevant context capability records.
* *
* @param string $sort
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
global $DB; global $DB;
$sort = 'ORDER BY contextlevel,component,name'; // To group them sensibly for display return $DB->get_records_list('capabilities', 'contextlevel', [
CONTEXT_COURSECAT,
$params = array(); CONTEXT_COURSE,
$sql = "SELECT * CONTEXT_MODULE,
FROM {capabilities} CONTEXT_BLOCK,
WHERE contextlevel IN (".CONTEXT_COURSECAT.",".CONTEXT_COURSE.",".CONTEXT_MODULE.",".CONTEXT_BLOCK.")"; ], $sort);
return $DB->get_records_sql($sql.' '.$sort, $params);
} }
/** /**
@ -6946,19 +6942,17 @@ class context_course extends context {
/** /**
* Returns array of relevant context capability records. * Returns array of relevant context capability records.
* *
* @param string $sort
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
global $DB; global $DB;
$sort = 'ORDER BY contextlevel,component,name'; // To group them sensibly for display return $DB->get_records_list('capabilities', 'contextlevel', [
CONTEXT_COURSE,
$params = array(); CONTEXT_MODULE,
$sql = "SELECT * CONTEXT_BLOCK,
FROM {capabilities} ], $sort);
WHERE contextlevel IN (".CONTEXT_COURSE.",".CONTEXT_MODULE.",".CONTEXT_BLOCK.")";
return $DB->get_records_sql($sql.' '.$sort, $params);
} }
/** /**
@ -7171,13 +7165,12 @@ class context_module extends context {
/** /**
* Returns array of relevant context capability records. * Returns array of relevant context capability records.
* *
* @param string $sort
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
global $DB, $CFG; global $DB, $CFG;
$sort = 'ORDER BY contextlevel,component,name'; // To group them sensibly for display
$cm = $DB->get_record('course_modules', array('id'=>$this->_instanceid)); $cm = $DB->get_record('course_modules', array('id'=>$this->_instanceid));
$module = $DB->get_record('modules', array('id'=>$cm->module)); $module = $DB->get_record('modules', array('id'=>$cm->module));
@ -7251,9 +7244,10 @@ class context_module extends context {
WHERE (contextlevel = ".CONTEXT_MODULE." WHERE (contextlevel = ".CONTEXT_MODULE."
AND component {$notcompsql} AND component {$notcompsql}
AND {$notlikesql}) AND {$notlikesql})
$extra"; $extra
ORDER BY $sort";
return $DB->get_records_sql($sql.' '.$sort, $params); return $DB->get_records_sql($sql, $params);
} }
/** /**
@ -7440,31 +7434,28 @@ class context_block extends context {
/** /**
* Returns array of relevant context capability records. * Returns array of relevant context capability records.
* *
* @param string $sort
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
global $DB; global $DB;
$sort = 'ORDER BY contextlevel,component,name'; // To group them sensibly for display
$params = array();
$bi = $DB->get_record('block_instances', array('id' => $this->_instanceid)); $bi = $DB->get_record('block_instances', array('id' => $this->_instanceid));
$extra = ''; $select = '(contextlevel = :level AND component = :component)';
$params = [
'level' => CONTEXT_BLOCK,
'component' => 'block_' . $bi->blockname,
];
$extracaps = block_method_result($bi->blockname, 'get_extra_capabilities'); $extracaps = block_method_result($bi->blockname, 'get_extra_capabilities');
if ($extracaps) { if ($extracaps) {
list($extra, $params) = $DB->get_in_or_equal($extracaps, SQL_PARAMS_NAMED, 'cap'); list($extra, $extraparams) = $DB->get_in_or_equal($extracaps, SQL_PARAMS_NAMED, 'cap');
$extra = "OR name $extra"; $select .= " OR name $extra";
$params = array_merge($params, $extraparams);
} }
$sql = "SELECT * return $DB->get_records_select('capabilities', $select, $params, $sort);
FROM {capabilities}
WHERE (contextlevel = ".CONTEXT_BLOCK."
AND component = :component)
$extra";
$params['component'] = 'block_' . $bi->blockname;
return $DB->get_records_sql($sql.' '.$sort, $params);
} }
/** /**

View File

@ -3643,6 +3643,58 @@ class core_accesslib_testcase extends advanced_testcase {
$this->assert_capability_list_contains($expectedcapabilities, $actual); $this->assert_capability_list_contains($expectedcapabilities, $actual);
} }
/**
* Test that {@see context_block::get_capabilities} returns capabilities relevant to blocks
*/
public function test_context_block_caps_returned_by_get_capabilities_block_context(): void {
$this->resetAfterTest();
$course = $this->getDataGenerator()->create_course();
$block = $this->getDataGenerator()->create_block('online_users', [
'parentcontextid' => context_course::instance($course->id)->id,
]);
$capabilities = context_block::instance($block->id)->get_capabilities();
// Just test a few representative capabilities.
$expected = ['block/online_users:addinstance', 'moodle/block:edit', 'moodle/block:view'];
$this->assert_capability_list_contains($expected, $capabilities);
// Now test with different sorting.
$capabilitiesbyname = context_block::instance($block->id)->get_capabilities('riskbitmask');
$capabilitynames = array_column($capabilities, 'name');
$capabilitynamesordered = array_column($capabilitiesbyname, 'name');
// Each array should contain the same data, ordered differently.
$this->assertEqualsCanonicalizing($capabilitynames, $capabilitynamesordered);
$this->assertNotSame($capabilitynames, $capabilitynamesordered);
}
/**
* Test that {@see context_user::get_capabilities} returns capabilities relevant to users
*/
public function test_context_user_caps_returned_by_get_capabilities_user_context(): void {
$this->resetAfterTest();
$user = $this->getDataGenerator()->create_user();
$capabilities = context_user::instance($user->id)->get_capabilities();
// Just test a few representative capabilities.
$expected = ['moodle/user:editmessageprofile', 'moodle/user:editprofile', 'moodle/user:viewalldetails'];
$this->assert_capability_list_contains($expected, $capabilities);
// Now test with different sorting.
$capabilitiesbyname = context_user::instance($user->id)->get_capabilities('name');
$capabilitynames = array_column($capabilities, 'name');
$capabilitynamesordered = array_column($capabilitiesbyname, 'name');
// Each array should contain the same data, ordered differently.
$this->assertEqualsCanonicalizing($capabilitynames, $capabilitynamesordered);
$this->assertNotSame($capabilitynames, $capabilitynamesordered);
}
/** /**
* Test updating of role capabilities during upgrade * Test updating of role capabilities during upgrade
*/ */

View File

@ -45,7 +45,7 @@ class context_bogus1 extends context {
* *
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
return array(); return array();
} }
} }
@ -69,7 +69,7 @@ class context_bogus2 extends context {
* *
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
return array(); return array();
} }
} }
@ -93,7 +93,7 @@ class context_bogus3 extends context {
* *
* @return array * @return array
*/ */
public function get_capabilities() { public function get_capabilities(string $sort = self::DEFAULT_CAPABILITY_SORT) {
return array(); return array();
} }
} }

View File

@ -14,6 +14,8 @@ information provided here is intended especially for developers.
* Behat timeout constants behat_base::TIMEOUT, EXTENDED_TIMEOUT, and REDUCED_TIMEOUT, which were deprecated in 3.7, have been removed. * Behat timeout constants behat_base::TIMEOUT, EXTENDED_TIMEOUT, and REDUCED_TIMEOUT, which were deprecated in 3.7, have been removed.
* \core_table\local\filter\filterset::JOINTYPE_DEFAULT is being changed from 1 (ANY) to 2 (ALL). Filterset implementations * \core_table\local\filter\filterset::JOINTYPE_DEFAULT is being changed from 1 (ANY) to 2 (ALL). Filterset implementations
can override the default filterset join type by overriding \core_table\local\filter\filterset::get_join_type() instead. can override the default filterset join type by overriding \core_table\local\filter\filterset::get_join_type() instead.
* A new optional parameter `$sort` has been added to all `$context->get_capabilities()` methods to be able to define order of
returned capability array.
=== 3.10 === === 3.10 ===
* PHPUnit has been upgraded to 8.5. That comes with a few changes: * PHPUnit has been upgraded to 8.5. That comes with a few changes: