Sha256: eec5b6d0df05733980dae722e92bc1d30b3f67df0e5311b7654a563d0258e70b

Contents?: true

Size: 1.15 KB

Versions: 6

Compression:

Stored size: 1.15 KB

Contents

require "action_controller/metal"
require 'rails'

# Failure application that will be called every time :warden is thrown from
# any strategy or hook.
module GDS
  module SSO
    class FailureApp < ActionController::Metal
      include ActionController::UrlFor
      include ActionController::Redirecting
      include Rails.application.routes.url_helpers

      def self.call(env)
        if ::GDS::SSO::ApiAccess.api_call?(env)
          [ 401, {'WWW-Authenticate' => %(Bearer error="invalid_token") }, [] ]
        else
          action(:redirect).call(env)
        end
      end

      def redirect
        store_location!
        redirect_to '/auth/gds'
      end

      # Stores requested uri to redirect the user after signing in. We cannot use
      # scoped session provided by warden here, since the user is not authenticated
      # yet, but we still need to store the uri based on scope, so different scopes
      # would never use the same uri to redirect.

      # TOTALLY NOT DOING THE SCOPE THING. PROBABLY SHOULD.
      def store_location!
        session["return_to"] = request.env['warden.options'][:attempted_path] if request.get?
      end

    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
gds-sso-13.4.0 lib/gds-sso/failure_app.rb
gds-sso-13.3.0 lib/gds-sso/failure_app.rb
gds-sso-13.2.1 lib/gds-sso/failure_app.rb
gds-sso-13.2.0 lib/gds-sso/failure_app.rb
gds-sso-13.1.0 lib/gds-sso/failure_app.rb
gds-sso-13.0.0 lib/gds-sso/failure_app.rb