16 lines
682 B
Ruby
16 lines
682 B
Ruby
|
class CreateUserProfileViews < ActiveRecord::Migration
|
||
|
def change
|
||
|
create_table :user_profile_views do |t|
|
||
|
t.integer :user_profile_id, null: false
|
||
|
t.datetime :viewed_at, null: false
|
||
|
t.inet :ip_address, null: false
|
||
|
t.integer :user_id
|
||
|
end
|
||
|
|
||
|
add_index :user_profile_views, :user_profile_id
|
||
|
add_index :user_profile_views, :user_id
|
||
|
add_index :user_profile_views, [:viewed_at, :ip_address, :user_profile_id], where: "user_id IS NULL", unique: true, name: 'unique_profile_view_ip'
|
||
|
add_index :user_profile_views, [:viewed_at, :user_id, :user_profile_id], where: "user_id IS NOT NULL", unique: true, name: 'unique_profile_view_user'
|
||
|
end
|
||
|
end
|