1 # == Schema Information
5 # id :integer not null, primary key
6 # reportable_type :string not null
7 # reportable_id :integer not null
8 # reported_user_id :integer not null
11 # resolved_at :datetime
12 # resolved_by :integer
14 # reports_count :integer default(0)
15 # created_at :datetime not null
16 # updated_at :datetime not null
20 # index_issues_on_reportable_id_and_reportable_type (reportable_id,reportable_type)
21 # index_issues_on_reported_user_id (reported_user_id)
22 # index_issues_on_updated_by (updated_by)
26 # issues_reported_user_id_fkey (reported_user_id => users.id) ON DELETE => cascade
27 # issues_updated_by_fkey (updated_by => users.id) ON DELETE => cascade
30 class Issue < ActiveRecord::Base
31 belongs_to :reportable, :polymorphic => true
32 belongs_to :reported_user, :class_name => "User", :foreign_key => :reported_user_id
33 belongs_to :user_updated, :class_name => "User", :foreign_key => :updated_by
35 has_many :reports, :dependent => :destroy
36 has_many :comments, :class_name => "IssueComment", :dependent => :destroy
38 validates :reportable_id, :uniqueness => { :scope => [:reportable_type] }
39 validates :reported_user_id, :presence => true
41 before_validation :set_reported_user
43 # Check if more statuses are needed
44 enum :status => %w[open ignored resolved]
45 enum :type => %w[administrator moderator]
47 scope :with_status, ->(issue_status) { where(:status => statuses[issue_status]) }
50 resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil
54 resolved_at.present? ? reports.where("updated_at >= ?", resolved_at) : reports
58 aasm :column => :status, :no_direct_assignment => true do
59 state :open, :initial => true
64 transitions :from => :open, :to => :ignored
68 transitions :from => :open, :to => :resolved
70 self.resolved_at = Time.now.getutc
75 transitions :from => :resolved, :to => :open
76 transitions :from => :ignored, :to => :open
83 self.reported_user = case reportable.class.name