Предоставляет ли OmniAuth простые подключения к API Graph Facebook? - PullRequest
7 голосов
/ 25 октября 2010

Я работаю над интеграцией Omniauth с моим новым приложением Facebook, и я просматриваю довольно скудную документацию, чтобы понять, дает ли она простые способы доступа к графическому API ... Я переезжаю из Koala, которая была довольно простой.

Кто-нибудь еще использовал Омниавт для этого?Я хочу получать фотографии из альбомов пользователей, а также сортировать и получать уникальные URL-адреса для них.

Ответы [ 6 ]

14 голосов
/ 25 октября 2010

Я наконец узнал:

1) включить этот камень

2) использовать камень:

user = FbGraph::User.new('me', :access_token => session[:omniauth]["credentials"]["token"])

user.fetch

3) получить вашу информацию user.name

Помните, что вы можете получить здесь что угодно ttp: //developers.facebook.com/docs/reference/api/user

4 голосов
/ 22 ноября 2010

Еще один хороший вариант - Коала: https://github.com/arsduo/koala

Если вы используете Facebook, у Koala есть собственная поддержка OAuth. Он также отлично работает с OmniAuth. Чтобы использовать их вместе, настройте OmniAuth в соответствии с этим Railscast: http://railscasts.com/episodes/235-omniauth-part-1

Затем добавьте столбец «токен» в таблицу «аутентификации» и все вспомогательные методы для получения токенов. Когда приложение должно взаимодействовать с Facebook, позвольте Коале взять токен и сделать свое дело. В контроллере:

if @token = current_user.facebook_token
  @graph = Koala::Facebook::GraphAPI.new(@token)
  @friends = @graph.get_connections("me", "friends")
end
3 голосов
/ 02 марта 2011

Во-первых, я бы пошел на fb_graph, просто сравните:

с коала :

graph = Koala::Facebook::GraphAPI.new OAUTH_ACCESS_TOKEN
friends = graph.get_connections("me", "friends")
graph.put_object("me", "feed", :message => "I am writing on my wall!")

с fb_graph :

me = FbGraph::User.me OAUTH_ACCESS_TOKEN
my_friends = me.friends
me.feed! :message => "I am writing on my wall!"

При использовании omniauth каждый пользователь имеет много полномочий (facebook, twitter, ...)

Для каждой авторизации пользователя вы должны хранить oauth токен , который возвращается в вашем хэше обратного вызова oauth.

auth = Authorization.create!(:user => user,
                             :uid =>      hash['uid'],
                             :provider => hash['provider'],
                             :token =>    hash['credentials']['token'])

Затем, где бы вы ни хотели получить доступ к альбомам и фотографиям, сделайте что-то вроде этого:

class User
  ...
  has_many :authorizations
  ...
  def grap_facebook_albums
    facebook = authorizations.where(:provider => :facebook).first
    fb_user = ::FbGraph::User.fetch facebook.uid, :access_token => facebook.token
    fb_albums = fb_user.albums
  end
  ...
end
2 голосов
/ 26 октября 2010

Так что я не смог заставить fb_graph работать должным образом - я все еще новичок, работавший на Ruby On Rails в общей сложности около 8-10 недель, и поэтому у меня нет инстинкта для того, что должно быть очевидные проблемы для других людей.

Тем не менее, я нашел этот замечательный небольшой пост в блоге, который описывает простой клиент Facebook и ясно показывает, как все это объединяется. Я обнаружил проблему с этим при получении объекта me / picture, так как Facebook возвращает http302, а не http200, но это было легко обойти с помощью автора. Проверьте это: http://bnerd.de/misc/ruby-write-basic-client-for-facebook-graph-api/

Я сейчас использую Omniauth для простоты взаимодействия по входу / регистрации, основанного на этом пошаговом руководстве здесь: blog.railsrumble.com/blog/2010/10/08/intridea-omniauth и с токеном, который я получаю, я используя этот простой FBClient из приведенной выше ссылки на bnerd для доступа к API Graph. Надеюсь, что то, что я нашел, помогает другим.

... вот моя версия кода bnerd, и он работал для меня:

    class FBClient

      def initialize(app, access_token = nil)
        @app = app
        @access_token = access_token
      end

      # request permission(s) from user
      def request(perms)
        #create a random verifier to identify user on fb callback
        verifier = (0...10).map{65.+(rand(25)).chr}.join
        uri = "https://graph.facebook.com/oauth/authorize?client_id=#{@app.app_id}&redirect_uri=#{@app.connect_url}?verifier=#{verifier}&scope=#{perms}"

        request = { :verifier => verifier, :uri => uri }
        return request

      end

      def connect(code, verifier)

        uri = URI.parse("https://graph.facebook.com/oauth/access_token?client_id=#{@app.app_id}&redirect_uri=#{@app.connect_url}?verifier=#{verifier}&client_secret=#{@app.secret}&code=#{CGI::escape(code)}")
        http = Net::HTTP.new(uri.host, uri.port)
        http.use_ssl = true

        request = Net::HTTP::Get.new(uri.path + "?" + uri.query)
        response = http.request(request)     
        data = response.body

        return data.split("=")[1]
      end

      # get, post
      def get(path, params = nil)
        uri = URI.parse("https://graph.facebook.com/" + path)
        http = Net::HTTP.new(uri.host, uri.port)
        http.use_ssl = true

        if params.nil?
          params = Hash.new
        end

        if params["access_token"].nil? 
          params["access_token"] = @access_token unless @access_token.nil?
        end

        request = Net::HTTP::Get.new(uri.path) 
        request.set_form_data( params )
        request = Net::HTTP::Get.new(uri.path + "?" + request.body)

        return response = http.request(request)
      end

      def post(path, params = nil)
        uri = URI.parse("https://graph.facebook.com/" + path)
        http = Net::HTTP.new(uri.host, uri.port)
        http.use_ssl = true        

        if params.nil?
          params = Hash.new
        end

        if params[:access_token].nil?
          params[:access_token] = @access_token unless @access_token.nil?
        end

        request = Net::HTTP::Post.new(uri.path) 
        request.set_form_data( params )
        request = Net::HTTP::Post.new(uri.path + "?" + request.body)

        response = http.request(request)
        response.code == "200" ? feed = JSON.parse(response.body) : raise("Sorry, an error occured. #{response.body}")
        return feed
      end
    end

Я уверен, что кто-то более опытный, чем я, мог бы улучшить это - у меня было около 10 недель на изучение Ruby (и мое первое программирование со времен Фортрана и Паскаля в университете в начале 90-х!).

0 голосов
/ 26 июля 2011

Я убедился, что oauth и oauth2 были удалены, а затем я установил oauth2.Похоже, что теперь omniauth и fb_graph работают ... но, вероятно, нужно проверить это больше.

0 голосов
/ 23 апреля 2011

У меня также были проблемы с получением решения devise + Omniauth. У меня были проблемы:

  1. Сеансовый cookie не хранит токен аутентификации facebook, необходимый для инициализации fb_graph и koala.
  2. Мне не удалось инициализировать fb_graph после установки токена аутентификации Facebook (но заставил Коалу работать после некоторой работы).

Я решил # 1, вставив 'session [: omniauth] = omniauth' в метод создания authentications_controller.rb.

Я решил # 2, используя Коалу. Похоже, что fb_graph требует oauth2, а для интеграции с omniauth используется oauth. Коала прекрасно работает с токеном аутентификации facebook, сохраненным сессией [: omniauth] ["credentials"] ["token"].

Вы инициализируете коалу так:
- @fbprofile = Коала :: Facebook :: GraphAPI.n ( сессии [: OmniAuth] [ "полномочие"] [ "Маркер"] )

...