¡@

Home 

OpenStack Study: 008_add_image_members_table.py

OpenStack Index

**** CubicPower OpenStack Study ****

def get_images_table(meta):

    """

    No changes to the images table from 007...

    """

    (get_images_table,) = from_migration_import(

        '007_add_owner', ['get_images_table'])

    images = get_images_table(meta)

    return images

**** CubicPower OpenStack Study ****

def get_image_properties_table(meta):

    """

    No changes to the image properties table from 007...

    """

    (get_image_properties_table,) = from_migration_import(

        '007_add_owner', ['get_image_properties_table'])

    image_properties = get_image_properties_table(meta)

    return image_properties

**** CubicPower OpenStack Study ****

def get_image_members_table(meta):

    images = get_images_table(meta)  # noqa

    image_members = Table('image_members',

                          meta,

                          Column('id',

                                 Integer(),

                                 primary_key=True,

                                 nullable=False),

                          Column('image_id',

                                 Integer(),

                                 ForeignKey('images.id'),

                                 nullable=False,

                                 index=True),

                          Column('member', String(255), nullable=False),

                          Column('can_share',

                                 Boolean(),

                                 nullable=False,

                                 default=False),

                          Column('created_at', DateTime(), nullable=False),

                          Column('updated_at', DateTime()),

                          Column('deleted_at', DateTime()),

                          Column('deleted',

                                 Boolean(),

                                 nullable=False,

                                 default=False,

                                 index=True),

                          UniqueConstraint('image_id', 'member'),

                          mysql_engine='InnoDB',

                          extend_existing=True)

    # DB2: an index has already been created for the UniqueConstraint option

    # specified on the Table() statement above.

    if meta.bind.name != "ibm_db_sa":

        Index('ix_image_members_image_id_member', image_members.c.image_id,

              image_members.c.member)

    return image_members

**** CubicPower OpenStack Study ****

def upgrade(migrate_engine):

    meta = MetaData()

    meta.bind = migrate_engine

    tables = [get_image_members_table(meta)]

    create_tables(tables)

**** CubicPower OpenStack Study ****

def downgrade(migrate_engine):

    meta = MetaData()

    meta.bind = migrate_engine

    tables = [get_image_members_table(meta)]

    drop_tables(tables)