2019-05-02 18:17:27 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-31 00:06:56 -04:00
|
|
|
class CreateForumThreadUser < ActiveRecord::Migration[4.2]
|
2013-02-05 14:16:51 -05:00
|
|
|
def up
|
|
|
|
create_table :forum_thread_users, id: false do |t|
|
|
|
|
t.integer :user_id, null: false
|
|
|
|
t.integer :forum_thread_id, null: false
|
|
|
|
t.boolean :starred, null: false, default: false
|
|
|
|
t.boolean :posted, null: false, default: false
|
|
|
|
t.integer :last_read_post_number, null: false, default: 1
|
2017-08-07 11:48:36 -04:00
|
|
|
t.timestamps null: false
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
execute "DELETE FROM read_posts"
|
2013-02-25 11:42:20 -05:00
|
|
|
|
|
|
|
add_index :forum_thread_users, [:forum_thread_id, :user_id], unique: true
|
2013-02-05 14:16:51 -05:00
|
|
|
|
|
|
|
drop_table :stars
|
|
|
|
drop_table :last_read_posts
|
|
|
|
end
|
|
|
|
|
|
|
|
def down
|
2013-02-25 11:42:20 -05:00
|
|
|
drop_table :forum_thread_users
|
2013-02-05 14:16:51 -05:00
|
|
|
|
|
|
|
create_table :stars, id: false do |t|
|
|
|
|
t.integer :parent_id, null: false
|
|
|
|
t.string :parent_type, limit: 50, null: false
|
2013-02-25 11:42:20 -05:00
|
|
|
t.integer :user_id, null: true
|
2017-08-07 11:48:36 -04:00
|
|
|
t.timestamps null: false
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
2013-02-25 11:42:20 -05:00
|
|
|
add_index :stars, [:parent_id, :parent_type, :user_id]
|
|
|
|
|
2013-02-05 14:16:51 -05:00
|
|
|
create_table :last_read_posts do |t|
|
|
|
|
t.integer :user_id, null: false
|
|
|
|
t.integer :forum_thread_id, null: false
|
|
|
|
t.integer :post_number, null: false
|
2017-08-07 11:48:36 -04:00
|
|
|
t.timestamps null: false
|
2013-02-05 14:16:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
add_index :last_read_posts, [:user_id, :forum_thread_id], unique: true
|
|
|
|
end
|
|
|
|
end
|