X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/d49922eb630abb73c7faffb650ab97b3c5d94c52..f643b6627c52cc778a9df01a231a5cdfb89e77f7:/app/models/issue.rb?ds=sidebyside diff --git a/app/models/issue.rb b/app/models/issue.rb index 277ea3569..a3f82ee40 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -1,43 +1,95 @@ -class Issue < ActiveRecord::Base - belongs_to :reportable, :polymorphic => true - has_many :reports - validates :reportable_id, :uniqueness => { :scope => [ :reportable_type ] } - belongs_to :user +# == 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