3 # Copyright (C) 2014 Red Hat Inc.
5 # This program is free software; you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 2 of the License, or
8 # (at your option) any later version.
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU General Public License for more details.
15 # You should have received a copy of the GNU General Public License
16 # along with this program; if not, write to the Free Software
17 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
27 parser = argparse.ArgumentParser (
29 description='Mini virtualization cluster management tool',
34 help='specify location of the configuration file',
39 subparsers = parser.add_subparsers ()
41 mclu_build.cmdline (subparsers)
43 mclu_console.cmdline (subparsers)
45 mclu_info.cmdline (subparsers)
47 mclu_list.cmdline (subparsers)
49 mclu_migrate.cmdline (subparsers)
51 mclu_shutdown.cmdline (subparsers)
53 mclu_start.cmdline (subparsers)
55 mclu_status.cmdline (subparsers)
57 mclu_stop.cmdline (subparsers)
59 mclu_viewer.cmdline (subparsers)
61 mclu_wake.cmdline (subparsers)
63 args = parser.parse_args()
65 # Default location of the config file if not defined on the command line:
67 config_dir = config.sysconfdir + "/" + config.PACKAGE_NAME
68 args.f = open (config_dir + "/" + "mclu.conf")
70 # config_dir is the directory containing mclu.conf
71 config_dir = os.path.dirname (args.f.name)
73 # Configuration file default settings. You cannot set defaults per
74 # section, so we have to rely on setting names not overlapping.
76 "home" : os.getenv ("HOME"),
77 "host" : "SET.THIS.IN.MCLU.CONF",
78 "config_dir" : config_dir,
79 "uri" : "qemu+ssh://root@%(host)s/system",
82 # Read the configuration file.
83 conf = ConfigParser.SafeConfigParser (conf_defaults)
86 # Global configuration.
87 images_dir = conf.get ("global", "images_dir")
88 if not os.path.isdir (images_dir):
89 sys.exit ("configuration error: [globals] 'images_dir' (%s) directory does not exist" % images_dir)
90 xmls_dir = conf.get ("global", "xmls_dir")
91 if not os.path.isdir (xmls_dir):
92 sys.exit ("configuration error: [globals] 'xmls_dir' (%s) directory does not exist", xmls_dir)
94 # Get the list of node names.
95 node_names = conf.items ("nodes")
96 node_names = filter (lambda (x, _) : re.search (r'^node', x), node_names)
97 node_names = [ value for _, value in node_names ]
99 sys.exit ("configuration error: [nodes] section in configuration file is empty")
101 # Get information about each node.
103 for node_name in node_names:
104 host = conf.get (node_name, "host")
107 mac = conf.get (node_name, "mac")
108 uri = conf.get (node_name, "uri")
109 node = Node (node_name, host, mac, uri)
110 nodes[node_name] = node
112 # A config dict with less-used configuration settings.
114 "config_file" : args.f.name,
115 "config_dir" : config_dir,
116 "images_dir" : images_dir,
117 "node_names" : node_names,
118 "xmls_dir" : xmls_dir,
123 # Run the subcommand.
124 args.run (c, args, nodes)