# -*- coding: utf-8 -*- """ rhodecode.lib.dbmigrate.__init__ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Database migration modules :created_on: Dec 11, 2010 :author: marcink :copyright: (C) 2009-2010 Marcin Kuzminski :license: GPLv3, see COPYING for more details. """ # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; version 2 # of the License or (at your opinion) any later version of the license. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, # MA 02110-1301, USA. import logging from sqlalchemy import engine_from_config from rhodecode import __dbversion__ from rhodecode.lib.dbmigrate.migrate.versioning import api from rhodecode.lib.dbmigrate.migrate.exceptions import \ DatabaseNotControlledError from rhodecode.lib.utils import BasePasterCommand, Command, add_cache from rhodecode.lib.db_manage import DbManage log = logging.getLogger(__name__) class UpgradeDb(BasePasterCommand): """Command used for paster to upgrade our database to newer version """ max_args = 1 min_args = 1 usage = "CONFIG_FILE" summary = "Upgrades current db to newer version given configuration file" group_name = "RhodeCode" parser = Command.standard_parser(verbose=True) def command(self): from pylons import config add_cache(config) repository_path = 'rhodecode/lib/dbmigrate' db_uri = config['sqlalchemy.db1.url'] try: curr_version = api.db_version(db_uri, repository_path) msg = ('Found current database under version' ' control with version %s' % curr_version) except (RuntimeError, DatabaseNotControlledError), e: curr_version = 1 msg = ('Current database is not under version control setting' ' as version %s' % curr_version) api.version_control(db_uri, repository_path, curr_version) self.notify_msg(msg) #now we have our dbversion we can do upgrade self.notify_msg('attempting to do database upgrade to version %s' \ % __dbversion__) api.upgrade(db_uri, repository_path, __dbversion__) self.notify_msg('Schema upgrade completed') #we need to make now some extra operations into database self.notify_msg('Prociding with database updates') dbmanage = DbManage(log_sql=True, dbconf=db_uri, root=config['here'], tests=False) self.notify_msg('Patching repo paths for newer version of rhodecode') dbmanage.fix_repo_paths() self.notify_msg('Changing ui settings') dbmanage.create_ui_settings() def update_parser(self): self.parser.add_option('--sql', action='store_true', dest='just_sql', help="Prints upgrade sql for further investigation", default=False)