Аутентифицированная система на Rails - PullRequest
0 голосов
/ 11 августа 2011

У меня есть приложение на Rails. Моя система аутентификации работает нормально, но: 1) всегда после авторизации захожу в THIS_path 2) если я не являюсь аутентифицированным пользователем, но попал, например, на страницу / research, после того, как я переброшу на страницу авторизации и после того, как я переброшу в pm_root_path, не выполнять reasearch_root_path.

Почему? Почему метод store_location не работает?

Моя библиотека lib / authenticated_system.rb:

module AuthenticatedSystem
protected

def logged_in?
  !!current_user
end

def current_user
  @current_user ||= login_from_session unless @current_user == false
  @current_user
end

def current_user=(new_user)
  session[:user_id] = new_user ? new_user.id : nil
  @current_user = new_user || false
end

def authorized?
  logged_in?
end


def login_required
  authorized? || access_denied
end

def access_denied
  respond_to do |format|
    format.html do
      store_location
      redirect_to root_path
    end
  end
end

def store_location
  session[:return_to] = request.request_uri
end

def redirect_back_or_default(default)
  redirect_to(session[:return_to] || default)
  session[:return_to] = nil
end

def self.included(base)
  base.send :helper_method, :current_user, :logged_in?
end

def login_from_session
  if session[:user_id]
    self.current_user = User.find_by_id(session[:user_id])
    self.current_user.last_logged_in = Time.now
    self.current_user.save
    self.current_user
  end
end

конец

И мой метод в session_controller:

def open_id_authentication(domain=nil)
  domain = "" if domain.nil?
  complete_identity_url = IDENTITY_URL + domain
  authenticate_with_open_id(complete_identity_url, OPENID_OPTS) do |openid_result, identity_url, registration|
    if openid_result.successful?
      matches = /\/a\/(.*)\/o8/.match(params["openid.op_endpoint"])
      google_domain = matches[1] if matches[1]
      if valid_account?(google_domain)
        account = Account.find_by_google_domain(google_domain)
        session[:account_id] = account.id
        self.current_user = User.openid_registration(registration, identity_url, account.id)
      else
        flash[:error] = t('flash.session.domain_not_registered')
        redirect_to accounts_path
        return false
    end

        redirect_back_or_default(THIS_path)
    else
      flash[:error] = t('flash.open_id.authentication_failed')
      redirect_to accounts_path
    end
  end
end

1 Ответ

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

Что отображается, если вы измените свой redirect_back_to_default, чтобы поднять сеанс [: return_to]

def redirect_back_or_default(default)
  raise session[:return_to].inspect
  redirect_to(session[:return_to] || default)
  session[:return_to] = nil
end

Код не выглядит странно для меня. Вы убедились, что store_location называется?

...