/AalWiNes

Primary LanguageC++GNU General Public License v3.0GPL-3.0

AalWiNes (Aalborg Wien Network Suite)

DOI

Compilation

Requirements for compilation:

build-essential flex bison cmake libboost-all-dev

For Ubuntu 19.10 (ssh keys must be already configured for github):

# install prerequisites 
sudo apt update
sudo apt upgrade
sudo apt install build-essential flex bison cmake libboost-all-dev libfl-dev


# get aalwines (P-Rex v2) and compile
git clone git@github.com:DEIS-Tools/aalwines.git
cd aalwines
mkdir build
cd build
cmake -DCMAKE_BUILD_TYPE=Release ..
make 
#export MOPED_PATH=`pwd`/../bin/moped
# binary will be in build/bin

Option for pseudo static linkage -> binary will not need libboost and other libs installed on target system:

cmake -DAALWINES_BuildBundle=ON -DCMAKE_BUILD_TYPE=Release ..

Usage Examples

This will run queryfile query.txt and weightfile weight.json over the network defined in the P-Rex data files, using Post* implementation as engine and producing a trace:

cd bin
./aalwines --topology ../../example_net/Agis-topo.xml --routing ../../example_net/Agis-routing.xml -w ../../example_net/Agis-weight.json -q ../../example_net/Agis-query.q -t -e 2

An example query.txt (syntax see below):

<.> [.#Stockton] .* [Santa_Clara#.] <.> 0 DUAL
<.> [.#Chicago] [^.#Los_Angeles]* [Santa_Clara#.] <.> 1 DUAL

An example weight.json (syntax see below):

[
        [
                {"atom": "tunnels"}
        ],
        [
                {"atom": "local_failures"},
                {"atom": "hops", "factor": 2}
        ]
]

will produce following output:

{
        "network-parsing-time":0.661911, "query-parsing-time":0.0021034,
        "answers":{
        "Q1" : {
                "result":   true,
                "engine":   "Post*",
                "mode":     "OVER",
                "reduction":[70918, 70918],
                "trace-weight": [0, 4],
                "trace":[
                        {"router":"Stockton","stack":["1599^"]},
                        {"ingoing":"iStockton","pre":"1599^","rule":{"weight":0, "via":"Santa_Clara", "ops":[{"swap":"1600"}]}, "priority-weight": ["0", "2"]},
                        {"router":"Santa_Clara","stack":["1600"]},
                        {"ingoing":"Stockton","pre":"1600","rule":{"weight":0, "via":"Los_Angeles", "ops":[{"swap":"1601"}]}, "priority-weight": ["0", "2"]},
                        {"router":"Los_Angeles","stack":["1601"]}
                ],
                "compilation-time":0.303446,
                "reduction-time":0.0012157,
                "verification-time":1.24293
        },
        "Q2" : {
                "result": true,
                "engine": "Post*",
                "mode":   "OVER",
                "reduction":[129519, 129519],
                "trace-weight": [1, 9],
                "trace":[
                        {"router":"Chicago","stack":["2922"]},
                        {"ingoing":"St_Louis","pre":"2922","rule":{"weight":1, "via":"Seattle", "ops":[{"swap":"2923"}, {"push":"3452"}]}, "priority-weight": ["1", "3"]},
                        {"router":"Seattle","stack":["3452","2923"]},
                        {"ingoing":"Chicago","pre":"3452","rule":{"weight":0, "via":"San_Francisco", "ops":[{"swap":"3451"}]}, "priority-weight": ["0", "2"]},
                        {"router":"San_Francisco","stack":["3451","2923"]},
                        {"ingoing":"Seattle","pre":"3451","rule":{"weight":0, "via":"Santa_Clara", "ops":[{"swap":"3450"}]}, "priority-weight": ["0", "2"]},
                        {"router":"Santa_Clara","stack":["3450","2923"]},
                        {"ingoing":"San_Francisco","pre":"3450","rule":{"weight":0, "via":"Los_Angeles", "ops":["pop"]}, "priority-weight": ["0", "2"]},
                        {"router":"Los_Angeles","stack":["2923"]}
                ],
                "compilation-time":0.484016,
                "reduction-time":0.0026069,
                "verification-time":2.01965
        }
}
}

Query Syntax

A query file contains one or more queries. They can be separated by space or new line. Each query consists out of following parts:

<preCondition> path <postCondition> linkFailures mode
part type description
preCondition regex-list labels before first router
path regex-list path through the network
postCondition regex-list labels after last router
linkFailures number maximum failed links
mode enum simulation mode: one out of OVER, UNDER, DUAL, EXACT

The type regex-list is a space separated list of regular expressions (syntax see below). For preCondition and postCondition it defines the labels on the stack of the packet. Packets must have at least 1 label when entering or leaving the network. For path it defines the interfaces(routers) the packet must, can or must not follow.

The mode can be OVER or UNDER. DUAL is a combination of OVER and UNDER. EXACT is not supported yet.

Weight Syntax

A weight file contains a priority in the outer array. The inner array contains the linear combination of atoms.

[
        [
                {"atom": ATOM, "factor": NUM},
                ...
        ], 
        ...
]

ATOM = {links, hops, distance, local_failures, tunnels, }

NUM = {0,1,2,...} factor is optional and NUM default is 1.

The different priority groups, of linear combinations, represent the order of which the weights are compared. The second priority group will be considered if two similar weighted traces in the first linear combination are equal.

links minimize the number of links in the trace.

hops minimize the number of hops (not counting links that are self-loops) in the trace.

distance minimize the accumulated distance between routers estimated from router coordinates.

local_failures minimize the sum of locally counted failed links at each router on the trace. This number may be higher than the global number of failed links in the case of loops, since some links may be counted twice.

tunnels minimize the number of push operations in the trace.

Regular Expression Syntax (regex)

Every regular expression in the regex-list is built out of following components:

syntax description
regex | regex OR: one or both regex must be fulfilled
. matches everything
regex+ multiple: regex must match once or multiple times
regex* optional multiple: regex must match zero, one or multiple times
regex? optional: regex must match zero or one time
[atom-list] matches the atom_list (see below)
[^atom-list] matches everything except the atom_list
ip matches any ip address
mpls matches any non-sticky mpls label
smpls matches any sticky mpls label
(regex-list) must match the given sub regex-list

The atom-list contains a comma separated list of atoms (for path) or labels(for preCondition and postCondition).

Only labels are allowed in preCondition and postCondition and only Atoms in the path.

The semantics of an atom-list is that of union (OR) and the negation-symbol ^ is intepreted as complement of the following atom-list.

Atom Syntax

An atom defines a hop between routers via their exit and entry interfaces. An atom-list with one entry looks like:

[exit_if#entry_if]

with multiple entries the syntax is:

[exit_if1#entry_if1,exit_if2#entry_if2,...]

Following possibilities can be used for entry_if and exit_if:

syntax description
name the router name (matches any interface of that router)
name.name specific interface of router
. any interface on any router

name itself can be either an identifier (starting with a character; defining an exact interface) or a literal (a double-quoted regular expression matching interfaces "regex"). The regex-matching of name is implemented via boost::basic_regex and follows this semantics.

Label Syntax

The syntax of a list with labels is:

syntax description
[$label] A sticky label. Can be used with all following types
[label1,label2] A list of labels. Can be used with all following types
[number] A mpls label with number
[number/mask] A range of mpls labels, specified by number and a mask in bits
[ip] An ip label. Can be an ipv4 or an ipv6 address
[ip/mask] An ip network. An ipv4 or an ipv6 address together with a mask in bits