X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/99df5f6179b63bac322ddcc6581350082f4b8846..e44f856b53fcba5b44af37126579a034ef654676:/app/models/issue.rb diff --git a/app/models/issue.rb b/app/models/issue.rb index b6a531824..d13f297a9 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -1,3 +1,32 @@ +# == Schema Information +# +# Table name: issues +# +# id :integer not null, primary key +# reportable_type :string not null +# reportable_id :integer not null +# reported_user_id :integer +# status :integer +# assigned_role :enum not null +# resolved_at :datetime +# resolved_by :integer +# updated_by :integer +# reports_count :integer default(0) +# created_at :datetime not null +# updated_at :datetime not null +# +# Indexes +# +# index_issues_on_reportable_id_and_reportable_type (reportable_id,reportable_type) +# index_issues_on_reported_user_id (reported_user_id) +# index_issues_on_updated_by (updated_by) +# +# Foreign Keys +# +# issues_reported_user_id_fkey (reported_user_id => users.id) ON DELETE => cascade +# issues_updated_by_fkey (updated_by => users.id) ON DELETE => cascade +# + class Issue < ActiveRecord::Base belongs_to :reportable, :polymorphic => true belongs_to :reported_user, :class_name => "User", :foreign_key => :reported_user_id @@ -7,13 +36,17 @@ class Issue < ActiveRecord::Base has_many :comments, :class_name => "IssueComment", :dependent => :destroy validates :reportable_id, :uniqueness => { :scope => [:reportable_type] } - validates :reported_user_id, :presence => true + + ASSIGNED_ROLES = %w[administrator moderator].freeze + validates :assigned_role, :presence => true, :inclusion => ASSIGNED_ROLES + + before_validation :set_default_assigned_role + before_validation :set_reported_user # Check if more statuses are needed - enum :status => %w(open ignored resolved) - enum :type => %w(administrator moderator) + enum :status => %w[open ignored resolved] - scope :with_status, -> (issue_status) { where(:status => statuses[issue_status]) } + scope :with_status, ->(issue_status) { where(:status => statuses[issue_status]) } def read_reports resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil @@ -45,4 +78,22 @@ class Issue < ActiveRecord::Base transitions :from => :ignored, :to => :open end end + + private + + def set_reported_user + self.reported_user = case reportable.class.name + when "User" + reportable + when "Note" + reportable.author + else + reportable.user + end + end + + def set_default_assigned_role + role = %w[Note].include?(reportable.class.name) ? "moderator" : "administrator" + self.assigned_role = role if assigned_role.blank? + end end