Merge branch 'MDL-81084-main' of https://github.com/andrewnicols/moodle
[moodle.git] / admin / modules.php
blob4104b4b202cfd6a51f4003be76e2bc04e5305248
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.
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/>.
17 /**
18 * A page to manage activity modules.
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
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");
30 define('MODULE_TABLE', 'module_administration_table');
32 admin_externalpage_setup('managemodules');
34 $plugin = optional_param('plugin', '', PARAM_PLUGIN);
35 $action = optional_param('action', '', PARAM_ALPHA);
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);
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
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
55 // Settings not required - only pages.
56 admin_get_root(true, false);
59 // Redirect back to the modules page with out any params.
60 redirect(new moodle_url('/admin/modules.php'));
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();