123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien@symfony.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\HttpFoundation\Tests;
- use PHPUnit\Framework\TestCase;
- use Symfony\Bridge\PhpUnit\ExpectDeprecationTrait;
- use Symfony\Component\HttpFoundation\IpUtils;
- class IpUtilsTest extends TestCase
- {
- use ExpectDeprecationTrait;
- public function testSeparateCachesPerProtocol()
- {
- $ip = '192.168.52.1';
- $subnet = '192.168.0.0/16';
- $this->assertFalse(IpUtils::checkIp6($ip, $subnet));
- $this->assertTrue(IpUtils::checkIp4($ip, $subnet));
- $ip = '2a01:198:603:0:396e:4789:8e99:890f';
- $subnet = '2a01:198:603:0::/65';
- $this->assertFalse(IpUtils::checkIp4($ip, $subnet));
- $this->assertTrue(IpUtils::checkIp6($ip, $subnet));
- }
- /**
- * @dataProvider getIpv4Data
- */
- public function testIpv4($matches, $remoteAddr, $cidr)
- {
- $this->assertSame($matches, IpUtils::checkIp($remoteAddr, $cidr));
- }
- public static function getIpv4Data()
- {
- return [
- [true, '192.168.1.1', '192.168.1.1'],
- [true, '192.168.1.1', '192.168.1.1/1'],
- [true, '192.168.1.1', '192.168.1.0/24'],
- [false, '192.168.1.1', '1.2.3.4/1'],
- [false, '192.168.1.1', '192.168.1.1/33'], // invalid subnet
- [true, '192.168.1.1', ['1.2.3.4/1', '192.168.1.0/24']],
- [true, '192.168.1.1', ['192.168.1.0/24', '1.2.3.4/1']],
- [false, '192.168.1.1', ['1.2.3.4/1', '4.3.2.1/1']],
- [true, '1.2.3.4', '0.0.0.0/0'],
- [true, '1.2.3.4', '192.168.1.0/0'],
- [false, '1.2.3.4', '256.256.256/0'], // invalid CIDR notation
- [false, 'an_invalid_ip', '192.168.1.0/24'],
- [false, '', '1.2.3.4/1'],
- ];
- }
- /**
- * @dataProvider getIpv6Data
- */
- public function testIpv6($matches, $remoteAddr, $cidr)
- {
- if (!\defined('AF_INET6')) {
- $this->markTestSkipped('Only works when PHP is compiled without the option "disable-ipv6".');
- }
- $this->assertSame($matches, IpUtils::checkIp($remoteAddr, $cidr));
- }
- public static function getIpv6Data()
- {
- return [
- [true, '2a01:198:603:0:396e:4789:8e99:890f', '2a01:198:603:0::/65'],
- [false, '2a00:198:603:0:396e:4789:8e99:890f', '2a01:198:603:0::/65'],
- [false, '2a01:198:603:0:396e:4789:8e99:890f', '::1'],
- [true, '0:0:0:0:0:0:0:1', '::1'],
- [false, '0:0:603:0:396e:4789:8e99:0001', '::1'],
- [true, '0:0:603:0:396e:4789:8e99:0001', '::/0'],
- [true, '0:0:603:0:396e:4789:8e99:0001', '2a01:198:603:0::/0'],
- [true, '2a01:198:603:0:396e:4789:8e99:890f', ['::1', '2a01:198:603:0::/65']],
- [true, '2a01:198:603:0:396e:4789:8e99:890f', ['2a01:198:603:0::/65', '::1']],
- [false, '2a01:198:603:0:396e:4789:8e99:890f', ['::1', '1a01:198:603:0::/65']],
- [false, '}__test|O:21:"JDatabaseDriverMysqli":3:{s:2', '::1'],
- [false, '2a01:198:603:0:396e:4789:8e99:890f', 'unknown'],
- [false, '', '::1'],
- [false, '127.0.0.1', '::1'],
- [false, '0.0.0.0/8', '::1'],
- [false, '::1', '127.0.0.1'],
- [false, '::1', '0.0.0.0/8'],
- [true, '::ffff:10.126.42.2', '::ffff:10.0.0.0/0'],
- ];
- }
- /**
- * @group legacy
- */
- public function testIpTriggersDeprecationOnNull()
- {
- $this->expectDeprecation('Since symfony/http-foundation 5.4: Passing null as $requestIp to "Symfony\Component\HttpFoundation\IpUtils::checkIp()" is deprecated, pass an empty string instead.');
- $this->assertFalse(IpUtils::checkIp(null, '192.168.1.1'));
- }
- /**
- * @group legacy
- */
- public function testIp4TriggersDeprecationOnNull()
- {
- $this->expectDeprecation('Since symfony/http-foundation 5.4: Passing null as $requestIp to "Symfony\Component\HttpFoundation\IpUtils::checkIp4()" is deprecated, pass an empty string instead.');
- $this->assertFalse(IpUtils::checkIp4(null, '192.168.1.1'));
- }
- /**
- * @group legacy
- */
- public function testIp6TriggersDeprecationOnNull()
- {
- $this->expectDeprecation('Since symfony/http-foundation 5.4: Passing null as $requestIp to "Symfony\Component\HttpFoundation\IpUtils::checkIp6()" is deprecated, pass an empty string instead.');
- $this->assertFalse(IpUtils::checkIp6(null, '2a01:198:603:0::/65'));
- }
- /**
- * @requires extension sockets
- */
- public function testAnIpv6WithOptionDisabledIpv6()
- {
- $this->expectException(\RuntimeException::class);
- if (\defined('AF_INET6')) {
- $this->markTestSkipped('Only works when PHP is compiled with the option "disable-ipv6".');
- }
- IpUtils::checkIp('2a01:198:603:0:396e:4789:8e99:890f', '2a01:198:603:0::/65');
- }
- /**
- * @dataProvider invalidIpAddressData
- */
- public function testInvalidIpAddressesDoNotMatch($requestIp, $proxyIp)
- {
- $this->assertFalse(IpUtils::checkIp4($requestIp, $proxyIp));
- }
- public static function invalidIpAddressData()
- {
- return [
- 'invalid proxy wildcard' => ['192.168.20.13', '*'],
- 'invalid proxy missing netmask' => ['192.168.20.13', '0.0.0.0'],
- 'invalid request IP with invalid proxy wildcard' => ['0.0.0.0', '*'],
- ];
- }
- /**
- * @dataProvider anonymizedIpData
- */
- public function testAnonymize($ip, $expected)
- {
- $this->assertSame($expected, IpUtils::anonymize($ip));
- }
- public static function anonymizedIpData()
- {
- return [
- ['192.168.1.1', '192.168.1.0'],
- ['1.2.3.4', '1.2.3.0'],
- ['2a01:198:603:0:396e:4789:8e99:890f', '2a01:198:603::'],
- ['2a01:198:603:10:396e:4789:8e99:890f', '2a01:198:603:10::'],
- ['::1', '::'],
- ['0:0:0:0:0:0:0:1', '::'],
- ['1:0:0:0:0:0:0:1', '1::'],
- ['0:0:603:50:396e:4789:8e99:0001', '0:0:603:50::'],
- ['[0:0:603:50:396e:4789:8e99:0001]', '[0:0:603:50::]'],
- ['[2a01:198::3]', '[2a01:198::]'],
- ['::ffff:123.234.235.236', '::ffff:123.234.235.0'], // IPv4-mapped IPv6 addresses
- ['::123.234.235.236', '::123.234.235.0'], // deprecated IPv4-compatible IPv6 address
- ];
- }
- /**
- * @dataProvider getIp4SubnetMaskZeroData
- */
- public function testIp4SubnetMaskZero($matches, $remoteAddr, $cidr)
- {
- $this->assertSame($matches, IpUtils::checkIp4($remoteAddr, $cidr));
- }
- public static function getIp4SubnetMaskZeroData()
- {
- return [
- [true, '1.2.3.4', '0.0.0.0/0'],
- [true, '1.2.3.4', '192.168.1.0/0'],
- [false, '1.2.3.4', '256.256.256/0'], // invalid CIDR notation
- ];
- }
- }
|