summaryrefslogtreecommitdiffstats
path: root/retiolum
diff options
context:
space:
mode:
authorLassulus <Lassulus@googlemail.com>2011-05-11 14:05:30 +0200
committerLassulus <Lassulus@googlemail.com>2011-05-11 14:05:30 +0200
commite3f90c0c1375857d6a0a5f94ebbdec987e0f5a26 (patch)
tree1856e32c929b2e18ebbc3cc0c95c10a53040d5a0 /retiolum
parent53bd7c025d30e0bb1bf69e50458dd7fb9fbb6a88 (diff)
parent638c7d31953cfa73e5efecabf0bdb62276ae44fa (diff)
Merge branch 'master' of github.com:miefda/retiolum
Diffstat (limited to 'retiolum')
-rwxr-xr-xretiolum/hosts/.scripts/parse.py81
-rwxr-xr-xretiolum/hosts/.scripts/sanitize.sh8
2 files changed, 89 insertions, 0 deletions
diff --git a/retiolum/hosts/.scripts/parse.py b/retiolum/hosts/.scripts/parse.py
new file mode 100755
index 00000000..54f6c35d
--- /dev/null
+++ b/retiolum/hosts/.scripts/parse.py
@@ -0,0 +1,81 @@
+#!/usr/bin/python2
+
+import sys
+""" TODO: Refactoring needed to pull the edges out of the node structures again,
+it should be easier to handle both structures"""
+
+def write_digraph(nodes):
+ """
+ writes the complete digraph in dot format
+ """
+ print ('graph retiolum {')
+ print (' node[shape=box,style=filled,fillcolor=grey]')
+ generate_stats(nodes)
+ merge_edges(nodes)
+ for k,v in nodes.iteritems():
+ write_node(k,v)
+ print ('}')
+def generate_stats(nodes):
+ """ Generates some statistics of the network and nodes
+ """
+ for k,v in nodes.iteritems():
+ v['num_conns'] = len(v.get('to',[]))
+
+def merge_edges(nodes):
+ """ merge back and forth edges into one
+ DESTRUCTS the current structure by deleting "connections" in the nodes
+
+ """
+ for k,v in nodes.iteritems():
+ for con in v.get('to',[]):
+ for i,secon in enumerate(nodes[con['name']].get('to',[])):
+ if k == secon['name']:
+ del (nodes[con['name']]['to'][i])
+
+
+def write_node(k,v):
+ """ writes a single node and its edges """
+ node = " "+k+"[label=\""
+ node += k+"\\l"
+ node += "external:"+v['external-ip']+":"+v['external-port']+"\\l"
+ if v.has_key('num_conns'):
+ node += "Num Connects:"+str(v['num_conns'])+"\\l"
+ node += "internal:"+v['internal-ip']+"\\l\""
+ if v['external-ip'] == "MYSELF":
+ node += ",fillcolor=steelblue1"
+ node += "]"
+ print (node)
+ for con in v.get('to',[]):
+ print " "+k+ " -- " +con['name'] + "[weight="+str(10/float(con['weight']))+"]"
+
+def parse_input():
+ nodes={}
+ for line in sys.stdin:
+ line = line.replace('\n','')
+ if line == 'Nodes:':
+ nodes={}
+ for line in sys.stdin:
+ if line == 'End of nodes.\n':
+ break
+ l = line.replace('\n','').split() #TODO unhack me
+ nodes[l[0]]= { 'external-ip': l[2], 'external-port' : l[4] }
+ if line == 'Subnet list:':
+ for line in sys.stdin:
+ if line == 'End of subnet list.\n':
+ break
+ l = line.replace('\n','').split()
+ nodes[l[2]]['internal-ip'] = l[0].split('#')[0]
+ if line == 'Edges:':
+ edges = {}
+ for line in sys.stdin:
+ if line == 'End of edges.\n':
+ break
+ l = line.replace('\n','').split()
+
+ if not nodes[l[0]].has_key('to') :
+ nodes[l[0]]['to'] = []
+ nodes[l[0]]['to'].append(
+ {'name':l[2],'addr':l[4],'port':l[6],'weight' : l[10] })
+ return nodes
+nodes = parse_input()
+write_digraph(nodes)
diff --git a/retiolum/hosts/.scripts/sanitize.sh b/retiolum/hosts/.scripts/sanitize.sh
new file mode 100755
index 00000000..83f45aef
--- /dev/null
+++ b/retiolum/hosts/.scripts/sanitize.sh
@@ -0,0 +1,8 @@
+GRAPH_SETTER=dot
+LOG_FILE=/var/log/everything.log
+
+sudo pkill -USR2 tincd
+sudo sed -n '/tinc.retiolum/{s/.*tinc.retiolum\[[1-9]*\]: //gp}' $LOG_FILE |\
+ ./parse.py | tee retiolum.dot |\
+ $GRAPH_SETTER -Tpng -o retiolum.png
+xdg-open retiolum.png