前提・実現したいこと
現在マッチングしたユーザー同士が、一対一でチャットができる機能を実装しています。
送信時の非同期化には成功したのですが、自動更新機能を実装している最中に、ターミナル上で500エラーが発生しておりうまくいきません。
原因と解決法をご教授いただけると幸いです。
※messageテーブルにaddressカラム(messageの宛先ユーザーid)を付与、current_user.idとaddressによりどのユーザー同士のチャットかをビュー側で判別するようにしています。
発生している問題・エラーメッセージ
GET http://localhost:3000/api/messages/24?id=133 500 (Internal Server Error)
該当のソースコード
js
1$(function() { 2 3~~新規メッセージ非同期化の記述~~ 4 5var reloadMessages = function() { 6 last_message_id = $('.message:last').data("message-id"); 7 $.ajax({ 8 url: "/api/messages/24", // 24は動作確認のため一旦仮で記述したユーザーidです 9 type: 'get', 10 dataType: 'json', 11 data: {id: last_message_id} 12 }) 13 .done(function(message) { 14 if (message.length !== 0) { 15 var insertHTML = ''; 16 $.each(messages, function(i, message) { 17 insertHTML += buildHTML(message) 18 }); 19 $('.chat_main').append(insertHTML); 20 $('.chat_main').animate({ scrollTop: $('.chat_main')[0].scrollHeight}); 21 } 22 }) 23 .fail(function() { 24 console.log("ERROR") 25 }); 26 }; 27 setInterval(reloadMessages, 5000); 28});
app/controllers/api/messages_controller
class Api::MessagesController < ApplicationController def show @user = User.find(params[:id]) last_message_id = params[:id].to_i @my_messages = current_user.messages.where(address: @user.id) @your_messages = @user.messages.where(address: current_user.id) message_groups = @my_messages + @your_messages // binding.pry messages = message_groups.where("id > #{last_message_id}") end end
app/config/routes.rb
Rails.application.routes.draw do root "events#index" devise_for :users resources :users do member do get :following, :followers end end resources :events do member do post :join end end resources :relationships, only: [:create, :destroy] resources :matching, only: [:index] resources :rooms, only: [:show] resources :messages, only: [:show, :create] namespace :api do resources :messages, only: :show, defaults: { format: 'json' } end get '/user/like', to: 'matching#like', as: :like get '/user/liked', to:'matching#liked', as: :liked end
試したこと
binding.pryを使って、データがどこまで持っていけているか確認しました。
app/controllers/api/messages_controller
class Api::MessagesController < ApplicationController def show @user = User.find(params[:id]) last_message_id = params[:id].to_i @my_messages = current_user.messages.where(address: @user.id) @your_messages = @user.messages.where(address: current_user.id) message_groups = @my_messages + @your_messages // ①binding.pryをここに記載した場合 messages = message_groups.where("id > #{last_message_id}") end end
上記の①の位置でbinding.pryした場合
message_groupsは意図した数値が取れていました。
class Api::MessagesController < ApplicationController def show @user = User.find(params[:id]) last_message_id = params[:id].to_i @my_messages = current_user.messages.where(address: @user.id) @your_messages = @user.messages.where(address: current_user.id) message_groups = @my_messages + @your_messages messages = message_groups.where("id > #{last_message_id}") // ②binding.pryをここに記載した場合 end end
上記②の位置でbinding.pryした場合は、処理が止まらず500エラーとなってしまいました。ターミナル上には以下のエラー文が表示されました。
NoMethodError (undefined method `where' for #<Array:0x00007ff83ce537d8>
補足情報(FW/ツールのバージョンなど)
rails 5.2.4.1
ruby 2.5.1
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。