# Copyright 2013 Cloudscaling Group, Inc # # 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. """ CLI interface for GCE API management. """ import os import sys from oslo_config import cfg from oslo_log import log from gceapi import config from gceapi.db import migration from gceapi.i18n import _ CONF = cfg.CONF def do_db_version(): """Print database's current migration level.""" print(migration.db_version()) def do_db_sync(): """Place a database under migration control and upgrade, creating if necessary. """ migration.db_sync(CONF.command.version) def add_command_parsers(subparsers): parser = subparsers.add_parser('db_version') parser.set_defaults(func=do_db_version) parser = subparsers.add_parser('db_sync') parser.set_defaults(func=do_db_sync) parser.add_argument('version', nargs='?') parser.add_argument('current_version', nargs='?') command_opt = cfg.SubCommandOpt('command', title='Commands', help='Available commands', handler=add_command_parsers) def main(): CONF.register_cli_opt(command_opt) try: config.parse_args(sys.argv) log.setup(CONF, "gceapi") except cfg.ConfigFilesNotFoundError: cfgfile = CONF.config_file[-1] if CONF.config_file else None if cfgfile and not os.access(cfgfile, os.R_OK): st = os.stat(cfgfile) print(_("Could not read %s. Re-running with sudo") % cfgfile) try: os.execvp('sudo', ['sudo', '-u', '#%s' % st.st_uid] + sys.argv) except Exception: print(_('sudo failed, continuing as if nothing happened')) print(_('Please re-run gce-api-manage as root.')) return(2) try: CONF.command.func() except Exception as e: sys.exit("ERROR: %s" % e)