Module: TinySupport::ActionController::RequestInit

Defined in:
lib/tiny_support/action_controller/request_init.rb

Defined Under Namespace

Modules: ControllerMethods, HelperMethods

Class Method Summary collapse

Class Method Details

.included(base) ⇒ Object



5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
# File 'lib/tiny_support/action_controller/request_init.rb', line 5

def self.included base
  base.class_eval do
    include ControllerMethods
    helper HelperMethods

    before_action do |controller|
      request = controller.send(:request)

      # logger
      if defined? Rails
        Rails.logger.debug "  - request logger start"
        Rails.logger.debug "    remote_ip: #{request.remote_ip}"
        Rails.logger.debug "    locale: #{I18n.locale}"
        Rails.logger.debug "    session:"
        session.to_hash.each do |key, value|
          Rails.logger.debug "     - #{key}: #{value}"
        end

        # set locale
        params_locale = params[:locale] || cookies[:locale]

        if params_locale.present?
          params_locale = params_locale.to_sym

          if I18n.available_locales.include?(params_locale)
            I18n.locale = params_locale
            set_cookies('locale', :value => params_locale)
          else
            I18n.locale = I18n.default_locale
          end
        else
          I18n.locale = I18n.default_locale
        end
      end
    end
  end
end