blob: 1d4abfbb09bdf92e6384aeef2fd8fc660c6aad9a [file] [log] [blame]
stevenvanrossemc5a536a2016-02-16 14:52:39 +01001"""
2son-emu network CLI
3(c) 2016 by Manuel Peuster <manuel.peuster@upb.de>
4"""
5
6import argparse
7import pprint
8from tabulate import tabulate
9import zerorpc
stevenvanrossem9315da42016-04-11 12:10:06 +020010import time
stevenvanrossemc5a536a2016-02-16 14:52:39 +010011
12
13pp = pprint.PrettyPrinter(indent=4)
14
15class ZeroRpcClient(object):
16
17 def __init__(self):
18 self.c = zerorpc.Client()
19 # TODO connect to DCNetwork API
20 #self.c.connect("tcp://127.0.0.1:4242") # TODO hard coded for now. we'll change this later
21 self.c.connect("tcp://127.0.0.1:5151")
22 self.cmds = {}
23
24 def execute_command(self, args):
25 if getattr(self, args["command"]) is not None:
26 # call the local method with the same name as the command arg
27 getattr(self, args["command"])(args)
28 else:
29 print "Command not implemented."
30
stevenvanrossema24b4372016-04-14 09:55:20 +020031 def setup_metric(self, args):
stevenvanrossemed711fd2016-04-11 16:59:29 +020032 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
33 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
stevenvanrossema24b4372016-04-14 09:55:20 +020034 r = self.c.setup_metric(
35 vnf_name,
36 vnf_interface,
37 args.get("metric"))
38 pp.pprint(r)
39 '''
stevenvanrossemed711fd2016-04-11 16:59:29 +020040 self.c.monitor_setup_rate_measurement(
41 vnf_name,
42 vnf_interface,
stevenvanrossemed711fd2016-04-11 16:59:29 +020043 args.get("metric"))
stevenvanrossem9315da42016-04-11 12:10:06 +020044 while True:
45 r = self.c.monitor_get_rate(
stevenvanrossemed711fd2016-04-11 16:59:29 +020046 vnf_name,
47 vnf_interface,
stevenvanrossemed711fd2016-04-11 16:59:29 +020048 args.get("metric"))
stevenvanrossem9315da42016-04-11 12:10:06 +020049 pp.pprint(r)
50 time.sleep(1)
stevenvanrossema24b4372016-04-14 09:55:20 +020051 '''
stevenvanrossemc5a536a2016-02-16 14:52:39 +010052
stevenvanrossemed711fd2016-04-11 16:59:29 +020053 def _parse_vnf_name(self, vnf_name_str):
54 vnf_name = vnf_name_str.split(':')[0]
55 return vnf_name
56
57 def _parse_vnf_interface(self, vnf_name_str):
58 try:
59 vnf_interface = vnf_name_str.split(':')[1]
60 except:
61 vnf_interface = None
62
63 return vnf_interface
stevenvanrossemc5a536a2016-02-16 14:52:39 +010064
65parser = argparse.ArgumentParser(description='son-emu network')
66parser.add_argument(
67 "command",
68 help="Action to be executed: get_rate")
69parser.add_argument(
70 "--vnf_name", "-vnf", dest="vnf_name",
71 help="vnf name to be monitored")
72parser.add_argument(
stevenvanrossemed711fd2016-04-11 16:59:29 +020073 "--metric", "-m", dest="metric",
stevenvanrossema24b4372016-04-14 09:55:20 +020074 help="tx_bytes, rx_bytes, tx_packets, rx_packets")
stevenvanrossemc5a536a2016-02-16 14:52:39 +010075
76def main(argv):
stevenvanrossema24b4372016-04-14 09:55:20 +020077 #print "This is the son-emu monitor CLI."
78 #print "Arguments: %s" % str(argv)
stevenvanrossemc5a536a2016-02-16 14:52:39 +010079 args = vars(parser.parse_args(argv))
80 c = ZeroRpcClient()
81 c.execute_command(args)