-class Issue < ActiveRecord::Base
- belongs_to :reportable, :polymorphic => true
- belongs_to :user, :class_name => "User", :foreign_key => :reported_user_id
+# == Schema Information
+#
+# Table name: issues
+#
+# id :integer not null, primary key
+# reportable_type :string not null
+# reportable_id :integer not null
+# reported_user_id :integer
+# status :enum default("open"), not null
+# assigned_role :enum not null
+# resolved_at :datetime
+# resolved_by :integer
+# updated_by :integer
+# reports_count :integer default(0)
+# created_at :datetime not null
+# updated_at :datetime not null
+#
+# Indexes
+#
+# index_issues_on_assigned_role (assigned_role)
+# index_issues_on_reportable_type_and_reportable_id (reportable_type,reportable_id)
+# index_issues_on_reported_user_id (reported_user_id)
+# index_issues_on_status (status)
+# index_issues_on_updated_by (updated_by)
+#
+# Foreign Keys
+#
+# issues_reported_user_id_fkey (reported_user_id => users.id)
+# issues_resolved_by_fkey (resolved_by => users.id)
+# issues_updated_by_fkey (updated_by => users.id)
+#
- 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
+class Issue < ApplicationRecord
+ belongs_to :reportable, :polymorphic => true
+ belongs_to :reported_user, :class_name => "User", :optional => true
+ belongs_to :user_resolved, :class_name => "User", :foreign_key => :resolved_by, :optional => true
+ belongs_to :user_updated, :class_name => "User", :foreign_key => :updated_by, :optional => true
- # Check if more statuses are needed
- enum status: %w( open ignored resolved )
- enum type: %w( administrator moderator )
+ has_many :reports, :dependent => :destroy
+ has_many :comments, :class_name => "IssueComment", :dependent => :destroy
- scope :with_status, -> (issue_status) { where(:status => statuses[issue_status])}
+ validates :reportable_id, :uniqueness => { :scope => [:reportable_type] }
- def read_reports
- resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil
- end
+ ASSIGNED_ROLES = %w[administrator moderator].freeze
+ validates :assigned_role, :presence => true, :inclusion => ASSIGNED_ROLES
- def unread_reports
+ before_validation :set_reported_user
+
+ scope :with_status, ->(issue_status) { where(:status => issue_status) }
+ scope :visible_to, ->(user) { where(:assigned_role => user.roles.map(&:role)) }
+
+ 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.utc
+ 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