class Issue < ActiveRecord::Base
- belongs_to :reportable, :polymorphic => true
- belongs_to :user, :class_name => "User", :foreign_key => :reported_user_id
- belongs_to :user_updated, :class_name => "User", :foreign_key => :updated_by
+ 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, dependent: :destroy
- has_many :comments, :class_name => "IssueComment", dependent: :destroy
-
- 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 )
- enum type: %w( administrator moderator )
+ validates :reportable_id, :uniqueness => { :scope => [:reportable_type] }
+ validates :reported_user_id, :presence => true
- scope :with_status, -> (issue_status) { where(:status => statuses[issue_status])}
+ before_validation :set_reported_user
- def read_reports
- resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil
- end
+ # Check if more statuses are needed
+ enum :status => %w[open ignored resolved]
+ enum :type => %w[administrator moderator]
- def unread_reports
+ scope :with_status, ->(issue_status) { where(:status => statuses[issue_status]) }
+
+ 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
+
+ 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
+
+ private
+
+ def set_reported_user
+ self.reported_user = case reportable.class.name
+ when "User"
+ reportable
+ when "Note"
+ reportable.author
+ else
+ reportable.user
+ end
+ end
end