Sha256: da8f1351b07e656dc1eebc32760ef166ee7fcd325ebd7558f025ed0778d5e646

Contents?: true

Size: 1.56 KB

Versions: 114

Compression:

Stored size: 1.56 KB

Contents

module Sessions::ControllerBase
  extend ActiveSupport::Concern

  # If user_return_to points to an oauth path we disable Turbo on the sign in form.
  # This makes it work when we need to redirect to external sites and/or custom protocols.
  # With Turbo enabled the browser will block those redirects with a CORS error.
  # https://github.com/bullet-train-co/bullet_train/issues/384
  def user_return_to_is_oauth
    session["user_return_to"]&.match(/^\/oauth/)
  end

  included do
    helper_method :user_return_to_is_oauth
  end

  def new
    # We allow people to pass in a URL to redirect to after sign in is complete. We have to do this because Safari
    # doesn't allow them to set this in a session before a redirect if there isn't already a session. However, for
    # security reasons we have to make sure we control the URL where we will redirect to, otherwise people could
    # trick folks into redirecting to a fake destination in a phishing scheme.
    if params[:return_url]&.start_with?(ENV["BASE_URL"])
      store_location_for(resource_name, params[:return_url])
    end

    super
  end

  def destroy
    if params.include?(:onboard_logout)
      signed_out = (Devise.sign_out_all_scopes ? sign_out : sign_out(resource_name))
      set_flash_message! :notice, :signed_out if signed_out
      yield if block_given?
      redirect_to root_path
    else
      super
    end
  end

  def pre_otp
    if (@email = params["user"]["email"].downcase.strip.presence)
      @user = User.find_by(email: @email)
    end

    respond_to do |format|
      format.js
    end
  end
end

Version data entries

114 entries across 114 versions & 1 rubygems

Version Path
bullet_train-1.14.0 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.13.0 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.12.3 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.12.2 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.12.1 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.12.0 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.11.0 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.10.0 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.9.0 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.8.5 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.8.4 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.8.3 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.8.2 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.8.1 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.8.0 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.7.23 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.7.22 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.7.21 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.7.20 app/controllers/concerns/sessions/controller_base.rb
bullet_train-1.7.19 app/controllers/concerns/sessions/controller_base.rb