2 // This file is part of Moodle - http://moodle.org/
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.
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/>.
18 * Allows admin to configure antiviruses.
20 * @package core_antivirus
21 * @copyright 2015 Ruslan Kabalin, Lancaster University.
22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
25 require_once('../config.php');
26 require_once($CFG->libdir
.'/adminlib.php');
27 require_once($CFG->libdir
.'/tablelib.php');
29 $action = required_param('action', PARAM_ALPHANUMEXT
);
30 $antivirus = required_param('antivirus', PARAM_PLUGIN
);
31 $confirm = optional_param('confirm', 0, PARAM_BOOL
);
33 $PAGE->set_url('/admin/antiviruses.php', array('action' => $action, 'antivirus' => $antivirus));
34 $PAGE->set_context(context_system
::instance());
38 $returnurl = "$CFG->wwwroot/$CFG->admin/settings.php?section=manageantiviruses";
40 // Get currently installed and enabled antivirus plugins.
41 $availableantiviruses = \core\antivirus\manager
::get_available();
42 if (!empty($antivirus) and empty($availableantiviruses[$antivirus])) {
43 redirect ($returnurl);
46 $activeantiviruses = explode(',', $CFG->antiviruses
);
47 foreach ($activeantiviruses as $key => $active) {
48 if (empty($availableantiviruses[$active])) {
49 unset($activeantiviruses[$key]);
53 if (!confirm_sesskey()) {
60 // Remove from enabled list.
61 $class = \core_plugin_manager
::resolve_plugininfo_class('antivirus');
62 $class::enable_plugin($antivirus, false);
66 // Add to enabled list.
67 if (!in_array($antivirus, $activeantiviruses)) {
68 $class = \core_plugin_manager
::resolve_plugininfo_class('antivirus');
69 $class::enable_plugin($antivirus, true);
74 $key = array_search($antivirus, $activeantiviruses);
75 // Check auth plugin is valid.
77 // Move down the list.
78 if ($key < (count($activeantiviruses) - 1)) {
79 $fsave = $activeantiviruses[$key];
80 $activeantiviruses[$key] = $activeantiviruses[$key +
1];
81 $activeantiviruses[$key +
1] = $fsave;
88 $key = array_search($antivirus, $activeantiviruses);
89 // Check auth is valid.
93 $fsave = $activeantiviruses[$key];
94 $activeantiviruses[$key] = $activeantiviruses[$key - 1];
95 $activeantiviruses[$key - 1] = $fsave;
106 $new = implode(',', $activeantiviruses);
107 add_to_config_log('antiviruses', $CFG->antiviruses
, $new, 'core');
108 set_config('antiviruses', $new);
109 core_plugin_manager
::reset_caches();
113 redirect ($returnurl);