]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/issue.rb
Fixed existing tests
[rails.git] / app / models / issue.rb
index 7a481fe6cc80e0594f51a7ff167075a0a983d22b..6de535e819b7a0fb147f7770827a5b7319de91eb 100644 (file)
@@ -1,22 +1,25 @@
 class Issue < ActiveRecord::Base
        belongs_to :reportable, :polymorphic => true
 class Issue < ActiveRecord::Base
        belongs_to :reportable, :polymorphic => true
+       belongs_to :user, :class_name => "User", :foreign_key => :reported_user_id
+
        has_many :reports
        has_many :comments, :class_name => "IssueComment"
        has_many :reports
        has_many :comments, :class_name => "IssueComment"
+       
        validates :reportable_id, :uniqueness => { :scope => [ :reportable_type ] }
        validates :reportable_id, :uniqueness => { :scope => [ :reportable_type ] }
-       belongs_to :user
-       validates :user_id, :presence => true
+       validates :reported_user_id, :presence => true
 
        # Check if more statuses are needed
        enum status: %w( open ignored resolved )
 
        # 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])}
 
        def read_reports
 
        scope :with_status, -> (issue_status) { where(:status => statuses[issue_status])}
 
        def read_reports
-               resolved_at.present? ? reports.where("created_at < ?", resolved_at) : nil
+               resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil
        end
 
        def unread_reports
        end
 
        def unread_reports
-    resolved_at.present? ? reports.where("created_at >= ?", resolved_at) : reports
+    resolved_at.present? ? reports.where("updated_at >= ?", resolved_at) : reports
        end
 
        include AASM
        end
 
        include AASM
@@ -38,8 +41,8 @@ class Issue < ActiveRecord::Base
 
                event :reopen do
                        transitions :from => :resolved, :to => :open
 
                event :reopen do
                        transitions :from => :resolved, :to => :open
+                       transitions :from => :ignored, :to => :open
                end
 
        end
                end
 
        end
-
 end
 end