RefineryCMS: переопределение обратных вызовов Devise Omniauth - PullRequest
1 голос
/ 12 августа 2011

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

Я пытаюсь интегрировать этот пользовательский логин, используя 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>

Olympus сейчас является кодовым названием проекта.

Контроллер обратного вызова 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

Журнал через rails s после нажатия на ссылку:

Started GET "/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

Так что он все еще пытается пройти через Devise :: OmniauthCallbacksController через RefineryCMS ... Кто-нибудь знает, как обойти это или, возможно, даже переопределить этот контроллер устройства?

Я также хотел бы сказать, что я совершенно новичок в работе с oauth-провайдерами / клиентами. Я работал с Facebook и Twitter, но делать их с нуля - это то, чем я занимаюсь. А также работа с Devise / Omniauth. Извините за мое невежество. Спасибо!

1 Ответ

0 голосов
/ 12 августа 2011

Исправлена ​​проблема с маршрутизацией при чтении этой статьи: http://groups.google.com/group/refinery-cms/browse_thread/thread/37917e227b26f5ca

Проблема, с которой я столкнулся сейчас, заключается в том, что она, похоже, не подключается к моему провайдеру oauth для выполнения аутентификации: (

...