X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/5310c7000c232cd48f48fe473beeca7f4ff02b53..9c83235f72aece554426751e334c1f0b4ccaea64:/app/models/issue.rb diff --git a/app/models/issue.rb b/app/models/issue.rb index 00ee934f7..f18581b5f 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -6,7 +6,7 @@ # reportable_type :string not null # reportable_id :integer not null # reported_user_id :integer -# status :integer +# status :enum default("open"), not null # assigned_role :enum not null # resolved_at :datetime # resolved_by :integer @@ -17,8 +17,10 @@ # # 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 @@ -42,13 +44,10 @@ class Issue < ActiveRecord::Base ASSIGNED_ROLES = %w[administrator moderator].freeze validates :assigned_role, :presence => true, :inclusion => ASSIGNED_ROLES - before_validation :set_default_assigned_role before_validation :set_reported_user - # Check if more statuses are needed - enum :status => %w[open ignored resolved] - scope :with_status, ->(issue_status) { where(:status => statuses[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 @@ -93,9 +92,4 @@ class Issue < ActiveRecord::Base reportable.user end end - - def set_default_assigned_role - role = %w[Note].include?(reportable.class.name) ? "moderator" : "administrator" - self.assigned_role = role if assigned_role.blank? - end end