A stand-alone class implementation of the IPv4+IPv6 IP+CIDR aggregator from CIDRAM.
How to install:
As a stand-alone PHP class, installing it is exceptionally easy. You can download the file containing the class, Aggregator.php, directly from this repository, and copy it to any projects that need it, or, if you'd prefer, you can install it using Composer:
composer require cidram/aggregator
Note: The code in this class is based upon code in the CIDRAM package, but the two are NOT dependent on each other.
After you've downloaded the file, to allow your projects to use the class, PSR-4 autoloading is preferred (particularly if you're using a large number of different, unrelated classes). If you're installing the class via Composer, all you have to do is
require_once 'vendor/autoload.php'; and everything will be taken care of. Alternatively, if you're installing it manually (or without Composer), and don't want to use a PSR-4 autoloader, you can simply require or include the class into your projects (which may be much easier in many cases) by including the respective statement to point to the class file in the relevant PHP files.
How to use:
The simplest way to use Aggregator is to create a new instance of the class and enter some data to be aggregated as a parameter to the aggregate method. The aggregate method will return an aggregate of the entered data.
<?php use \CIDRAM\Aggregator\Aggregator; $Aggregator = new Aggregator(); $Output = $Aggregator->aggregate($Input);
Or, if the file
helpers.php is loaded, this function will be available:
$Output = aggregate($Input);
Note: The function
aggregate will be available if you installed the package via
composer, but otherwise, you'll need to include the file
In the case of the above example, if this is entered as
127.0.0.1 Some arbitrary single IPs from here 127.0.0.2 127.0.0.3 1:: 1::1 1:2:3:4:: 1:2:3:4::1 1:2:3:4::2 1:2:3:4::3 2002::1 127.0.0.4 127.0.0.5 2184.108.40.2069 Some arbitrary INVALID single IPs from here 555.666.777.888 2002:abcd:efgh::1 10.0.0.0/9 Some arbitrary CIDRs from here 10.128.0.0/9 10.192.0.0/10 220.127.116.11/10 18.104.22.168/10 22.214.171.124/9 126.96.36.199/9 188.8.131.52/9 184.108.40.206/9 192.168.0.0/8 Some arbitrary INVALID CIDRs from here 192.168.0.0/9 192.168.0.0/10 192.168.192.0/10 220.127.116.11/10 18.104.22.168/10 22.214.171.124/255.255.255.254 Some arbitrary netmasks from here 126.96.36.199/255.255.255.255 188.8.131.52/255.255.255.255 184.108.40.206/255.255.255.0 220.127.116.11/255.255.255.0 18.104.22.168/255.252.0.0 22.214.171.124/126.96.36.199 Some arbitrary INVALID netmasks from here 255.255.255.254/188.8.131.52 184.108.40.206/255.255.255.254 220.127.116.11/255.255.254.255 Foobar Some garbage data from here ASDFQWER!@#$ >>HelloWorld<< SDFSDFSDF QWEQWEQWE
$Output will be expected to contain this:
18.104.22.168/31 22.214.171.124/32 10.0.0.0/8 126.96.36.199/9 188.8.131.52/7 184.108.40.206/14 220.127.116.11/32 127.0.0.1/32 127.0.0.2/31 127.0.0.4/31 1::/127 1:2:3:4::/126 2002::1/128
Data is newline-delimited and each line represents one item to be aggregated. Aggregator handles IPv4+IPv6 seamlessly, attempts to clean up each item (i.e., remove invalid and superfluous data in order to reduce to a valid IP, CIDR, or netmask), attempts to aggregate the resultant cleaned up data (unreadable and invalid data is rejected), and then returns the resultant aggregated data.
It is possible to obtain more information about each aggregation operation if desired. If "Results" is set to
true (it is
false by default), then "NumberEntered" (the total number of lines entered when an operation begins), "NumberRejected" (the number of lines or items "rejected", i.e., perceived as invalid, or unreadable; note that this number will also also duplicate items, due to that duplicates are stripped along with invalid and superfluous data prior to aggregation), "NumberAccepted" (the number of lines or items accepted for aggregation; i.e.,
NumberAccepted = NumberEntered - NumberRejected), "NumberMerged" (the total number of items aggregated or merged), and "NumberReturned" (the total number of items returned at the end of an operation) will be populated during operation accordingly. These values can be retrieved after each operation from the class instance or object:
<?php use \CIDRAM\Aggregator\Aggregator; $Aggregator = new Aggregator(); $Aggregator->Results = true; $Output = $Aggregator->aggregate($Input); echo $Output; echo "\n\n"; echo $Aggregator->NumberEntered . "\n"; echo $Aggregator->NumberRejected . "\n"; echo $Aggregator->NumberAccepted . "\n"; echo $Aggregator->NumberMerged . "\n"; echo $Aggregator->NumberReturned . "\n";
Generally, it is better to create a new class instance for each aggregation operation. However, if you want to recycle an old instance, and want to continue to retrieve these values after each operation, you can reset these values to their initial state between operations by using the "resetNumbers" method:
Regardless of whether "Results" is
false, after each aggregation operation, "ProcessingTime" will be available, in case you want to know how much was consumed during the operation. This could be useful both for debugging and for general vanity purposes.
<?php use \CIDRAM\Aggregator\Aggregator; $Aggregator = new Aggregator(); $Output = $Aggregator->aggregate($Input); echo $Aggregator->ProcessingTime . "\n";
Additionally, "ExpandIPv4" and "ExpandIPv6" public methods are provided with the class, and they function in exactly the same way their CIDRAM package closure counterparts. Calling either of these with an IPv4 or IPv6 IP address respectively will return an array containing the potential factors for the given IP address. The potential factors are all possible subnets (or CIDRs) that the given IP address is a member of. When a valid IP address is supplied, "ExpandIPv4" and "ExpandIPv6" and should return an array with 32 and 128 elements respectively.
If you want Aggregator to return results as netmasks instead of CIDRs, you can instantiate the object with a parameter value of
1, like this:
<?php use \CIDRAM\Aggregator\Aggregator; $Aggregator = new Aggregator(1); $Output = $Aggregator->aggregate($Input);
In the case of the example input mentioned earlier, the output should look something like this:
18.104.22.168/255.255.255.254 22.214.171.124/255.255.255.255 10.0.0.0/255.0.0.0 126.96.36.199/255.128.0.0 188.8.131.52/254.0.0.0 184.108.40.206/255.252.0.0 220.127.116.11/255.255.255.255 127.0.0.1/255.255.255.255 127.0.0.2/255.255.255.254 127.0.0.4/255.255.255.254 1::/ffff:ffff:ffff:ffff:ffff:ffff:ffff:fffe:0 1:2:3:4::/ffff:ffff:ffff:ffff:ffff:ffff:ffff:fffc:0 2002::1/ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff:0
Licensed as GNU General Public License version 2.0 (GPLv2).
Please use the issues page of this repository.
Last Updated: 27 January 2019 (2019.01.27).