b03df3e31b8d_.py 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. """empty message
  2. Revision ID: b03df3e31b8d
  3. Revises:
  4. Create Date: 2021-08-11 12:46:17.757283
  5. """
  6. from alembic import op
  7. import sqlalchemy as sa
  8. # revision identifiers, used by Alembic.
  9. revision = 'b03df3e31b8d'
  10. down_revision = None
  11. branch_labels = None
  12. depends_on = None
  13. def upgrade():
  14. # ### commands auto generated by Alembic - please adjust! ###
  15. op.create_table('label_provider',
  16. sa.Column('id', sa.Integer(), nullable=False),
  17. sa.Column('name', sa.String(), nullable=False),
  18. sa.Column('description', sa.String(), nullable=True),
  19. sa.Column('root_folder', sa.String(), nullable=False),
  20. sa.Column('configuration_file', sa.String(), nullable=False),
  21. sa.PrimaryKeyConstraint('id'),
  22. sa.UniqueConstraint('root_folder', 'configuration_file')
  23. )
  24. op.create_table('model',
  25. sa.Column('id', sa.Integer(), nullable=False),
  26. sa.Column('name', sa.String(), nullable=False),
  27. sa.Column('description', sa.String(), nullable=True),
  28. sa.Column('root_folder', sa.String(), nullable=False),
  29. sa.Column('supports_encoded', sa.String(), nullable=False),
  30. sa.PrimaryKeyConstraint('id'),
  31. sa.UniqueConstraint('root_folder')
  32. )
  33. op.create_table('project',
  34. sa.Column('id', sa.Integer(), nullable=False),
  35. sa.Column('name', sa.String(), nullable=False),
  36. sa.Column('description', sa.String(), nullable=True),
  37. sa.Column('created', sa.DateTime(), nullable=False),
  38. sa.Column('model_id', sa.Integer(), nullable=True),
  39. sa.Column('label_provider_id', sa.Integer(), nullable=True),
  40. sa.Column('root_folder', sa.String(), nullable=False),
  41. sa.Column('external_data', sa.Boolean(), nullable=False),
  42. sa.Column('data_folder', sa.String(), nullable=False),
  43. sa.ForeignKeyConstraint(['label_provider_id'], ['label_provider.id'], ondelete='SET NULL'),
  44. sa.ForeignKeyConstraint(['model_id'], ['model.id'], ondelete='SET NULL'),
  45. sa.PrimaryKeyConstraint('id'),
  46. sa.UniqueConstraint('root_folder')
  47. )
  48. op.create_index(op.f('ix_project_created'), 'project', ['created'], unique=False)
  49. op.create_table('collection',
  50. sa.Column('id', sa.Integer(), nullable=False),
  51. sa.Column('name', sa.String(), nullable=False),
  52. sa.Column('project_id', sa.Integer(), nullable=False),
  53. sa.Column('reference', sa.String(), nullable=False),
  54. sa.Column('description', sa.String(), nullable=True),
  55. sa.Column('position', sa.Integer(), nullable=False),
  56. sa.Column('autoselect', sa.Boolean(), nullable=False),
  57. sa.ForeignKeyConstraint(['project_id'], ['project.id'], ondelete='CASCADE'),
  58. sa.PrimaryKeyConstraint('id'),
  59. sa.UniqueConstraint('project_id', 'reference')
  60. )
  61. op.create_table('label',
  62. sa.Column('name', sa.String(), nullable=False),
  63. sa.Column('id', sa.Integer(), nullable=False),
  64. sa.Column('project_id', sa.Integer(), nullable=False),
  65. sa.Column('parent_id', sa.Integer(), nullable=True),
  66. sa.Column('created', sa.DateTime(), nullable=False),
  67. sa.Column('reference', sa.String(), nullable=True),
  68. sa.Column('hierarchy_level', sa.String(), nullable=True),
  69. sa.ForeignKeyConstraint(['parent_id'], ['label.id'], ondelete='SET NULL'),
  70. sa.ForeignKeyConstraint(['project_id'], ['project.id'], ondelete='CASCADE'),
  71. sa.PrimaryKeyConstraint('id'),
  72. sa.UniqueConstraint('project_id', 'reference')
  73. )
  74. op.create_index(op.f('ix_label_created'), 'label', ['created'], unique=False)
  75. op.create_table('file',
  76. sa.Column('id', sa.Integer(), nullable=False),
  77. sa.Column('name', sa.String(), nullable=False),
  78. sa.Column('uuid', sa.String(), nullable=False),
  79. sa.Column('extension', sa.String(), nullable=False),
  80. sa.Column('type', sa.String(), nullable=False),
  81. sa.Column('size', sa.Integer(), nullable=False),
  82. sa.Column('created', sa.DateTime(), nullable=False),
  83. sa.Column('path', sa.String(), nullable=False),
  84. sa.Column('frames', sa.Integer(), nullable=True),
  85. sa.Column('fps', sa.Float(), nullable=True),
  86. sa.Column('project_id', sa.Integer(), nullable=False),
  87. sa.Column('collection_id', sa.Integer(), nullable=True),
  88. sa.ForeignKeyConstraint(['collection_id'], ['collection.id'], ondelete='SET NULL'),
  89. sa.ForeignKeyConstraint(['project_id'], ['project.id'], ondelete='CASCADE'),
  90. sa.PrimaryKeyConstraint('id'),
  91. sa.UniqueConstraint('project_id', 'path')
  92. )
  93. op.create_index(op.f('ix_file_created'), 'file', ['created'], unique=False)
  94. op.create_table('result',
  95. sa.Column('id', sa.Integer(), nullable=False),
  96. sa.Column('file_id', sa.Integer(), nullable=False),
  97. sa.Column('origin', sa.String(), nullable=False),
  98. sa.Column('type', sa.String(), nullable=False),
  99. sa.Column('label_id', sa.Integer(), nullable=True),
  100. sa.Column('data_encoded', sa.String(), nullable=True),
  101. sa.ForeignKeyConstraint(['file_id'], ['file.id'], ondelete='CASCADE'),
  102. sa.ForeignKeyConstraint(['label_id'], ['label.id'], ondelete='SET NULL'),
  103. sa.PrimaryKeyConstraint('id')
  104. )
  105. # ### end Alembic commands ###
  106. def downgrade():
  107. # ### commands auto generated by Alembic - please adjust! ###
  108. op.drop_table('result')
  109. op.drop_index(op.f('ix_file_created'), table_name='file')
  110. op.drop_table('file')
  111. op.drop_index(op.f('ix_label_created'), table_name='label')
  112. op.drop_table('label')
  113. op.drop_table('collection')
  114. op.drop_index(op.f('ix_project_created'), table_name='project')
  115. op.drop_table('project')
  116. op.drop_table('model')
  117. op.drop_table('label_provider')
  118. # ### end Alembic commands ###