X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=src%2Femuvim%2Fcli%2Frest%2Fmonitor.py;h=8be1e7f2f0bd57b09d8a018c009de34feea6fbc1;hb=c62be48ec66570a0aba61cd680a37698d1e2626a;hp=7e9b83923e4ef88e4dc97032e2831b6a1d9c7b40;hpb=aba0a5ebb8a7c606e988bbbb01c7875447d23ebe;p=osm%2Fvim-emu.git diff --git a/src/emuvim/cli/rest/monitor.py b/src/emuvim/cli/rest/monitor.py index 7e9b839..8be1e7f 100755 --- a/src/emuvim/cli/rest/monitor.py +++ b/src/emuvim/cli/rest/monitor.py @@ -25,11 +25,10 @@ the Horizon 2020 and 5G-PPP programmes. The authors would like to acknowledge the contributions of their colleagues of the SONATA partner consortium (www.sonata-nfv.eu). """ + from requests import get, put, delete -from tabulate import tabulate import pprint import argparse -import json from emuvim.cli import prometheus pp = pprint.PrettyPrinter(indent=4) @@ -47,52 +46,47 @@ class RestApiClient(): print("Command not implemented.") def setup_metric(self, args): - vnf_name = self._parse_vnf_name(args.get("vnf_name")) - vnf_interface = self._parse_vnf_interface(args.get("vnf_name")) - response = put("%s/restapi/monitor/%s/%s/%s" % - (args.get("endpoint"), - vnf_name, - vnf_interface, - args.get("metric"))) - pp.pprint(response.json()) + params = self._create_dict( + vnf_name=self._parse_vnf_name(args.get("vnf_name")), + vnf_interface = self._parse_vnf_interface(args.get("vnf_name")), + metric = args.get("metric")) + + url = "{0}/restapi/monitor/interface".format(args.get("endpoint")) + response = put(url, params=params) + pp.pprint(response.text) def stop_metric(self, args): - vnf_name = self._parse_vnf_name(args.get("vnf_name")) - vnf_interface = self._parse_vnf_interface(args.get("vnf_name")) + params = self._create_dict( + vnf_name=self._parse_vnf_name(args.get("vnf_name")), + vnf_interface=self._parse_vnf_interface(args.get("vnf_name")), + metric=args.get("metric")) - response = delete("%s/restapi/monitor/%s/%s/%s" % - (args.get("endpoint"), - vnf_name, - vnf_interface, - args.get("metric"))) - pp.pprint(response.json()) + url = "{0}/restapi/monitor/interface".format(args.get("endpoint")) + response = put(url, params=params) + pp.pprint(response.text) def setup_flow(self, args): - vnf_name = self._parse_vnf_name(args.get("vnf_name")) - vnf_interface = self._parse_vnf_interface(args.get("vnf_name")) - - response = put("%s/restapi/monitor/%s/%s/%s/%s" % - (args.get("endpoint"), - vnf_name, - vnf_interface, - args.get("metric"), - args.get("cookie"))) + params = self._create_dict( + vnf_name=self._parse_vnf_name(args.get("vnf_name")), + vnf_interface=self._parse_vnf_interface(args.get("vnf_name")), + metric=args.get("metric"), + cookie=args.get("cookie")) - pp.pprint(response.json()) + url = "{0}/restapi/monitor/flow".format(args.get("endpoint")) + response = put(url, params=params) + pp.pprint(response.text) def stop_flow(self, args): - vnf_name = self._parse_vnf_name(args.get("vnf_name")) - vnf_interface = self._parse_vnf_interface(args.get("vnf_name")) + params = self._create_dict( + vnf_name=self._parse_vnf_name(args.get("vnf_name")), + vnf_interface=self._parse_vnf_interface(args.get("vnf_name")), + metric=args.get("metric"), + cookie=args.get("cookie")) - response = delete("%s/restapi/monitor/%s/%s/%s/%s" % - (args.get("endpoint"), - vnf_name, - vnf_interface, - args.get("metric"), - args.get("cookie"))) - - pp.pprint(response.json()) + url = "{0}/restapi/monitor/flow".format(args.get("endpoint")) + response = put(url, params=params) + pp.pprint(response.text) def prometheus(self, args): # This functions makes it more user-friendly to create the correct prometheus query @@ -101,6 +95,7 @@ class RestApiClient(): vnf_interface = self._parse_vnf_interface(args.get("vnf_name")) dc_label = args.get("datacenter") query = args.get("query") + vnf_status = get("%s/restapi/compute/%s/%s" % (args.get("endpoint"), args.get("datacenter"), @@ -123,7 +118,10 @@ class RestApiClient(): return vnf_interface -parser = argparse.ArgumentParser(description='son-emu monitor') + def _create_dict(self, **kwargs): + return kwargs + +parser = argparse.ArgumentParser(description='son-emu-cli monitor') parser.add_argument( "command", choices=['setup_metric', 'stop_metric', 'setup_flow', 'stop_flow','prometheus'], @@ -146,7 +144,7 @@ parser.add_argument( parser.add_argument( "--endpoint", "-e", dest="endpoint", default="http://127.0.0.1:5001", - help="UUID of the plugin to be manipulated.") + help="REST API endpoint of son-emu (default:http://127.0.0.1:5001)") def main(argv): args = vars(parser.parse_args(argv))