blob: 34853a61580ceadf7e7fbfe8f1f8a6ad8ccbaf25 [file] [log] [blame]
stevenvanrossemc5a536a2016-02-16 14:52:39 +01001"""
stevenvanrossemadfd06f2016-04-22 10:39:08 +02002son-emu monitor CLI
stevenvanrossemc5a536a2016-02-16 14:52:39 +01003(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)
stevenvanrossemb098cb52016-04-15 13:28:23 +020039
stevenvanrossembbdb5ee2016-04-15 15:18:44 +020040 def stop_metric(self, args):
stevenvanrossemb098cb52016-04-15 13:28:23 +020041 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
42 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
stevenvanrossem300e1e52016-04-22 22:17:51 +020043 r = self.c.stop_metric(
stevenvanrossemed711fd2016-04-11 16:59:29 +020044 vnf_name,
45 vnf_interface,
stevenvanrossemed711fd2016-04-11 16:59:29 +020046 args.get("metric"))
stevenvanrossemb098cb52016-04-15 13:28:23 +020047 pp.pprint(r)
stevenvanrossemc5a536a2016-02-16 14:52:39 +010048
stevenvanrossem461941c2016-05-10 11:41:29 +020049 def setup_flow(self, args):
50 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
51 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
52 r = self.c.setup_flow(
53 vnf_name,
54 vnf_interface,
55 args.get("metric"),
56 args.get("cookie"))
57 pp.pprint(r)
58
stevenvanrossem81955a52016-05-12 14:34:12 +020059 def stop_flow(self, args):
60 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
61 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
62 r = self.c.stop_flow(
63 vnf_name,
64 vnf_interface,
65 args.get("metric"),
66 args.get("cookie"))
67 pp.pprint(r)
68
stevenvanrossem461941c2016-05-10 11:41:29 +020069 def prometheus(self, args):
70 vnf_name = self._parse_vnf_name(args.get("vnf_name"))
71 vnf_interface = self._parse_vnf_interface(args.get("vnf_name"))
72 r = self.c.prometheus(
73 args.get("datacenter"),
74 vnf_name,
75 vnf_interface,
76 args.get("query"))
77 pp.pprint(r)
78
79
stevenvanrossemed711fd2016-04-11 16:59:29 +020080 def _parse_vnf_name(self, vnf_name_str):
81 vnf_name = vnf_name_str.split(':')[0]
82 return vnf_name
83
84 def _parse_vnf_interface(self, vnf_name_str):
85 try:
86 vnf_interface = vnf_name_str.split(':')[1]
87 except:
88 vnf_interface = None
89
90 return vnf_interface
stevenvanrossemc5a536a2016-02-16 14:52:39 +010091
stevenvanrossem461941c2016-05-10 11:41:29 +020092parser = argparse.ArgumentParser(description='son-emu monitor')
stevenvanrossemc5a536a2016-02-16 14:52:39 +010093parser.add_argument(
94 "command",
stevenvanrossem81955a52016-05-12 14:34:12 +020095 choices=['setup_metric', 'stop_metric', 'setup_flow', 'stop_flow','prometheus'],
stevenvanrossem1ef77022016-05-12 16:36:10 +020096 help="setup/stop a metric/flow to be monitored or Prometheus query")
stevenvanrossemc5a536a2016-02-16 14:52:39 +010097parser.add_argument(
98 "--vnf_name", "-vnf", dest="vnf_name",
stevenvanrossembbdb5ee2016-04-15 15:18:44 +020099 help="vnf name:interface to be monitored")
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100100parser.add_argument(
stevenvanrossemed711fd2016-04-11 16:59:29 +0200101 "--metric", "-m", dest="metric",
stevenvanrossema24b4372016-04-14 09:55:20 +0200102 help="tx_bytes, rx_bytes, tx_packets, rx_packets")
stevenvanrossem461941c2016-05-10 11:41:29 +0200103parser.add_argument(
104 "--cookie", "-c", dest="cookie",
105 help="flow cookie to monitor")
106parser.add_argument(
107 "--query", "-q", dest="query",
108 help="prometheus query")
109parser.add_argument(
110 "--datacenter", "-d", dest="datacenter",
111 help="Data center where the vnf is deployed")
stevenvanrossem994245b2016-05-04 12:36:57 +0200112
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100113def main(argv):
stevenvanrossema24b4372016-04-14 09:55:20 +0200114 #print "This is the son-emu monitor CLI."
115 #print "Arguments: %s" % str(argv)
stevenvanrossemc5a536a2016-02-16 14:52:39 +0100116 args = vars(parser.parse_args(argv))
117 c = ZeroRpcClient()
118 c.execute_command(args)