blob: 642391775a1b533797343e1616a043e3959d53d6 [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):
18 self.c = zerorpc.Client()
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:
27 print "Command not implemented."
28
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"))
33
stevenvanrossem994245b2016-05-04 12:36:57 +020034 pp.pprint('nwlist1: {0}'.format(nw_list))
35
peusterm58310762016-01-12 17:09:20 +010036 r = self.c.compute_action_start(
peusterm45dce612016-01-29 15:34:38 +010037 args.get("datacenter"),
38 args.get("name"),
39 args.get("image"),
stevenvanrossem994245b2016-05-04 12:36:57 +020040 nw_list,
41 args.get("docker_command")
stevenvanrossem6b1d9b92016-05-02 13:10:40 +020042 )
peusterm58310762016-01-12 17:09:20 +010043 pp.pprint(r)
44
45 def stop(self, args):
46 r = self.c.compute_action_stop(
47 args.get("datacenter"), args.get("name"))
48 pp.pprint(r)
49
50 def list(self, args):
peusterm2ec74e12016-01-13 11:17:53 +010051 r = self.c.compute_list(
52 args.get("datacenter"))
53 table = []
54 for c in r:
55 # for each container add a line to the output table
56 if len(c) > 1:
57 name = c[0]
58 status = c[1]
59 eth0ip = None
60 eth0status = "down"
61 if len(status.get("network")) > 0:
62 eth0ip = status.get("network")[0][1]
63 eth0status = "up" if status.get(
64 "network")[0][3] else "down"
65 table.append([status.get("datacenter"),
66 name,
67 status.get("image"),
68 eth0ip,
69 eth0status,
70 status.get("state").get("Status")])
71 headers = ["Datacenter",
72 "Container",
73 "Image",
74 "eth0 IP",
75 "eth0 status",
76 "Status"]
77 print tabulate(table, headers=headers, tablefmt="grid")
peusterm58310762016-01-12 17:09:20 +010078
79 def status(self, args):
peusterm2ec74e12016-01-13 11:17:53 +010080 r = self.c.compute_status(
81 args.get("datacenter"), args.get("name"))
82 pp.pprint(r)
peusterm58310762016-01-12 17:09:20 +010083
stevenvanrossem994245b2016-05-04 12:36:57 +020084 def profile(self, args):
85 nw_list = list()
86 if args.get("network") is not None:
87 nw_list = self._parse_network(args.get("network"))
88 logging.info('nwlist: {0}'.format(nw_list))
89 r = self.c.compute_profile(
90 args.get("datacenter"),
91 args.get("name"),
92 args.get("image"),
93 network=nw_list,
94 command=args.get("docker_command"),
95 input=args.get("input"),
96 output=args.get("output")
97 )
98 pp.pprint(r)
99
stevenvanrossem14c89052016-04-10 23:49:59 +0200100 def _parse_network(self, network_str):
101 '''
102 parse the options for all network interfaces of the vnf
103 :param network_str: (id=x,ip=x.x.x.x/x), ...
104 :return: list of dicts [{"id":x,"ip":"x.x.x.x/x"}, ...]
105 '''
106 nw_list = list()
107 networks = network_str[1:-1].split('),(')
108 for nw in networks:
109 nw_dict = dict(tuple(e.split('=')) for e in nw.split(','))
110 nw_list.append(nw_dict)
111
112 return nw_list
113
114
peusterm58310762016-01-12 17:09:20 +0100115
116parser = argparse.ArgumentParser(description='son-emu compute')
peusterm58310762016-01-12 17:09:20 +0100117parser.add_argument(
peusterm45dce612016-01-29 15:34:38 +0100118 "command",
peustermd313dc12016-02-04 15:36:02 +0100119 choices=['start', 'stop', 'list', 'status'],
120 help="Action to be executed.")
peusterm58310762016-01-12 17:09:20 +0100121parser.add_argument(
peusterm45dce612016-01-29 15:34:38 +0100122 "--datacenter", "-d", dest="datacenter",
123 help="Data center to in which the compute instance should be executed")
peusterm7973f052016-01-29 14:38:05 +0100124parser.add_argument(
peusterm45dce612016-01-29 15:34:38 +0100125 "--name", "-n", dest="name",
126 help="Name of compute instance e.g. 'vnf1'")
127parser.add_argument(
stevenvanrossem8fbf9782016-02-17 11:40:23 +0100128 "--image","-i", dest="image",
peusterm0dc3ae02016-04-27 09:33:28 +0200129 help="Name of container image to be used e.g. 'ubuntu:trusty'")
peusterm45dce612016-01-29 15:34:38 +0100130parser.add_argument(
stevenvanrossem8fbf9782016-02-17 11:40:23 +0100131 "--dcmd", "-c", dest="docker_command",
132 help="Startup command of the container e.g. './start.sh'")
133parser.add_argument(
peusterm45dce612016-01-29 15:34:38 +0100134 "--net", dest="network",
peusterm7f8e8402016-02-28 18:38:10 +0100135 help="Network properties of compute instance e.g. \
136 '10.0.0.123/8' or '10.0.0.123/8,11.0.0.123/24' for multiple interfaces.")
stevenvanrossem994245b2016-05-04 12:36:57 +0200137parser.add_argument(
138 "--input", "-in", dest="input",
139 help="input interface of the vnf to profile")
140parser.add_argument(
141 "--output", "-out", dest="output",
142 help="output interface of the vnf to profile")
peusterm58310762016-01-12 17:09:20 +0100143
144
145def main(argv):
146 args = vars(parser.parse_args(argv))
147 c = ZeroRpcClient()
148 c.execute_command(args)