athlon1600 / php-cidr-range-optimizer
Given a list of IP ranges, merge them into the smallest possible list of CIDRs.
v1.0.2
2024-08-16 19:26 UTC
Requires
- php: >=7.4.0
Requires (Dev)
- phpstan/phpstan: ^1.11
- phpunit/phpunit: >=8.0
This package is auto-updated.
Last update: 2025-01-16 20:43:47 UTC
README
Given a list of IP address ranges, minify that list to the smallest possible size by performing the following optimizations:
- removing invalid IP addresses/ranges from the list
- removing duplicates
- removing IP ranges already covered by larger ranges in the list
- merging adjacent IP ranges into larger, contiguous blocks
⭐ Demo
An online tool that uses a near exact version of this library:
Installation
composer require athlon1600/php-cidr-range-optimizer
Usage
Build your list of IP ranges into CIDRList
object, then use RangeOptimizer
class to optimize it. Example:
use ProxyNova\RangeOptimizer\CIDRList; use ProxyNova\RangeOptimizer\RangeOptimizer; $ranges = CIDRList::fromArray([ "192.168.1.0/26", "192.168.1.64/27", "192.168.1.96/27", "10.1.0.0/26", "10.1.0.64/26" ]); // returns new optimized CIDRList object $optimized = RangeOptimizer::optimize($ranges); echo $optimized;
Output:
10.1.0.0/25
192.168.1.0/25