Rails 4.1.4 を 4.1.5 にアップグレードした後、Facebook omniauth セッションでエラーが発生しました。それ以来、すべてが正常に機能していました。ユーザーセッションを作成すると、ActiveModel::ForbiddenAttributesError
ルート:
match 'auth/:provider/callback', to: 'sessions#create', as: 'signin', via: :get
セッション#作成コントローラー:
def create
user = User.from_omniauth(env["omniauth.auth"])
session[:user_id] = user.id
session[:user_name] = user.name
redirect_to root_path
end
そして、このようなユーザーモデル:
def self.from_omniauth(auth)
where(auth.slice(:provider, :uid)).first_or_create.tap do |user|
user.provider ||= auth.provider
user.uid = auth.uid
user.name = auth.info.name
user.save
end
end
パーミットを追加することで、ActiveModel エラーを回避できます。そのような私のユーザーモデルのメソッド:
where(auth.slice(:provider, :uid).permit!).first_or_create.tap do |user|
しかし、それはデータベースの最初のユーザーを上書きします...session[:user_id]
常にデータベースの最初のユーザーのようです。
それが強力なパラメーターの問題なのか、Omniauth の問題なのか、それともその両方なのかわかりません。