Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.2.x will end 22 April 2024 (12 months).
  • Bug fixes for security issues in 4.2.x will end 7 October 2024 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.1.x is supported too.
/admin/ -> modules.php (source)

Differences Between: [Versions 310 and 402] [Versions 311 and 402] [Versions 39 and 402] [Versions 400 and 402] [Versions 401 and 402]

   1  <?php
   2  // This file is part of Moodle - http://moodle.org/
   3  //
   4  // Moodle is free software: you can redistribute it and/or modify
   5  // it under the terms of the GNU General Public License as published by
   6  // the Free Software Foundation, either version 3 of the License, or
   7  // (at your option) any later version.
   8  //
   9  // Moodle is distributed in the hope that it will be useful,
  10  // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12  // GNU General Public License for more details.
  13  //
  14  // You should have received a copy of the GNU General Public License
  15  // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
  16  
  17  /**
  18   * A page to manage activity modules.
  19   *
  20   * @package   core_admin
  21   * @copyright 2023 Andrew Lyons <andrew@nicols.co.uk>
  22   * @license   http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   */
  24  
  25  require_once('../config.php');
  26  require_once ('../course/lib.php');
  27  require_once("{$CFG->libdir}/adminlib.php");
  28  require_once("{$CFG->libdir}/tablelib.php");
  29  
  30  define('MODULE_TABLE', 'module_administration_table');
  31  
  32  admin_externalpage_setup('managemodules');
  33  
  34  $plugin = optional_param('plugin', '', PARAM_PLUGIN);
  35  $action = optional_param('action', '', PARAM_ALPHA);
  36  
  37  // If data submitted, then process and store.
  38  if (!empty($action) && !empty($plugin) && confirm_sesskey()) {
  39      $manager = \core_plugin_manager::resolve_plugininfo_class('mod');
  40      $pluginname = get_string('pluginname', $plugin);
  41  
  42      if ($action === 'disable' && $manager::enable_plugin($plugin, 0)) {
  43          \core\notification::add(
  44              get_string('plugin_disabled', 'core_admin', $pluginname),
  45              \core\notification::SUCCESS
  46          );
  47          // Settings not required - only pages.
  48          admin_get_root(true, false);
  49      } else if ($action === 'enable' && $manager::enable_plugin($plugin, 1)) {
  50          \core\notification::add(
  51              get_string('plugin_enabled', 'core_admin', $pluginname),
  52              \core\notification::SUCCESS
  53          );
  54  
  55          // Settings not required - only pages.
  56          admin_get_root(true, false);
  57      }
  58  
  59      // Redirect back to the modules page with out any params.
  60      redirect(new moodle_url('/admin/modules.php'));
  61  }
  62  
  63  echo $OUTPUT->header();
  64  echo $OUTPUT->heading(get_string("activities"));
  65  $table = new \core_admin\table\activity_management_table();
  66  $table->out();
  67  echo $OUTPUT->footer();