Browse Source

Localize with i18n for Devise::FailureApp (#2309)

This PR fixes I18n.locale for rake middlewares. Mastodon uses Devise that depends on Warden.
Warden::Manager can be found in rake middleware. It is outside of the controller.

In the case of authentication failed, warden calls throw(:warden). At the time Warden::Manager
delegates request to failure_app to generate response and flash[:alert] after catching it.
Unfortunately, I18n.locale is already reset then because I18n.with_locale is enabled only
inside the controller. If we used I18n.locale=, Devise::FailureApp could get the current locale.
master
alpaca-tc 7 years ago
committed by Eugen Rochko
parent
commit
9317ec8eb1
3 changed files with 21 additions and 17 deletions
  1. +2
    -3
      app/controllers/application_controller.rb
  2. +5
    -14
      app/controllers/concerns/localized.rb
  3. +14
    -0
      spec/controllers/auth/sessions_controller_spec.rb

+ 2
- 3
app/controllers/application_controller.rb View File

@ -115,8 +115,7 @@ class ApplicationController < ActionController::Base
end
def respond_with_error(code)
set_locale do
render "errors/#{code}", layout: 'error', status: code
end
set_locale
render "errors/#{code}", layout: 'error', status: code
end
end

+ 5
- 14
app/controllers/concerns/localized.rb View File

@ -4,25 +4,16 @@ module Localized
extend ActiveSupport::Concern
included do
around_action :set_locale
before_action :set_locale
end
private
def set_locale
locale = default_locale
if user_signed_in?
begin
locale = current_user.try(:locale) || default_locale
rescue I18n::InvalidLocale
locale = default_locale
end
end
I18n.with_locale(locale) do
yield
end
I18n.locale = default_locale
I18n.locale = current_user.locale if user_signed_in?
rescue I18n::InvalidLocale
I18n.locale = default_locale
end
def default_locale

+ 14
- 0
spec/controllers/auth/sessions_controller_spec.rb View File

@ -49,6 +49,20 @@ RSpec.describe Auth::SessionsController, type: :controller do
expect(controller.current_user).to be_nil
end
end
context 'using an unconfirmed password' do
before do
request.headers['Accept-Language'] = accept_language
post :create, params: { user: { email: unconfirmed_user.email, password: unconfirmed_user.password } }
end
let(:unconfirmed_user) { user.tap { |u| u.update!(confirmed_at: nil) } }
let(:accept_language) { 'fr' }
it 'shows a translated login error' do
expect(flash[:alert]).to eq(I18n.t('devise.failure.unconfirmed', locale: accept_language))
end
end
end
context 'using two-factor authentication' do

Loading…
Cancel
Save