У меня есть стандартные методы current_user в моем application_controller.authlogic current_user is no
def current_user_session
return @current_user_session if defined?
(@current_user_session)
@current_user_session = UserSession.find
end
def current_user
return @current_user if defined?(@current_user)
@current_user = current_user_session &&
current_user_session.record
end
В моем UserSessionController создать метод, я проверил на registration_complete? (просто проверка на значение столбца, который отлично работает), а затем перенаправить пользователя на страницу редактирования пользователя, если регистрация не завершена. Когда я отлаживаю это, я вижу, что существует tryed_record для объекта @user_session, и он указывает правильному пользователю, но метод current_user в redirect_to edit_user_path (current_user), всегда возвращает ноль.
Что здесь не так?
def create
@user_session = UserSession.new(params[:user_session])
# uses a block to prevent double render error...
# because oauth and openid use redirects
@user_session.save do |result|
if result
flash[:notice] = "Login successful!"
if @user_session.new_registration?
logger.info "Session controller : new
registration"
logger.info "Complete -
#{@user_session.registration_complete?}"
flash[:notice] = "Please review profile"
redirect_to edit_user_path(current_user)
else
if @user_session.registration_complete?
logger.info "Session Controller - registration
complete"
else
flash[:notice] = "Please complete profile"
logger.info "Session Controller - registration
not complete"
redirect_to edit_user_path(current_user)
#current_user nil here
end
end
redirect_to current_user ? profile_url(current_user) :
login_url
else
if @user_session.errors.on(:user)
# if we set error on the base object, likely it's
because we didn't find a user
render :action => :confirm
else
render :action => :new
end
end
end
end
Если вы все еще хотите ответить на эти вопросы ... смотрите ответ на вопрос http://stackoverflow.com/q/5305306/1188763 Надеюсь, что это помогает! – Norto23