opf/warden-basic_auth

View on GitHub
lib/warden/strategies/basic_auth.rb

Summary

Maintainability
A
0 mins
Test Coverage
require 'warden'
require 'rack/auth/basic'

module Warden
  module Strategies
    class BasicAuth < Base
      def valid?
        request.provided? && request.basic? && request.credentials
      end

      def authenticate!
        user = authenticate_user username, password

        if user
          authentication_successful user
        else
          authentication_failed
        end
      end

      def authenticate_user(username, password)
        raise NotImplementedError
      end

      def authentication_successful(user)
        success! user
      end

      def authentication_failed
        headers 'WWW-Authenticate' => %(#{auth_scheme} realm="#{realm}")

        fail! 'unauthorized'
      end

      def store?
        false
      end

      def username
        request.credentials[0]
      end

      def password
        request.credentials[1]
      end

      def request
        @request ||= Rack::Auth::Basic::Request.new(env)
      end

      def auth_scheme
        'Basic'
      end

      def realm
        'private area'
      end
    end
  end
end