X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/3e5a4a14df070909ebbfb76add8caae230d0d31d..550c4a3a45814fde5c809334c85f1ebc47659a82:/db/migrate/20160822153055_create_issues_and_reports.rb diff --git a/db/migrate/20160822153055_create_issues_and_reports.rb b/db/migrate/20160822153055_create_issues_and_reports.rb index cd0dc7a9f..07a549820 100644 --- a/db/migrate/20160822153055_create_issues_and_reports.rb +++ b/db/migrate/20160822153055_create_issues_and_reports.rb @@ -1,10 +1,12 @@ class CreateIssuesAndReports < ActiveRecord::Migration[5.0] - def change + def up + create_enumeration :issue_status_enum, %w[open ignored resolved] + create_table :issues do |t| t.string :reportable_type, :null => false t.integer :reportable_id, :null => false t.integer :reported_user_id - t.integer :status + t.column :status, :issue_status_enum, :null => false, :default => "open" t.column :assigned_role, :user_role_enum, :null => false t.datetime :resolved_at t.integer :resolved_by @@ -13,12 +15,15 @@ class CreateIssuesAndReports < ActiveRecord::Migration[5.0] t.timestamps :null => false end - add_foreign_key :issues, :users, :column => :reported_user_id, :name => "issues_reported_user_id_fkey", :on_delete => :cascade - add_foreign_key :issues, :users, :column => :updated_by, :name => "issues_updated_by_fkey", :on_delete => :cascade + add_foreign_key :issues, :users, :column => :reported_user_id, :name => "issues_reported_user_id_fkey" + add_foreign_key :issues, :users, :column => :resolved_by, :name => "issues_resolved_by_fkey" + add_foreign_key :issues, :users, :column => :updated_by, :name => "issues_updated_by_fkey" - add_index :issues, :reported_user_id - add_index :issues, [:reportable_id, :reportable_type] - add_index :issues, :updated_by + add_index :issues, [:reportable_type, :reportable_id] + add_index :issues, [:reported_user_id] + add_index :issues, [:status] + add_index :issues, [:assigned_role] + add_index :issues, [:updated_by] create_table :reports do |t| t.integer :issue_id, :null => false @@ -28,11 +33,11 @@ class CreateIssuesAndReports < ActiveRecord::Migration[5.0] t.timestamps :null => false end - add_foreign_key :reports, :issues, :name => "reports_issue_id_fkey", :on_delete => :cascade - add_foreign_key :reports, :users, :column => :user_id, :name => "reports_user_id_fkey", :on_delete => :cascade + add_foreign_key :reports, :issues, :name => "reports_issue_id_fkey" + add_foreign_key :reports, :users, :column => :user_id, :name => "reports_user_id_fkey" - add_index :reports, :user_id add_index :reports, :issue_id + add_index :reports, :user_id create_table :issue_comments do |t| t.integer :issue_id, :null => false @@ -41,10 +46,17 @@ class CreateIssuesAndReports < ActiveRecord::Migration[5.0] t.timestamps :null => false end - add_foreign_key :issue_comments, :issues, :name => "issue_comments_issue_id_fkey", :on_delete => :cascade - add_foreign_key :issue_comments, :users, :column => :user_id, :name => "issue_comments_user_id", :on_delete => :cascade + add_foreign_key :issue_comments, :issues, :name => "issue_comments_issue_id_fkey" + add_foreign_key :issue_comments, :users, :column => :user_id, :name => "issue_comments_user_id_fkey" - add_index :issue_comments, :user_id add_index :issue_comments, :issue_id + add_index :issue_comments, :user_id + end + + def down + drop_table :issue_comments + drop_table :reports + drop_table :issues + drop_enumeration :issue_status_enum end end