diff --git a/classes/form/smartmenu_edit_form.php b/classes/form/smartmenu_edit_form.php index c8768d6c0dc..724813191fe 100644 --- a/classes/form/smartmenu_edit_form.php +++ b/classes/form/smartmenu_edit_form.php @@ -208,6 +208,16 @@ public function definition() { $mform->setType('rolecontext', PARAM_INT); $mform->addHelpButton('rolecontext', 'smartmenusrolecontext', 'theme_boost_union'); + // Add restrict visibility by admin as header element. + $mform->addElement('header', 'restrictbyadminheader', + get_string('smartmenusrestrictbyadminheader', 'theme_boost_union')); + if (isset($this->_customdata['menu']) && $this->_customdata['menu']->byadmin) { + $mform->setExpanded('restrictbyadminheader'); + } + // Add admin restriction as advcheckbox element. + $mform->addElement('advcheckbox', 'byadmin', get_string('smartmenusbyadmin', 'theme_boost_union')); + $mform->addHelpButton('byadmin', 'smartmenusbyadmin', 'theme_boost_union'); + // Add restrict visibility by cohorts as header element. $mform->addElement('header', 'restrictbycohortsheader', get_string('smartmenusrestrictbycohortsheader', 'theme_boost_union')); diff --git a/classes/form/smartmenu_item_edit_form.php b/classes/form/smartmenu_item_edit_form.php index 6ae779396d5..4a6281e6fc7 100644 --- a/classes/form/smartmenu_item_edit_form.php +++ b/classes/form/smartmenu_item_edit_form.php @@ -377,6 +377,16 @@ public function definition() { $mform->setType('rolecontext', PARAM_INT); $mform->addHelpButton('rolecontext', 'smartmenusrolecontext', 'theme_boost_union'); + // Add restrict visibility by admin as header element. + $mform->addElement('header', 'restrictbyadminheader', + get_string('smartmenusrestrictbyadminheader', 'theme_boost_union')); + if (isset($this->_customdata['menuitem']) && $this->_customdata['menuitem']->byadmin) { + $mform->setExpanded('restrictbyadminheader'); + } + // Add admin restriction as advcheckbox element. + $mform->addElement('advcheckbox', 'byadmin', get_string('smartmenusbyadmin', 'theme_boost_union')); + $mform->addHelpButton('byadmin', 'smartmenusbyadmin', 'theme_boost_union'); + // Add restrict visibility by cohorts as header element. $mform->addElement('header', 'restrictbycohortsheader', get_string('smartmenusrestrictbycohortsheader', 'theme_boost_union')); diff --git a/db/install.xml b/db/install.xml index 5abf6d15d74..a1bb583694c 100644 --- a/db/install.xml +++ b/db/install.xml @@ -50,6 +50,7 @@ + @@ -93,6 +94,7 @@ + diff --git a/db/upgrade.php b/db/upgrade.php index 8ae375c810c..8ada2daee60 100644 --- a/db/upgrade.php +++ b/db/upgrade.php @@ -324,5 +324,29 @@ function xmldb_theme_boost_union_upgrade($oldversion) { upgrade_plugin_savepoint(true, 2023102027, 'theme', 'boost_union'); } + if ($oldversion < 2024100702) { + + // Define field byadmin to be added to theme_boost_union_menus. + $table = new xmldb_table('theme_boost_union_menus'); + $field = new xmldb_field('byadmin', XMLDB_TYPE_INTEGER, '9', null, XMLDB_NOTNULL, null, '0', 'visible'); + + // Conditionally launch add field byadmin. + if (!$dbman->field_exists($table, $field)) { + $dbman->add_field($table, $field); + } + + // Define field byadmin to be added to theme_boost_union_menuitems. + $table = new xmldb_table('theme_boost_union_menuitems'); + $field = new xmldb_field('byadmin', XMLDB_TYPE_INTEGER, '9', null, XMLDB_NOTNULL, null, '0', 'timemodified'); + + // Conditionally launch add field byadmin. + if (!$dbman->field_exists($table, $field)) { + $dbman->add_field($table, $field); + } + + // Boost_union savepoint reached. + upgrade_plugin_savepoint(true, 2024100702, 'theme', 'boost_union'); + } + return true; } diff --git a/lang/en/theme_boost_union.php b/lang/en/theme_boost_union.php index c748fd2b20b..ba9cdd16766 100644 --- a/lang/en/theme_boost_union.php +++ b/lang/en/theme_boost_union.php @@ -1120,6 +1120,8 @@ $string['smartmenusbylanguage_help'] = 'Restrict the visibility based on the user\'s language'; $string['smartmenusbyrole'] = 'By role'; $string['smartmenusbyrole_help'] = 'Restrict the visibility based on the user\'s roles.'; +$string['smartmenusbyadmin'] = 'Only for site admin'; +$string['smartmenusbyadmin_help'] = 'Restrict the visibility to site admin users.'; $string['smartmenusdynamiccoursescompletionstatus'] = 'Completion status'; $string['smartmenusdynamiccoursescompletionstatus_help'] = 'The dynamic courses menu item list will contain all courses of the user which match the selected completion status. For example, if you select \'In progress\' as the completion status, the dynamic courses menu item list will only contain courses that the current user is currently working on.'; $string['smartmenusdynamiccoursescompletionstatuscompleted'] = 'Completed'; @@ -1277,6 +1279,7 @@ $string['smartmenusrestrictbydateheader'] = 'Restrict visibility by date'; $string['smartmenusrestrictbylanguageheader'] = 'Restrict visibility by language'; $string['smartmenusrestrictbyrolesheader'] = 'Restrict visibility by roles'; +$string['smartmenusrestrictbyadminheader'] = 'Restrict visibility to admins'; $string['smartmenusrolecontext'] = 'Context'; $string['smartmenusrolecontext_help'] = 'Select the context for which the user\'s role should be checked (Any context or system context only)'; $string['smartmenussavechangesandconfigure'] = 'Save and configure items'; diff --git a/smartmenus/menulib.php b/smartmenus/menulib.php index 6703d401509..f7b1b0fdae5 100644 --- a/smartmenus/menulib.php +++ b/smartmenus/menulib.php @@ -97,6 +97,11 @@ public function verify_access_restrictions() { // Restriction by roles. $this->restriction_byroles($query); + // Restricted to admins. + if (!$this->restriction_byadminrole()) { + return false; + } + // Restriction by cohorts. $this->restriction_bycohorts($query); @@ -180,6 +185,19 @@ public function restriction_byroles(&$query) { $query->params += array_merge($params, $inparam); } + /** + * Verify if the menu is restricted to admins. + * + * @return bool True if the user is a site admin + */ + public function restriction_byadminrole() { + // Check if the item is restricted to admins. + if ($this->data->byadmin) { + return is_siteadmin($this->userid); // Returns true if the user is a site admin. + } + return true; + } + /** * The purpose of this function is to check if a user is assigned to one or more cohorts that are specified in a menu. * For the operator "ALL" it gets the count of records and verfiy the records count is same as count of selected cohorts. diff --git a/tests/behat/theme_boost_union_smartmenusettings_menuitems_rules.feature b/tests/behat/theme_boost_union_smartmenusettings_menuitems_rules.feature index 992b849d7de..204bfafdd24 100644 --- a/tests/behat/theme_boost_union_smartmenusettings_menuitems_rules.feature +++ b/tests/behat/theme_boost_union_smartmenusettings_menuitems_rules.feature @@ -101,6 +101,26 @@ Feature: Configuring the theme_boost_union plugin on the "Smart menus" page, app | Guest | Any | should not | should not | should not | should | should not | should not | should not | | Visitor | Any | should not | should not | should not | should not | should not | should not | should | + @javascript + Scenario Outline: Smartmenu: Menu items: Rules - Show smart menu item based on being site admin + When I navigate to smart menus + And I should see "Quick links" in the "smartmenus" "table" + And I should see smart menu "Quick links" item "Resources" in location "Main, Menu, User, Bottom" + And I click on ".action-list-items" "css_element" in the "Quick links" "table_row" + And I click on ".action-edit" "css_element" in the "Resources" "table_row" + And I expand all fieldsets + And I set the field "Only for site admin" to "" + And I click on "Save changes" "button" + And I see smart menu "Quick links" item "Resources" in location "Main, Menu, User, Bottom" + And I log out + And I log in as "student1" + Then I see smart menu "Quick links" item "Resources" in location "Main, Menu, User, Bottom" + + Examples: + | byadmin | adminshouldorshouldnot | student1shouldorshouldnot | + | 1 | should | should not | + | 0 | should | should | + @javascript Scenario Outline: Smartmenu: Menu items: Rules - Show smart menu item based on the user assignment in single cohorts When I navigate to smart menus diff --git a/tests/behat/theme_boost_union_smartmenusettings_menus_rules.feature b/tests/behat/theme_boost_union_smartmenusettings_menus_rules.feature index 8020396328f..6e9d86bf9b6 100644 --- a/tests/behat/theme_boost_union_smartmenusettings_menus_rules.feature +++ b/tests/behat/theme_boost_union_smartmenusettings_menus_rules.feature @@ -96,6 +96,25 @@ Feature: Configuring the theme_boost_union plugin on the "Smart menus" page, app | Guest | Any | should not | should not | should not | should | should not | should not | should not | | Visitor | Any | should not | should not | should not | should not | should not | should not | should | +@javascript + Scenario Outline: Smartmenu: Menus: Rules - Show smart menu based on being site admin + When I navigate to smart menus + And I should see "Quick links" in the "smartmenus" "table" + And I should see smart menu "Quick links" item "Resources" in location "Main, Menu, User, Bottom" + And I click on ".action-edit" "css_element" in the "Quick links" "table_row" + And I expand all fieldsets + And I set the field "Only for site admin" to "" + And I click on "Save and return" "button" + And I see smart menu "Quick links" in location "Main, Menu, User, Bottom" + And I log out + And I log in as "student1" + Then I see smart menu "Quick links" in location "Main, Menu, User, Bottom" + + Examples: + | byadmin | adminshouldorshouldnot | student1shouldorshouldnot | + | 1 | should | should not | + | 0 | should | should | + @javascript Scenario Outline: Smartmenu: Menus: Rules - Show smart menu based on the user assignment in single cohorts When I navigate to smart menus diff --git a/version.php b/version.php index 352fb08bc8f..04e98603984 100644 --- a/version.php +++ b/version.php @@ -25,7 +25,7 @@ defined('MOODLE_INTERNAL') || die(); $plugin->component = 'theme_boost_union'; -$plugin->version = 2024100701; +$plugin->version = 2024100702; $plugin->release = 'v4.5-r2'; $plugin->requires = 2024100700; $plugin->supported = [405, 405];