if session[:user]
@user = User.where(:id => session[:user]).where("status IN ('active', 'confirmed', 'suspended')").first
- if @user.display_name != cookies["_osm_username"]
- logger.info "Session user '#{@user.display_name}' does not match cookie user '#{cookies['_osm_username']}'"
- reset_session
- @user = nil
- elsif @user.status == "suspended"
+ if @user.status == "suspended"
session.delete(:user)
session_expires_automatically
if request.get?
redirect_to :controller => 'user', :action => 'login', :referer => request.fullpath
else
- render :nothing => true, :status => :forbidden
+ render :text => "", :status => :forbidden
end
end
end
flash[:error] = t('application.require_moderator.not_a_moderator')
redirect_to :action => 'index'
else
- render :nothing => true, :status => :forbidden
+ render :text => "", :status => :forbidden
end
end
end
response.header['Vary'] = 'Accept-Language'
if @user && !@user.languages.empty?
- request.user_preferred_languages = @user.languages
+ http_accept_language.user_preferred_languages = @user.languages
response.header['Vary'] = '*'
end
I18n.locale = select_locale
- if @user && @user.languages.empty? && !request.user_preferred_languages.empty?
- @user.languages = request.user_preferred_languages
+ if @user && @user.languages.empty? && !http_accept_language.user_preferred_languages.empty?
+ @user.languages = http_accept_language.user_preferred_languages
@user.save
end
def select_locale(locales = I18n.available_locales)
if params[:locale]
- request.user_preferred_languages = [ params[:locale] ]
+ http_accept_language.user_preferred_languages = [ params[:locale] ]
end
- if request.compatible_language_from(locales).nil?
- request.user_preferred_languages = request.user_preferred_languages.collect do |pl|
+ if http_accept_language.compatible_language_from(locales).nil?
+ http_accept_language.user_preferred_languages = http_accept_language.user_preferred_languages.collect do |pl|
pls = [ pl ]
while pl.match(/^(.*)-[^-]+$/)
end.flatten
end
- request.compatible_language_from(locales) || I18n.default_locale
+ http_accept_language.compatible_language_from(locales) || I18n.default_locale
end
helper_method :select_locale
begin
yield
rescue ActiveRecord::RecordNotFound => ex
- render :nothing => true, :status => :not_found
+ render :text => "", :status => :not_found
rescue LibXML::XML::Error, ArgumentError => ex
report_error ex.message, :bad_request
rescue ActiveRecord::RecordInvalid => ex
rescue ActionView::Template::Error => ex
ex = ex.original_exception
- if ex.is_a?(ActiveRecord::StatementInvalid) and ex.message =~ /^Timeout::Error/
+ if ex.is_a?(ActiveRecord::StatementInvalid) and ex.message =~ /execution expired/
ex = Timeout::Error.new
end
respond_to do |format|
format.html { render :template => "user/no_such_user", :status => :not_found }
- format.all { render :nothing => true, :status => :not_found }
+ format.all { render :text => "", :status => :not_found }
end
end
request.body.rewind
end
+ def preferred_editor
+ editor = if params[:editor]
+ params[:editor]
+ elsif @user and @user.preferred_editor
+ @user.preferred_editor
+ else
+ DEFAULT_EDITOR
+ end
+
+ if request.env['HTTP_USER_AGENT'] =~ /MSIE/ and editor == 'id'
+ editor = 'potlatch2'
+ end
+
+ editor
+ end
+
+ helper_method :preferred_editor
+
private
# extract authorisation credentials from headers, returns user = nil if none