setup_actions();
}
return self::$instance;
}
/**
* Load admin actions
*/
private function setup_actions() {
add_action( 'admin_menu', [ $this, 'action_admin_menu' ] );
add_action( 'wp_ajax_pantheon_clear_session', [ $this, 'handle_clear_session' ] );
}
/**
* Register the admin menu
*/
public function action_admin_menu() {
add_management_page( __( 'Pantheon Sessions', 'wp-native-php-sessions' ), __( 'Sessions', 'wp-native-php-sessions' ), self::$capability, 'pantheon-sessions', [ $this, 'handle_page' ] );
}
/**
* Render the admin page
*/
public function handle_page() {
global $wpdb;
require_once ABSPATH . 'wp-admin/includes/class-wp-list-table.php';
require_once __DIR__ . '/class-list-table.php';
echo '
';
echo '
';
$query_args = [
'action' => 'pantheon_clear_session',
'nonce' => wp_create_nonce( 'pantheon_clear_session' ),
'session' => 'all',
];
if ( $wpdb->get_var( "SELECT COUNT(session_id) FROM $wpdb->pantheon_sessions" ) ) {
echo '
' . esc_html__( 'Clear All', 'wp-native-php-sessions' ) . '';
}
echo '
' . esc_html__( 'Pantheon Sessions', 'wp-native-php-sessions' ) . '
';
if ( isset( $_GET['message'] ) && in_array( $_GET['message'], [ 'delete-all-session', 'delete-session' ], true ) ) {
if ( 'delete-all-session' === $_GET['message'] ) {
$message = __( 'Cleared all sessions.', 'wp-native-php-sessions' );
} elseif ( 'delete-session' === $_GET['message'] ) {
$message = __( 'Session cleared.', 'wp-native-php-sessions' );
}
echo '
' . esc_html( $message ) . '
';
}
echo '
';
$wp_list_table = new List_Table();
$wp_list_table->prepare_items();
$wp_list_table->display();
echo '
';
add_action( 'admin_footer', [ $this, 'action_admin_footer' ] );
}
/**
* Handle a request to clear all sessions
*/
public function handle_clear_session() {
global $wpdb;
if ( ! current_user_can( self::$capability ) || ! wp_verify_nonce( $_GET['nonce'], 'pantheon_clear_session' ) ) {
wp_die( esc_html__( "You don't have permission to do this.", 'wp-native-php-sessions' ) );
}
if ( ! empty( $_GET['session'] ) && 'all' === $_GET['session'] ) {
$wpdb->query( "DELETE FROM $wpdb->pantheon_sessions" );
$message = 'delete-all-session';
} else {
$wpdb->query( $wpdb->prepare( "DELETE FROM $wpdb->pantheon_sessions WHERE session_id=%s", sanitize_text_field( $_GET['session'] ) ) );
$message = 'delete-session';
}
wp_safe_redirect( add_query_arg( 'message', $message, wp_get_referer() ) );
exit;
}
/**
* Stuff that needs to go in the footer
*/
public function action_admin_footer() {
?>