Ruby(Ruby on Rails)でオリジナルアプリを作っている者です
そのアプリにTwitterを利用してのログイン機能を実装しようと下の記事を参考にやってみたのですが、連携アプリを認証の画面には進めるのですがログインできないという状況に陥ってしまっています
参考記事:https://qiita.com/keiya01/items/c96a0393c76f5560ee41
発生している問題・エラーメッセージ
ActiveRecord::StatementInvalid in UsersController#create SQLite3::SQLException: no such column: users.provider: SELECT "users".* FROM "users" WHERE "users"."provider" = ? AND "users"."uid" = ? LIMIT ?
上記のエラ〜メッセージが出ていて、調べてみたところデータベースにテーブルが見当たらない時に出るエラー(間違っていたらすみません)というところまではわかりました
この情報を基にこのエラーの解決法を調べ他の人たちが解決できた方法を試した(下記の試したことの欄に詳しく載せています)のですがエラーは解消できませんでした
該当のソースコード
**.env** TWITTER_CONSUMER_KEY = "Consumer Key" TWITTER_CONSUMER_SECRET = "Consumer Secret"
**secrets.yml** default_twitter: &default_twitter twitter_api_key: <%= ENV["TWITTER_CONSUMER_KEY"] %> twitter_api_secret: <%= ENV["TWITTER_CONSUMER_SECRET"] %> development: secret_key_base: #最初から記入されているはず <<: *default_twitter test: secret_key_base: #最初から記入されているはず <<: *default_twitter production: secret_key_base: <%= ENV["SECRET_KEY_BASE"] %> twitter_api_key: <%= ENV["TWITTER_CONSUMER_KEY"] %> twitter_api_secret: <%= ENV["TWITTER_CONSUMER_SECRET"] %>
**initializers/omniauth.rb** Rails.application.config.middleware.use OmniAuth::Builder do provider :twitter, ENV['TWITTER_CONSUMER_KEY'], ENV['TWITTER_CONSUMER_SECRET'] end
**model/users.rb** class User < ApplicationRecord # has_secure_passwordメソッドを追加してください has_secure_password validates :name, {presence: true} validates :email, {presence: true, uniqueness: true} has_many :posts def posts return Post.where(user_id: self.id) end #twitter認証の def self.find_or_create_from_auth_hash(auth_hash) provider = auth_hash[:provider] uid = auth_hash[:uid] name = auth_hash[:info][:name] image_url = auth_hash[:info][:image] self.find_or_create_by(provider: provider,uid: uid) do |user| user.username = name user.image_url = image_url end end #twitter認証の end
**controllers/users_controller.rb** class UsersController < ApplicationController before_action :authenticate_user,{only:[:index,:show,:edit,:update]} before_action :forbid_login_user,{only:[:new,:create,:login_form,:login]} before_action :ensure_correct_user,{only:[:edit,:update]} def show @user = User.find_by(id: params[:id]) @post = Post.where(user_id: @user.id) end def new @user = User.new end def create @user = User.new( name: params[:name], email: params[:email], image_name: "pile-up3.jpg", password: params[:password] ) if @user.save session[:user_id] = @user.id redirect_to("/users/#{@user.id}") else render("users/new") end #twitter認証の user = User.find_or_create_from_auth_hash(request.env['omniauth.auth']) if user session[:user_id] = user.id redirect_to '/posts/index', notice: "ログインしました。" else redirect_to root_path, notice: "失敗しました。" end #twitter認証の end def edit @user = User.find_by(id: params[:id]) end def update @user = User.find_by(id: params[:id]) @user.name = params[:name] @user.email = params[:email] if params[:image] @user.image_name = "#{@user.id}.jpg" image = params[:image] File.binwrite("public/user_images/#{@user.image_name}",image.read) end if @user.save redirect_to("/users/#{@user.id}") else render("users/edit") end end def login_form end def login @user = User.find_by(email: params[:email]) if @user && @user.authenticate(params[:password]) session[:user_id] = @user.id redirect_to("/users/#{@user.id}") else @error_message = "メールアドレスまたはパスワードが間違っています" @email = params[:email] @password = params[:password] render("users/login_form") end end def logout session[:user_id] = nil redirect_to("/login") end def ensure_correct_user if @current_user.id != params[:id].to_i flash[:notice] = "権限がありません" redirect_to("/posts/index") end end end
**route.rb** get 'auth/:provider/callback' => 'users#create' root 'home#top'
試したこと
このエラーについて調べてみたところ
・rake db:migrate したら解決できた
・コンソールして ActiveRecord::Base.connection.execute("BEGIN TRANSACTION; END;") としたら解決できた(解決できなかった場合はdependent:destroyと付け加えた)
というような記事が出てきたのでどちらも試してみたのですが、解決にはいたりませんでした(当初と同じエラーを吐き続けました)
このエラーの解消法にお心当たりのある方はアドバイスの方お願いいたします
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/03/07 02:39
2020/03/07 09:41