<?php /** * Plugin Name: Redis User Session Storage * Plugin URI: https://ethitter.com/plugins/redis-user-session-storage/ * Description: Store WordPress session tokens in Redis rather than the usermeta table. Requires the Redis PECL extension. * Version: 0.2 * Author: Erick Hitter * Author URI: https://ethitter.com/ * * This program 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 2 of the License, or * (at your option) any later version. * * This program 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 this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA * * @package Redis_User_Session_Storage */ namespace Redis_User_Session_Storage; use Redis; use WP_Redis_User_Session_Storage; use WP_Session_Tokens; /** * Load plugin when safe to do so, accounting for previous plugin name. * * WordPress.org no longer accepts plugins beginning with the `WP` prefix, so * this was renamed to comply. * * @return void */ function load() { if ( ! class_exists( Redis::class, false ) ) { return; } if ( ! class_exists( WP_Session_Tokens::class, false ) ) { return; } if ( class_exists( WP_Redis_User_Session_Storage::class, false ) ) { // TODO: warn user to disable old plugin. return; } require_once __DIR__ . '/inc/class-plugin.php'; class_alias( Plugin::class, 'WP_Redis_User_Session_Storage', false ); add_filter( 'session_token_manager', __NAMESPACE__ . '\set_session_token_manager' ); } add_action( 'plugins_loaded', __NAMESPACE__ . '\load' ); /** * Override Core's default usermeta-based token storage. * * @return string */ function set_session_token_manager() { return Plugin::class; }