]> git.openstreetmap.org Git - rails.git/blobdiff - app/models/user_sweeper.rb
Use before_validation with :on rather than before_validation_on_xxx
[rails.git] / app / models / user_sweeper.rb
index 7f172317d4adc0fc7d5e67efeccdb9581667a0e2..7e420ae40b42684d4acdbf0dde025ad243dc2c57 100644 (file)
@@ -14,14 +14,19 @@ private
   def expire_cache_for(old_record, new_record)
     if old_record and
         (new_record.nil? or
-         old_record.visible != new_record.visible or
-         old_record.display_name != new_record.display_name)
+         old_record.visible? != new_record.visible? or
+         old_record.display_name != new_record.display_name or
+         old_record.image != new_record.image)
       old_record.diary_entries.each do |entry|
         expire_action(:controller => 'diary_entry', :action => 'view', :display_name => old_record.display_name, :id => entry.id)
         expire_action(:controller => 'diary_entry', :action => 'list', :language => entry.language_code, :display_name => nil)
         expire_action(:controller => 'diary_entry', :action => 'rss', :language => entry.language_code, :display_name => nil)
       end
 
+      old_record.diary_comments.each do |comment|
+        expire_action(:controller => 'diary_entry', :action => 'view', :display_name => comment.diary_entry.user.display_name, :id => comment.diary_entry.id)
+      end
+
       expire_action(:controller => 'diary_entry', :action => 'list', :language => nil, :display_name => nil)
       expire_action(:controller => 'diary_entry', :action => 'list', :language => nil, :display_name => old_record.display_name)