blob: daa885767a023f36eb13da62682648cc2ed8c91a [file] [log] [blame]
"""Add new field 'is_restricted' to SqlMetric and DruidMetric
Revision ID: d8bc074f7aad
Revises: 1226819ee0e3
Create Date: 2016-06-07 12:33:25.756640
"""
# revision identifiers, used by Alembic.
revision = 'd8bc074f7aad'
down_revision = '1226819ee0e3'
from alembic import op
import sqlalchemy as sa
from superset import db
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import (
Column, Integer, Boolean)
Base = declarative_base()
class DruidMetric(Base):
"""Declarative class used to do query in upgrade"""
__tablename__ = 'metrics'
id = Column(Integer, primary_key=True)
is_restricted = Column(Boolean, default=False, nullable=True)
class SqlMetric(Base):
"""Declarative class used to do query in upgrade"""
__tablename__ = 'sql_metrics'
id = Column(Integer, primary_key=True)
is_restricted = Column(Boolean, default=False, nullable=True)
def upgrade():
op.add_column('metrics', sa.Column('is_restricted', sa.Boolean(), nullable=True))
op.add_column('sql_metrics', sa.Column('is_restricted', sa.Boolean(), nullable=True))
bind = op.get_bind()
session = db.Session(bind=bind)
# don't use models.DruidMetric
# because it assumes the context is consistent with the application
for obj in session.query(DruidMetric).all():
obj.is_restricted = False
for obj in session.query(SqlMetric).all():
obj.is_restricted = False
session.commit()
session.close()
def downgrade():
with op.batch_alter_table('sql_metrics', schema=None) as batch_op:
batch_op.drop_column('is_restricted')
with op.batch_alter_table('metrics', schema=None) as batch_op:
batch_op.drop_column('is_restricted')