X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/0df788d74232330eea5c2d4854ba0d10796053eb..e44f856b53fcba5b44af37126579a034ef654676:/app/models/issue.rb diff --git a/app/models/issue.rb b/app/models/issue.rb index 7294b07f5..d13f297a9 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -5,7 +5,7 @@ # id :integer not null, primary key # reportable_type :string not null # reportable_id :integer not null -# reported_user_id :integer not null +# reported_user_id :integer # status :integer # assigned_role :enum not null # resolved_at :datetime @@ -36,14 +36,15 @@ class Issue < ActiveRecord::Base has_many :comments, :class_name => "IssueComment", :dependent => :destroy validates :reportable_id, :uniqueness => { :scope => [:reportable_type] } - validates :reported_user_id, :presence => true + + 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] - enum :type => %w[administrator moderator] scope :with_status, ->(issue_status) { where(:status => statuses[issue_status]) } @@ -92,7 +93,7 @@ class Issue < ActiveRecord::Base end def set_default_assigned_role - role = %w[Changeset Note].include?(reportable.class.name) ? "moderator" : "administrator" + role = %w[Note].include?(reportable.class.name) ? "moderator" : "administrator" self.assigned_role = role if assigned_role.blank? end end