Class: OmniAuth::Strategies::Facebook

Inherits:
OAuth2
  • Object
show all
Defined in:
lib/omniauth/strategies/facebook.rb

Overview

Authenticate to Facebook utilizing OAuth 2.0 and retrieve basic user information.

Examples:

Basic Usage

use OmniAuth::Strategies::Facebook, 'client_id', 'client_secret'

Instance Attribute Summary

Attributes inherited from OAuth2

#client_id, #client_options, #client_secret, #options

Instance Method Summary collapse

Methods inherited from OAuth2

#callback_url, #client

Constructor Details

#initialize(app, client_id = nil, client_secret = nil, options = {}, &block) ⇒ Facebook

Returns a new instance of Facebook.

Parameters:

  • app (Rack Application)

    standard middleware application parameter

  • client_id (String) (defaults to: nil)

    the application id as [registered on Facebook](www.facebook.com/developers/)

  • client_secret (String) (defaults to: nil)

    the application secret as registered on Facebook

  • options (Hash) (defaults to: {})

    a customizable set of options

Options Hash (options):

  • :scope (String) — default: 'email,offline_access'

    comma-separated extended permissions such as ‘email` and `manage_pages`



16
17
18
# File 'lib/omniauth/strategies/facebook.rb', line 16

def initialize(app, client_id = nil, client_secret = nil, options = {}, &block)
  super(app, :facebook, client_id, client_secret, {:site => 'https://graph.facebook.com/'}, options, &block)
end

Instance Method Details

#auth_hashObject



61
62
63
64
65
66
67
# File 'lib/omniauth/strategies/facebook.rb', line 61

def auth_hash
  OmniAuth::Utils.deep_merge(super, {
    'uid' => user_data['id'],
    'user_info' => ,
    'extra' => {'user_hash' => user_data}
  })
end

#build_access_tokenObject



29
30
31
32
33
34
35
# File 'lib/omniauth/strategies/facebook.rb', line 29

def build_access_token
  if facebook_session.nil? || facebook_session.empty?
    super
  else
    @access_token = ::OAuth2::AccessToken.new(client, facebook_session['access_token'])
  end
end

#facebook_sessionObject



37
38
39
40
41
42
43
44
# File 'lib/omniauth/strategies/facebook.rb', line 37

def facebook_session
  session_cookie = request.cookies["fbs_#{client.id}"]
  if session_cookie
    @facebook_session ||= Rack::Utils.parse_query(request.cookies["fbs_#{client.id}"].gsub('"', ''))
  else
    nil
  end
end

#request_phaseObject



24
25
26
27
# File 'lib/omniauth/strategies/facebook.rb', line 24

def request_phase
  options[:scope] ||= "email,offline_access"
  super
end

#user_dataObject



20
21
22
# File 'lib/omniauth/strategies/facebook.rb', line 20

def user_data
  @data ||= MultiJson.decode(@access_token.get('/me', {}, { "Accept-Language" => "en-us,en;"}))
end

#user_infoObject



46
47
48
49
50
51
52
53
54
55
56
57
58
59
# File 'lib/omniauth/strategies/facebook.rb', line 46

def 
  {
    'nickname' => user_data["link"].split('/').last,
    'email' => (user_data["email"] if user_data["email"]),
    'first_name' => user_data["first_name"],
    'last_name' => user_data["last_name"],
    'name' => "#{user_data['first_name']} #{user_data['last_name']}",
    'image' => "http://graph.facebook.com/#{user_data['id']}/picture?type=square",
    'urls' => {
      'Facebook' => user_data["link"],
      'Website' => user_data["website"],
    }
  }
end