mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-11-04 16:36:52 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace Tests\Unit\Http\Middleware\Api;
 | 
						|
 | 
						|
use Pterodactyl\Models\ApiKey;
 | 
						|
use Tests\Unit\Http\Middleware\MiddlewareTestCase;
 | 
						|
use Pterodactyl\Http\Middleware\Api\AuthenticateIPAccess;
 | 
						|
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
 | 
						|
 | 
						|
class AuthenticateIPAccessTest extends MiddlewareTestCase
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Test middleware when there are no IP restrictions.
 | 
						|
     */
 | 
						|
    public function testWithNoIPRestrictions()
 | 
						|
    {
 | 
						|
        $model = factory(ApiKey::class)->make(['allowed_ips' => []]);
 | 
						|
        $this->setRequestAttribute('api_key', $model);
 | 
						|
 | 
						|
        $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test middleware works correctly when a valid IP accesses
 | 
						|
     * and there is an IP restriction.
 | 
						|
     */
 | 
						|
    public function testWithValidIP()
 | 
						|
    {
 | 
						|
        $model = factory(ApiKey::class)->make(['allowed_ips' => ['127.0.0.1']]);
 | 
						|
        $this->setRequestAttribute('api_key', $model);
 | 
						|
 | 
						|
        $this->request->shouldReceive('ip')->withNoArgs()->once()->andReturn('127.0.0.1');
 | 
						|
 | 
						|
        $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test that a CIDR range can be used.
 | 
						|
     */
 | 
						|
    public function testValidIPAgainstCIDRRange()
 | 
						|
    {
 | 
						|
        $model = factory(ApiKey::class)->make(['allowed_ips' => ['192.168.1.1/28']]);
 | 
						|
        $this->setRequestAttribute('api_key', $model);
 | 
						|
 | 
						|
        $this->request->shouldReceive('ip')->withNoArgs()->once()->andReturn('192.168.1.15');
 | 
						|
 | 
						|
        $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Test that an exception is thrown when an invalid IP address
 | 
						|
     * tries to connect and there is an IP restriction.
 | 
						|
     */
 | 
						|
    public function testWithInvalidIP()
 | 
						|
    {
 | 
						|
        $this->expectException(AccessDeniedHttpException::class);
 | 
						|
 | 
						|
        $model = factory(ApiKey::class)->make(['allowed_ips' => ['127.0.0.1']]);
 | 
						|
        $this->setRequestAttribute('api_key', $model);
 | 
						|
 | 
						|
        $this->request->shouldReceive('ip')->withNoArgs()->twice()->andReturn('127.0.0.2');
 | 
						|
 | 
						|
        $this->getMiddleware()->handle($this->request, $this->getClosureAssertions());
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Return an instance of the middleware to be used when testing.
 | 
						|
     *
 | 
						|
     * @return \Pterodactyl\Http\Middleware\Api\AuthenticateIPAccess
 | 
						|
     */
 | 
						|
    private function getMiddleware(): AuthenticateIPAccess
 | 
						|
    {
 | 
						|
        return new AuthenticateIPAccess();
 | 
						|
    }
 | 
						|
}
 |