4c6f827684
Change the file name from inital_version to initial_version Change-Id: Iefa8c736fccd7705c72841a347cd6041c5e02e73
277 lines
10 KiB
Python
277 lines
10 KiB
Python
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
# implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
"""empty message
|
|
|
|
Revision ID: 001
|
|
Revises: None
|
|
Create Date: 2014-05-29 16:32:33.698760
|
|
|
|
"""
|
|
|
|
# revision identifiers, used by Alembic.
|
|
revision = '001'
|
|
down_revision = None
|
|
|
|
import uuid
|
|
|
|
from alembic import op
|
|
from oslo_utils import timeutils
|
|
import sqlalchemy as sa
|
|
from sqlalchemy.sql.expression import table as sa_table
|
|
|
|
from murano.common import consts
|
|
from murano.db.sqla import types as st
|
|
|
|
|
|
MYSQL_ENGINE = 'InnoDB'
|
|
MYSQL_CHARSET = 'utf8'
|
|
|
|
|
|
def _create_default_categories(op):
|
|
bind = op.get_bind()
|
|
table = sa_table(
|
|
'category',
|
|
sa.Column('id', sa.String(length=36), primary_key=True),
|
|
sa.Column('created', sa.DateTime()),
|
|
sa.Column('updated', sa.DateTime()),
|
|
sa.Column('name', sa.String(length=80)))
|
|
|
|
now = timeutils.utcnow()
|
|
|
|
for category in consts.CATEGORIES:
|
|
values = {'id': uuid.uuid4().hex,
|
|
'name': category,
|
|
'updated': now,
|
|
'created': now}
|
|
bind.execute(table.insert(values=values))
|
|
|
|
|
|
def upgrade():
|
|
op.create_table(
|
|
'environment',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.String(length=255), nullable=False),
|
|
sa.Column('name', sa.String(length=255), nullable=False),
|
|
sa.Column('tenant_id', sa.String(length=36), nullable=False),
|
|
sa.Column('version', sa.BigInteger(), nullable=False),
|
|
sa.Column('description', sa.Text(), nullable=False),
|
|
sa.Column('networking', sa.Text(), nullable=True),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
sa.UniqueConstraint('tenant_id', 'name'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_table(
|
|
'tag',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.String(length=36), nullable=False),
|
|
sa.Column('name', sa.String(length=80), nullable=False),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
sa.UniqueConstraint('name'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_table(
|
|
'category',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.String(length=36), nullable=False),
|
|
sa.Column('name', sa.String(length=80), nullable=False, unique=True),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_index('ix_category_name', 'category', ['name'])
|
|
|
|
op.create_table(
|
|
'apistats',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.Integer(), nullable=False),
|
|
sa.Column('host', sa.String(length=80), nullable=True),
|
|
sa.Column('request_count', sa.BigInteger(), nullable=True),
|
|
sa.Column('error_count', sa.BigInteger(), nullable=True),
|
|
sa.Column('average_response_time', sa.Float(), nullable=True),
|
|
sa.Column('requests_per_tenant', sa.Text(), nullable=True),
|
|
sa.Column('requests_per_second', sa.Float(), nullable=True),
|
|
sa.Column('errors_per_second', sa.Float(), nullable=True),
|
|
sa.Column('cpu_count', sa.Integer(), nullable=True),
|
|
sa.Column('cpu_percent', sa.Float(), nullable=True),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_table(
|
|
'instance_stats',
|
|
sa.Column('environment_id', sa.String(length=255), nullable=False),
|
|
sa.Column('instance_id', sa.String(length=255), nullable=False),
|
|
sa.Column('instance_type', sa.Integer(), nullable=False),
|
|
sa.Column('created', sa.Integer(), nullable=False),
|
|
sa.Column('destroyed', sa.Integer(), nullable=True),
|
|
sa.Column('type_name', sa.String(length=512), nullable=False),
|
|
sa.Column('type_title', sa.String(length=512), nullable=True),
|
|
sa.Column('unit_count', sa.Integer(), nullable=True),
|
|
sa.Column('tenant_id', sa.String(length=36), nullable=False),
|
|
sa.PrimaryKeyConstraint('environment_id', 'instance_id'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_table(
|
|
'package',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.String(length=36), nullable=False),
|
|
sa.Column('archive', st.LargeBinary(), nullable=True),
|
|
sa.Column('fully_qualified_name',
|
|
sa.String(length=128),
|
|
nullable=False,
|
|
unique=True),
|
|
sa.Column('type', sa.String(length=20), nullable=False),
|
|
sa.Column('author', sa.String(length=80), nullable=True),
|
|
sa.Column('name', sa.String(length=80), nullable=False),
|
|
sa.Column('enabled', sa.Boolean(), nullable=True),
|
|
sa.Column('description', sa.String(length=512), nullable=False),
|
|
sa.Column('is_public', sa.Boolean(), nullable=True),
|
|
sa.Column('logo', st.LargeBinary(), nullable=True),
|
|
sa.Column('owner_id', sa.String(length=36), nullable=False),
|
|
sa.Column('ui_definition', sa.Text(), nullable=True),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_index('ix_package_fqn',
|
|
'package',
|
|
['fully_qualified_name'])
|
|
|
|
op.create_table(
|
|
'session',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.String(length=36), nullable=False),
|
|
sa.Column('environment_id', sa.String(length=255), nullable=True),
|
|
sa.Column('user_id', sa.String(length=36), nullable=False),
|
|
sa.Column('state', sa.String(length=36), nullable=False),
|
|
sa.Column('description', sa.Text(), nullable=False),
|
|
sa.Column('version', sa.BigInteger(), nullable=False),
|
|
sa.ForeignKeyConstraint(['environment_id'], ['environment.id'], ),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_table(
|
|
'deployment',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.String(length=36), nullable=False),
|
|
sa.Column('started', sa.DateTime(), nullable=False),
|
|
sa.Column('finished', sa.DateTime(), nullable=True),
|
|
sa.Column('description', sa.Text(), nullable=False),
|
|
sa.Column('environment_id', sa.String(length=255), nullable=True),
|
|
sa.ForeignKeyConstraint(['environment_id'], ['environment.id'], ),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_table(
|
|
'class_definition',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.String(length=36), nullable=False),
|
|
sa.Column('name',
|
|
sa.String(length=128),
|
|
nullable=False,
|
|
unique=True),
|
|
sa.Column('package_id', sa.String(length=36), nullable=True),
|
|
sa.ForeignKeyConstraint(['package_id'], ['package.id'], ),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_index('ix_class_definition_name',
|
|
'class_definition',
|
|
['name'])
|
|
|
|
op.create_table(
|
|
'status',
|
|
sa.Column('created', sa.DateTime(), nullable=False),
|
|
sa.Column('updated', sa.DateTime(), nullable=False),
|
|
sa.Column('id', sa.String(length=36), nullable=False),
|
|
sa.Column('entity_id', sa.String(length=255), nullable=True),
|
|
sa.Column('entity', sa.String(length=10), nullable=True),
|
|
sa.Column('deployment_id', sa.String(length=36), nullable=True),
|
|
sa.Column('text', sa.Text(), nullable=False),
|
|
sa.Column('level', sa.String(length=32), nullable=False),
|
|
sa.Column('details', sa.Text(), nullable=True),
|
|
sa.ForeignKeyConstraint(['deployment_id'], ['deployment.id'], ),
|
|
sa.PrimaryKeyConstraint('id'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_table(
|
|
'package_to_tag',
|
|
sa.Column('package_id', sa.String(length=36), nullable=False),
|
|
sa.Column('tag_id', sa.String(length=36), nullable=False),
|
|
sa.ForeignKeyConstraint(['package_id'], ['package.id'], ),
|
|
sa.ForeignKeyConstraint(['tag_id'], ['tag.id'], ondelete='CASCADE'),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
op.create_table(
|
|
'package_to_category',
|
|
sa.Column('package_id', sa.String(length=36), nullable=False),
|
|
sa.Column('category_id', sa.String(length=36), nullable=False),
|
|
sa.ForeignKeyConstraint(['category_id'],
|
|
['category.id'],
|
|
ondelete='RESTRICT'),
|
|
sa.ForeignKeyConstraint(['package_id'], ['package.id'], ),
|
|
mysql_engine=MYSQL_ENGINE,
|
|
mysql_charset=MYSQL_CHARSET
|
|
)
|
|
|
|
_create_default_categories(op)
|
|
# end Alembic commands #
|
|
|
|
|
|
def downgrade():
|
|
op.drop_index('ix_category_name', table_name='category')
|
|
op.drop_index('ix_package_fqn', table_name='package')
|
|
op.drop_index('ix_class_definition_name', table_name='class_definition')
|
|
|
|
op.drop_table('status')
|
|
op.drop_table('package_to_category')
|
|
op.drop_table('class_definition')
|
|
op.drop_table('deployment')
|
|
op.drop_table('package_to_tag')
|
|
op.drop_table('session')
|
|
op.drop_table('instance_stats')
|
|
op.drop_table('package')
|
|
op.drop_table('apistats')
|
|
op.drop_table('category')
|
|
op.drop_table('tag')
|
|
op.drop_table('environment')
|
|
# end Alembic commands #
|