]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/issue.rb
Merge remote-tracking branch 'upstream/pull/5387'
[rails.git] / app / models / issue.rb
index f678e94e13ec67d7461e2e9c7e4d34e572951bac..a3f82ee40b11881bddf5d5226404f8209668f614 100644 (file)
@@ -1,42 +1,95 @@
-class Issue < ActiveRecord::Base
-       belongs_to :reportable, :polymorphic => true
-       has_many :reports
-       validates :reportable_id, :uniqueness => { :scope => [ :reportable_type ] }
+# == 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)
+#
 
 
-       # Check if more statuses are needed
-       enum status: %w( open ignored resolved )
+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
 
 
-       scope :with_status, -> (issue_status) { where(:status => statuses[issue_status])}
+  has_many :reports, :dependent => :destroy
+  has_many :comments, :class_name => "IssueComment", :dependent => :destroy
 
 
-       def read_reports
-               resolved_at.present? ? reports.where("created_at < ?", resolved_at) : nil
-       end
+  validates :reportable_id, :uniqueness => { :scope => [:reportable_type] }
 
 
-       def unread_reports
-    resolved_at.present? ? reports.where("created_at >= ?", resolved_at) : reports
-       end
+  ASSIGNED_ROLES = %w[administrator moderator].freeze
+  validates :assigned_role, :presence => true, :inclusion => ASSIGNED_ROLES
 
 
-       include AASM
-       aasm :column => :status, :no_direct_assignment => true do
-               state :open, :initial => true
-               state :ignored
-               state :resolved
+  before_validation :set_reported_user
 
 
-               event :ignore do
-                       transitions :from => :open, :to => :ignored 
-               end
+  scope :with_status, ->(issue_status) { where(:status => issue_status) }
+  scope :visible_to, ->(user) { where(:assigned_role => user.roles.map(&:role)) }
 
 
-               event :resolve do
-                       transitions :from => :open, :to => :resolved
-                       after do
-                               self.resolved_at = Time.now.getutc
-                       end
-               end
+  def read_reports
+    resolved_at.present? ? reports.where(:updated_at => ...resolved_at) : nil
+  end
 
 
-               event :reopen do
-                       transitions :from => :resolved, :to => :open
-               end
+  def unread_reports
+    resolved_at.present? ? reports.where(:updated_at => resolved_at..) : reports
+  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
 end