X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/57a05a40fcc81048c2df1f78e024d4671acd46b1..882700c5c8890ba28dc83a9dc526b7bc242a0278:/app/controllers/diary_entry_controller.rb?ds=sidebyside diff --git a/app/controllers/diary_entry_controller.rb b/app/controllers/diary_entry_controller.rb index 8daeac5de..73e9629e0 100644 --- a/app/controllers/diary_entry_controller.rb +++ b/app/controllers/diary_entry_controller.rb @@ -8,6 +8,10 @@ class DiaryEntryController < ApplicationController before_filter :check_database_writable, :only => [:new, :edit] before_filter :require_administrator, :only => [:hide, :hidecomment] + caches_action :list, :view, :layout => false + caches_action :rss, :layout => true + cache_sweeper :diary_sweeper, :only => [:new, :edit, :comment, :hide, :hidecomment], :unless => STATUS == :database_offline + def new @title = t 'diary_entry.new.title' @@ -67,7 +71,7 @@ class DiaryEntryController < ApplicationController def list if params[:display_name] - @this_user = User.find_by_display_name(params[:display_name], :conditions => { :visible => true }) + @this_user = User.find_by_display_name(params[:display_name], :conditions => { :status => ["active", "confirmed"] }) if @this_user @title = t 'diary_entry.list.user_title', :user => @this_user.display_name @@ -88,7 +92,7 @@ class DiaryEntryController < ApplicationController @title = t 'diary_entry.list.in_language_title', :language => Language.find(params[:language]).english_name @entry_pages, @entries = paginate(:diary_entries, :include => :user, :conditions => { - :users => { :visible => true }, + :users => { :status => ["active", "confirmed"] }, :visible => true, :language_code => params[:language] }, @@ -98,7 +102,7 @@ class DiaryEntryController < ApplicationController @title = t 'diary_entry.list.title' @entry_pages, @entries = paginate(:diary_entries, :include => :user, :conditions => { - :users => { :visible => true }, + :users => { :status => ["active", "confirmed"] }, :visible => true }, :order => 'created_at DESC', @@ -110,7 +114,7 @@ class DiaryEntryController < ApplicationController request.format = :rss if params[:display_name] - user = User.find_by_display_name(params[:display_name], :conditions => { :visible => true }) + user = User.find_by_display_name(params[:display_name], :conditions => { :status => ["active", "confirmed"] }) if user @entries = DiaryEntry.find(:all, @@ -129,7 +133,7 @@ class DiaryEntryController < ApplicationController elsif params[:language] @entries = DiaryEntry.find(:all, :include => :user, :conditions => { - :users => { :visible => true }, + :users => { :status => ["active", "confirmed"] }, :visible => true, :language_code => params[:language] }, @@ -141,7 +145,7 @@ class DiaryEntryController < ApplicationController else @entries = DiaryEntry.find(:all, :include => :user, :conditions => { - :users => { :visible => true }, + :users => { :status => ["active", "confirmed"] }, :visible => true }, :order => 'created_at DESC', @@ -153,7 +157,7 @@ class DiaryEntryController < ApplicationController end def view - user = User.find_by_display_name(params[:display_name], :conditions => { :visible => true }) + user = User.find_by_display_name(params[:display_name], :conditions => { :status => ["active", "confirmed"] }) if user @entry = DiaryEntry.find(:first, :conditions => { @@ -162,7 +166,7 @@ class DiaryEntryController < ApplicationController :visible => true }) if @entry - @title = t 'diary_entry.view.title', :user => params[:display_name] + @title = t 'diary_entry.view.title', :user => params[:display_name], :title => @entry.title else @title = t 'diary_entry.no_such_entry.title', :id => params[:id] render :action => 'no_such_entry', :status => :not_found @@ -183,7 +187,7 @@ class DiaryEntryController < ApplicationController def hidecomment comment = DiaryComment.find(params[:comment]) comment.update_attributes(:visible => false) - redirect_to :action => "view", :id => comment.diary_entry.id + redirect_to :action => "view", :display_name => comment.diary_entry.user.display_name, :id => comment.diary_entry.id end private ##