0

Omniauth w/ twitter はほとんど機能していますが、twitter の資格情報を検証した後に自分のアプリにリダイレクトしようとすると、次の長いエラーが発生します。

ActiveRecord::StatementInvalid in AuthenticationsController#create

SQLite3::ConstraintException: constraint failed: INSERT INTO "users" 
("created_at",  "current_sign_in_at", "current_sign_in_ip", "email", 
"encrypted_password", "last_sign_in_at", "last_sign_in_ip", 
"password_salt", "remember_created_at", "remember_token", 
 "reset_password_token", "sign_in_count", "updated_at") VALUES 
 (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)

ユーザー.rb:

class User < ActiveRecord::Base
  has_many :authentications

  # Include default devise modules. Others available are:
  # :token_authenticatable, :lockable, :timeoutable and :activatable
  devise :database_authenticatable, :registerable, 
         :recoverable, :rememberable, :trackable, :validatable

  # Setup accessible (or protected) attributes for your model
  attr_accessible :email, :password, :password_confirmation
  # attr_accessible :title, :body

  def apply_omniauth(omniauth)
    self.email = omniauth['info']['email'] if email.blank?
    authentications.build(:provider => omniauth['provider'], :uid => omniauth['uid'])

  end

  def password_required?
    (authentications.empty? || !password.blank?) && super
  end

  def email_required?
    super && :provider.blank?
  end
end

認証コントローラー:

    class AuthenticationsController < ApplicationController
  def create
    omniauth = request.env["omniauth.auth"]
    authentication = Authentication.find_by_provider_and_uid(omniauth['provider'], omniauth['uid'])
    if authentication
      flash[:notice] = "Signed in successfully."
      sign_in_and_redirect(:user, authentication.user)
    elsif current_user
      current_user.authentications.create!(:provider => omniauth['provider'], :uid => omniauth['uid'])
      flash[:notice] = "Authentication successful."
      redirect_to authentications_url
    else
      user = User.new
      user.apply_omniauth(omniauth)
      if p user user.save
        flash[:notice] = "Signed in successfully."
        sign_in_and_redirect(:user, user)
      else
        session[:omniauth] = omniauth.except('extra')
        redirect_to new_user_registration_url
      end
    end
  end

end
4

1 に答える 1

0

user.save 部分を次のように変更できます。

p user
if user.save

これにより、ユーザー オブジェクトの内容がコンソールまたはログ ファイルに記録されます (Rails の実行方法によって異なります)。その後、出力 ( のようになります#<User id: 15, sign_in_count: 3...) を調べて、SQLite エラーにリストされているすべての列に適切な値があることを確認できます。たとえば、データベースで「email」が必要であるのに、ユーザーが email に対して nil を持っていることに気付くかもしれません。

于 2013-02-28T22:11:13.860 に答える