008_version_1_5_0.py
135 lines
| 4.4 KiB
| text/x-python
|
PythonLexer
r1 | import logging | |||
import datetime | ||||
from sqlalchemy import * | ||||
from sqlalchemy.exc import DatabaseError | ||||
from sqlalchemy.orm import relation, backref, class_mapper, joinedload | ||||
from sqlalchemy.orm.session import Session | ||||
from sqlalchemy.ext.declarative import declarative_base | ||||
from rhodecode.lib.dbmigrate.migrate import * | ||||
from rhodecode.lib.dbmigrate.migrate.changeset import * | ||||
from rhodecode.model.meta import Base | ||||
from rhodecode.model import meta | ||||
from rhodecode.lib.dbmigrate.versions import _reset_base | ||||
log = logging.getLogger(__name__) | ||||
def upgrade(migrate_engine): | ||||
""" | ||||
Upgrade operations go here. | ||||
Don't create your own engine; bind migrate_engine to your metadata | ||||
""" | ||||
_reset_base(migrate_engine) | ||||
from rhodecode.lib.dbmigrate.schema import db_1_5_0 | ||||
#========================================================================== | ||||
# USER LOGS | ||||
#========================================================================== | ||||
tbl = db_1_5_0.UserLog.__table__ | ||||
username = Column("username", String(255, convert_unicode=False), | ||||
nullable=True, unique=None, default=None) | ||||
# create username column | ||||
username.create(table=tbl) | ||||
_Session = meta.Session() | ||||
## after adding that column fix all usernames | ||||
users_log = _Session.query(db_1_5_0.UserLog)\ | ||||
.options(joinedload(db_1_5_0.UserLog.user))\ | ||||
.options(joinedload(db_1_5_0.UserLog.repository)).all() | ||||
for entry in users_log: | ||||
entry.username = entry.user.username | ||||
_Session.add(entry) | ||||
_Session.commit() | ||||
#alter username to not null | ||||
tbl_name = db_1_5_0.UserLog.__tablename__ | ||||
tbl = Table(tbl_name, | ||||
MetaData(bind=migrate_engine), autoload=True, | ||||
autoload_with=migrate_engine) | ||||
col = tbl.columns.username | ||||
# remove nullability from revision field | ||||
col.alter(nullable=False) | ||||
# issue fixups | ||||
fixups(db_1_5_0, meta.Session) | ||||
def downgrade(migrate_engine): | ||||
meta = MetaData() | ||||
meta.bind = migrate_engine | ||||
def get_by_key(cls, key): | ||||
return cls.query().filter(cls.permission_name == key).scalar() | ||||
def get_by_name(cls, key): | ||||
return cls.query().filter(cls.app_settings_name == key).scalar() | ||||
def fixups(models, _SESSION): | ||||
# ** create default permissions ** # | ||||
#===================================== | ||||
for p in models.Permission.PERMS: | ||||
if not get_by_key(models.Permission, p[0]): | ||||
new_perm = models.Permission() | ||||
new_perm.permission_name = p[0] | ||||
new_perm.permission_longname = p[0] #translation err with p[1] | ||||
print 'Creating new permission %s' % p[0] | ||||
_SESSION().add(new_perm) | ||||
_SESSION().commit() | ||||
# ** populate default permissions ** # | ||||
#===================================== | ||||
user = models.User.query().filter(models.User.username == 'default').scalar() | ||||
def _make_perm(perm): | ||||
new_perm = models.UserToPerm() | ||||
new_perm.user = user | ||||
new_perm.permission = get_by_key(models.Permission, perm) | ||||
return new_perm | ||||
def _get_group(perm_name): | ||||
return '.'.join(perm_name.split('.')[:1]) | ||||
perms = models.UserToPerm.query().filter(models.UserToPerm.user == user).all() | ||||
defined_perms_groups = map( | ||||
_get_group, (x.permission.permission_name for x in perms)) | ||||
log.debug('GOT ALREADY DEFINED:%s' % perms) | ||||
DEFAULT_PERMS = models.Permission.DEFAULT_USER_PERMISSIONS | ||||
# for every default permission that needs to be created, we check if | ||||
# it's group is already defined, if it's not we create default perm | ||||
for perm_name in DEFAULT_PERMS: | ||||
gr = _get_group(perm_name) | ||||
if gr not in defined_perms_groups: | ||||
log.debug('GR:%s not found, creating permission %s' | ||||
% (gr, perm_name)) | ||||
new_perm = _make_perm(perm_name) | ||||
_SESSION().add(new_perm) | ||||
_SESSION().commit() | ||||
# ** create default options ** # | ||||
#=============================== | ||||
skip_existing = True | ||||
for k, v in [ | ||||
('default_repo_enable_locking', False), | ||||
('default_repo_enable_downloads', False), | ||||
('default_repo_enable_statistics', False), | ||||
('default_repo_private', False), | ||||
('default_repo_type', 'hg')]: | ||||
if skip_existing and get_by_name(models.RhodeCodeSetting, k) is not None: | ||||
log.debug('Skipping option %s' % k) | ||||
continue | ||||
setting = models.RhodeCodeSetting(k, v) | ||||
_SESSION().add(setting) | ||||
_SESSION().commit() | ||||