Upgrade to http_accept_language 2.x
This commit is contained in:
parent
029547855f
commit
0e9e6e6f8f
8 changed files with 22 additions and 20 deletions
2
Gemfile
2
Gemfile
|
@ -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'
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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|
|
||||||
|
|
|
@ -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?
|
||||||
|
|
|
@ -3,10 +3,12 @@
|
||||||
# https://github.com/iain/http_accept_language/pull/6
|
# https://github.com/iain/http_accept_language/pull/6
|
||||||
#
|
#
|
||||||
module HttpAcceptLanguage
|
module HttpAcceptLanguage
|
||||||
def compatible_language_from(available_languages)
|
class Parser
|
||||||
user_preferred_languages.find do |x|
|
def compatible_language_from(available_languages)
|
||||||
available_languages.find { |y| y.to_s == x.to_s } ||
|
user_preferred_languages.find do |x|
|
||||||
available_languages.find { |y| y.to_s =~ /^#{Regexp.escape(x.to_s)}-/ }
|
available_languages.find { |y| y.to_s == x.to_s } ||
|
||||||
|
available_languages.find { |y| y.to_s =~ /^#{Regexp.escape(x.to_s)}-/ }
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -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}"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue