Skip to main content

IPv4 and IPv6 prefix list compressor

Project description

Requirements Status Coverage Status

aggregate6

aggregate6 will compress an unsorted list of IP prefixes (both IPv4 and IPv6).

Description

Takes a list of IPv6 prefixes in conventional format on stdin, and performs two optimisations to attempt to reduce the length of the prefix list. The first optimisation is to remove any supplied prefixes which are superfluous because they are already included in another supplied prefix. For example, 2001:67c:208c:10::/64 would be removed if 2001:67c:208c::/48 was also supplied.

The second optimisation identifies adjacent prefixes that can be combined under a single, shorter-length prefix. For example, 2001:67c:208c::/48 and 2001:67c:208d::/48 can be combined into the single prefix 2001:67c:208c::/47.

The above optimalisation steps are often useful in context of compressing firewall rules or BGP prefix-list filters.

The following command line options are available:

-4          Only output IPv4 prefixes
-6          Only output IPv6 prefixes
-h, --help  show help message and exit
-m N        Sets the maximum prefix length for entries read, longer prefixes will be discarded prior to processing
-t          truncate IP/mask to network/mask
-v          Display verbose information about the optimisations
-V          Display aggregate6 version

Installation

OpenBSD:

$ doas pkg_add aggregate6

CentOS/RHEL/Rocky:

$ yum install epel-release
$ yum install aggregate6

Fedora:

$ dnf install aggregate6

Other platforms:

$ pip3 install aggregate6

CLI Usage

Either provide the list of IPv4 and IPv6 prefixes on STDIN, or give filenames containing lists of IPv4 and IPv6 prefixes as arguments.

$ # via STDIN
$ cat file_with_list_of_prefixes | aggregate6
   ... output ...

$ # with a filename as argument
$ aggregate6 file_with_list_of_prefixes [ ... optional_other_prefix_lists ]
   ... output ...

$ # Whitespace separated works too
$ echo 2001:67c:208c::/48 2000::/3 | aggregate6
2000::/3

$ # You can combine IPv4 and IPv6
$ echo 10.0.0.0/16 10.0.0.0/24 2000::/3 | aggregate6
10.0.0.0/16
2000::/3

Library Usage

Aggregate6 can be used in your own pyp/python2/python3 project as python module. Currently there is just one simple public function: aggregate() which takes a list as parameter.

>>> from aggregate6 import aggregate
>>> aggregate(["10.0.0.0/8", "10.0.0.0/24"])
['10.0.0.0/8']
>>>

Bugs

Please report bugs at https://github.com/job/aggregate6/issues

Author

Job Snijders job@instituut.net

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aggregate6-1.0.14.tar.gz (8.9 kB view details)

Uploaded Source

File details

Details for the file aggregate6-1.0.14.tar.gz.

File metadata

  • Download URL: aggregate6-1.0.14.tar.gz
  • Upload date:
  • Size: 8.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for aggregate6-1.0.14.tar.gz
Algorithm Hash digest
SHA256 425a3a7934935f9ff439bdbb3ada6218f61a1d2a3ef37f0f856313ca5709c07c
MD5 76280715e5a509c823eab61071c6cfb6
BLAKE2b-256 e1215779f94817a7a83bb19855c1c807b39db7456d27128f40bdb4ee96185050

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page