mirror of
https://github.com/omniauth/omniauth.git
synced 2022-11-09 12:31:49 -05:00
47 lines
1.1 KiB
Ruby
47 lines
1.1 KiB
Ruby
require 'hashie/mash'
|
|
|
|
module OmniAuth
|
|
# The AuthHash is a normalized schema returned by all OmniAuth
|
|
# strategies. It maps as much user information as the provider
|
|
# is able to provide into the InfoHash (stored as the `'info'`
|
|
# key).
|
|
class AuthHash < Hashie::Mash
|
|
# Tells you if this is considered to be a valid
|
|
# OmniAuth AuthHash. The requirements for that
|
|
# are that it has a provider name, a uid, and a
|
|
# valid info hash. See InfoHash#valid? for
|
|
# more details there.
|
|
def valid?
|
|
uid? && provider? && info? && info.valid?
|
|
end
|
|
|
|
def regular_writer(key, value)
|
|
if key.to_s == 'info' && !value.is_a?(InfoHash)
|
|
value = InfoHash.new(value)
|
|
end
|
|
super
|
|
end
|
|
|
|
class InfoHash < Hashie::Mash
|
|
def name
|
|
return self[:name] if self[:name]
|
|
return "#{first_name} #{last_name}".strip if first_name? || last_name?
|
|
return nickname if nickname?
|
|
return email if email?
|
|
nil
|
|
end
|
|
|
|
def name?; !!name end
|
|
|
|
def valid?
|
|
name?
|
|
end
|
|
|
|
def to_hash
|
|
hash = super
|
|
hash['name'] ||= name
|
|
hash
|
|
end
|
|
end
|
|
end
|
|
end
|