X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/effb1b7f4170bb7244c4dfffcbe6134fe00e2bc4..a65ccb55b5f9699d31088e98f61f9846f3f8505e:/app/models/report.rb?ds=sidebyside diff --git a/app/models/report.rb b/app/models/report.rb index b857d7375..9bbf221df 100644 --- a/app/models/report.rb +++ b/app/models/report.rb @@ -1,6 +1,42 @@ +# == Schema Information +# +# Table name: reports +# +# id :integer not null, primary key +# issue_id :integer not null +# user_id :integer not null +# details :text not null +# category :string not null +# created_at :datetime not null +# updated_at :datetime not null +# +# Indexes +# +# index_reports_on_issue_id (issue_id) +# index_reports_on_user_id (user_id) +# +# Foreign Keys +# +# reports_issue_id_fkey (issue_id => issues.id) +# reports_user_id_fkey (user_id => users.id) +# + class Report < ActiveRecord::Base belongs_to :issue, :counter_cache => true - belongs_to :user, :class_name => "User", :foreign_key => :reporter_user_id + belongs_to :user + + validates :issue, :presence => true + validates :user, :presence => true + validates :details, :presence => true, :characters => true + validates :category, :presence => true - validates :details, :presence => true + def self.categories_for(reportable) + case reportable.class.name + when "DiaryEntry" then %w[spam offensive threat other] + when "DiaryComment" then %w[spam offensive threat other] + when "User" then %w[spam offensive threat vandal other] + when "Note" then %w[spam personal abusive other] + else %w[other] + end + end end