2011-08-12 12 views
1

私は別のサーバーでセットアップしたカスタムoauthプロバイダーを介して認証したいアプリケーションで作業しています。RefineryCMS:Devise Omniauthコールバックをオーバーライド

私はRefineryCMSを使用してこのカスタムログインを統合しようとしています。私は自分のルート設定をしていますが、何らかの理由で依然としてRefineryCMSに組み込まれている案件ルートに従っています。

routes.rbを

devise_for :users, :controllers => { :omniauth_callbacks => "users/omniauth_callbacks" } 
devise_scope :users do 
match '/users/auth/:provider', :to => 'users/omniauth_callbacks#passthru' 
end 

リンクコールバック

<p><%= link_to "Sign in with Olympus", user_omniauth_callback_path(:olympus) %></p> 

オリンパスは今のプロジェクトのコードネームです。

Omniauthコールバック・コントローラは:レールの経由

class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController 
    def olympus 
    auth = env["omniauth.auth"] 
    ap auth 
    end 

    def passthru 
    render :file => "#{Rails.root}/public/404.html", :status => 404, :layout => false 
    end 
end 

ログリンクがクリックされた後:

Started GET "https://stackoverflow.com/users/auth/olympus/callback" for 127.0.0.1 at 2011-08-12 07:52:09 -0500 
    Processing by Devise::OmniauthCallbacksController#failure as 
    SQL (0.7ms) SHOW TABLES 
    SQL (0.6ms) SHOW TABLES 
    Page Load (0.3ms) SELECT `pages`.`id`, `pages`.`depth`, `pages`.`parent_id`, `pages`.`lft`, `pages`.`rgt`, `pages`.`link_url`, `pages`.`menu_match`, page_translations.title as page_title FROM `pages` INNER JOIN `page_translations` ON `page_translations`.`page_id` = `pages`.`id` WHERE `pages`.`draft` = 0 AND `pages`.`show_in_menu` = 1 AND `page_translations`.`locale` = 'en' ORDER BY lft ASC 
    Slug Load (0.1ms) SELECT `slugs`.* FROM `slugs` WHERE (`slugs`.`sluggable_id` IN (1,3) and `slugs`.`sluggable_type` = 'Page' AND (`slugs`.`locale` = 'en')) ORDER BY id DESC 
    Slug Load (0.2ms) SELECT `slugs`.* FROM `slugs` WHERE (`slugs`.sluggable_id = 3 AND `slugs`.sluggable_type = 'Page') ORDER BY id DESC 
    SQL (1.3ms) describe `roles_users` 
    Role Load (0.1ms) SELECT `roles`.* FROM `roles` WHERE `roles`.`title` = 'Refinery' LIMIT 1 
    SQL (1.4ms) describe `roles_users` 
    User Load (0.2ms) SELECT * FROM `users` INNER JOIN `roles_users` ON `users`.id = `roles_users`.user_id WHERE (`roles_users`.role_id = 1) 
Redirected to http://localhost:3000/users/login 

だから、その、まだRefineryCMSを通じて考案:: OmniauthCallbacksControllerを通過しようとしています..誰かがこれを回避する方法を知っているのでしょうか?

私はoauthプロバイダー/クライアントで働くことについて全く新しいことを言いたいと思います。私はFacebookやTwitterで仕事をしてきましたが、最初からやっていることは、私が新しいことです。 Devise/Omniauthと協力するだけでなく、だから私の無知を許す。ありがとう!この記事を読んだことで

答えて

関連する問題