Upgrade to http_accept_language 2.x

This commit is contained in:
Tom Hughes 2013-09-24 20:22:44 +01:00
parent 029547855f
commit 0e9e6e6f8f
8 changed files with 22 additions and 20 deletions

View file

@ -45,7 +45,7 @@ gem 'oauth-plugin', '>= 0.5.1'
gem 'open_id_authentication', '>= 1.1.0' gem 'open_id_authentication', '>= 1.1.0'
gem 'validates_email_format_of', '>= 1.5.1' gem 'validates_email_format_of', '>= 1.5.1'
gem 'composite_primary_keys', '>= 6.0.0' gem 'composite_primary_keys', '>= 6.0.0'
gem 'http_accept_language', '~> 1.0.2' gem 'http_accept_language', '~> 2.0.0'
gem 'paperclip', '~> 3.0' gem 'paperclip', '~> 3.0'
gem 'deadlock_retry', '>= 1.2.0' gem 'deadlock_retry', '>= 1.2.0'
gem 'openstreetmap-i18n-js', '>= 3.0.0.rc5.2', :require => 'i18n-js' gem 'openstreetmap-i18n-js', '>= 3.0.0.rc5.2', :require => 'i18n-js'

View file

@ -55,7 +55,7 @@ GEM
multipart-post (~> 1.2.0) multipart-post (~> 1.2.0)
hike (1.2.3) hike (1.2.3)
htmlentities (4.3.1) htmlentities (4.3.1)
http_accept_language (1.0.2) http_accept_language (2.0.0)
httpauth (0.2.0) httpauth (0.2.0)
httpclient (2.3.4.1) httpclient (2.3.4.1)
i18n (0.6.5) i18n (0.6.5)
@ -182,7 +182,7 @@ DEPENDENCIES
dynamic_form dynamic_form
ejs ejs
htmlentities htmlentities
http_accept_language (~> 1.0.2) http_accept_language (~> 2.0.0)
httpclient httpclient
iconv (= 0.1) iconv (= 0.1)
jquery-rails jquery-rails

View file

@ -185,10 +185,10 @@ class AmfController < ApplicationController
user = getuser(usertoken) user = getuser(usertoken)
if user && !user.languages.empty? if user && !user.languages.empty?
request.user_preferred_languages = user.languages http_accept_language.user_preferred_languages = user.languages
end end
lang = request.compatible_language_from(getlocales) lang = http_accept_language.compatible_language_from(getlocales)
(real_lang, localised) = getlocalized(lang) (real_lang, localised) = getlocalized(lang)
# Tell Potlatch what language it's using # Tell Potlatch what language it's using

View file

@ -284,14 +284,14 @@ class ApplicationController < ActionController::Base
response.header['Vary'] = 'Accept-Language' response.header['Vary'] = 'Accept-Language'
if @user && !@user.languages.empty? if @user && !@user.languages.empty?
request.user_preferred_languages = @user.languages http_accept_language.user_preferred_languages = @user.languages
response.header['Vary'] = '*' response.header['Vary'] = '*'
end end
I18n.locale = select_locale I18n.locale = select_locale
if @user && @user.languages.empty? && !request.user_preferred_languages.empty? if @user && @user.languages.empty? && !http_accept_language.user_preferred_languages.empty?
@user.languages = request.user_preferred_languages @user.languages = http_accept_language.user_preferred_languages
@user.save @user.save
end end
@ -300,11 +300,11 @@ class ApplicationController < ActionController::Base
def select_locale(locales = I18n.available_locales) def select_locale(locales = I18n.available_locales)
if params[:locale] if params[:locale]
request.user_preferred_languages = [ params[:locale] ] http_accept_language.user_preferred_languages = [ params[:locale] ]
end end
if request.compatible_language_from(locales).nil? if http_accept_language.compatible_language_from(locales).nil?
request.user_preferred_languages = request.user_preferred_languages.collect do |pl| http_accept_language.user_preferred_languages = http_accept_language.user_preferred_languages.collect do |pl|
pls = [ pl ] pls = [ pl ]
while pl.match(/^(.*)-[^-]+$/) while pl.match(/^(.*)-[^-]+$/)
@ -316,7 +316,7 @@ class ApplicationController < ActionController::Base
end.flatten end.flatten
end end
request.compatible_language_from(locales) || I18n.default_locale http_accept_language.compatible_language_from(locales) || I18n.default_locale
end end
helper_method :select_locale helper_method :select_locale

View file

@ -154,7 +154,7 @@ class GeocoderController < ApplicationController
end end
# ask nominatim # ask nominatim
response = fetch_xml("#{NOMINATIM_URL}search?format=xml&q=#{escape_query(query)}#{viewbox}#{exclude}&accept-language=#{request.user_preferred_languages.join(',')}") response = fetch_xml("#{NOMINATIM_URL}search?format=xml&q=#{escape_query(query)}#{viewbox}#{exclude}&accept-language=#{http_accept_language.user_preferred_languages.join(',')}")
# create result array # create result array
@results = Array.new @results = Array.new
@ -241,7 +241,7 @@ class GeocoderController < ApplicationController
@results = Array.new @results = Array.new
# ask nominatim # ask nominatim
response = fetch_xml("#{NOMINATIM_URL}reverse?lat=#{lat}&lon=#{lon}&zoom=#{zoom}&accept-language=#{request.user_preferred_languages.join(',')}") response = fetch_xml("#{NOMINATIM_URL}reverse?lat=#{lat}&lon=#{lon}&zoom=#{zoom}&accept-language=#{http_accept_language.user_preferred_languages.join(',')}")
# parse the response # parse the response
response.elements.each("reversegeocode/result") do |result| response.elements.each("reversegeocode/result") do |result|

View file

@ -79,7 +79,7 @@ class UserController < ApplicationController
@user.data_public = true @user.data_public = true
@user.description = "" if @user.description.nil? @user.description = "" if @user.description.nil?
@user.creation_ip = request.remote_ip @user.creation_ip = request.remote_ip
@user.languages = request.user_preferred_languages @user.languages = http_accept_language.user_preferred_languages
@user.terms_agreed = Time.now.getutc @user.terms_agreed = Time.now.getutc
@user.terms_seen = true @user.terms_seen = true
@user.openid_url = nil if @user.openid_url and @user.openid_url.empty? @user.openid_url = nil if @user.openid_url and @user.openid_url.empty?

View file

@ -3,6 +3,7 @@
# https://github.com/iain/http_accept_language/pull/6 # https://github.com/iain/http_accept_language/pull/6
# #
module HttpAcceptLanguage module HttpAcceptLanguage
class Parser
def compatible_language_from(available_languages) def compatible_language_from(available_languages)
user_preferred_languages.find do |x| user_preferred_languages.find do |x|
available_languages.find { |y| y.to_s == x.to_s } || available_languages.find { |y| y.to_s == x.to_s } ||
@ -10,3 +11,4 @@ module HttpAcceptLanguage
end end
end end
end end
end

View file

@ -3,7 +3,7 @@ module Nominatim
def self.describe_location(lat, lon, zoom = nil, language = nil) def self.describe_location(lat, lon, zoom = nil, language = nil)
zoom = zoom || 14 zoom = zoom || 14
language = language || request.user_preferred_languages.join(',') language = language || http_accept_language.user_preferred_languages.join(',')
Rails.cache.fetch "/nominatim/location/#{lat}/#{lon}/#{zoom}/#{language}" do Rails.cache.fetch "/nominatim/location/#{lat}/#{lon}/#{zoom}/#{language}" do
url = "http://nominatim.openstreetmap.org/reverse?lat=#{lat}&lon=#{lon}&zoom=#{zoom}&accept-language=#{language}" url = "http://nominatim.openstreetmap.org/reverse?lat=#{lat}&lon=#{lon}&zoom=#{zoom}&accept-language=#{language}"