HEX
Server: nginx/1.20.1
System: Linux VM-0-8-centos 3.10.0-1160.11.1.el7.x86_64 #1 SMP Fri Dec 18 16:34:56 UTC 2020 x86_64
User: www (1000)
PHP: 7.3.29
Disabled: passthru,system,chroot,chgrp,chown,shell_exec,popen,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,popepassthru,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/www.ycfawu.com/wp-content/plugins/tidio-live-chat/src/Admin/AdminController.php
<?php

namespace TidioLiveChat\Admin;

if (!defined('WPINC')) {
    die('File loaded directly. Exiting.');
}

use TidioLiveChat\Admin\Notice\DismissibleNoticeService;
use TidioLiveChat\TidioSdk\Exception\CannotIntegrateWithProjectException;
use TidioLiveChat\TidioSdk\Exception\CannotRetrieveAccessTokensException;
use TidioLiveChat\TidioSdk\TidioIntegrationService;
use TidioLiveChat\IntegrationState;
use TidioLiveChat\TidioLiveChat;
use TidioLiveChat\Utils\QueryParameters;
use TidioLiveChat\WooCommerceSdk\WooCommerceIntegrationService;

class AdminController
{
    /**
     * @var TidioIntegrationService
     */
    private $integrationFacade;
    /**
     * @var IntegrationState
     */
    private $integrationState;
    /**
     * @var WooCommerceIntegrationService
     */
    private $wooCommerceIntegrationService;
    /**
     * @var NonceValidator
     */
    private $nonceValidator;
    /**
     * @var DismissibleNoticeService
     */
    private $dismissibleNoticeService;

    /**
     * @param TidioIntegrationService $integrationFacade
     * @param IntegrationState $integrationState
     * @param WooCommerceIntegrationService $wooCommerceIntegrationService
     * @param NonceValidator $nonceValidator
     * @param DismissibleNoticeService $dismissibleNoticeService
     */
    public function __construct($integrationFacade, $integrationState, $wooCommerceIntegrationService, $nonceValidator, $dismissibleNoticeService)
    {
        $this->integrationFacade = $integrationFacade;
        $this->integrationState = $integrationState;
        $this->wooCommerceIntegrationService = $wooCommerceIntegrationService;
        $this->nonceValidator = $nonceValidator;
        $this->dismissibleNoticeService = $dismissibleNoticeService;
    }

    public function handleIntegrateProjectAction()
    {
        if (!$this->isRequestNonceValid(AdminRouting::INTEGRATE_PROJECT_ACTION)) {
            wp_die('', 403);
        }

        $refreshToken = QueryParameters::get('refreshToken');
        try {
            $this->integrationFacade->integrateProject($refreshToken);
        } catch (CannotIntegrateWithProjectException $exception) {
            $errorCode = $exception->getErrorCode();
            $this->redirectToPluginAdminDashboardWithError($errorCode);
        }

        $this->redirectToPluginAdminDashboard();
    }

    public function handleAuthorizeWooCommerceAction()
    {
        if (!$this->isRequestNonceValid(AdminRouting::AUTHORIZE_WOOCOMMERCE_ACTION)) {
            wp_die('', 403);
        }

        try {
            $authUrl = $this->wooCommerceIntegrationService->getAuthUrl();
        } catch (CannotRetrieveAccessTokensException $exception) {
            $this->redirectToPluginAdminDashboardWithError($exception->getErrorCode());
        }

        $this->redirectToUrl($authUrl);
    }

    public function handleIntegrateWooCommerceAction()
    {
        if (!$this->isRequestNonceValid(AdminRouting::INTEGRATE_WOOCOMMERCE_ACTION)) {
            wp_die('', 403);
        }

        if (QueryParameters::has('success') && QueryParameters::get('success') === '1') {
            $this->integrationState->integrateWooCommerce();
        }

        $this->redirectToPluginAdminDashboard();
    }

    public function handleToggleAsyncLoadingAction()
    {
        if (!$this->isRequestNonceValid(AdminRouting::TOGGLE_ASYNC_LOADING_ACTION)) {
            wp_die('', 403);
        }

        $this->integrationState->toggleAsyncLoading();

        $this->redirectToPluginsListDashboard();
    }

    public function handleClearAccountDataAction()
    {
        if (!$this->isRequestNonceValid(AdminRouting::CLEAR_ACCOUNT_DATA_ACTION)) {
            wp_die('', 403);
        }

        $this->integrationState->removeIntegration();
        $this->dismissibleNoticeService->clearDismissedNoticesHistory();

        $this->redirectToPluginsListDashboard();
    }

    /**
     * @param string $nonce
     * @return bool
     */
    private function isRequestNonceValid($nonce)
    {
        return $this->nonceValidator->isRequestNonceValid($nonce);
    }

    private function redirectToPluginsListDashboard()
    {
        $this->redirectToUrl(admin_url('plugins.php'));
    }

    private function redirectToPluginAdminDashboard()
    {
        $url = 'admin.php?page=' . TidioLiveChat::TIDIO_PLUGIN_TECHNICAL_NAME;
        $this->redirectToUrl(admin_url($url));
    }

    /**
     * @param string $errorCode
     */
    private function redirectToPluginAdminDashboardWithError($errorCode)
    {
        $url = sprintf('admin.php?page=%s&error=%s', TidioLiveChat::TIDIO_PLUGIN_TECHNICAL_NAME, $errorCode);
        $this->redirectToUrl(admin_url($url));
    }

    /**
     * @param string $url
     * @return never-return
     */
    private function redirectToUrl($url)
    {
        wp_redirect($url);
        die();
    }
}