]> git.openstreetmap.org Git - rails.git/blob - db/migrate/20160822153055_create_issues_and_reports.rb
a25523cb9c57b68263a37f845037670c1107966a
[rails.git] / db / migrate / 20160822153055_create_issues_and_reports.rb
1 require "migrate"
2
3 class CreateIssuesAndReports < ActiveRecord::Migration
4   def change
5     create_table :issues do |t|
6       t.string :reportable_type, :null => false
7       t.integer :reportable_id, :null => false
8       t.integer :reported_user_id, :null => false
9       t.integer :status
10       t.string :issue_type
11       t.datetime :resolved_at
12       t.integer :resolved_by
13       t.integer :updated_by
14       t.timestamps :null => false
15     end
16
17     add_foreign_key :issues, :users, :column => :reported_user_id, :name => "issues_reported_user_id_fkey", :on_delete => :cascade
18
19     add_index :issues, :reported_user_id
20     add_index :issues, [:reportable_id, :reportable_type]
21
22     create_table :reports do |t|
23       t.integer :issue_id
24       t.integer :reporter_user_id
25       t.text :details, :null => false
26       t.timestamps :null => false
27     end
28
29     add_foreign_key :reports, :issues, :name => "reports_issue_id_fkey", :on_delete => :cascade
30     add_foreign_key :reports, :users, :column => :reporter_user_id, :name => "reports_reporter_user_id_fkey", :on_delete => :cascade
31
32     add_index :reports, :reporter_user_id
33     add_index :reports, :issue_id
34   end
35 end