Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/mets.corals.io/wp-content/plugins/give/src/DonorDashboards/Routes/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/mets.corals.io/wp-content/plugins/give/src/DonorDashboards/Routes/LogoutRoute.php
<?php

namespace Give\DonorDashboards\Routes;

use Give\API\RestRoute;
use Give\DonorDashboards\Helpers as DonorDashboardHelpers;
use WP_REST_Request;
use WP_REST_Response;


/**
 * @since 2.10.0
 */
class LogoutRoute implements RestRoute
{

    /** @var string */
    protected $endpoint = 'donor-dashboard/logout';

    /**
     * @inheritDoc
     */
    public function registerRoute()
    {
        register_rest_route(
            'give-api/v2',
            $this->endpoint,
            [
                [
                    'methods' => 'POST',
                    'callback' => [$this, 'handleRequest'],
                    'permission_callback' => [$this, 'permissionsCheck'],
                ],
            ]
        );
    }

    /**
     * Handles logout request
     *
     * @since 2.10.0
     *
     * @param WP_REST_Request $request
     *
     * @return WP_REST_Response
     *
     */
    public function handleRequest(WP_REST_Request $request): WP_REST_Response
    {
        // Check if WP user is logged in
        if (get_current_user_id() !== 0) {
            // Handle logout logic for WP users

            /**
             * Fires before processing user logout.
             *
             * @since 1.0
             */
            do_action('give_before_user_logout');

            // Logout user (and destroys current Give Session, via hook registered in Give_Session class)
            wp_logout();

            /**
             * Fires after processing user logout.
             *
             * @since 1.0
             */
            do_action('give_after_user_logout');
        } else {
            // Destroy current Give Session
            give()->session->destroy_session();
        }

        return new WP_REST_Response(
            [
                'status' => 200,
                'response' => 'logout_successful',
                'body_response' => [
                    'message' => __('User was logged out successfully.', 'give'),
                ],
            ]
        );
    }

    /**
     * Check permissions
     */
    public function permissionsCheck(): bool
    {
        return DonorDashboardHelpers::isDonorLoggedIn();
    }
}

Spamworldpro Mini