scinote-web/db/migrate/20200331183640_add_repository_snapshots.rb
2020-04-29 10:42:00 +02:00

39 lines
1.5 KiB
Ruby

# frozen_string_literal: true
class AddRepositorySnapshots < ActiveRecord::Migration[6.0]
def up
change_table :repositories, bulk: true do |t|
t.string :type
t.bigint :parent_id, null: true
t.integer :status, null: true
end
add_reference :repositories, :my_module
execute "UPDATE \"repositories\" SET \"type\" = 'Repository'"
execute "UPDATE \"activities\" SET \"subject_type\" = 'RepositoryBase' WHERE \"subject_type\" = 'Repository'"
add_column :repository_columns, :parent_id, :bigint, null: true
add_column :repository_rows, :parent_id, :bigint, null: true
remove_reference :repository_list_items, :repository, index: true, foreign_key: true
remove_reference :repository_status_items, :repository, foreign_key: true
remove_reference :repository_checklist_items, :repository, foreign_key: true
end
def down
add_reference :repository_list_items, :repository, index: true, foreign_key: true
add_reference :repository_status_items, :repository, index: true, foreign_key: true
add_reference :repository_checklist_items, :repository, index: true, foreign_key: true
remove_column :repository_columns, :parent_id
remove_column :repository_rows, :parent_id
execute "UPDATE \"activities\" SET \"subject_type\" = 'Repository' WHERE \"subject_type\" = 'RepositoryBase'"
remove_column :repositories, :parent_id, :bigint, null: true
remove_reference :repositories, :my_module
remove_column :repositories, :type, :string
end
end