mirror of
https://github.com/omniauth/omniauth.git
synced 2022-11-09 12:31:49 -05:00
2242e6467c
Increase test coverage
178 lines
4.8 KiB
Ruby
178 lines
4.8 KiB
Ruby
require 'rack'
|
|
require 'singleton'
|
|
require 'logger'
|
|
|
|
module OmniAuth
|
|
class Error < StandardError; end
|
|
|
|
module Strategies
|
|
autoload :Developer, 'omniauth/strategies/developer'
|
|
end
|
|
|
|
autoload :Builder, 'omniauth/builder'
|
|
autoload :Strategy, 'omniauth/strategy'
|
|
autoload :Test, 'omniauth/test'
|
|
autoload :Form, 'omniauth/form'
|
|
autoload :AuthHash, 'omniauth/auth_hash'
|
|
autoload :FailureEndpoint, 'omniauth/failure_endpoint'
|
|
autoload :AuthenticityTokenProtection, 'omniauth/authenticity_token_protection'
|
|
|
|
def self.strategies
|
|
@strategies ||= []
|
|
end
|
|
|
|
class Configuration
|
|
include Singleton
|
|
|
|
def self.default_logger
|
|
logger = Logger.new(STDOUT)
|
|
logger.progname = 'omniauth'
|
|
logger
|
|
end
|
|
|
|
def self.defaults # rubocop:disable MethodLength
|
|
@defaults ||= {
|
|
:camelizations => {},
|
|
:path_prefix => '/auth',
|
|
:on_failure => OmniAuth::FailureEndpoint,
|
|
:failure_raise_out_environments => ['development'],
|
|
:request_validation_phase => OmniAuth::AuthenticityTokenProtection,
|
|
:before_request_phase => nil,
|
|
:before_callback_phase => nil,
|
|
:before_options_phase => nil,
|
|
:form_css => Form::DEFAULT_CSS,
|
|
:test_mode => false,
|
|
:logger => default_logger,
|
|
:allowed_request_methods => %i[post],
|
|
:mock_auth => {:default => AuthHash.new('provider' => 'default', 'uid' => '1234', 'info' => {'name' => 'Example User'})},
|
|
:silence_get_warning => false
|
|
}
|
|
end
|
|
|
|
def initialize
|
|
self.class.defaults.each_pair { |k, v| send("#{k}=", v) }
|
|
end
|
|
|
|
def on_failure(&block)
|
|
if block_given?
|
|
@on_failure = block
|
|
else
|
|
@on_failure
|
|
end
|
|
end
|
|
|
|
def before_callback_phase(&block)
|
|
if block_given?
|
|
@before_callback_phase = block
|
|
else
|
|
@before_callback_phase
|
|
end
|
|
end
|
|
|
|
def before_options_phase(&block)
|
|
if block_given?
|
|
@before_options_phase = block
|
|
else
|
|
@before_options_phase
|
|
end
|
|
end
|
|
|
|
def request_validation_phase(&block)
|
|
if block_given?
|
|
@request_validation_phase = block
|
|
else
|
|
@request_validation_phase
|
|
end
|
|
end
|
|
|
|
def before_request_phase(&block)
|
|
if block_given?
|
|
@before_request_phase = block
|
|
else
|
|
@before_request_phase
|
|
end
|
|
end
|
|
|
|
def add_mock(provider, original = {})
|
|
# Create key-stringified new hash from given auth hash
|
|
mock = {}
|
|
original.each_pair do |key, val|
|
|
mock[key.to_s] = if val.is_a? Hash
|
|
Hash[val.each_pair { |k, v| [k.to_s, v] }]
|
|
else
|
|
val
|
|
end
|
|
end
|
|
|
|
# Merge with the default mock and ensure provider is correct.
|
|
mock = mock_auth[:default].dup.merge(mock)
|
|
mock['provider'] = provider.to_s
|
|
|
|
# Add it to the mocks.
|
|
mock_auth[provider.to_sym] = mock
|
|
end
|
|
|
|
# This is a convenience method to be used by strategy authors
|
|
# so that they can add special cases to the camelization utility
|
|
# method that allows OmniAuth::Builder to work.
|
|
#
|
|
# @param name [String] The underscored name, e.g. `oauth`
|
|
# @param camelized [String] The properly camelized name, e.g. 'OAuth'
|
|
def add_camelization(name, camelized)
|
|
camelizations[name.to_s] = camelized.to_s
|
|
end
|
|
|
|
attr_writer :on_failure, :before_callback_phase, :before_options_phase, :before_request_phase, :request_validation_phase
|
|
attr_accessor :failure_raise_out_environments, :path_prefix, :allowed_request_methods, :form_css,
|
|
:test_mode, :mock_auth, :full_host, :camelizations, :logger, :silence_get_warning
|
|
end
|
|
|
|
def self.config
|
|
Configuration.instance
|
|
end
|
|
|
|
def self.configure
|
|
yield config
|
|
end
|
|
|
|
def self.logger
|
|
config.logger
|
|
end
|
|
|
|
def self.mock_auth_for(provider)
|
|
config.mock_auth[provider.to_sym] || config.mock_auth[:default]
|
|
end
|
|
|
|
module Utils
|
|
module_function # rubocop:disable Layout/IndentationWidth
|
|
|
|
def form_css
|
|
"<style type='text/css'>#{OmniAuth.config.form_css}</style>"
|
|
end
|
|
|
|
def deep_merge(hash, other_hash)
|
|
target = hash.dup
|
|
|
|
other_hash.each_key do |key|
|
|
if other_hash[key].is_a?(::Hash) && hash[key].is_a?(::Hash)
|
|
target[key] = deep_merge(target[key], other_hash[key])
|
|
next
|
|
end
|
|
|
|
target[key] = other_hash[key]
|
|
end
|
|
|
|
target
|
|
end
|
|
|
|
def camelize(word, first_letter_in_uppercase = true)
|
|
return OmniAuth.config.camelizations[word.to_s] if OmniAuth.config.camelizations[word.to_s]
|
|
|
|
if first_letter_in_uppercase
|
|
word.to_s.gsub(%r{/(.?)}) { '::' + Regexp.last_match[1].upcase }.gsub(/(^|_)(.)/) { Regexp.last_match[2].upcase }
|
|
else
|
|
camelize(word).tap { |w| w[0] = w[0].downcase }
|
|
end
|
|
end
|
|
end
|
|
end
|