EmanueleGallone / RyuTries

IP Lookup tries

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Tries data structures made for IP lookups in Ryu Framework

Getting started

Binary Trie

Usage:

import BinaryNode

to use a custom prefix table:

  • just edit the db.txt file. Be careful to respect the file format (ip\mask, ip_in_binary)

create the Binary Trie:

root = BinaryNode.Create('Default value')

where the 'Default value' is the default prefix that is returned whenever the lookup fails (e.g. '0')

find longest prefix match:

root.Lookup(ip_bin)

where ip_bin is the binary representation of the ip.

e.g. ip to lookup =189.xxx.xxx.xxx\6 -> 101111 :

result = root.Lookup("001101")

Alternative:

You can also build manually the trie (the 'db.txt' file will be ignored):

import BinaryTrie

root = BinaryNode.BinaryNode('0')
root.AddChild("189.xxx.xxx.xxx", '101111')

Multibit Trie

Usage:

import MultibitNode

to use a custom prefix table:

  • just edit the db.txt file. Be careful to respect the file format (ip\mask, ip_in_binary)

EXPERIMENTAL: You can also change the Stride of the Trie:

MultibitTrie.STRIDE = 2

Create the Trie:

root = MultibitNode.Create()

find longest prefix match:

MultibitNode.Lookup(binary_address, 'Default value')

where:

  • binary_address is the binary representation of an IP address
  • 'Default value' is the value the is returned in case Lookup fails (e.g. '0'):

Compressed Trie

Usage:

import CompressedNode

to use a custom prefix table:

  • just edit the db.txt file. Be careful to respect the file format (ip\mask, ip_in_binary)

Create the Trie:

root = CompressedNode.Create("Default_value")

where Default_value is the value that is returned whenever the Lookup fails.

Find the longest prefix:

result = CompressedNode.Lookup("0101101")

Alternative:

You can also build manually the trie (the 'db.txt' file will be ignored):

import CompressedNode

root = CompressedNode.CompressedNode('0')
root.AddChild('189.xxx.xxx.xxx', '101111')
root.AddChild('93.91.xxx.xxx', '0101110101011011')  # that is 93.91.xxx.xxx\16
.
.

root.Compress()

About

IP Lookup tries

License:MIT License


Languages

Language:Python 100.0%