NULL::something

Login via flickr, はてな, TypeKey.

2006-03-10

ログインに使ってるスクリプト

weblogin.rb, 名前失敗したけどもういいや。

そのうち忘れるので使い方をめもる。

@cgi.header を使うことを前提にしてる。

api_keys = {
    "Flickr" => {
        "api_key" => "Flickr70c55b82e10021ffaaapi_key6",
        "secret"  => "Flickrdf5secret3"
    },

    "TypeKey" => "fsakfsTypeKeyafasAPI"
}
require "weblogin.rb"
@cgi = CGI.new
WebLogin.open(@cgi, api_keys) do |login|
    begin
        case login.auth
        when :login
            # login したときの処理
            # DB にユーザ ID とユーザ情報を保存したり
        end
    rescue WebLogin::NoActionError => e
        puts @cgi.header("type" => "text/plain")
        puts login.services # 有効なサービスの配列
    end
end

上のようなのを認証スクリプトとしておいとく。このサイトだと /login.rb がコレ。ログインスクリプトの query_string が logout だったらセッションを破棄してリファラにリダイレクトする。ちょっとアレ。

/login.rb/Flickr?return_path= のようなリクエストをすると Flickr にリダイレクトして認証させる。認証されるとコールバック (Flickr の対応する API key のコールバックには http://example.com/login.rb/Flickr/callback のように指定しておく) にリダイレクトされるので、セッションに情報をセットして、return_path にリダイレクトする。

login.auth は、path_info に何も指定されていなかったりすると NoActionError を投げる。

require "weblogin.rb"
@cgi = CGI.new
WebLogin.open(@cgi, api_keys) do |login|
    if login.service
        # login している場合
        login.service #=> "Flickr"
        login.id #=> "25514198@N00"
        login.user_name #=> "cho45"
        login.profile_uri #=> "http://www.flickr.com/photos/25514198@N00/"
        login.icon #=> "http://static.flickr.com/23/buddyicons/25514198@N00.jpg"
        login.full_name #=> "Hiroh Satoh"
    else
        # login していない場合
        # id その他上記メソッドは全て nil
    end
end

いまいち気持ち悪いんだけどどうにもこうにもわからんのでこんな感じ。ブロックをとっているのはセッションファイルを確実に閉じるため。fcgi 環境で死ぬことがあったのでこういうことやってる。

WebLogin クラスは、それ以下にある、サービス名に対応するクラスをインスタンス化してメソッドを呼び出す。例えば /login.rb/Flickr?return_path=somepath の場合、WebLogin::Flickr.new(@cgi, @session, @api_keys["Flickr"]).auth が呼ばれる。

各サービス名の auth メソッドはサービスの認証画面にリダイレクトする。サービスは /login.rb/Flickr/callback にリダイレクトする。

callback が指定されている場合、インスタンス化されたサービスクラスの callback メソッドを呼ぶ。callback メソッドはユーザ情報をまとめて Hash にして返す。WebLogin はその Hash をセッションに保存して、最初に指定された return_path にリダイレクトする。

いろいろアレなことが思い浮かんだけどあとで考えよう。

new にブロックって一般的じゃないんじゃ?という指摘をうけたので open にした。確かに new にブロックは微妙だった。

Inserted at 2006-03-11T18:51:02+09:00

Comments (0)

Trackback URI: http://lowreal.net/logs/2006/03/10/3.trackback

NULL

RSS feed meter for http://lowreal.net/logs/latest

Alternates

  1. RSS 1.0
  2. Atom 1.0

Generated with Taglibro

この日記は Taglibro と呼ばれる XML ベースの XSLT をテンプレートとして使ったシステムを使っています。現在の Taglibro は Ruby, ruby-xslt, libxml-ruby による実装です。ソースコードはとりあえず公開していません。