class ApplicationController < ActionController::Base
  
  # Prevent CSRF attacks by raising an exception.
  # For APIs, you may want to use :null_session instead.

  protect_from_forgery with: :exception
  
  before_filter :config_site
  
  before_filter :check_admin_mode
  
  before_filter :configure_permitted_parameters, if: :devise_controller?
  
  def configure_permitted_parameters
    devise_parameter_sanitizer.for(:account_update) { |u| u.permit(:first_name, :last_name, :email, :current_password, :avatar, :password, :password_confirmation, :avatar_tmp, :avatar_processing) }
    devise_parameter_sanitizer.for(:sign_up) { |u| u.permit(:first_name, :last_name, :email, :password) }
  end
    
  def config_site  
    @config = Info.first
    #I18n.config.enforce_available_locales = false
    I18n.default_locale = @config.default_language
  end
  
  protected

    def check_admin_mode
      if @config.maintenance_mode && controller_name != 'sessions' && !user_signed_in? && action_name != 'maintenance_mode'
        render 'admin_panel/maintenance_mode'
      elsif !@config.maintenance_mode && !user_signed_in? && action_name == 'maintenance_mode'
        redirect_to root_path
      end
    end
  
end