008_version_1_5_0.py
62 lines
| 2.0 KiB
| text/x-python
|
PythonLexer
r3052 | import logging | |||
import datetime | ||||
from sqlalchemy import * | ||||
from sqlalchemy.exc import DatabaseError | ||||
r3063 | from sqlalchemy.orm import relation, backref, class_mapper, joinedload | |||
r3052 | 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 | ||||
r3148 | from rhodecode.lib.dbmigrate.versions import _reset_base | |||
r3052 | ||||
log = logging.getLogger(__name__) | ||||
def upgrade(migrate_engine): | ||||
""" | ||||
Upgrade operations go here. | ||||
Don't create your own engine; bind migrate_engine to your metadata | ||||
""" | ||||
r3063 | #========================================================================== | |||
# USER LOGS | ||||
#========================================================================== | ||||
r3148 | _reset_base(migrate_engine) | |||
r3063 | from rhodecode.lib.dbmigrate.schema.db_1_5_0 import UserLog | |||
tbl = UserLog.__table__ | ||||
username = Column("username", String(255, convert_unicode=False, | ||||
assert_unicode=None), nullable=True, | ||||
unique=None, default=None) | ||||
# create username column | ||||
username.create(table=tbl) | ||||
r3086 | _Session = Session() | |||
## after adding that column fix all usernames | ||||
users_log = _Session.query(UserLog)\ | ||||
.options(joinedload(UserLog.user))\ | ||||
.options(joinedload(UserLog.repository)).all() | ||||
for entry in users_log: | ||||
entry.username = entry.user.username | ||||
_Session.add(entry) | ||||
_Session.commit() | ||||
#alter username to not null | ||||
r3065 | from rhodecode.lib.dbmigrate.schema.db_1_5_0 import UserLog | |||
tbl_name = UserLog.__tablename__ | ||||
tbl = Table(tbl_name, | ||||
MetaData(bind=migrate_engine), autoload=True, | ||||
autoload_with=migrate_engine) | ||||
r3086 | col = tbl.columns.username | |||
r3065 | ||||
# remove nullability from revision field | ||||
r3086 | col.alter(nullable=False) | |||
r3052 | ||||
r3056 | ||||
r3052 | def downgrade(migrate_engine): | |||
meta = MetaData() | ||||
meta.bind = migrate_engine | ||||