fe2d52aa17
The barbican-db-manage.py script was failing due to the adoption of oslo_log. This is now fixed. Change-Id: I9d9645d1d2a708351fc66faafbb9cff177107901
144 lines
5.3 KiB
Python
Executable File
144 lines
5.3 KiB
Python
Executable File
#!/usr/bin/env python
|
|
|
|
import os
|
|
import sys
|
|
import argparse
|
|
|
|
sys.path.insert(0, os.getcwd())
|
|
|
|
from barbican.model.migration import commands
|
|
from oslo_config import cfg
|
|
from oslo_log import log
|
|
|
|
|
|
class DatabaseManager:
|
|
"""
|
|
Builds and executes a CLI parser to manage the Barbican database,
|
|
using Alembic commands.
|
|
"""
|
|
|
|
def __init__(self):
|
|
self.parser = self.get_main_parser()
|
|
self.subparsers = self.parser.add_subparsers(
|
|
title='subcommands',
|
|
description='Action to perform')
|
|
self.add_revision_args()
|
|
self.add_downgrade_args()
|
|
self.add_upgrade_args()
|
|
self.add_history_args()
|
|
self.add_current_args()
|
|
|
|
def get_main_parser(self):
|
|
"""Create top-level parser and arguments."""
|
|
parser = argparse.ArgumentParser(description='Barbican DB manager.')
|
|
parser.add_argument('--dburl', '-d', default=None,
|
|
help='URL to the database.')
|
|
|
|
return parser
|
|
|
|
def add_revision_args(self):
|
|
"""Create 'revision' command parser and arguments."""
|
|
create_parser = self.subparsers.add_parser('revision', help='Create a '
|
|
'new DB version file.')
|
|
create_parser.add_argument('--message', '-m', default='DB change',
|
|
help='the message for the DB change')
|
|
create_parser.add_argument('--autogenerate',
|
|
help='autogenerate from models',
|
|
action='store_true')
|
|
create_parser.set_defaults(func=self.revision)
|
|
|
|
def add_upgrade_args(self):
|
|
"""Create 'upgrade' command parser and arguments."""
|
|
create_parser = self.subparsers.add_parser('upgrade',
|
|
help='Upgrade to a '
|
|
'future version DB '
|
|
'version file')
|
|
create_parser.add_argument('--version', '-v', default='head',
|
|
help='the version to upgrade to, or else '
|
|
'the latest/head if not specified.')
|
|
create_parser.set_defaults(func=self.upgrade)
|
|
|
|
def add_downgrade_args(self):
|
|
"""Create 'downgrade' command parser and arguments."""
|
|
create_parser = self.subparsers.add_parser('downgrade',
|
|
help='Downgrade to a '
|
|
'previous DB '
|
|
'version file.')
|
|
create_parser.add_argument('--version', '-v', default='need version',
|
|
help='the version to downgrade back to.')
|
|
create_parser.set_defaults(func=self.downgrade)
|
|
|
|
def add_history_args(self):
|
|
"""Create 'history' command parser and arguments."""
|
|
create_parser = self.subparsers.add_parser(
|
|
'history',
|
|
help='List changeset scripts in chronological order.')
|
|
create_parser.add_argument('--verbose', '-V', action="store_true",
|
|
help='Show full information about the '
|
|
'revisions.')
|
|
create_parser.set_defaults(func=self.history)
|
|
|
|
def add_current_args(self):
|
|
"""Create 'current' command parser and arguments."""
|
|
create_parser = self.subparsers.add_parser(
|
|
'current',
|
|
help='Display the current revision for a database.')
|
|
create_parser.add_argument('--verbose', '-V', action="store_true",
|
|
help='Show full information about the '
|
|
'revision.')
|
|
create_parser.set_defaults(func=self.current)
|
|
|
|
def revision(self, args):
|
|
"""Process the 'revision' Alembic command."""
|
|
commands.generate(autogenerate=args.autogenerate,
|
|
message=args.message,
|
|
sql_url=args.dburl)
|
|
|
|
def upgrade(self, args):
|
|
"""Process the 'upgrade' Alembic command."""
|
|
commands.upgrade(to_version=args.version, sql_url=args.dburl)
|
|
|
|
def downgrade(self, args):
|
|
"""Process the 'downgrade' Alembic command."""
|
|
commands.downgrade(to_version=args.version, sql_url=args.dburl)
|
|
|
|
def history(self, args):
|
|
commands.history(args.verbose, sql_url=args.dburl)
|
|
|
|
def current(self, args):
|
|
commands.current(args.verbose, sql_url=args.dburl)
|
|
|
|
def execute(self):
|
|
"""Parse the command line arguments."""
|
|
args = self.parser.parse_args()
|
|
|
|
# Perform other setup here...
|
|
|
|
args.func(args)
|
|
|
|
|
|
def _exception_is_successfull_exit(thrown_exception):
|
|
return (isinstance(thrown_exception, SystemExit) and
|
|
(thrown_exception.code is None or thrown_exception.code == 0))
|
|
|
|
|
|
def main():
|
|
# Import and configure logging.
|
|
CONF = cfg.CONF
|
|
log.register_options(CONF)
|
|
log.setup(CONF, 'barbican-db-manage')
|
|
LOG = log.getLogger(__name__)
|
|
LOG.debug("Performing database schema migration...")
|
|
|
|
try:
|
|
dm = DatabaseManager()
|
|
dm.execute()
|
|
except Exception as ex:
|
|
if _exception_is_successfull_exit(ex):
|
|
pass
|
|
LOG.exception('Problem trying to execute Alembic commands')
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|