1 class DiaryEntryController < ApplicationController
2 layout 'site', :except => :rss
4 before_filter :authorize_web
5 before_filter :set_locale
6 before_filter :require_user, :only => [:new, :edit, :comment, :hide, :hidecomment]
7 before_filter :check_database_readable
8 before_filter :check_database_writable, :only => [:new, :edit]
9 before_filter :require_administrator, :only => [:hide, :hidecomment]
11 caches_action :list, :view, :layout => false
12 caches_action :rss, :layout => true
13 cache_sweeper :diary_sweeper, :only => [:new, :edit, :comment, :hide, :hidecomment]
16 @title = t 'diary_entry.new.title'
18 if params[:diary_entry]
19 @diary_entry = DiaryEntry.new(params[:diary_entry])
20 @diary_entry.user = @user
23 default_lang = @user.preferences.where(:k => "diary.default_language").first
25 default_lang.v = @diary_entry.language_code
28 @user.preferences.create(:k => "diary.default_language", :v => @diary_entry.language_code)
30 redirect_to :controller => 'diary_entry', :action => 'list', :display_name => @user.display_name
32 render :action => 'edit'
35 default_lang = @user.preferences.where(:k => "diary.default_language").first
36 lang_code = default_lang ? default_lang.v : @user.preferred_language
37 @diary_entry = DiaryEntry.new(:language_code => lang_code)
38 render :action => 'edit'
43 @title= t 'diary_entry.edit.title'
44 @diary_entry = DiaryEntry.find(params[:id])
46 if @user != @diary_entry.user
47 redirect_to :controller => 'diary_entry', :action => 'view', :id => params[:id]
48 elsif params[:diary_entry]
49 if @diary_entry.update_attributes(params[:diary_entry])
50 redirect_to :controller => 'diary_entry', :action => 'view', :id => params[:id]
53 rescue ActiveRecord::RecordNotFound
54 render :action => "no_such_entry", :status => :not_found
58 @entry = DiaryEntry.find(params[:id])
59 @diary_comment = @entry.comments.build(params[:diary_comment])
60 @diary_comment.user = @user
61 if @diary_comment.save
62 if @diary_comment.user != @entry.user
63 Notifier.diary_comment_notification(@diary_comment).deliver
66 redirect_to :controller => 'diary_entry', :action => 'view', :display_name => @entry.user.display_name, :id => @entry.id
68 render :action => 'view'
73 if params[:display_name]
74 @this_user = User.where(:status => ["active", "confirmed"]).find_by_display_name(params[:display_name])
77 @title = t 'diary_entry.list.user_title', :user => @this_user.display_name
78 @entry_pages, @entries = paginate(:diary_entries,
80 :user_id => @this_user.id,
83 :order => 'created_at DESC',
86 @title = t'diary_entry.no_such_user.title'
87 @not_found_user = params[:display_name]
89 render :action => 'no_such_user', :status => :not_found
91 elsif params[:language]
92 @title = t 'diary_entry.list.in_language_title', :language => Language.find(params[:language]).english_name
93 @entry_pages, @entries = paginate(:diary_entries, :include => :user,
95 :users => { :status => ["active", "confirmed"] },
97 :language_code => params[:language]
99 :order => 'created_at DESC',
102 @title = t 'diary_entry.list.title'
103 @entry_pages, @entries = paginate(:diary_entries, :include => :user,
105 :users => { :status => ["active", "confirmed"] },
108 :order => 'created_at DESC',
114 @entries = DiaryEntry.includes(:user).order("created_at DESC").limit(20)
116 if params[:display_name]
117 user = User.where("status IN ('active', 'confirmed')").find_by_display_name(params[:display_name])
120 @entries = @entries.where(:user_id => user.id, :visible => true )
121 @title = I18n.t('diary_entry.feed.user.title', :user => user.display_name)
122 @description = I18n.t('diary_entry.feed.user.description', :user => user.display_name)
123 @link = "http://#{SERVER_URL}/user/#{user.display_name}/diary"
125 render :nothing => true, :status => :not_found
127 elsif params[:language]
128 @entries = @entries.where(:users => { :status => ["active", "confirmed"] },
130 :language_code => params[:language])
131 @title = I18n.t('diary_entry.feed.language.title', :language_name => Language.find(params[:language]).english_name)
132 @description = I18n.t('diary_entry.feed.language.description', :language_name => Language.find(params[:language]).english_name)
133 @link = "http://#{SERVER_URL}/diary/#{params[:language]}"
135 @entries = @entries.where(:users => { :status => ["active", "confirmed"] },
137 @title = I18n.t('diary_entry.feed.all.title')
138 @description = I18n.t('diary_entry.feed.all.description')
139 @link = "http://#{SERVER_URL}/diary"
144 user = User.where("status IN ('active', 'confirmed')").find_by_display_name(params[:display_name])
147 @entry = DiaryEntry.where(:id => params[:id],
149 :visible => true).first
151 @title = t 'diary_entry.view.title', :user => params[:display_name], :title => @entry.title
153 @title = t 'diary_entry.no_such_entry.title', :id => params[:id]
154 render :action => 'no_such_entry', :status => :not_found
157 @not_found_user = params[:display_name]
159 render :action => 'no_such_user', :status => :not_found
164 entry = DiaryEntry.find(params[:id])
165 entry.update_attributes(:visible => false)
166 redirect_to :action => "list", :display_name => entry.user.display_name
170 comment = DiaryComment.find(params[:comment])
171 comment.update_attributes(:visible => false)
172 redirect_to :action => "view", :display_name => comment.diary_entry.user.display_name, :id => comment.diary_entry.id
176 # require that the user is a administrator, or fill out a helpful error message
177 # and return them to the user page.
178 def require_administrator
179 unless @user.administrator?
180 flash[:error] = t('user.filter.not_an_administrator')
181 redirect_to :controller => 'diary_entry', :action => 'view', :display_name => params[:id]