blob: 4869a17c1bde0764219c3bdedb4dab4beeadce53 [file] [log] [blame]
peusterm58310762016-01-12 17:09:20 +01001"""
2son-emu compute CLI
peusterm2ec74e12016-01-13 11:17:53 +01003(c) 2016 by Manuel Peuster <manuel.peuster@upb.de>
peusterm58310762016-01-12 17:09:20 +01004"""
5
6import argparse
7import pprint
peusterm2ec74e12016-01-13 11:17:53 +01008from tabulate import tabulate
peusterm58310762016-01-12 17:09:20 +01009import zerorpc
10
11
12pp = pprint.PrettyPrinter(indent=4)
13
14
15class ZeroRpcClient(object):
16
17 def __init__(self):
stevenvanrossem461941c2016-05-10 11:41:29 +020018 self.c = zerorpc.Client(heartbeat=None, timeout=120) #heartbeat=None, timeout=120
peusterm2ec74e12016-01-13 11:17:53 +010019 self.c.connect("tcp://127.0.0.1:4242") # TODO hard coded for now. we'll change this later
peusterm58310762016-01-12 17:09:20 +010020 self.cmds = {}
21
22 def execute_command(self, args):
23 if getattr(self, args["command"]) is not None:
24 # call the local method with the same name as the command arg
25 getattr(self, args["command"])(args)
26 else:
stevenvanrossem49378152016-05-19 11:33:48 +020027 print("Command not implemented.")
peusterm58310762016-01-12 17:09:20 +010028
29 def start(self, args):
peusterm7f8e8402016-02-28 18:38:10 +010030 nw_list = list()
peusterm45dce612016-01-29 15:34:38 +010031 if args.get("network") is not None:
stevenvanrossem14c89052016-04-10 23:49:59 +020032 nw_list = self._parse_network(args.get("network"))
peusterm58310762016-01-12 17:09:20 +010033 r = self.c.compute_action_start(
peusterm45dce612016-01-29 15:34:38 +010034 args.get("datacenter"),
35 args.get("name"),
36 args.get("image"),
stevenvanrossem994245b2016-05-04 12:36:57 +020037 nw_list,
38 args.get("docker_command")
stevenvanrossem6b1d9b92016-05-02 13:10:40 +020039 )
peusterm58310762016-01-12 17:09:20 +010040 pp.pprint(r)
41
42 def stop(self, args):
43 r = self.c.compute_action_stop(
44 args.get("datacenter"), args.get("name"))
45 pp.pprint(r)
46
47 def list(self, args):
peusterm2ec74e12016-01-13 11:17:53 +010048 r = self.c.compute_list(
49 args.get("datacenter"))
50 table = []
51 for c in r:
52 # for each container add a line to the output table
53 if len(c) > 1:
54 name = c[0]
55 status = c[1]
56 eth0ip = None
57 eth0status = "down"
58 if len(status.get("network")) > 0:
peusterma3ddeba2016-05-13 14:40:02 +020059 eth0ip = status.get("network")[0].get("ip")
peusterm2ec74e12016-01-13 11:17:53 +010060 eth0status = "up" if status.get(
peusterma3ddeba2016-05-13 14:40:02 +020061 "network")[0].get("up") else "down"
peusterm2ec74e12016-01-13 11:17:53 +010062 table.append([status.get("datacenter"),
63 name,
64 status.get("image"),
65 eth0ip,
66 eth0status,
67 status.get("state").get("Status")])
68 headers = ["Datacenter",
69 "Container",
70 "Image",
71 "eth0 IP",
72 "eth0 status",
73 "Status"]
stevenvanrossem49378152016-05-19 11:33:48 +020074 print(tabulate(table, headers=headers, tablefmt="grid"))
peusterm58310762016-01-12 17:09:20 +010075
76 def status(self, args):
peusterm2ec74e12016-01-13 11:17:53 +010077 r = self.c.compute_status(
78 args.get("datacenter"), args.get("name"))
79 pp.pprint(r)
peusterm58310762016-01-12 17:09:20 +010080
stevenvanrossem994245b2016-05-04 12:36:57 +020081 def profile(self, args):
82 nw_list = list()
83 if args.get("network") is not None:
84 nw_list = self._parse_network(args.get("network"))
stevenvanrossem5b376412016-05-04 15:34:49 +020085
86 params = self._create_dict(
87 network=nw_list,
88 command=args.get("docker_command"),
stevenvanrossembb084ef2016-05-20 09:27:01 +020089 image=args.get("image"),
stevenvanrossem5b376412016-05-04 15:34:49 +020090 input=args.get("input"),
91 output=args.get("output"))
92
stevenvanrossem461941c2016-05-10 11:41:29 +020093 for output in self.c.compute_profile(
stevenvanrossem994245b2016-05-04 12:36:57 +020094 args.get("datacenter"),
95 args.get("name"),
stevenvanrossembb084ef2016-05-20 09:27:01 +020096 params):
stevenvanrossem461941c2016-05-10 11:41:29 +020097 print(output + '\n')
98
99 #pp.pprint(r)
100 #print(r)
stevenvanrossem994245b2016-05-04 12:36:57 +0200101
stevenvanrossem5b376412016-05-04 15:34:49 +0200102 def _create_dict(self, **kwargs):
103 return kwargs
104
stevenvanrossem14c89052016-04-10 23:49:59 +0200105 def _parse_network(self, network_str):
106 '''
107 parse the options for all network interfaces of the vnf
108 :param network_str: (id=x,ip=x.x.x.x/x), ...
109 :return: list of dicts [{"id":x,"ip":"x.x.x.x/x"}, ...]
110 '''
111 nw_list = list()
112 networks = network_str[1:-1].split('),(')
113 for nw in networks:
114 nw_dict = dict(tuple(e.split('=')) for e in nw.split(','))
115 nw_list.append(nw_dict)
116
117 return nw_list
118
119
peusterm58310762016-01-12 17:09:20 +0100120
121parser = argparse.ArgumentParser(description='son-emu compute')
peusterm58310762016-01-12 17:09:20 +0100122parser.add_argument(
peusterm45dce612016-01-29 15:34:38 +0100123 "command",
stevenvanrossemedcbeeb2016-05-04 17:28:08 +0200124 choices=['start', 'stop', 'list', 'status', 'profile'],
peustermd313dc12016-02-04 15:36:02 +0100125 help="Action to be executed.")
peusterm58310762016-01-12 17:09:20 +0100126parser.add_argument(
peusterm45dce612016-01-29 15:34:38 +0100127 "--datacenter", "-d", dest="datacenter",
128 help="Data center to in which the compute instance should be executed")
peusterm7973f052016-01-29 14:38:05 +0100129parser.add_argument(
peusterm45dce612016-01-29 15:34:38 +0100130 "--name", "-n", dest="name",
131 help="Name of compute instance e.g. 'vnf1'")
132parser.add_argument(
stevenvanrossem8fbf9782016-02-17 11:40:23 +0100133 "--image","-i", dest="image",
peusterm0dc3ae02016-04-27 09:33:28 +0200134 help="Name of container image to be used e.g. 'ubuntu:trusty'")
peusterm45dce612016-01-29 15:34:38 +0100135parser.add_argument(
stevenvanrossem8fbf9782016-02-17 11:40:23 +0100136 "--dcmd", "-c", dest="docker_command",
137 help="Startup command of the container e.g. './start.sh'")
138parser.add_argument(
peusterm45dce612016-01-29 15:34:38 +0100139 "--net", dest="network",
stevenvanrossem49378152016-05-19 11:33:48 +0200140 help="Network properties of a compute instance e.g. \
141 '(id=input,ip=10.0.10.3/24),(id=output,ip=10.0.10.4/24)' for multiple interfaces.")
stevenvanrossem994245b2016-05-04 12:36:57 +0200142parser.add_argument(
143 "--input", "-in", dest="input",
144 help="input interface of the vnf to profile")
145parser.add_argument(
146 "--output", "-out", dest="output",
147 help="output interface of the vnf to profile")
peusterm58310762016-01-12 17:09:20 +0100148
149
150def main(argv):
151 args = vars(parser.parse_args(argv))
152 c = ZeroRpcClient()
153 c.execute_command(args)