orientation/orientation

View on GitHub
app/controllers/application_controller.rb

Summary

Maintainability
A
0 mins
Test Coverage
require "application_responder"

class ApplicationController < ActionController::Base
  self.responder = ApplicationResponder
  respond_to :html

  before_action :authenticate_user!
  before_action :warn_about_email_whitelist

  private

  def current_user
    @current_user ||= begin
      user = nil

      # In the development environment, your current_user will be the
      # first User in the database or a dummy one created below.
      if Rails.env.development? || Rails.env.test? || demo_app?
        user = User.first_or_create!(name: "Orientation", email: "about@orientation.io")
        session[:user_id] = user.id
      else
        user = User.find(session[:user_id]) if session[:user_id].present?
      end

      # Draper decorators still instantiate a decorator when passed nil,
      # so we have to be careful not to return anything if no user could
      # be found.
      AuthorDecorator.decorate(user) if user.present?
    end
  end
  helper_method :current_user

  def user_signed_in?
    current_user.present?
  end
  helper_method :user_signed_in?

  def authenticate_user!
    return true if current_user
    session["return_to"] ||= request.url
    redirect_to sign_in_path unless redirect_loop?
  end
  helper_method :authenticate_user!

  def redirect_loop?
    login_redirect? || oauth_callback?
  end

  def login_redirect?
    request.path == sign_in_path
  end

  def oauth_callback?
    request.path == oauth_callback_path("google_oauth2")
  end

  def warn_about_email_whitelist
    if Rails.env.production? && !demo_app? && !User.email_whitelist_enabled?
      flash[:error] = "WARNING: email whitelisting is currently disabled, set ENV['ORIENTATION_EMAIL_WHITELIST'] to enable it."
    end
  end

  def demo_app?
    return false if ENV["ORIENTATION_FORCE_AUTH_IN_DEMO"]

    ENV["HEROKU_APP_NAME"] == "orientation-demo"
  end
end