__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

www-data@216.73.216.10: ~ $
<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle.  If not, see <http://www.gnu.org/licenses/>.

/**
 * Defines classes used for plugin info.
 *
 * @package    core
 * @copyright  2016 Marina Glancy
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
namespace core\plugininfo;

/**
 * Class for media plugins
 *
 * @package    core
 * @copyright  2016 Marina Glancy
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class media extends base {

    public static function plugintype_supports_disabling(): bool {
        return true;
    }

    public function is_uninstall_allowed() {
        return true;
    }

    /**
     * Get the name for the settings section.
     *
     * @return string
     */
    public function get_settings_section_name() {
        return 'mediasetting' . $this->name;
    }

    /**
     * Load the global settings for a particular availability plugin (if there are any)
     *
     * @param \part_of_admin_tree $adminroot
     * @param string $parentnodename
     * @param bool $hassiteconfig
     */
    public function load_settings(\part_of_admin_tree $adminroot, $parentnodename, $hassiteconfig) {
        global $CFG, $USER, $DB, $OUTPUT, $PAGE; // In case settings.php wants to refer to them.
        /** @var \admin_root $ADMIN */
        $ADMIN = $adminroot; // May be used in settings.php.
        $plugininfo = $this; // Also can be used inside settings.php
        $availability = $this; // Also to be used inside settings.php.

        if (!$this->is_installed_and_upgraded()) {
            return;
        }

        if (!$hassiteconfig) {
            return;
        }

        $section = $this->get_settings_section_name();

        $settings = null;
        if (file_exists($this->full_path('settings.php'))) {
            $settings = new \admin_settingpage($section, $this->displayname, 'moodle/site:config', $this->is_enabled() === false);
            include($this->full_path('settings.php')); // This may also set $settings to null.
        }
        if ($settings) {
            $ADMIN->add($parentnodename, $settings);
        }
    }

    /**
     * Return URL used for management of plugins of this type.
     * @return \moodle_url
     */
    public static function get_manage_url() {
        return new \moodle_url('/admin/settings.php', array('section' => 'managemediaplayers'));
    }

    public static function get_enabled_plugins() {
        global $CFG;

        $order = (!empty($CFG->media_plugins_sortorder)) ? explode(',', $CFG->media_plugins_sortorder) : [];
        if ($order) {
            $plugins = \core_plugin_manager::instance()->get_installed_plugins('media');
            $order = array_intersect($order, array_keys($plugins));
        }
        return array_combine($order, $order);
    }

    public static function enable_plugin(string $pluginname, int $enabled): bool {
        global $CFG;

        $haschanged = false;
        $plugins = [];
        if (!empty($CFG->media_plugins_sortorder)) {
            $plugins = explode(',', $CFG->media_plugins_sortorder);
        }
        // Only set visibility if it's different from the current value.
        if ($enabled && !in_array($pluginname, $plugins)) {
            // Enable media plugin.

            /** @var \core\plugininfo\media[] $pluginsbytype */
            $pluginsbytype = \core_plugin_manager::instance()->get_plugins_of_type('media');
            if (!array_key_exists($pluginname, $pluginsbytype)) {
                // Can not be enabled.
                return false;
            }

            $rank = $pluginsbytype[$pluginname]->get_rank();
            $position = 0;
            // Insert before the first enabled plugin which default rank is smaller than the default rank of this one.
            foreach ($plugins as $playername) {
                if (($player = $pluginsbytype[$playername]) && ($rank > $player->get_rank())) {
                    break;
                }
                $position++;
            }
            array_splice($plugins, $position, 0, [$pluginname]);
            $haschanged = true;
        } else if (!$enabled && in_array($pluginname, $plugins)) {
            // Disable media plugin.
            $key = array_search($pluginname, $plugins);
            unset($plugins[$key]);
            $haschanged = true;
        }

        if ($haschanged) {
            add_to_config_log('media_plugins_sortorder', !$enabled, $enabled, $pluginname);
            self::set_enabled_plugins($plugins);
        }

        return $haschanged;
    }

    /**
     * Sets the current plugin as enabled or disabled
     * When enabling tries to guess the sortorder based on default rank returned by the plugin.
     * @param bool $newstate
     */
    public function set_enabled($newstate = true) {
        self::enable_plugin($this->name, $newstate);
    }

    /**
     * Set the list of enabled media players in the specified sort order
     * To be used when changing settings or in unit tests
     * @param string|array $list list of plugin names without frankenstyle prefix - comma-separated string or an array
     */
    public static function set_enabled_plugins($list) {
        if (empty($list)) {
            $list = [];
        } else if (!is_array($list)) {
            $list = explode(',', $list);
        }
        if ($list) {
            $plugins = \core_plugin_manager::instance()->get_installed_plugins('media');
            $list = array_intersect($list, array_keys($plugins));
        }
        set_config('media_plugins_sortorder', join(',', $list));
        \core_plugin_manager::reset_caches();
        \core_media_manager::reset_caches();
    }

    /**
     * Returns the default rank of this plugin for default sort order
     * @return int
     */
    public function get_rank() {
        $classname = '\media_'.$this->name.'_plugin';
        if (class_exists($classname)) {
            $object = new $classname();
            return $object->get_rank();
        }
        return 0;
    }

    /**
     * Returns human-readable string of supported file/link types for the "Manage media players" page
     * @param array $extensions
     * @return string
     */
    public function supports(&$extensions) {
        $classname = '\media_'.$this->name.'_plugin';
        if (class_exists($classname)) {
            $object = new $classname();
            $result = $object->supports($extensions);
            foreach ($object->get_supported_extensions() as $ext) {
                $extensions[$ext] = $ext;
            }
            return $result;
        }
        return '';
    }

    public static function plugintype_supports_ordering(): bool {
        return true;
    }

    // phpcs:ignore VariableAnalysis.CodeAnalysis.VariableAnalysis.UnusedVariable
    public static function get_sorted_plugins(bool $enabledonly = false): ?array {
        $pluginmanager = \core_plugin_manager::instance();

        $plugins = $pluginmanager->get_plugins_of_type('media');
        $enabledplugins = $pluginmanager->get_enabled_plugins('media');

        // Sort plugins so enabled plugins are displayed first and all others are displayed in the end sorted by rank.
        \core_collator::asort_objects_by_method($plugins, 'get_rank', \core_collator::SORT_NUMERIC);

        $order = array_values($enabledplugins);
        if (!$enabledonly) {
            $order = array_merge($order, array_diff(array_reverse(array_keys($plugins)), $order));
        }

        $sortedplugins = [];
        foreach ($order as $name) {
            $sortedplugins[$name] = $plugins[$name];
        }

        return $sortedplugins;
    }

    public static function change_plugin_order(string $pluginname, int $direction): bool {
        $activeeditors = array_keys(self::get_sorted_plugins(true));
        $key = array_search($pluginname, $activeeditors);
        [$media] = explode('_', $pluginname, 2);

        if ($key === false) {
            return false;
        }

        $sortorder = array_values(self::get_enabled_plugins());

        if ($direction === self::MOVE_DOWN) {
            // Move down the list.
            if ((($pos = array_search($media, $sortorder)) !== false) && ($pos < count($sortorder) - 1)) {
                $tmp = $sortorder[$pos + 1];
                $sortorder[$pos + 1] = $sortorder[$pos];
                $sortorder[$pos] = $tmp;
                self::set_enabled_plugins($sortorder);

                return true;
            }
        } else if ($direction === self::MOVE_UP) {
            if (($pos = array_search($media, $sortorder)) > 0) {
                $tmp = $sortorder[$pos - 1];
                $sortorder[$pos - 1] = $sortorder[$pos];
                $sortorder[$pos] = $tmp;
                self::set_enabled_plugins($sortorder);

                return true;
            }
        }

        return false;
    }
}

Filemanager

Name Type Size Permission Actions
aiplacement.php File 6.33 KB 0777
aiprovider.php File 7.62 KB 0777
antivirus.php File 5.41 KB 0777
auth.php File 5.48 KB 0777
availability.php File 5.48 KB 0777
base.php File 24.47 KB 0777
block.php File 6.35 KB 0777
cachelock.php File 1.08 KB 0777
cachestore.php File 1.28 KB 0777
calendartype.php File 2.69 KB 0777
communication.php File 4.7 KB 0777
contenttype.php File 7.67 KB 0777
coursereport.php File 1.08 KB 0777
customfield.php File 5.04 KB 0777
dataformat.php File 7.09 KB 0777
editor.php File 6.72 KB 0777
enrol.php File 6.5 KB 0777
fileconverter.php File 6.27 KB 0777
filter.php File 6.45 KB 0777
format.php File 7.01 KB 0777
general.php File 1.11 KB 0777
gradeexport.php File 1.08 KB 0777
gradeimport.php File 1.08 KB 0777
gradereport.php File 1.08 KB 0777
gradingform.php File 2.29 KB 0777
h5plib.php File 2.63 KB 0777
local.php File 2.24 KB 0777
media.php File 9.26 KB 0777
message.php File 4.29 KB 0777
mlbackend.php File 2.87 KB 0777
mnetservice.php File 1.25 KB 0777
mod.php File 9.7 KB 0777
orphaned.php File 2.82 KB 0777
paygw.php File 5.22 KB 0777
plagiarism.php File 2.15 KB 0777
portfolio.php File 4.57 KB 0777
profilefield.php File 1.39 KB 0777
qbank.php File 5.65 KB 0777
qbehaviour.php File 4.71 KB 0777
qformat.php File 1.07 KB 0777
qtype.php File 5.3 KB 0777
report.php File 1.3 KB 0777
repository.php File 6.82 KB 0777
search.php File 1.56 KB 0777
smsgateway.php File 2.94 KB 0777
theme.php File 2.88 KB 0777
tool.php File 2.56 KB 0777
webservice.php File 4.08 KB 0777
Filemanager