. /** * Task to cleanup old question statistics cache. * * @package core * @copyright 2019 Simey Lameze * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace core\task; defined('MOODLE_INTERNAL') || die(); /** * A task to cleanup old question statistics cache. * * @copyright 2019 Simey Lameze * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class question_stats_cleanup_task extends scheduled_task { /** * Get a descriptive name for this task (shown to admins). * * @return string */ public function get_name() { return get_string('taskquestionstatscleanupcron', 'admin'); } /** * Perform the cleanup task. */ public function execute() { global $DB; mtrace("\n Cleaning up old question statistics cache records...", ''); $expiretime = time() - 5 * HOURSECS; $DB->delete_records_select('question_statistics', 'timemodified < ?', [$expiretime]); $responseanlysisids = $DB->get_records_select_menu('question_response_analysis', 'timemodified < ?', [$expiretime], 'id', 'id, id AS id2'); $DB->delete_records_list('question_response_analysis', 'id', $responseanlysisids); $DB->delete_records_list('question_response_count', 'analysisid', $responseanlysisids); mtrace('done.'); } }