Combine migrations into one
[rails.git] / app / models / issue.rb
1 # == Schema Information
2 #
3 # Table name: issues
4 #
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
9 #  status           :integer
10 #  issue_type       :string
11 #  resolved_at      :datetime
12 #  resolved_by      :integer
13 #  updated_by       :integer
14 #  reports_count    :integer          default(0)
15 #  created_at       :datetime         not null
16 #  updated_at       :datetime         not null
17 #
18 # Indexes
19 #
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)
23 #
24 # Foreign Keys
25 #
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
28 #
29
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
34
35   has_many :reports, :dependent => :destroy
36   has_many :comments, :class_name => "IssueComment", :dependent => :destroy
37
38   validates :reportable_id, :uniqueness => { :scope => [:reportable_type] }
39   validates :reported_user_id, :presence => true
40
41   before_validation :set_reported_user
42
43   # Check if more statuses are needed
44   enum :status => %w[open ignored resolved]
45   enum :type => %w[administrator moderator]
46
47   scope :with_status, ->(issue_status) { where(:status => statuses[issue_status]) }
48
49   def read_reports
50     resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil
51   end
52
53   def unread_reports
54     resolved_at.present? ? reports.where("updated_at >= ?", resolved_at) : reports
55   end
56
57   include AASM
58   aasm :column => :status, :no_direct_assignment => true do
59     state :open, :initial => true
60     state :ignored
61     state :resolved
62
63     event :ignore do
64       transitions :from => :open, :to => :ignored
65     end
66
67     event :resolve do
68       transitions :from => :open, :to => :resolved
69       after do
70         self.resolved_at = Time.now.getutc
71       end
72     end
73
74     event :reopen do
75       transitions :from => :resolved, :to => :open
76       transitions :from => :ignored, :to => :open
77     end
78   end
79
80   private
81
82   def set_reported_user
83     self.reported_user = case reportable.class.name
84                          when "User"
85                            reportable
86                          when "Note"
87                            reportable.author
88                          else
89                            reportable.user
90                          end
91   end
92 end