X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/5add3cf67145e1d3ccefcfb6095b8e56321e2057..69c1f6d1862aad00f80a0d2e32dbbe70aba65649:/app/models/issue.rb?ds=sidebyside diff --git a/app/models/issue.rb b/app/models/issue.rb index f678e94e1..690a02477 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -1,19 +1,26 @@ class Issue < ActiveRecord::Base belongs_to :reportable, :polymorphic => true - has_many :reports + belongs_to :user, :class_name => "User", :foreign_key => :reported_user_id + belongs_to :user_updated, :class_name => "User", :foreign_key => :updated_by + + has_many :reports, dependent: :destroy + has_many :comments, :class_name => "IssueComment", dependent: :destroy + validates :reportable_id, :uniqueness => { :scope => [ :reportable_type ] } + validates :reported_user_id, :presence => true # Check if more statuses are needed enum status: %w( open ignored resolved ) + enum type: %w( administrator moderator ) scope :with_status, -> (issue_status) { where(:status => statuses[issue_status])} def read_reports - resolved_at.present? ? reports.where("created_at < ?", resolved_at) : nil + resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil end def unread_reports - resolved_at.present? ? reports.where("created_at >= ?", resolved_at) : reports + resolved_at.present? ? reports.where("updated_at >= ?", resolved_at) : reports end include AASM @@ -35,8 +42,8 @@ class Issue < ActiveRecord::Base event :reopen do transitions :from => :resolved, :to => :open + transitions :from => :ignored, :to => :open end end - end