end
end
- # check if the user has been banned
- unless @user.nil? or @user.active_blocks.empty?
- # NOTE: need slightly more helpful message than this.
- render :text => t('application.setup_user_auth.blocked'), :status => :forbidden
+ # have we identified the user?
+ if @user
+ # check if the user has been banned
+ if not @user.active_blocks.empty?
+ # NOTE: need slightly more helpful message than this.
+ report_error t('application.setup_user_auth.blocked'), :forbidden
+ end
+
+ # if the user hasn't seen the contributor terms then don't
+ # allow editing - they have to go to the web site and see
+ # (but can decline) the CTs to continue.
+ if REQUIRE_TERMS_SEEN and not @user.terms_seen
+ set_locale
+ report_error t('application.setup_user_auth.need_to_see_terms'), :forbidden
+ end
end
end
end
end
+ if request.compatible_language_from(I18n.available_locales).nil?
+ request.user_preferred_languages = request.user_preferred_languages.collect do |pl|
+ pls = [ pl ]
+
+ while pl.match(/^(.*)-[^-]+$/)
+ pls.push($1) if I18n.available_locales.include?($1.to_sym)
+ pl = $1
+ end
+
+ pls
+ end.flatten
+
+ if @user and not request.compatible_language_from(I18n.available_locales).nil?
+ @user.languages = request.user_preferred_languages
+ @user.save
+ end
+ end
+
I18n.locale = request.compatible_language_from(I18n.available_locales)
response.headers['Content-Language'] = I18n.locale.to_s