4e390ee67b
Add oslo libraries for works with database and config. Refactor database relation code. Move it in refstack/db. Now after istallation of refstack available a command-line utility: `refstack-manage` and `refstack-api`. `refstack-manage` This utlity provide commands for manipulation of database migrations and setup config file through --config-file /path/to/refstack.conf option. Config file should contain database connection string. For example: [DEFAULT] sql_connection = mysql://root:passw0rd@127.0.0.1/refstack Add ability to runtime updrade/downgrade db through command-line utillity. `refstack-api` This utility allow to launch api on gunicorn server. Specify config through --env REFSTACK_OSLO_CONFIG=/path/to/refstack.conf Change-Id: Ibea97d433d54d307233aa04e9487f1a1230e7487
95 lines
3.3 KiB
Python
Executable File
95 lines
3.3 KiB
Python
Executable File
#!/usr/bin/env python
|
|
|
|
# Copyright (c) 2015 Mirantis, Inc.
|
|
# 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.
|
|
"""
|
|
Command-line utility for database manage
|
|
"""
|
|
|
|
import sys
|
|
|
|
from oslo.config import cfg
|
|
|
|
from refstack.db import migration
|
|
|
|
CONF = cfg.CONF
|
|
|
|
|
|
class DatabaseManager(object):
|
|
|
|
def version(self):
|
|
print(migration.version())
|
|
|
|
def upgrade(self):
|
|
migration.upgrade(CONF.command.revision)
|
|
|
|
def downgrade(self):
|
|
migration.downgrade(CONF.command.revision)
|
|
|
|
def stamp(self):
|
|
migration.stamp(CONF.command.revision)
|
|
|
|
def revision(self):
|
|
migration.revision(CONF.command.message, CONF.command.autogenerate)
|
|
|
|
|
|
def add_command_parsers(subparsers):
|
|
db_manager = DatabaseManager()
|
|
|
|
parser = subparsers.add_parser('version',
|
|
help='show current database version')
|
|
parser.set_defaults(func=db_manager.version)
|
|
|
|
parser = subparsers.add_parser('upgrade',
|
|
help='upgrade database to '
|
|
'the specified version')
|
|
parser.set_defaults(func=db_manager.upgrade)
|
|
parser.add_argument('--revision', nargs='?',
|
|
help='desired database version')
|
|
|
|
parser = subparsers.add_parser('downgrade',
|
|
help='downgrade database '
|
|
'to the specified version')
|
|
parser.set_defaults(func=db_manager.downgrade)
|
|
parser.add_argument('--revision', nargs='?',
|
|
help='desired database version')
|
|
|
|
parser = subparsers.add_parser('stamp',
|
|
help='stamp database with provided '
|
|
'revision. Don\'t run any migrations')
|
|
parser.add_argument('--revision', nargs='?',
|
|
help='should match one from repository or head - '
|
|
'to stamp database with most recent revision')
|
|
parser.set_defaults(func=db_manager.stamp)
|
|
|
|
parser = subparsers.add_parser('revision',
|
|
help='create template for migration')
|
|
parser.add_argument('-m', '--message',
|
|
help='text that will be used for migration title')
|
|
parser.add_argument('--autogenerate', action='store_true',
|
|
help='if True - generates diff based '
|
|
'on current database state (True by default)')
|
|
parser.set_defaults(func=db_manager.revision)
|
|
|
|
command_opt = cfg.SubCommandOpt('command',
|
|
title='Available commands',
|
|
handler=add_command_parsers)
|
|
|
|
CONF.register_cli_opt(command_opt)
|
|
|
|
if __name__ == '__main__':
|
|
CONF(sys.argv[1:], project='refstack')
|
|
CONF.command.func()
|