trove/bin/reddwarf-manage

152 lines
4.6 KiB
Python
Executable File

#!/usr/bin/env python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
# Copyright 2011 OpenStack LLC.
# All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
import gettext
import optparse
import os
import sys
gettext.install('reddwarf', unicode=1)
# If ../reddwarf/__init__.py exists, add ../ to Python search path, so that
# it will override what happens to be installed in /usr/(local/)lib/python...
possible_topdir = os.path.normpath(os.path.join(os.path.abspath(sys.argv[0]),
os.pardir,
os.pardir))
if os.path.exists(os.path.join(possible_topdir, 'reddwarf', '__init__.py')):
sys.path.insert(0, possible_topdir)
from reddwarf import version
from reddwarf.common import config
from reddwarf.common import utils
from reddwarf.db import db_api
from reddwarf.instance import models as instance_models
def create_options(parser):
"""Sets up the CLI and config-file options.
:param parser: The option parser
:returns: None
"""
parser.add_option('-p', '--port', dest="port", metavar="PORT",
type=int, default=9898,
help="Port the Reddwarf API host listens on. "
"Default: %default")
config.add_common_options(parser)
config.add_log_options(parser)
class Commands(object):
def __init__(self, conf):
self.conf = conf
def db_sync(self):
db_api.db_sync(self.conf, repo_path=None)
def db_upgrade(self, version=None, repo_path=None):
db_api.db_upgrade(self.conf, version, repo_path=None)
def db_downgrade(self, version, repo_path=None):
db_api.db_downgrade(self.conf, version, repo_path=None)
def execute(self, command_name, *args):
if self.has(command_name):
return getattr(self, command_name)(*args)
def image_update(self, service_name, image_id):
db_api.configure_db(self.conf)
image = db_api.find_by(instance_models.ServiceImage,
service_name=service_name)
if image is None:
# Create a new one
image = instance_models.ServiceImage()
image.id = utils.generate_uuid()
image.service_name = service_name
image.image_id = image_id
db_api.save(image)
def db_wipe(self, repo_path, service_name, image_id):
"""Drops the database and recreates it."""
from reddwarf.instance import models
from reddwarf.db.sqlalchemy import session
db_api.drop_db(self.conf)
self.db_sync()
# Sets up database engine, so the next line will work...
session.configure_db(self.conf)
models.ServiceImage.create(service_name=service_name,
image_id=image_id)
_commands = ['db_sync', 'db_upgrade', 'db_downgrade', 'db_wipe',
'image_update']
@classmethod
def has(cls, command_name):
return (command_name in cls._commands)
@classmethod
def all(cls):
return cls._commands
def params_of(self, command_name):
if Commands.has(command_name):
return utils.MethodInspector(getattr(self, command_name))
def usage():
usage = """
%prog action [args] [options]
Available actions:
"""
for action in Commands.all():
usage = usage + ("\t%s\n" % action)
return usage.strip()
if __name__ == '__main__':
oparser = optparse.OptionParser(version="%%prog %s"
% version.version_string(),
usage=usage())
create_options(oparser)
(options, args) = config.parse_options(oparser)
if len(args) < 1 or not Commands.has(args[0]):
oparser.print_usage()
sys.exit(2)
try:
conf = config.Config.load_paste_config('reddwarf', options, args)
config.setup_logging(options, conf)
command_name = args.pop(0)
Commands(conf).execute(command_name, *args)
sys.exit(0)
except TypeError:
print _("Possible wrong number of arguments supplied")
command_params = Commands(conf).params_of(command_name)
print "Usage: reddwarf-manage %s" % command_params
sys.exit(2)
except Exception:
print _("Command failed, please check log for more info")
raise