kbeckman/omniauth-wsfed

View on GitHub
lib/omniauth/strategies/wsfed/auth_callback_validator.rb

Summary

Maintainability
A
0 mins
Test Coverage
module OmniAuth
  module Strategies
    class WSFed

      class AuthCallbackValidator

        attr_accessor :auth_callback, :wsfed_settings

        ISSUER_MISMATCH     = 'AuthN token issuer does not match configured issuer.'
        AUDIENCE_MISMATCH   = 'AuthN token audience does not match configured realm.'
        TOKEN_EXPIRED       = 'AuthN token has expired.'
        NO_CLAIMS           = 'AuthN token contains no claims.'
        NO_USER_IDENTIFIER  = 'AuthN token contains no user identifier. Verify that configured :id_claim setting is correct.'

        def initialize(auth_callback, wsfed_settings)
          self.auth_callback  = auth_callback
          self.wsfed_settings = wsfed_settings
        end

        def validate!
          validate_issuer!
          validate_audience!
          validate_token_expiration!
          validate_claims!
          validate_uid!

          true
        end

        def validate_issuer!
          raise OmniAuth::Strategies::WSFed::ValidationError.new(ISSUER_MISMATCH) unless
              auth_callback.issuer == wsfed_settings[:issuer_name]
        end

        def validate_audience!
          raise OmniAuth::Strategies::WSFed::ValidationError.new(AUDIENCE_MISMATCH) unless
              auth_callback.audience == wsfed_settings[:realm]
        end

        def validate_token_expiration!
          raise OmniAuth::Strategies::WSFed::ValidationError.new(TOKEN_EXPIRED) unless
              auth_callback.expires_at > Time.now.utc
        end

        def validate_claims!
          if auth_callback.claims.nil? || auth_callback.claims.empty?
            raise OmniAuth::Strategies::WSFed::ValidationError.new(NO_CLAIMS)
          end
        end

        def validate_uid!
          if auth_callback.name_id.nil? || auth_callback.name_id.empty?
            raise OmniAuth::Strategies::WSFed::ValidationError.new(NO_USER_IDENTIFIER)
          end
        end

      end

    end
  end
end