X-Git-Url: https://git.openstreetmap.org/rails.git/blobdiff_plain/c7bc13668b78afde72e9b8f6644b001799e84eb9..65e1dbb4a69cf5251c638e50e480aee3b77bca50:/app/models/issue.rb diff --git a/app/models/issue.rb b/app/models/issue.rb index 604b73d98..40e0bb82a 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -1,48 +1,48 @@ class Issue < ActiveRecord::Base - belongs_to :reportable, :polymorphic => true - belongs_to :user, :class_name => "User", :foreign_key => :reported_user_id + belongs_to :reportable, :polymorphic => true + belongs_to :reported_user, :class_name => "User", :foreign_key => :reported_user_id + belongs_to :user_updated, :class_name => "User", :foreign_key => :updated_by - has_many :reports - has_many :comments, :class_name => "IssueComment" - - validates :reportable_id, :uniqueness => { :scope => [ :reportable_type ] } - validates :reported_user_id, :presence => true + has_many :reports, :dependent => :destroy + has_many :comments, :class_name => "IssueComment", :dependent => :destroy - # Check if more statuses are needed - enum status: %w( open ignored resolved ) + validates :reportable_id, :uniqueness => { :scope => [:reportable_type] } + validates :reported_user_id, :presence => true - scope :with_status, -> (issue_status) { where(:status => statuses[issue_status])} + # Check if more statuses are needed + enum :status => %w[open ignored resolved] + enum :type => %w[administrator moderator] - def read_reports - resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil - end + scope :with_status, ->(issue_status) { where(:status => statuses[issue_status]) } - def unread_reports - resolved_at.present? ? reports.where("updated_at >= ?", resolved_at) : reports - end - - include AASM - aasm :column => :status, :no_direct_assignment => true do - state :open, :initial => true - state :ignored - state :resolved - - event :ignore do - transitions :from => :open, :to => :ignored - end - - event :resolve do - transitions :from => :open, :to => :resolved - after do - self.resolved_at = Time.now.getutc - end - end - - event :reopen do - transitions :from => :resolved, :to => :open - transitions :from => :ignored, :to => :open - end - - end + def read_reports + resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil + end + def unread_reports + resolved_at.present? ? reports.where("updated_at >= ?", resolved_at) : reports + end + + include AASM + aasm :column => :status, :no_direct_assignment => true do + state :open, :initial => true + state :ignored + state :resolved + + event :ignore do + transitions :from => :open, :to => :ignored + end + + event :resolve do + transitions :from => :open, :to => :resolved + after do + self.resolved_at = Time.now.getutc + end + end + + event :reopen do + transitions :from => :resolved, :to => :open + transitions :from => :ignored, :to => :open + end + end end