Warning
This document is for an old release of Galaxy. You can alternatively view this page in the latest release if it exists or view the top of the latest release's documentation.
Source code for tool_shed.webapp.model.migrate.versions.0013_add_review_tables
"""
Migration script to add the repository_review, component_review and component tables and the Repository Reviewer group and role.
"""
import datetime
import logging
import sys
from sqlalchemy import (
Boolean,
Column,
DateTime,
ForeignKey,
Integer,
MetaData,
Table,
TEXT,
)
# Need our custom types, but don't import anything else from model
from galaxy.model.custom_types import TrimmedString
log = logging.getLogger(__name__)
log.setLevel(logging.DEBUG)
handler = logging.StreamHandler(sys.stdout)
format = "%(name)s %(levelname)s %(asctime)s %(message)s"
formatter = logging.Formatter(format)
handler.setFormatter(formatter)
log.addHandler(handler)
metadata = MetaData()
IUC = "Intergalactic Utilities Commission"
NOW = datetime.datetime.utcnow
REVIEWER = "Repository Reviewer"
ROLE_TYPE = "system"
[docs]def nextval(migrate_engine, table, col="id"):
if migrate_engine.name in ["postgresql", "postgres"]:
return f"nextval('{table}_{col}_seq')"
elif migrate_engine.name == "mysql" or migrate_engine.name == "sqlite":
return "null"
else:
raise Exception(f"Unable to convert data for unknown database type: {migrate_engine.name}")
[docs]def localtimestamp(migrate_engine):
if migrate_engine.name in ["postgresql", "postgres"] or migrate_engine.name == "mysql":
return "LOCALTIMESTAMP"
elif migrate_engine.name == "sqlite":
return "current_date || ' ' || current_time"
else:
raise Exception(f"Unable to convert data for unknown database type: {migrate_engine.name}")
[docs]def boolean_false(migrate_engine):
if migrate_engine.name in ["postgresql", "postgres"] or migrate_engine.name == "mysql":
return False
elif migrate_engine.name == "sqlite":
return 0
else:
raise Exception(f"Unable to convert data for unknown database type: {migrate_engine.name}")
RepositoryReview_table = Table(
"repository_review",
metadata,
Column("id", Integer, primary_key=True),
Column("create_time", DateTime, default=NOW),
Column("update_time", DateTime, default=NOW, onupdate=NOW),
Column("repository_id", Integer, ForeignKey("repository.id"), index=True),
Column("changeset_revision", TrimmedString(255), index=True),
Column("user_id", Integer, ForeignKey("galaxy_user.id"), index=True, nullable=False),
Column("approved", TrimmedString(255)),
Column("rating", Integer, index=True),
Column("deleted", Boolean, index=True, default=False),
)
ComponentReview_table = Table(
"component_review",
metadata,
Column("id", Integer, primary_key=True),
Column("create_time", DateTime, default=NOW),
Column("update_time", DateTime, default=NOW, onupdate=NOW),
Column("repository_review_id", Integer, ForeignKey("repository_review.id"), index=True),
Column("component_id", Integer, ForeignKey("component.id"), index=True),
Column("comment", TEXT),
Column("private", Boolean, default=False),
Column("approved", TrimmedString(255)),
Column("rating", Integer),
Column("deleted", Boolean, index=True, default=False),
)
Component_table = Table(
"component",
metadata,
Column("id", Integer, primary_key=True),
Column("name", TrimmedString(255)),
Column("description", TEXT),
)
[docs]def upgrade(migrate_engine):
print(__doc__)
metadata.bind = migrate_engine
metadata.reflect()
# Create new review tables.
try:
Component_table.create()
except Exception:
log.exception("Creating component table failed.")
try:
RepositoryReview_table.create()
except Exception:
log.exception("Creating repository_review table failed.")
try:
ComponentReview_table.create()
except Exception:
log.exception("Creating component_review table failed.")
# Insert default Component values.
names = ["Data types", "Functional tests", "README", "Tool dependencies", "Tools", "Workflows"]
descriptions = [
"Proprietary datatypes defined in a file named datatypes_conf.xml included in the repository",
"Functional tests defined in each tool config included in the repository along with test data files",
"An appropriately named file included in the repository that contains installation information or 3rd-party tool dependency licensing information",
"Tool dependencies defined in a file named tool_dependencies.xml included in the repository for contained tools",
"Galaxy tools included in the repository",
"Exported Galaxy workflows included in the repository",
]
for tup in zip(names, descriptions):
name, description = tup
cmd = "INSERT INTO component VALUES ("
cmd += f"{nextval(migrate_engine, 'component')}, "
cmd += f"'{name}', "
cmd += f"'{description}' "
cmd += ");"
migrate_engine.execute(cmd)
# Insert a REVIEWER role into the role table.
cmd = "INSERT INTO role VALUES ("
cmd += f"{nextval(migrate_engine, 'role')}, "
cmd += f"{localtimestamp(migrate_engine)}, "
cmd += f"{localtimestamp(migrate_engine)}, "
cmd += f"'{REVIEWER}', "
cmd += "'A user or group member with this role can review repositories.', "
cmd += f"'{ROLE_TYPE}', "
cmd += f"{boolean_false(migrate_engine)}"
cmd += ");"
migrate_engine.execute(cmd)
# Get the id of the REVIEWER role.
cmd = f"SELECT id FROM role WHERE name = '{REVIEWER}' and type = '{ROLE_TYPE}';"
row = migrate_engine.execute(cmd).fetchone()
if row:
role_id = row[0]
else:
role_id = None
# Insert an IUC group into the galaxy_group table.
cmd = "INSERT INTO galaxy_group VALUES ("
cmd += f"{nextval(migrate_engine, 'galaxy_group')}, "
cmd += f"{localtimestamp(migrate_engine)}, "
cmd += f"{localtimestamp(migrate_engine)}, "
cmd += f"'{IUC}', "
cmd += f"{boolean_false(migrate_engine)}"
cmd += ");"
migrate_engine.execute(cmd)
# Get the id of the IUC group.
cmd = f"SELECT id FROM galaxy_group WHERE name = '{IUC}';"
row = migrate_engine.execute(cmd).fetchone()
if row:
group_id = row[0]
else:
group_id = None
if group_id and role_id:
# Insert a group_role_association for the IUC group and the REVIEWER role.
cmd = "INSERT INTO group_role_association VALUES ("
cmd += f"{nextval(migrate_engine, 'group_role_association')}, "
cmd += "%d, " % int(group_id)
cmd += "%d, " % int(role_id)
cmd += f"{localtimestamp(migrate_engine)}, "
cmd += f"{localtimestamp(migrate_engine)} "
cmd += ");"
migrate_engine.execute(cmd)
[docs]def downgrade(migrate_engine):
metadata.bind = migrate_engine
metadata.reflect()
# Drop review tables.
try:
ComponentReview_table.drop()
except Exception:
log.exception("Dropping component_review table failed.")
try:
RepositoryReview_table.drop()
except Exception:
log.exception("Dropping repository_review table failed.")
try:
Component_table.drop()
except Exception:
log.exception("Dropping component table failed.")
# Get the id of the REVIEWER group.
cmd = f"SELECT id FROM galaxy_group WHERE name = '{IUC}';"
row = migrate_engine.execute(cmd).fetchone()
if row:
group_id = row[0]
else:
group_id = None
# Get the id of the REVIEWER role.
cmd = f"SELECT id FROM role WHERE name = '{REVIEWER}' and type = '{ROLE_TYPE}';"
row = migrate_engine.execute(cmd).fetchone()
if row:
role_id = row[0]
else:
role_id = None
# See if we have at least 1 user
cmd = "SELECT * FROM galaxy_user;"
users = migrate_engine.execute(cmd).fetchall()
if role_id:
if users:
# Delete all UserRoleAssociations for the REVIEWER role.
cmd = "DELETE FROM user_role_association WHERE role_id = %d;" % int(role_id)
migrate_engine.execute(cmd)
if group_id:
# Delete all UserGroupAssociations for members of the IUC group.
cmd = "DELETE FROM user_group_association WHERE group_id = %d;" % int(group_id)
migrate_engine.execute(cmd)
# Delete all GroupRoleAssociations for the IUC group and the REVIEWER role.
cmd = "DELETE FROM group_role_association WHERE group_id = %d and role_id = %d;" % (
int(group_id),
int(role_id),
)
migrate_engine.execute(cmd)
# Delete the IUC group from the galaxy_group table.
cmd = "DELETE FROM galaxy_group WHERE id = %d;" % int(group_id)
migrate_engine.execute(cmd)
# Delete the REVIEWER role from the role table.
cmd = "DELETE FROM role WHERE id = %d;" % int(role_id)
migrate_engine.execute(cmd)